@charset "UTF-8";

html {
	font-size: 10px;
	line-height: 1.6;
	letter-spacing: 1px;
	overflow-x: hidden;
	font-family: "Zen Kaku Gothic New", sans-serif;
	color: #333;
}

body{
	word-wrap: break-word;
	-webkit-text-size-adjust: 100%;
	overflow-x: hidden;
	-webkit-tap-highlight-color:rgba(0,0,0,0);
	background: #fff;
	position: relative;
	margin: 0;
	padding: 0;
	vertical-align: baseline;
}

.grecaptcha-badge { visibility: hidden; }

#wrapper a:link      { text-decoration: none; color: #1668b3; }
#wrapper a:visited   { text-decoration: none; color: #1668b3; }
#wrapper a:hover     { text-decoration: none; }
#wrapper a:active    { text-decoration: none; }

a[href^="tel:"] {
	pointer-events: none;
}

a,:focus {
	outline: none;
}

::-webkit-search-cancel-button {
	-webkit-appearance: none;
}

.img img {
	width: 100%;
	height: auto;
}

.tb   { display: none!important;}
.tbsp { display: none!important;}
.sp   { display: none!important;}

.pc   { display: inline-block!important;}
.pctb { display: inline-block!important;}
.pcsp { display: inline-block!important;}

.opacity a:hover,
.opacity input:hover {
	opacity: 0.60;
	filter: alpha(opacity=60);
	-ms-filter: "alpha(opacity=60)";
	-moz-opacity: 0.60;
	-khtml-opacity: 0.60;
	-webkit-transition: all 0.3s ease;
	-moz-transition: all 0.3s ease;
	-o-transition: all 0.3s ease;
	transition: all 0.3s ease;
	text-decoration: none!important;
}

/*======================================================
  common
======================================================*/

.wtLnk a:link,
.wtLnk a:visited {
	color: #fff!important;
	text-decoration: none!important;
}

.bkLnk a:link,
.bkLnk a:visited {
	color: #333!important;
	text-decoration: none!important;
}

.wtTxt {
	color: #fff;
}

.bkTxt {
	color: #333;
}

.grdBg {
	background: #125DA2;
	background: linear-gradient(320deg,rgba(18, 93, 162, 1) 100%, rgba(22, 104, 179, 1) 0%);
}

.cntWrp {
	max-width: 1200px;
	margin: 0 auto;
}

.cntMinWrp {
	max-width: 900px;
	margin: 0 auto;
}

.cntTtlBoxCt {
	text-align: center;
	margin: 0 0 50px;
}

.cntTtlBoxLt {
	margin: 0 0 50px;
}

.cntTtlEn {
	font-weight: 900;
	font-size: 1.4rem;
	line-height: 1;
	letter-spacing: -0.005em;
	color: #1668b3;
	margin: 0 0 13px;
}

.cntTtl {
	font-weight: 700;
	font-size: 3.4rem;
	line-height: 1.2;
}

.cntMinTtl {
	font-weight: 700;
	font-size: 2rem;
	line-height: 1.2;
	margin: 0 0 30px;
	padding: 0 0 0 20px;
	border-left: solid 4px #1668b3;
}

.cntBtn {
	max-width: 500px;
	width: 100%;
	margin: 60px auto 0;
}

.cntBtn a {
	text-align: center;
	min-height: 70px;
	position: relative;
	display: block;
	font-weight: 700;
	font-size: 1.6rem;
	line-height: 1.2;
	padding: 25px 60px 25px 25px;
	box-sizing: border-box;
	border-radius: 6px;
	z-index: 1;
}

.blBg a {
	background: #1668b3;
}

.wtBg a {
	background: #fff;
}

.blBg a:link,
.blBg a:visited {
	color: #fff!important;
	text-decoration: none!important;
}

.wtBg a:link,
.wtBg a:visited {
	color: #1668b3!important;
	text-decoration: none!important;
}

.cntBtn a:hover {
	color: #333!important;
	background: #ffbc00;
	transition: all 0.3s ease;
}

.cntBtn a:after {
	content: "";
	position: absolute;
	right: 20px;
	top: calc(50% - 7.5px);
	width: 15px;
	height: 15px;
	z-index: 3;
}

.blBg a:after {
	background: url(../images/common/icn_arrow_rt_wt.png) center no-repeat;
	background-size: 15px auto;
}

.wtBg a:after {
	background: url(../images/common/icn_arrow_rt_bl.png) center no-repeat;
	background-size: 15px auto;
}


.cntBtn a:hover:after {
	background: url(../images/common/icn_arrow_rt_bk.png) center no-repeat;
	background-size: 15px auto;
}

.cntMinBtn a {
	display: inline-block;
	font-weight: 700;
	font-size: 1.4rem;
	line-height: 1.2;
	padding: 7px 25px 7px 20px;
	background: url(../images/common/icn_arrow_rt_wt.png) right 10px center no-repeat #1668b3;
	background-size: 8px auto;
	border-radius: 50px;
}

.cntMinBtn a:hover {
	color: #333!important;
	background: url(../images/common/icn_arrow_rt_bk.png) right 10px center no-repeat #ffbc00;
	background-size: 8px auto;
	transition: all 0.3s ease;
}

@media screen and (max-width:767px) {
	.cntTtlBoxCt {
		margin: 0 0 30px;
	}

	.cntTtlBoxLt {
		text-align: center;
		margin: 0 0 30px;
	}

	.cntTtlEn {
		font-size: 1.3rem;
		margin: 0 0 7px;
	}

	.cntTtl {
		font-size: 2.4rem;
	}

	.cntMinTtl {
		font-size: 1.8rem;
		margin: 0 0 20px;
		padding: 0 0 0 15px;
		border-left: solid 3px #1668b3;
	}

	.cntBtn {
		max-width: 260px;
		margin: 30px auto 0;
	}

	.cntBtn a {
		min-height: 50px;
		font-size: 1.4rem;
		padding: 15px 25px;
		border-radius: 50px;
	}

	.cntBtn a:after {
		right: 15px;
		top: calc(50% - 5px);
		width: 10px;
		height: 10px;
	}

	.blBg a:after {
		background-size: 10px auto;
	}

	.wtBg a:after {
		background-size: 10px auto;
	}


	.cntBtn a:hover:after {
		background-size: 10px auto;
	}

	.cntMinBtn a {
		width: 260px;
		padding: 15px 25px;
		box-sizing: border-box;
	}
}

/*======================================================
  header
======================================================*/

header {
	width: 100%;
	height: 100px;
	position: fixed;
	top: 0;
	left: 0;
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 0 30px;
	box-sizing: border-box;
	z-index: 1500;
	transition: all 0.3s ease;
}

header.chg {
	background: #fff;
	box-shadow: 0 2px 3px rgba(0,0,0,0.1);
}

.pagCth {
	font-weight: 500;
	font-size: 1.2rem;
	line-height: 1;
	color: #fff;
	margin: 0 0 10px;
}

header.chg .pagCth {
	color: #333;
}

.pagLg {
	max-width: 170px;
}

.pagLgBk {
	display: none;
}

header.chg .pagLgWt {
	display: none;
}

header.chg .pagLgBk {
	display: block;
}

@media screen and (min-width:768px) and (max-width:1040px) {
	header {
		height: 80px;
		padding: 0 20px;
	}
	
	.hdrLgBox {
		display: flex;
		align-items: center;
	}
	
	.hdrLgBox .pagCth {
		order: 2;
		margin: 0;
	}
	
	.hdrLgBox .pagLg {
		order: 1;
		margin: 0 15px 0 0;
	}
}

@media screen and (max-width:767px) {
	header {
		height: 60px;
		padding: 0 15px;
	}
	
	.hdrLgBox .pagCth {
		display: none;
	}
	
	.hdrLgBox .pagLg {
		max-width: 150px;
	}
}

/* gNav */
.gNav {
	display: flex;
	align-items: center;
	font-weight: 700;
	font-size: 1.8rem;
	line-height: 1;
}

.gNav li {
	margin: 0 0 0 50px;
}

header.chg .gNav a:link,
header.chg .gNav a:visited {
	color: #333!important;
	text-decoration: none!important;
}

@media screen and (max-width:1300px) {
	.gNav {
		font-size: 1.6rem;
	}

	.gNav li {
		margin: 0 0 0 25px;
	}
}

@media screen and (max-width:1040px) {
	.gNav {
		display: none;
	}
}

/* mdlAra */
.mdlAra {
	display: none;
}

@media screen and (max-width:1040px) {
	.mdlAra {
		display: block;
	}

	.menu, .menu span {
		display: inline-block;
		-webkit-transition: all .2s;
		transition: all .2s;
		box-sizing: border-box;
	}

	.menu {
		position: fixed;
		top: 15px;
		right: 15px;
		width: 50px;
		height: 50px;
		box-sizing: border-box;
		background: #1668b3;
		border: solid 1px #eee;
		border-radius: 4px;
		z-index: 2000;
		cursor: pointer;
		transition: all 0.3s ease;
	}

	.menu:hover {
		background: #fabe00;
		transition: all  0.3s ease;
	}

	.menu span {
		width: 30px;
		height: 2px;
		position: absolute;
		left: 10px;
		background: #fff;
		border-radius: 2px;
		z-index: 1000;
	}

	.menu:hover span {
		background: #333;
	}

	button {
		border: none;
		background: none;
	}

	.menu span:nth-of-type(1) {
		top: 16px;
	}

	.menu span:nth-of-type(2) {
		top: 24px;
		width: 18px;
	}

	.menu span:nth-of-type(3) {
		top: 32px;
	}

	.menu.active span:nth-of-type(1) {
		-webkit-transform: translateY(8px) rotate(45deg);
		transform: translateY(8px) rotate(45deg);
	}

	.menu.active span:nth-of-type(2) {
		opacity: 0;
	}

	.menu.active span:nth-of-type(3) {
		-webkit-transform: translateY(-8px) rotate(-45deg);
		transform: translateY(-8px) rotate(-45deg);
	}

	.mdlNavBox {
		position: fixed;
		top: 0;
		right: 0;
		width: 100% ;
		height: 100vh;
		opacity: 0;
		padding: 50px 30px;
		overflow-y: scroll;
		box-sizing: border-box;
		background: url(../images/common/bg_modal.png) top no-repeat #060c17;
		background-size: 100% auto;
		transition: all  0.3s ease;
		visibility: hidden;
		z-index: 2000;
	}

	.mdlNavInr {
		max-width: 800px;
		margin: 0 auto;
	}

	.mdlNavBox.active {
		right: 0;
		opacity: 1;
		-moz-transform: translateX(0);
		-webkit-transform: translateX(0);
		transform: translateX(0);
		visibility: visible;
	}

	.mdlLg {
		max-width: 170px;
		margin: 0 auto 30px;
	}

	.mdlNav {
		font-weight: 700;
		font-size: 1.8rem;
		line-height: 1.2;
		overflow: hidden;
		border: solid 1px #eee;
		border-radius: 10px;
	}

	.mdlNav a {
		position: relative;
		display: block;
		padding: 20px 30px;
		background: url(../images/common/icn_arrow_rt_bl.png) right 15px center no-repeat #fff;
		background-size: 15px auto;
		z-index: 1;
	}

	.mdlNav a:before {
		content: "";
		position: absolute;
		top: 10px;
		left: 10px;
		width: 5px;
		height: calc(100% - 20px);
		background: #1668b3;
		border-radius: 3px;
	}

	.mdlNav a:hover {
		transition: all 0.3s ease;
		background: url(../images/common/icn_arrow_rt_bk.png) right 15px center no-repeat #ffbc00;
		background-size: 15px auto;
	}

	.mdlNav li:not(:last-child) {
		border-bottom: solid 1px #eee;
	}
}

@media screen and (max-width:767px) {
	.menu {
		top: 10px;
		right: 10px;
		width: 40px;
		height: 40px;
	}
	
	.menu span {
		width: 24px;
		left: 7px;
	}

	.menu span:nth-of-type(1) {
		top: 10px;
	}

	.menu span:nth-of-type(2) {
		top: 18px;
		width: 16px;
	}

	.menu span:nth-of-type(3) {
		top: 26px;
	}

	.mdlNavBox {
		padding: 30px 15px;
		background: url(../images/common/bg_modal_sp.png) top no-repeat #060c17;
		background-size: 100% auto;
	}

	.mdlLg {
		max-width: 150px;
		margin: 0 auto 30px;
	}

	.mdlNav {
		font-size: 1.6rem;
		border-radius: 8px;
	}

	.mdlNav a {
		padding: 15px 20px;
		background: url(../images/common/icn_arrow_rt_bl.png) right 10px center no-repeat #fff;
		background-size: 10px auto;
		z-index: 1;
	}
	
	.mdlNav a:hover {
		background: url(../images/common/icn_arrow_rt_bk.png) right 10px center no-repeat #ffbc00;
		background-size: 10px auto;
	}

	.mdlNav a:before {
		top: 6px;
		left: 6px;
		width: 4px;
		height: calc(100% - 12px);
	}
}

/*======================================================
  mnAra
======================================================*/

.mnAra {
	height: 750px;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 0 30px;
	background: url(../images/index/img_category_01.jpg) center no-repeat #1668b3;
	background-size: cover;
}

.mnCtr {
	max-width: 800px;
	width: 100%;
}

.mnSrcCtr {
	max-width: 800px;
	display: flex;
	justify-content: center;
	overflow: hidden;
	margin: 0 auto;
	border: solid 1px #eee;
	border-radius: 3px;
}

.mnSrcInr {
	order: 2;
	display: flex;
	justify-content: center;
}

.mnSrcBox input {
	width: 500px;
	height: 55px;
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-weight: 700;
	font-size: 1.8rem;
	line-height: 1.2;
	padding: 15px;
	box-sizing: border-box;
	border: none;
}

.mnSrcBox input::placeholder {
	color: #b1b1b1;
}

.mnSrcBtn input {
	width: 90px;
	height: 55px;
	background: url(../images/common/icn_search_wt.png) center no-repeat #1668b3;
	background-size: 35px auto;
	border: none;
	cursor: pointer;
}

.mnSrcBtn input:hover {
	background: url(../images/common/icn_search_bk.png) center no-repeat #fabe00;
	background-size: 35px auto;
	transition: all 0.3s ease;
}

.mnSrcSlc {
	order: 1;
	position: relative;
	z-index: 2;
}

.mnSrcSlc select {
	width: 210px;
	height: 55px;
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-weight: 700;
	font-size: 1.6rem;
	line-height: 1.2;
	padding: 15px;
	color: #333;
	box-sizing: border-box;
	background: #fff;
	border: none;
	border-right: solid 1px #eee;
	cursor: pointer;
	z-index: 1;
}

.mnCntBox {
	margin: 30px 0 0;
	padding: 25px;
	box-sizing: border-box;
	background: rgba(0,0,0,0.8);
	border-radius: 6px;
}

.mnTagLst {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	margin: 0 -5px -10px;
}

.mnTagLst li {
	margin: 0 5px 10px;
}

.mnTagLst li a {
	text-align: center;
	min-width: 60px;
	display: block;
	font-weight: 700;
	font-size: 1.4rem;
	line-height: 1.2;
	padding: 10px;
	box-sizing: border-box;
	background: #fff;
	border-radius: 4px;
}

.mnTagLst li a:hover {
	color: #333!important;
	background: #fabe00;
	transition: all 0.3s ease;
}

.mnCntTxt {
	text-align: center;
	font-weight: 500;
	font-size: 1.6rem;
	line-height: 1.5;
	color: #fff;
	margin: 25px 0 0;
}

.mnCntTxt .stgTxt {
	color: #fff94d;
}

@media screen and (min-width:768px) and (max-width:1040px) {
	.mnAra {
		height: 650px;
	}

	.mnCtr {
		max-width: 700px;
		width: 100%;
	}

	.mnSrcBox input {
		width: 420px;
	}

	.mnSrcBtn input {
		width: 80px;
	}

	.mnSrcSlc select {
		width: 200px;
		padding: 15px 10px;
	}
}

@media screen and (max-width:767px) {
	.mnAra {
		height: 450px;
		padding: 80px 15px 30px;
	}

	.mnSrcCtr {
		max-width: 300px;
		display: block;
		margin: 0 auto;
	}
	
	.mnSrcInr {
		border-bottom: solid 1px #eee;
	}

	.mnSrcBox input {
		width: 250px;
		height: 45px;
		font-size: 1.5rem;
		padding: 5px 10px;
	}

	.mnSrcBtn input {
		width: 50px;
		height: 45px;
		background-size: 25px auto;
	}

	.mnSrcBtn input:hover {
		background-size: 25px auto;
	}
	
	.mnSrcSlc:after {
		content: "▼";
		position: absolute;
		top: 10px;
		right: 10px;
		color: #333!important;
		z-index: 3;
	}

	.mnSrcSlc select {
		width: 300px;
		height: 35px;
		font-size: 1.4rem;
		padding: 5px 10px;
	}

	.mnCntBox {
		max-width: 300px;
		margin: 15px auto 0;
		padding: 15px;
	}

	.mnTagLst li a {
		min-width: 40px;
		font-size: 1.3rem;
		padding: 7px;
	}

	.mnCntTxt {
		font-size: 1.4rem;
		margin: 10px 0 0;
	}
}

/*======================================================
  content
======================================================*/

/* ctlAra */
.ctlAra {
	padding: 100px 30px;
	background: url(../images/common/bg_catalog.png) bottom right no-repeat,
	url(../images/common/bg_diamond.png) bottom left no-repeat;
	background-size: 1400px auto, 900px auto;
}

.ctlAra .cntTtlEn,
.ctlAra .cntTtl {
	color: #fff;
}

.ctlLst {
	display: flex;
	margin: 0 -30px;
}

.ctlLst li {
	width: calc(33.33% - 60px);
	margin: 0 30px;
}

.ctlLstImg {
	margin: 0 0 20px;
	overflow: hidden;
	border-radius: 6px;
	aspect-ratio: 700 / 430;
	display: flex;
	justify-content: center;
	align-items: center;
}

.ctlLstImg img {
	max-width: 100%;
	max-height: 100%;
	object-fit: contain;
}

.ctlLstTtltBox {
	text-align: center;
}

.ctlLstTyp {
	display: inline-block;
	font-weight: 500;
	font-size: 1.4rem;
	line-height: 1.2;
	margin: 0 0 15px;
	padding: 3px 10px;
	border: solid 1px rgba(255,255,255,0.5);
}

.ctlLstTtl {
	font-weight: 700;
	font-size: 2.2rem;
	line-height: 1.2;
}

/* slide */
.prvArw,.nxtArw {
	position: absolute;
	top: calc(50% - 30px);
	display: block;
	width: 60px;
	height: 60px;
	background: #fff;
	border-radius: 50%;
	transition: all .3s ease;
	cursor: pointer;
	z-index: 1000;
}

.prvArw {
	left: 50px;
}

.nxtArw {
	right: 50px;
}

.prvArw:before,
.nxtArw:before {
	content: "";
	position: absolute;
	top: 22.5px;
	left: 22.5px;
	width: 15px;
	height: 15px;
	z-index: 1001;
}

.prvArw:before {
	background: url(../images/common/icn_arrow_lt_bl.png) center no-repeat;
	background-size: 15px auto;
}

.nxtArw:before {
	background: url(../images/common/icn_arrow_rt_bl.png) center no-repeat;
	background-size: 15px auto;
}

.prvArw:hover,
.nxtArw:hover {
	opacity: 0.60;
	transition: all  0.3s ease;
}

@media screen and (min-width:768px) and (max-width:1040px) {
	.prvArw,.nxtArw {
		top: calc(50% - 25px);
		width: 50px;
		height: 50px;
	}
	
	.prvArw {
		left: 30px;
	}

	.nxtArw {
		right: 30px;
	}
	
	.prvArw:before,
	.nxtArw:before {
		top: 18px;
		left: 18px;
	}
}

@media screen and (max-width:767px) {
	.ctlAra {
		padding: 30px 15px;
		background-size: 700px auto, 450px auto;
	}
	
	.ctlLst li {
		width: calc(33.33% - 30px);
		margin: 0 15px;
	}
	
	.ctlLstTyp {
		font-size: 1.3rem;
		margin: 0 0 10px;
	}

	.ctlLstTtl {
		font-size: 1.8rem;
	}

	.prvArw,.nxtArw {
		top: calc(50% - 40px);
		display: block;
		width: 30px;
		height: 80px;
		transition: all .3s ease;
		cursor: pointer;
		z-index: 1000;
	}

	.prvArw {
		left: 15px;
		border-radius: 0 4px 4px 0;
	}

	.nxtArw {
		right: 15px;
		border-radius: 4px 0 0 4px;
	}

	.prvArw:before,
	.nxtArw:before {
		content: "";
		position: absolute;
		top: 30px;
		width: 15px;
		height: 15px;
		z-index: 1001;
	}

	.prvArw:before {
		left: 6px;
		background-size: 15px auto;
	}

	.nxtArw:before {
		left: 10px;
		background-size: 15px auto;
	}
}

/* casAra */
.casAra {
	padding: 100px 30px;
	background: #f8f8f8;
}

.casLst {
	display: flex;
	flex-wrap: wrap;
	margin: 0 -15px -20px;
}

.casLst li {
	width: calc(33.33% - 30px);
	margin: 0 15px 20px;
	padding: 15px;
	box-sizing: border-box;
	background: #fff;
	border: solid 1px #eee;
	border-radius: 10px;
}

.casLstCntBox {
	display: flex;
	align-items: center;
	margin: 0 0 10px;
	padding: 0 0 10px;
	border-bottom: solid 1px #eee;
}

.casLstImg {
	max-width: 60px;
	width: 100%;
	position: relative;
	margin: 0 15px 0 0;
	overflow: hidden;
	border-radius: 50%;
}

.casLstImg:before {
	content: "";
	display: block;
	padding-top: 100%;
}

.casLstImg img {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.casLstTtl {
	font-weight: 700;
	font-size: 1.6rem;
	line-height: 1.4;
}

.casLstNmeBox {
	text-align: right;
}

.casLstNme {
	position: relative;
	display: inline-block;
	font-weight: 500;
	font-size: 1.4rem;
	line-height: 1.2;
	padding: 0 25px 0 0;
}

.casLstNme:after {
	content: "";
	position: absolute;
	top: calc(50% - 8px);
	right: 0;
	width: 16px;
	height: 16px;
	background: url(../images/common/icn_arrow_rt_wt.png) center no-repeat #1668b3;
	background-size: 8px auto;
	border-radius: 50%;
}

@media screen and (min-width:768px) and (max-width:1040px) {
	.casLst {
		margin: 0 -10px -20px;
	}

	.casLst li {
		width: calc(33.33% - 20px);
		margin: 0 10px 20px;
	}
}

@media screen and (max-width:767px) {
	.casAra {
		padding: 30px 15px;
	}

	.casLst {
		display: block;
		margin: 0 0 -10px;
	}

	.casLst li {
		width: 100%;
		margin: 0 0 10px;
		padding: 10px;
		border-radius: 8px;
	}

	.casLstImg {
		max-width: 50px;
		margin: 0 10px 0 0;
	}

	.casLstTtl {
		font-size: 1.5rem;
	}
	
	.casLstNme {
		font-size: 1.3rem;
	}
}

/* cteAra */
.cteAra {
	padding: 100px 30px;
	background: url(../images/common/bg_category.png) top right no-repeat;
	background-size: 1000px auto;
}

.cteAra .cntTtlEn,
.cteAra .cntTtl {
	color: #fff;
}

.cteLst:not(.cteMinLst) {
	display: flex;
	flex-wrap: wrap;
	margin: 0 -30px -60px;
}

.cteAra li:not(.cteMinLst li) {
	width: calc(50% - 60px);
	margin: 0 30px 60px;
	overflow: hidden;
	background: #fff;
	border-radius: 10px;
	box-shadow: 0 3px 4px rgba(0,0,0,0.15);
}

.cteLstImg {
	position: relative;
	overflow: hidden;
}

.cteLstImg:before {
	content: "";
	display: block;
	padding-top: 56.15%;
}

.cteLstImg img {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.cteLstInr {
	padding: 20px 30px;
}

.cteLstTtlBtnBox {
	margin: 0 30px;
	padding: 15px 0;
	border-bottom: solid 1px #eee;
}

.cteLstTtlBtn {
	position: relative;
	font-weight: 700;
	font-size: 2.4rem;
	line-height: 1.2;
	padding: 0 30px 0 0;
}

.cteLstTtlBtn:after {
	content: "";
	position: absolute;
	top: calc(50% - 10px);
	right: 0;
	width: 20px;
	height: 20px;
	background: url(../images/common/icn_arrow_rt_wt.png) center no-repeat #1668b3;
	background-size: 10px auto;
	border-radius: 50%;
}

.cteLstTtlBtn a {
	display: block;
}

.cteMinLst {
	font-weight: 500;
	font-size: 1.6rem;
	line-height: 2;
}

.cteMinLst li:not(:last-child) {
	margin: 0 0 10px;
}

.cteMinLst li a {
	position: relative;
	display: block;
	padding: 0 0 0 15px;
}

.cteMinLst li a:before {
	content: "";
	position: absolute;
	top: calc(50% - 5px);
	left: 0;
	width: 10px;
	height: 10px;
	background: url(../images/common/icn_arrow_rt_bl.png) center no-repeat;
	background-size: 10px auto;
}

@media screen and (min-width:768px) and (max-width:1040px) {
	.cteLst:not(.cteMinLst) {
		margin: 0 -15px -30px;
	}

	.cteAra li:not(.cteMinLst li) {
		width: calc(50% - 30px);
		margin: 0 15px 30px;
	}
}

@media screen and (max-width:767px) {
	.cteAra {
		padding: 30px 15px;
		background-size: 350px auto;
	}

	.cteLst:not(.cteMinLst) {
		display: block;
		margin: 0 0 -20px;
	}

	.cteAra li:not(.cteMinLst li) {
		width: 100%;
		margin: 0 0 20px;
		border-radius: 8px;
	}

	.cteLstBox {
		display: flex;
		align-items: center;
		border-bottom: solid 1px #eee;
	}

	.cteLstImg {
		max-width: 130px;
		width: 100%;
	}

	.cteLstImg:before {
		padding-top: 55%;
	}

	.cteLstInr {
		width: 100%;
		padding: 15px;
		box-sizing: border-box;
	}

	.cteLstTtlBtnBox {
		width: calc(100% - 150px);
		margin: 0;
		padding: 15px;
		border: none;
	}

	.cteLstTtlBtn {
		font-size: 2rem;
		padding: 0 25px 0 0;
	}

	.cteLstTtlBtn:after {
		top: calc(50% - 8px);
		width: 16px;
		height: 16px;
		background: url(../images/common/icn_arrow_rt_wt.png) center no-repeat #1668b3;
		background-size: 8px auto;
	}

	.cteMinLst {
		font-size: 1.5rem;
	}
}

/* nwaAra */
.nwaAra {
	padding: 100px 30px;
}

.nwaLst {
	display: flex;
	margin: 0 -30px;
}

.nwaLst li {
	width: calc(25% - 60px);
	margin: 0 30px;
	display: flex;
}

.nwaLstBox {
	display: flex;
	flex-direction: column;
}

.nwaLstImg {
	overflow: hidden;
	border-radius: 10px;
	margin: 0 0 30px;
	aspect-ratio: 700 / 430;
	display: flex;
	justify-content: center;
	align-items: center;
}

.nwaLstImg img {
	max-width: 100%;
	max-height: 100%;
	object-fit: contain;
}

.nwaLstDta {
	display: block;
	font-weight: 500;
	font-size: 1.6rem;
	line-height: 1.2;
	color: #828282;
	margin: 0 0 7px;
}

.nwaLstTtl {
	position: relative;
	font-weight: 700;
	font-size: 2.2rem;
	line-height: 1.2;
	margin: 0 0 40px;
	padding: 0 30px 0 0;
	flex-grow: 1;
}

.nwaLstTtl:after {
	content: "";
	position: absolute;
	top: calc(50% - 10px);
	right: 0;
	width: 20px;
	height: 20px;
	background: url(../images/common/icn_arrow_rt_wt.png) center no-repeat #1668b3;
	background-size: 10px auto;
	border-radius: 50%;
}

.nwaLstTyp {
	display: inline-block;
	font-weight: 500;
	font-size: 1.4rem;
	line-height: 1.2;
	padding: 3px 10px;
	color: #1668b3;
	border: solid 1px #1668b3;
	align-self: flex-start;
}

@media screen and (min-width:768px) and (max-width:1040px) {
	.nwaLst {
		margin: 0 -15px;
	}

	.nwaLst li {
		width: calc(50% - 30px);
		margin: 0 15px;
	}
}

@media screen and (max-width:767px) {
	.nwaAra {
		padding: 30px 15px;
	}

	.nwaLst {
		flex-wrap: wrap;
		justify-content: center;
		margin: 0 -7.5px -20px;
	}

	.nwaLst li {
		width: calc(50% - 15px);
		margin: 0 7.5px 20px;
	}

	.nwaLstImg {
		border-radius: 8px;
		margin: 0 0 15px;
	}

	.nwaLstDta {
		font-size: 1.5rem;
		margin: 0 0 5px;
	}

	.nwaLstTtl {
		font-size: 1.8rem;
		margin: 0 0 20px;
		padding: 0 25px 0 0;
	}

	.nwaLstTtl:after {
		top: calc(50% - 8px);
		width: 16px;
		height: 16px;
		background: url(../images/common/icn_arrow_rt_wt.png) center no-repeat #1668b3;
		background-size: 8px auto;
	}

	.nwaLstTyp {
		font-size: 1.3rem;
	}
}

/* cntBnrAra */
.cntBnrAra {
	padding: 100px 30px;
	background: #f8f8f8;
}

.cntBnr {
	max-width: 800px;
	margin: 0 auto 60px;
}

.cntBnrLst {
	display: flex;
	margin: 0 -15px 30px;
}

.cntBnrLst li:nth-child(1) {
	width: calc(65.85% - 30px);
	margin: 0 15px;
}

.cntBnrLst li:nth-child(2) {
	width: calc(34.15% - 30px);
	margin: 0 15px;
}

.cntBtnLst {
	display: flex;
	margin: 0 -15px;
}

.cntBtnLst li {
	width: calc(50% - 30px);
	margin: 0 15px;
}

.cntSubBtn a {
	position: relative;
	display: block;
	padding: 10px;
	box-sizing: border-box;
	background: #fff;
	border: solid 1px #eee;
	border-radius: 10px;
	z-index: 1;
}

.cntSubBtn a:after {
	content: "";
	position: absolute;
	top: calc(50% - 20px);
	right: 20px;
	width: 40px;
	height: 40px;
	border-radius: 50%;
	z-index: 2;
}

.logBtn a:after {
	background: url(../images/common/icn_login_wt.png) center no-repeat #1668b3;
	background-size: 20px auto;
}

.pubBtn a:after {
	background: url(../images/common/icn_publish_wt.png) center no-repeat #1668b3;
	background-size: 20px auto;
}

.cntSubBtnInr {
	display: flex;
	align-items: center;
}

.cntSubBtnImg {
	max-width: 120px;
	margin: 0 20px 0 0;
	overflow: hidden;
	border-radius: 6px;
}

.cntSubBtnTtl {
	font-weight: 700;
	font-size: 2rem;
	line-height: 1.3;
}

.cntSubBtnTtl .minTxt {
	font-size: 1.5rem;
}

.cntSubBtnTtl .bigTxt {
	font-size: 2.4rem;
	letter-spacing: -0.05em;
}

@media screen and (min-width:768px) and (max-width:1040px) {
	.cntSubBtnImg {
		max-width: 100px;
		margin: 0 15px 0 0;
	}

	.cntSubBtnTtl {
		font-size: 2rem;
	}

	.cntSubBtnTtl .minTxt {
		font-size: 1.4rem;
	}

	.cntSubBtnTtl .bigTxt {
		font-size: 2.4rem;
	}
}

@media screen and (max-width:767px) {
	.cntBnrAra {
		padding: 30px 15px;
	}

	.cntBnr {
		margin: 0 auto 20px;
	}

	.cntBnrLst {
		display: block;
		margin: 0 0 15px;
	}

	.cntBnrLst li:nth-child(1) {
		width: 100%;
		margin: 0 0 15px;
	}

	.cntBnrLst li:nth-child(2) {
		width: 100%;
		margin: 0;
	}

	.cntBtnLst {
		display: block;
		margin: 0 0 -20px;
	}

	.cntBtnLst li {
		width: 100%;
		margin: 0 0 15px;
	}

	.cntSubBtn a {
		border-radius: 8px;
	}

	.cntSubBtn a:after {
		top: calc(50% - 15px);
		right: 10px;
		width: 30px;
		height: 30px;
	}

	.logBtn a:after {
		background-size: 15px auto;
	}

	.pubBtn a:after {
		background-size: 15px auto;
	}

	.cntSubBtnImg {
		max-width: 80px;
		margin: 0 10px 0 0;
	}

	.cntSubBtnTtl {
		font-size: 1.6rem;
	}

	.cntSubBtnTtl .minTxt {
		font-size: 1.3rem;
	}

	.cntSubBtnTtl .bigTxt {
		font-size: 2rem;
	}
}

/* infAra */
.infAra {
	padding: 100px 30px 50px;
	background: url(../images/common/bg_info.png) top right no-repeat;
	background-size: auto 100%;
}

.infWrp {
	max-width: 1200px;
	display: flex;
	margin: 0 auto;
}

.infBoxLt {
	width: calc(50% - 30px);
	position: relative;
	margin: 0 30px 0 0;
	padding: 30px;
	box-sizing: border-box;
	background: #fff;
	border-radius: 10px;
	box-shadow: 0 3px 4px rgba(0,0,0,0.15);
}

.infBoxRt {
	width: calc(50% - 30px);
	position: relative;
	margin: 0 0 0 30px;
	padding: 30px;
	box-sizing: border-box;
	background: #fff;
	border-radius: 10px;
	box-shadow: 0 3px 4px rgba(0,0,0,0.15);
}

.infTtlBox {
	display: flex;
	justify-content: space-between;
	margin: 0 0 40px;
}

.infTtl {
	position: relative;
	font-weight: 700;
	font-size: 2.2rem;
	line-height: 1.4;
	color: #1668b3;
	padding: 0 0 0 20px;
}

.infTtl:before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 5px;
	height: 100%;
	background: #1668b3;
	border-radius: 5px;
}

.infLst li:not(:last-child) {
	margin: 0 0 20px;
	padding: 0 0 20px;
	border-bottom: solid 1px #eee;
}

.infLstBox {
	display: flex;
}

.infLstImgBox {
	max-width: 100px;
	width: 100%;
	margin: 0 15px 0 0;
}

.infLstImg {
	position: relative;
	overflow: hidden;
}

.infLstImg:before {
	content: "";
	display: block;
	padding-top: 80%;
}

.infLstImg img {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.infLstDta {
	display: block;
	font-weight: 500;
	font-size: 1.6rem;
	line-height: 1.2;
	color: #828282;
	margin: 0 0 5px;
}

.infLstTtl {
	font-weight: 700;
	font-size: 1.6rem;
	line-height: 1.3;
}

@media screen and (min-width:768px) and (max-width:1040px) {
	.infBoxLt {
		width: calc(50% - 15px);
		margin: 0 15px 0 0;
		padding: 20px;
	}

	.infBoxRt {
		width: calc(50% - 15px);
		margin: 0 0 0 15px;
		padding: 20px;
	}
	
	.infTtlBox {
		display: block;
	}
	
	.cntMinBtnBox {
		text-align: right;
	}
	
	.infTtl {
		margin: 0 0 15px;
	}
}

@media screen and (max-width:767px) {
	.infAra {
		padding: 30px 15px 20px;
		background: url(../images/common/bg_info.png) top right no-repeat;
		background-size: 100% auto;
	}
	
	.infWrp {
		display: block;
	}

	.infBoxLt {
		width: 100%;
		margin: 0 0 20px;
		padding: 15px 15px 80px;
		border-radius: 8px;
	}

	.infBoxRt {
		width: 100%;
		margin: 0 0 20px;
		padding: 15px 15px 80px;
		border-radius: 8px;
	}

	.infTtlBox {
		display: block;
		margin: 0 0 20px;
	}

	.infTtl {
		font-size: 1.8rem;
		padding: 0 0 0 18px;
	}

	.infTtl:before {
		width: 4px;
	}
	
	.cntMinBtnBox {
		text-align: center;
	}
	
	.infAra .cntMinBtn {
		position: absolute;
		bottom: 15px;
		left: 0;
		right: 0;
		margin: 0 auto;
	}

	.infLst li:not(:last-child) {
		margin: 0 0 15px;
		padding: 0 0 15px;
	}

	.infLstImgBox {
		max-width: 80px;
		margin: 0 10px 0 0;
	}

	.infLstDta {
		font-size: 1.5rem;
	}

	.infLstTtl {
		font-size: 1.4rem;
	}
}

/* btmBnrAra */
.btmBnrAra {
	padding: 60px 30px;
	background: #f8f8f8;
}

.btmBnrLst {
	display: flex;
	flex-wrap: wrap;
	margin: 0 -5px -10px;
}

.btmBnrLst li {
	width: calc(16.66% - 10px);
	margin: 0 5px 10px;
	overflow: hidden;
	box-sizing: border-box;
	border: solid 1px #eee;
	border-radius: 8px;
}

@media screen and (min-width:768px) and (max-width:1040px) {
	.btmBnrLst li {
		width: calc(33.33% - 10px);
	}
}

@media screen and (max-width:767px) {
	.btmBnrAra {
		padding: 30px 15px 60px;
	}

	.btmBnrLst li {
		width: calc(50% - 10px);
		border-radius: 6px;
	}
}

/*======================================================
  footer
======================================================*/

.ptpBtn {
	position: fixed;
	right: 15px;
	z-index: 200;
}

.ptpBtn a {
	text-align: center;
	width: 50px;
	height: 50px;
	display: block;
	padding: 16px 0 0;
	box-sizing: border-box;
	background: #1668b3;
	border: solid 1px #f8f8f8;
	border-radius: 5px;
}

.ptpBtn a:hover {
	background: #fabe00;
	transition: all 0.3s ease;
}

.ptpBtn img {
	max-width: 15px;
	height: auto;
	margin: 0 auto;
}

@media screen and (max-width:767px) {
	.ptpBtn {
		right: 5px;
	}

	.ptpBtn a {
		width: 36px;
		height: 36px;
		padding: 10px 0 0;
		border-radius: 4px;
	}
}

/* ftrAra */
.ftrAra {
	padding: 50px 30px 30px;
	background: #333;
}

.ftrBox {
	display: flex;
	align-items: center;
	justify-content: space-between;
	box-sizing: border-box;
	margin: 0 0 70px;
}

.ftrLg {
	max-width: 170px;
}

.ftrNav {
	display: flex;
	justify-content: flex-end;
	font-weight: 500;
	font-size: 1.6rem;
	line-height: 1.2;
}

.ftrNav li {
	position: relative;
	margin: 0 0 0 40px;
}

.ftrNav li:not(:last-child):after {
	content: "";
	position: absolute;
	top: calc(50% - 7.5px);
	right: -20px;
	width: 1px;
	height: 15px;
	background: rgba(222,222,222,0.3);
}

.cpyTxt {
	text-align: right;
	font-weight: 500;
	font-size: 1.2rem;
	color: #adadad;
}

@media screen and (min-width:768px) and (max-width:1040px) {
	.ftrNav {
		font-size: 1.5rem;
	}

	.ftrNav li {
		margin: 0 0 0 30px;
	}
	
	.ftrNav li:after {
		right: -15px;
	}
}

@media screen and (max-width:767px) {
	.ftrAra {
		padding: 30px 15px;
	}

	.ftrBox {
		display: block;
		margin: 0 0 30px;
	}

	.ftrLgBox {
		text-align: center;
		margin: 0 0 30px;
	}

	.ftrLgBox .pagLg {
		max-width: 150px;
		margin: 0 auto;
	}

	.ftrNav {
		flex-wrap: wrap;
		justify-content: center;
		font-size: 1.5rem;
		margin: 0 -15px -20px;
	}

	.ftrNav li {
		position: relative;
		margin: 0 15px 30px;
		box-sizing: border-box;
	}

	.ftrNav li:not(:last-child):after {
		content: none;
	}

	.ftrNav li:nth-child(1):after {
		content: "";
		position: absolute;
		top: calc(50% - 7.5px);
		right: -15px;
		width: 1px;
		height: 15px;
		background: rgba(222,222,222,0.3);
	}
	
	.ftrNav li:nth-child(5) {
		width: 100%;
	}
	
	.ftrNav li:nth-child(5) a {
		text-align: center; 
		max-width: 260px;
		display: block;
		font-size: 1.4rem!important;
		margin: 0 auto;
		padding: 15px;
		box-sizing: border-box;
		background: #1668b3;
		border-radius: 50px;
	}

	.cpyTxt {
		text-align: center;
	}

}

/*=========================================================

lower

=========================================================*/

/* lwrHdr */
.lwrHdr {
	background: #fff;
}

.lwrHdr .pagCth {
	color: #333;
}

/* lwrMnAra */
.lwrMnAra {
	margin: 100px 0 0;
	padding: 0 30px;
	background: url(../images/common/bg_main_lower.png) top right no-repeat,
	url(../images/common/bg_diamond.png) bottom left no-repeat;
	background-size: 1400px auto, 900px auto;
}

.lwrMnWrp {
	max-width: 1200px;
	height: 300px;
	display: flex;
	align-items: center;
	margin: 0 auto;
}

.lwrMnTtlBox {
	color: #fff;
}

.lwrMnTtlEn {
	font-weight: 900;
	font-size: 1.4rem;
	line-height: 1;
	letter-spacing: -0.005em;
	margin: 0 0 13px;
}

.lwrMnTtl {
	font-weight: 700;
	font-size: 4rem;
	line-height: 1.2;
}

@media screen and (min-width:768px) and (max-width:1040px) {
	.lwrMnAra {
		margin: 80px 0 0;
		background: url(../images/common/bg_main_lower.png) top 0 right -150px no-repeat,
		url(../images/common/bg_diamond.png) bottom 0 left -350px no-repeat;
		background-size: 1400px auto, 900px auto;
	}
}

@media screen and (max-width:767px) {
	.lwrMnAra {
		margin: 60px 0 0;
		padding: 0 15px;
		background: url(../images/common/bg_main_lower.png) top 0 right -100px no-repeat,
		url(../images/common/bg_diamond.png) bottom 0 left -100px no-repeat;
		background-size: auto 100%, 450px auto;
	}
	
	.lwrMnWrp {
		height: 150px;
	}

	.lwrMnTtlEn {
		font-size: 1.3rem;
		margin: 0 0 10px;
	}

	.lwrMnTtl {
		font-size: 2.6rem;
	}
}

/* pkzAra */
.pkzAra {
	margin: 60px 0 0;
	padding: 0 30px;
}

.pkzNav {
	max-width: 1200px;
	display: flex;
	align-items: center;
	font-weight: 700;
	font-size: 1.4rem;
	line-height: 1.3;
	margin: 0 auto;
	padding: 15px 40px;
	box-sizing: border-box;
	background: #f8f8f8;
	border-radius: 100px;
	box-shadow: inset 0 1px 2px rgba(197,197,197,0.4);
}

.pkzNav li:not(:last-child) {
	position: relative;
	margin: 0 30px 0 0;
}

.pkzNav li:not(:last-child):after {
	content: "";
	position: absolute;
	top: 4px;
	right: -20px;
	width: 10px;
	height: 10px;
	background: url(../images/common/icn_arrow_rt_gl.png) center no-repeat;
	background-size: 10px auto;
}

.pkzNav a {
	transition: all  0.3s ease;
}

.pkzNav a:link,
.pkzNav a:visited {
	text-decoration: underline!important;
}

.pkzNav a:hover {
	color: #1668b3!important;
}

@media screen and (max-width:767px) {
	.pkzAra {
		margin: 0;
		padding: 0;
		width: 100%;
		overflow-x: scroll;
		white-space: nowrap;
		background: #f8f8f8;
	}

	.pkzNav {
		font-size: 1.3rem;
		padding: 10px 20px;
		border-radius: 0;
		border: none;
overflow-x:auto;
overflow-y:hidden;
-webkit-overflow-scrolling:touch;
overflow-scrolling: touch;
overflow: auto;		
	}

	.pkzNav li:not(:last-child) {
		margin: 0 20px 0 0;
	}

	.pkzNav li:not(:last-child):after {
		top: 5px;
		right: -15px;
		width: 8px;
		height: 8px;
		background-size: 8px auto;
	}
}

/* common */
.lwrItrAra {
	padding: 100px 30px 0;
}

.lwrItrCth {
	position: relative;
	font-weight: 700;
	font-size: 1.8rem;
	line-height: 1.2;
	color: #1668b3;
	padding: 0 0 0 30px;
}

.lwrItrCth:before {
	content: "!";
	text-align: center;
	position: absolute;
	top: 0;
	left: 0;
	width: 20px;
	height: 20px;
	font-weight: 900;
	font-size: 1.6rem;
	line-height: 1.1;
	color: #fff;
	padding: 0 0 0 2.5px;
	box-sizing: border-box;
	background: #1668b3;
	border-radius: 50%;
	z-index: 2;
}

.lwrCntTtl {
	position: relative;
	font-weight: 700;
	font-size: 4.5em;
	line-height: 1.5;
	margin: 0 0 45px;
	padding: 0 0 10px;
	z-index: 1;
}

/*
.lwrCntTtl:before {
	content: "";
	position: absolute;
	bottom: -15px;
	left: 0;
	width: 100%;
	height: 3px;
	background: #eee;
	z-index: 2;
}

.lwrCntTtl:after {
	content: "";
	position: absolute;
	bottom: -15px;
	left: 0;
	width: 150px;
	height: 3px;
	background: #1668b3;
	z-index: 3;
}
*/

.lwrCntTtlEn {
	font-weight: 900;
	font-size: 1.8rem;
	line-height: 1.2;
	letter-spacing: -0.005em;
	color: #1668b3;
	margin: 0 0 0 20px;
}

.navBtnBox {
	display: flex;
	align-items: center;
	justify-content: space-between;
	font-weight: 700;
	font-size: 1.6rem;
	line-height: 1.2;
	margin: 80px 0 0;
}

.navBtnPrv a {
	padding: 0 0 0 90px;
	position: relative;
}

.navBtnNxt a {
	padding: 0 90px;
	position: relative;
}

.navBtnPrv a:before {
	content: "";
	position: absolute;
	top: calc(50% - 35px);
	left: 0;
	width: 70px;
	height: 70px;
	background: url(../images/common/icn_arrow_lt_wt.png) center no-repeat #1668b3;
	background-size: 15px auto;
	border-radius: 50%;
}

.navBtnNxt a:before {
	content: "";
	position: absolute;
	top: calc(50% - 35px);
	right: 0;
	width: 70px;
	height: 70px;
	background: url(../images/common/icn_arrow_rt_wt.png) center no-repeat #1668b3;
	background-size: 15px auto;
	border-radius: 50%;
}

@media screen and (max-width:767px) {
	.lwrItrAra {
		padding: 30px 15px 0;
	}

	.lwrItrCth {
		font-size: 1.6rem;
		padding: 0 0 0 25px;
	}

	.lwrItrCth:before {
		width: 16px;
		height: 16px;
		font-weight: 900;
		font-size: 1.4rem;
		padding: 0 0 0 1px;
	}

	.lwrCntTtl {
		font-size: 2.4em;
		margin: 0 0 20px;
	}

	.lwrCntTtl:before {
		bottom: -10px;
		height: 2px;
	}

	.lwrCntTtl:after {
		bottom: -10px;
		width: 50px;
		height: 2px;
	}

	.lwrCntTtlEn {
		font-size: 1.4rem;
		margin: 0 0 0 15px;
	}

	.navBtnBox {
		max-width: 300px;
		font-size: 1.4rem;
		margin: 40px auto;
	}

	.navBtnPrv a {
		padding: 0 0 0 50px;
		position: relative;
	}

	.navBtnNxt a {
		padding: 0 50px;
	}

	.navBtnPrv a:before {
		top: calc(50% - 20px);
		width: 40px;
		height: 40px;
		background-size: 10px auto;
	}

	.navBtnNxt a:before {
		top: calc(50% - 20px);
		width: 40px;
		height: 40px;
		background-size: 10px auto;
	}
}

/* layout */
.cntClmBox {
	display: flex;
}

.cntMnClmBox {
	width: calc(100% - 400px);
}

.cntSubClmBox {
	max-width: 350px;
	width: 100%;
	margin: 0 0 0 50px;
}

@media screen and (min-width:768px) and (max-width:1040px) {
	.cntMnClmBox {
		width: calc(100% - 300px);
	}

	.cntSubClmBox {
		max-width: 280px;
		margin: 0 0 0 20px;
	}
}

@media screen and (max-width:767px) {
	.cntClmBox {
		display: block;
	}
	
	.cntMnClmBox {
		width: 100%;
		margin: 0 0 30px;
	}

	.cntSubClmBox {
		max-width: 100%;
		margin: 0;
	}
}

/* blog */
.blgBox table {
	width: 100%;
}

.blgBox .navi {
	display: none;
}

.blgBox h2 {
	font-weight: 700;
	font-size: 3.2rem;
	line-height: 1.2;
	margin: 0 0 30px;
}

.blgBox h3 {
	position: relative;
	font-weight: 700;
	font-size: 3rem;
	line-height: 1.2;
	margin: 0 0 20px;
	padding: 10px 10px 10px 40px;
	background: #f8f8f8;
	border-radius: 4px;
}

.blgBox h3:before {
	content: "";
	position: absolute;
	top: 10px;
	left: 20px;
	width: 4px;
	height: calc(100% - 20px);
	background: #1668b3;
}

.blgBox h4 {
	position: relative;
	font-weight: 700;
	font-size: 2.4rem;
	line-height: 1.2;
	margin: 40px 0 20px;
	z-index: 1;
}

.blgBox h4:before {
	content: "";
	position: absolute;
	top: -20px;
	left: 0;
	width: 100%;
	height: 2px;
	background: #eee;
	z-index: 2;
}

.blgBox h4:after {
	content: "";
	position: absolute;
	top: -20px;
	left: 0;
	width: 120px;
	height: 2px;
	background: #1668b3;
	z-index: 3;
}

.blgBox h5 {
	font-weight: 700;
	font-size: 2.4rem;
	line-height: 1.2;
	color: #1668b3;
	margin: 0 0 20px;
}

.blgBox h6 {
	font-weight: 700;
	font-size: 2rem;
	line-height: 1.2;
	margin: 0 0 20px;
	padding: 0 0 5px;
	border-bottom: solid 1px #333;
}

.blgBox img {
	max-width: 100%;
	/*
	width: auto;
	height: auto;
	*/
}

#entry {
	font-size: 1.2rem;
}

.blgBox p {
	font-weight: 400;
	font-size: 1.6rem;
	line-height: 1.8;
}

.blgBox a {
	font-weight: 400;
	font-size: 1.6rem;
	line-height: 1.8;
	text-decoration: underline!important;
}

.blgBox a:hover {
	opacity: 0.60;
	filter: alpha(opacity=60);
	transition: all 0.3s ease;
}

.blgBox strong {
	font-weight: 700;
	font-size: 1.8rem;
	line-height: 1.8;
}

.blgBox bloquote {
	display: block;
	font-weight: 500;
	font-size: 1.6rem;
	font-style: italic;
	line-height: 1.8;
	margin: 0 0 30px;
	padding: 15px;
	background: #f8f8f8;
	border-radius: 10px;
}

.blgBox figure {
	display: block;
	font-weight: 500;
	font-size: 1.6rem;
	line-height: 1.8;
	margin: 0 0 30px;
	padding: 15px;
	border: solid 1px #eee;
	border-radius: 10px;
}

.blgBox ul,.blgBox ol {
	font-weight: 400;
	font-size: 1.8rem;
	line-height: 1.8;
}

.blgBox ul li {
	margin: 0 0 30px;
	padding: 0 0 0 20px;
}

.blgBox ol li {
	margin: 0 0 30px 20px;
}

.blgBox ul li strong {
	position: relative;
	font-weight: 700;
	font-size: 2.2rem;
	margin: 0 0 0 -20px;
	padding: 0 0 0 20px;
}

.blgBox ul li strong:before {
	content: "";
	position: absolute;
	top: 13px;
	left: 0;
	width: 8px;
	height: 8px;
	background: #1668b3;
}

.blgBox .dot strong {
	width: 100%;
	display: block;
	font-weight: 700;
	font-size: 2rem;
	line-height: 1.2;
	color: #fff!important;
	padding: 10px 20px;
	box-sizing: border-box;
	background: #1668b3;
	border-radius: 4px;
}

.blgBox .lastupdated {
	display: inline-block;
	font-weight: 500;
	font-size: 1.4rem;
	line-height: 1.2;
	color: #1668b3;
	margin: 30px 0;
	padding: 5px 10px;
	background: #f8f8f8;
}

.blgBox .demand_marchan img {
	display: none;
}

.blgBox .demand_marchan {
	position: relative;
}

.lwrCtlDtlAra .blgBox .demand_marchan img,
.lwrCasDtlAra .blgBox .demand_marchan img {
	display: inline;
	vertical-align: middle;
	width: 90px;
	height: 30px;
}

.h5.maroon {
	font-size: 1.8rem;
	padding: 0 0 10px;	
	font-weight: 700;
	border-bottom: 1px solid #1668b3;
	display: block;
	color: #1668b3;
}

@media screen and (max-width:767px) {
	.blgBox h2 {
		font-size: 2rem;
		margin: 0 0 20px;
	}

	.blgBox h3 {
		font-size: 1.8rem;
		margin: 0 0 10px;
		padding: 10px 10px 10px 25px;
	}

	.blgBox h3:before {
		left: 10px;
		width: 3px;
	}

	.blgBox h4 {
		font-size: 1.7rem;
		margin: 30px 0 10px;
	}

	.blgBox h4:before {
		top: -10px;
	}

	.blgBox h4:after {
		top: -10px;
		width: 80px;
	}

	.blgBox h5 {
		font-size: 1.6rem;
		margin: 0 0 10px;
	}

	.blgBox h6 {
		font-size: 1.5rem;
		margin: 0 0 10px;
		padding: 0 0 3px;
	}

	.blgBox p {
		font-size: 1.5rem;
		line-height: 1.6;
	}

	.blgBox a {
		font-size: 1.5rem;
		line-height: 1.6;
	}

	.blgBox strong {
		font-size: 1.6rem;
		line-height: 1.6;
	}

	.blgBox bloquote {
		font-size: 1.4rem;
		line-height: 1.6;
		margin: 0 0 20px;
		border-radius: 8px;
	}

	.blgBox figure {
		font-size: 1.4rem;
		line-height: 1.6;
		margin: 0 0 20px;
		border-radius: 8px;
	}

	.blgBox ul,.blgBox ol {
		font-size: 1.5rem;
		line-height: 1.6;
	}

	.blgBox ul li {
		margin: 0 0 20px;
		padding: 0 0 0 15px;
	}

	.blgBox ol li {
		margin: 0 0 20px 15px;
	}

	.blgBox ul li strong {
		font-size: 1.8rem;
		margin: 0 0 0 -15px;
		padding: 0 0 0 15px;
	}

	.blgBox ul li strong:before {
		top: 12px;
		width: 6px;
		height: 6px;
	}

	.blgBox .dot strong {
		font-size: 1.6rem;
		padding: 10px;
	}

	.blgBox .lastupdated {
		font-size: 1.3rem;
		margin: 20px 0;
	}
}

@media screen and (max-width:600px) {
	.blgBox img {
		max-width: 100%;
		height: auto;
	}
}

/*=========================================================

お問い合わせフォーム

=========================================================*/

.lwrFrmAra {
	padding: 100px 30px;
}

.lwrFrmFlwImg {
	max-width: 500px;
	margin: 0 auto 50px;
}

.lwrFrmCthBox {
	text-align: center;
	margin: 0 0 50px;
}

.lwrFrmCth {
	display: inline-block;
	font-weight: 700;
	font-size: 1.7rem;
	line-height: 1.4;
	color: #1668b3;
	padding: 7px 15px;
	border: solid 1px #1668b3;
}

.lwrFrmErrCth {
	display: inline-block;
	font-weight: 700;
	font-size: 1.7rem;
	line-height: 1.4;
	color: #ff0000;
	padding: 7px 15px;
	border: solid 1px #ff0000;
}

.lwrFrmErrCth .minTxt {
	font-size: 1.4rem;
}

.lwrFrmErrTxt {
	position: relative;
	font-weight: 500;
	font-size: 1.4rem;
	line-height: 1.2;
	color: #ff0000;
	margin: 10px 0 0;
	padding: 0 0 0 22px;
}

.lwrFrmErrTxt:before {
	content: "!";
	position: absolute;
	top: calc(50% - 8px);
	left: 0;
	text-align: center;
	width: 16px;
	height: 16px;
	color: #fff;
	padding: 0 0 0 2px;
	box-sizing: border-box;
	background: #ff0000;
	border-radius: 50%;
}

.lwrFrmCapTxt {
	text-align: right;
	font-weight: 700;
	font-size: 1.4rem;
	line-height: 1.2;
	margin: 0 0 10px;
}

.lwrFrmCapTxt .stgTxt {
	color: #ff0000;
	margin: 0 5px 0 0;
}

.lwrFrmLstBox {
	padding: 15px 0 30px;
	background: #f8f8f8;
	border-radius: 10px;
}

.lwrFrmLst li:not(.lwrFrmTxtLst li) {
	display: flex;
	padding: 15px;
}

.lwrFrmLst li:not(:last-child,.lwrFrmTxtLst li) {
	border-bottom: solid 1px #eee;
}

.lwrFrmLstTtl {
	width: 260px;
	font-weight: 700;
	font-size: 1.6rem;
	line-height: 1.2;
	padding: 15px;
	box-sizing: border-box;
}

.lwrFrmLstTtl .stgTxt {
	color: #ff0000;
	margin: 0 0 0 5px;
}

.lwrFrmLstTxt {
	font-weight: 500;
	font-size: 1.6rem;
	line-height: 1.2;
	padding: 15px;
}

.lwrFrmLstCntBox {
	width: calc(100% - 260px);
}

.lwrFrmSlcBox {
	display: inline-block;
	margin: 0 0 15px;
}

.frmBox01 {
	width: 100%;
	height: 40px;
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-weight: 700;
	font-size: 1.6rem;
	line-height: 1.2;
	padding: 15px;
	box-sizing: border-box;
	border: solid 1px #e1e1e1;
	border-radius: 4px!important;
}

.frmBox02 {
	width: 150px;
	height: 40px;
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-weight: 700;
	font-size: 1.6rem;
	line-height: 1.2;
	padding: 15px;
	box-sizing: border-box;
	border: solid 1px #e1e1e1;
	border-radius: 4px!important;
}

.frmBox03 {
	width: 100%;
	height: 150px;
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-weight: 700;
	font-size: 1.6rem;
	line-height: 1.5;
	padding: 15px;
	box-sizing: border-box;
	border: solid 1px #e1e1e1;
	border-radius: 4px!important;
}

.lwrFrmLstCntBox select {
	width: 250px;
	height: 40px;
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-weight: 700;
	font-size: 1.6rem;
	line-height: 1.2;
	color: #333!important;
	padding: 5px 15px;
	box-sizing: border-box;
	background: #fff!important;
	border: solid 1px #e1e1e1;
	border-radius: 4px!important;
	cursor: pointer;
}

.frmBar {
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-weight: 700;
	font-size: 1.6rem;
	line-height: 40px;
	margin: 0 12px 0 15px;
}

.lwrFrmMinBox {
	margin: 0 0 -10px;
}

.lwrFrmMinBox input {
	margin: 0 0 10px;
}

.lwrFrmTxtLst {
	display: flex;
	font-weight: 700;
	font-size: 1.6rem;
	line-height: 1.2;
}

.lwrFrmTxtLst li:not(:last-child) {
	margin: 0 50px 0 0;
}

.lwrFrmTxtLst li input {
	margin: 4px 8px 0 0;
}

.lwrFrmBtn {
	max-width: 500px;
	width: 100%;
	margin: 30px auto 0;
}

.lwrFrmBtn input {
	text-align: center;
	width: 100%;
	position: relative;
	display: block;
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-weight: 700;
	font-size: 1.6rem;
	line-height: 1.2;
	color: #fff;
	padding: 25px;
	background: url(../images/common/icn_arrow_rt_wt.png) right 20px center no-repeat #1668b3;
	background-size: 15px auto;
	box-sizing: border-box;
	border: none;
	border-radius: 6px!important;
	cursor: pointer;
	z-index: 1;
}

.lwrFrmBtn input:hover {
	color: #333;
	background: url(../images/common/icn_arrow_rt_bk.png) right 20px center no-repeat #ffbc00;
	background-size: 15px auto;
	transition: all 0.3s ease;
}

.lwrFrmBakBtn {
	max-width: 300px;
	width: 100%;
	margin: 20px auto 0;
}

.lwrFrmBakBtn input,
.lwrFrmBakBtn a {
	text-align: center;
	width: 100%;
	position: relative;
	display: block;
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-weight: 700;
	font-size: 1.5rem;
	line-height: 1.2;
	color: #333;
	padding: 17.5px;
	background: url(../images/common/icn_arrow_lt_bl.png) left 15px center no-repeat #e1e1e1;
	background-size: 15px auto;
	box-sizing: border-box;
	border: none;
	border-radius: 6px!important;
	cursor: pointer;
	z-index: 1;
	text-decoration: none;
}

.lwrFrmBakBtn input:hover,
.lwrFrmBakBtn a:hover {
	color: #fff;
	background: url(../images/common/icn_arrow_lt_wt.png) left 15px center no-repeat #333;
	background-size: 15px auto;
	transition: all 0.3s ease;
}

/*lwrFrmDonAra */
.lwrFrmDonAra {
	padding: 100px 30px;
}

.lwrFrmDonTtl {
	text-align: center;
	position: relative;
	font-weight: 700;
	font-size: 3.2rem;
	line-height: 1.2;
	margin: 0 0 50px;
}

.lwrFrmDonTtl:after {
	content: "";
	position: absolute;
	bottom: -15px;
	left: calc(50% - 15px);
	width: 30px;
	height: 3px;
	background: #1668b3;
}

.lwrFrmDonTxtBox {
	text-align: center;
}

.lwrFrmDonTxt {
	display: inline-block;
	font-weight: 700;
	font-size: 2.2rem;
	line-height: 1.6;
	padding: 30px;
	background: #f8f8f8;
	border-radius: 10px;
}

@media screen and (max-width:767px) {
	.lwrFrmAra {
		padding: 30px 15px 60px;
	}

	.lwrFrmFlwImg {
		max-width: 300px;
		margin: 0 auto 30px;
	}

	.lwrFrmCthBox {
		text-align: left;
		margin: 0 0 30px;
	}

	.lwrFrmCth {
		display: block;
		font-size: 1.5rem;
		padding: 7px 10px;
	}

	.lwrFrmErrCth {
		display: block;
		font-size: 1.5rem;
		padding: 7px 10px;
	}
	
	.lwrFrmErrCth .minTxt {
		font-size: 1.3rem;
	}
	
	.lwrFrmCapTxt {
		font-size: 1.3rem;
	}

	.lwrFrmLstBox {
		padding: 5px 0 30px;
		border-radius: 8px;
	}

	.lwrFrmLst li:not(.lwrFrmTxtLst li) {
		display: block;
	}

	.lwrFrmLstTtl {
		width: 100%;
		font-size: 1.5rem;
		margin: 0 0 10px; 
		padding: 0;
	}
	
	.lwrFrmLstTxt {
		font-size: 1.5rem;
		padding: 0;
	}

	.lwrFrmLstCntBox {
		width: 100%;
	}
	
	.lwrFrmSlcBox {
		margin: 0 0 10px;
		position: relative;
		z-index: 2;
	}

	.lwrFrmSlcBox:after {
		content: "▼";
		position: absolute;
		top: 12px;
		right: 10px;
		color: #333!important;
		z-index: 3;
	}

	.frmBox01 {
		font-size: 1.5rem;
		padding: 10px;
	}

	.frmBox02 {
		width: 120px;
		font-size: 1.5rem;
		padding: 10px;
	}

	.frmBox03 {
		height: 120px;
		font-size: 1.5rem;
		padding: 10px;
	}

	.lwrFrmLstCntBox select {
		width: 200px;
		font-size: 1.5rem;
		padding: 5px 10px;
	}

	.frmBar {
		font-size: 1.5rem;
		margin: 0 7px 0 10px;
	}

	.errTxt {
		font-size: 1.3rem;
	}

	.lwrFrmTxtLst {
		justify-content: center;
		font-size: 1.5rem;
	}

	.lwrFrmTxtLst li:not(:last-child) {
		margin: 0 30px 0 0;
	}

	.lwrFrmTxtLst li input {
		margin: 3px 6px 0 0;
	}

	.lwrFrmBtn {
		max-width: 260px;
		margin: 15px auto 0;
	}

	.lwrFrmBtn input {
		min-height: 50px;
		font-size: 1.4rem;
		padding: 15px 25px;
		border-radius: 50px!important;
	}
	
	.lwrFrmBakBtn {
		max-width: 200px;
		margin: 15px auto 0;
	}

	.lwrFrmBakBtn input,
	.lwrFrmBakBtn a {
		min-height: 40px;
		font-size: 1.4rem;
		padding: 10px 25px;
		border-radius: 50px!important;
	}

	.lwrFrmDonAra {
		padding:30px 15px;
	}

	.lwrFrmDonTtl {
		font-size: 2.2rem;
		margin: 0 0 25px;
	}

	.lwrFrmDonTtl:after {
		bottom: -7px;
		left: calc(50% - 10px);
		width: 20px;
		height: 2px;
	}

	.lwrFrmDonTxt {
		text-align: left;
		font-size: 1.6rem;
		padding: 15px;
		border-radius: 8px;
	}
}

/*=========================================================

サイトマップ

=========================================================*/

.lwrStmAra {
	padding: 100px 30px;
}

.lwrStmLst {
	display: flex;
	flex-wrap: wrap;
	margin: 0 -7.5px;
}

.lwrStmLst dt {
	width: 100%;
	margin: 0 7.5px;
	padding: 30px 0;
	border-top: solid 1px #eee;
}

.lwrStmLst dt:first-child {
	padding: 0 0 30px;
	border-top: none;
}

.lwrStmLst dd {
	width: calc(50% - 15px);
	margin: 0 7.5px;
	box-sizing: border-box;
}

.lwrStmLstTtlBtn {
	display: inline-block;
	font-weight: 700;
	font-size: 2.2rem;
	line-height: 1.3;
	padding: 0 30px 0 20px;
	background: url(../images/common/icn_arrow_rt_gl.png) right no-repeat;
	background-size: 25px auto;
	border-left: solid 4px #1668b3;
}

.lwrStmLstMinTtlBtn {
	margin: 0 0 15px;
}

.lwrStmLstMinTtlBtn a {
	position: relative;
	display: block;
	font-weight: 700;
	font-size: 1.8rem;
	line-height: 1.2;
	padding: 15px 35px 15px 15px;
	background: #f8f8f8;
}

.lwrStmLstMinTtlBtn a:after {
    content: "";
    position: absolute;
    top: calc(50% - 10px);
    right: 15px;
    width: 20px;
    height: 20px;
    background: url(../images/common/icn_arrow_rt_wt.png) center no-repeat #1668b3;
    background-size: 10px auto;
    border-radius: 50%;
}

.lwrStmLstTtlBtn a:link,
.lwrStmLstTtlBtn a:visited,
.lwrStmLstMinTtlBtn a:link,
.lwrStmLstMinTtlBtn a:visited {
	color: #333!important;
}

.lwrStmLst dd .cteMinLst {
	margin: 0 0 30px;
	padding: 0 0 0 30px;
}

@media screen and (max-width:767px) {
	.lwrStmAra {
		padding: 30px 15px;
	}

	.lwrStmLst {
		display: block;
		margin: 0;
	}

	.lwrStmLst dt {
		margin: 0;
		padding: 15px 0;
	}

	.lwrStmLst dt:first-child {
		padding: 0 0 15px;
	}

	.lwrStmLst dd {
		width: 100%;
		margin: 0;
	}

	.lwrStmLstTtlBtn {
		font-size: 1.8rem;
		padding: 0 20px 0 10px;
		background-size: 15px auto;
		border-left: solid 3px #1668b3;
	}

	.lwrStmLstMinTtlBtn {
		margin: 0 0 10px;
	}

	.lwrStmLstMinTtlBtn a {
		font-size: 1.6rem;
		padding: 15px 25px 15px 10px;
	}

	.lwrStmLstMinTtlBtn a:after {
		content: "";
		position: absolute;
		top: calc(50% - 8px);
		right: 10px;
		width: 16px;
		height: 16px;
		background: url(../images/common/icn_arrow_rt_wt.png) center no-repeat #1668b3;
		background-size: 8px auto;
		border-radius: 50%;
	}

	.lwrStmLst dd .cteMinLst {
		margin: 0 0 15px;
		padding: 0 0 0 15px;
	}
}

/*=========================================================

管理画面ログイン

=========================================================*/

.lwrLgiAra {
	padding: 100px 30px;
}

.lwrLgiTtlBox {
	text-align: center;
	margin: 0 0 40px;
}

.lwrLgiTtl {
	text-align: left;
	position: relative;
	display: inline-block;
	font-weight: 700;
	font-size: 1.6rem;
	line-height: 1.3;
	color: #1668b3;
	padding: 10px 10px 10px 50px;
	border: solid 1px #1668b3;
	z-index: 1;
}

.lwrLgiTtl:before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 40px;
	height: 100%;
	background: url(../images/common/icn_login_wt.png) center no-repeat #1668b3;
	background-size: 20px auto;
	z-index: 2;
}

.lwrLgiTxt {
	text-align: center;
	font-weight: 700;
	font-size: 1.6rem;
	line-height: 1.5;
	margin: 60px 0 0;
}

@media screen and (max-width:767px) {
	.lwrLgiAra {
		padding: 30px 15px 60px;
	}

	.lwrLgiTtlBox {
		margin: 0 0 30px;
	}

	.lwrLgiTtl {
		font-size: 1.5rem;
		padding: 7px 7px 7px 40px;
	}

	.lwrLgiTtl:before {
		width: 30px;
		background-size: 15px auto;
	}

	.lwrLgiTxt {
		text-align: left;
		font-size: 1.5rem;
		margin: 30px 0 0;
	}
}

/*=========================================================

ソフト比較

=========================================================*/

.lwrCprAra {
	padding: 100px 30px;
}

.lwrCprTbl {
	width: 100%;
	table-layout: fixed;
	border-top: solid 1px #eee;
	border-right: solid 1px #eee;
}

.lwrCprTbl th {
	text-align: center;
	width: 170px;
	font-weight: 700;
	font-size: 1.6rem;
	line-height: 1.2;
	color: #fff;
	padding: 30px 15px;
	box-sizing: border-box;
	background: #1668b3;
	border-bottom: solid 1px #eee;
	vertical-align: middle;
}

.lwrCprTbl td {
	text-align: center;
	font-weight: 700;
	font-size: 1.6rem;
	line-height: 1.2;
	padding: 30px 15px;
	border-bottom: solid 1px #eee;
	vertical-align: middle;
}

.lwrCprTbl td:nth-child(odd) {
	background: #f8f8f8;
}

.lwrCprTblTtl {
	font-weight: 700;
	font-size: 2rem;
	line-height: 1.2;
}

.lwrCprTblImg {
	max-width: 250px;
	margin: 0 auto;
	overflow: hidden;
	border-radius: 6px;
}

.lwrCprTblMinTxt {
	text-align: left;
	font-weight: 400;
	font-size: 1.6rem;
	line-height: 1.5;
}

.lwrCprTblChk input {
    margin: 4px 8px 0 0;
}

@media screen and (min-width:768px) and (max-width:1040px) {
	.lwrCprTbl th {
		width: 120px;
		padding: 20px 10px;
	}
	
	.lwrCprTbl td {
		padding: 20px 10px;
	}
}

@media screen and (max-width:767px) {
	.lwrCprAra {
		padding: 30px 15px;
	}
	
	.lwrCprTblBox {
		overflow: auto;
	}
	
	.lwrCprTbl {
		min-width: 800px;
	}
	
	.lwrCprTbl th {
		width: 90px;
		font-size: 1.4rem;
		padding: 10px 5px;
	}

	.lwrCprTbl td {
		font-size: 1.5rem;
		padding: 10px;
	}

	.lwrCprTblTtl {
		font-size: 1.7rem;
	}

	.lwrCprTblMinTxt {
		font-size: 1.4rem;
	}

	.lwrCprTblChk input {
		margin: 3px 6px 0 0;
	}
}

/*=========================================================

建設DXカタログ一覧

=========================================================*/

.lwrCtlAra {
	padding: 60px 30px 100px;
}

.lwrCtlTypLstBox {
	display: inline-block;
	box-sizing: border-box;
	margin: 50px 0 0;
	padding: 5px;
	background: #f8f8f8;
	border-radius: 100px;
	box-shadow: inset 0 1px 2px rgba(197,197,197,0.4);
}

.lwrCtlTypLst {
	display: flex;
	text-align: center;
	font-weight: 500;
	font-size: 1.4rem;
	line-height: 1.2;
}

.lwrCtlTypLst a {
	min-width: 100px;
	display: block;
	padding: 10px;
	box-sizing: border-box;
}

.lwrCtlTypLst a:hover {
	color: #1668b3!important;
	transition: all 0.3s ease;
	text-decoration: none!important;
}

.lwrCtlTypLst .act a {
	color: #fff!important;
	background: #1668b3;
	border-radius: 100px;
}

.lwrCtlTypLst .act a:hover {
	color: #333!important;
	background: #ffbc00;
	transition: all 0.3s ease;
}

.lwrCtlLst li {
	padding: 15px;
	background: #fff;
	border: solid 1px #eee;
	border-radius: 10px
}

.lwrCtlLst li:not(:last-child) {
	margin: 0 0 20px;
}

.lwrCtlLstBox {
	display: flex;
}

.lwrCtlLstImgBox {
	max-width: 280px;
	width: 100%;
	margin: 0 20px 0 0;
}

.lwrCtlLstImg {
	position: relative;
	overflow: hidden;
	border-radius: 10px;
}

.lwrCtlLstImg:before {
	content: "";
	display: block;
	padding-top: 60.715%;
}

.lwrCtlLstImg img {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.lwrCtlLstCntBox {
	width: calc(100% - 300px);
	position: relative;
	padding: 0 60px 0 0;
}

.lwrCtlLstCntBox:after {
	content: "";
	position: absolute;
	top: calc(50% - 10px);
	right: 0;
	width: 20px;
	height: 20px;
	background: url(../images/common/icn_arrow_rt_wt.png) center no-repeat #1668b3;
	background-size: 10px auto;
	border-radius: 50%;
}

.lwrCtlLstTtl {
	font-weight: 700;
	font-size: 2rem;
	line-height: 1.2;
	margin: 0 0 10px;
}

.lwrCtlLstTxt {
	font-weight: 400;
	font-size: 1.6rem;
	line-height: 1.5;
	margin: 0 0 15px;
	color: #333!important;
}

.lwrCtlLstNmeBox {
	text-align: right;
}

.lwrCtlNme {
	display: inline-block;
	font-weight: 500;
	font-size: 1.4rem;
	line-height: 1.2;
	padding: 3px 10px;
	color: #1668b3;
	border: solid 1px #1668b3;
}

@media screen and (max-width:767px) {
	.lwrCtlAra {
		padding: 20px 15px 30px;
	}

	.lwrCtlTypLstBox {
		width: 100%;
		margin: 30px 0 0;
		border-radius: 8px;
	}

	.lwrCtlTypLst {
		text-align: center;
		flex-wrap: wrap;
		justify-content: center;
		font-size: 1.3rem;
		white-space: nowrap;
	}

	.lwrCtlTypLst li {
		width: 33.33%;
	}

	.lwrCtlTypLst a {
		min-width: auto;
		width: 100%;
	}

	.lwrCtlTypLst .act a {
		border-radius: 6px;
	}

	.lwrCtlLst li {
		border-radius: 8px
	}

	.lwrCtlLstBox {
		display: block;
	}

	.lwrCtlLstImgBox {
		max-width: 100%;
		margin: 0 0 15px;
	}

	.lwrCtlLstImg {
		border-radius: 8px;
	}

	.lwrCtlLstCntBox {
		width: calc(100% - 20px);
		padding: 0 20px 0 0;
	}

	.lwrCtlLstCntBox:after {
		content: "";
		position: absolute;
		top: calc(50% - 8px);
		right: 0;
		width: 16px;
		height: 16px;
		background: url(../images/common/icn_arrow_rt_wt.png) center no-repeat #1668b3;
		background-size: 8px auto;
		border-radius: 50%;
	}

	.lwrCtlLstTtl {
		font-size: 1.8rem;
	}

	.lwrCtlLstTxt {
		font-size: 1.5rem;
	}

	.lwrCtlLstNmeBox {
		text-align: center;
	}

	.lwrCtlNme {
		font-weight: 500;
		font-size: 1.3rem;
	}
}

/*=========================================================

建設DXカタログ詳細

=========================================================*/

/* lwrCtlDtlAra */
.lwrCtlDtlAra {
	padding: 60px 30px 100px;
}

.lwrCtlDtlNmeBox {
	text-align: right;
	margin: -40px 0 60px;
}

@media screen and (max-width:767px) {
	.lwrCtlDtlAra {
		padding: 20px 15px 30px;
	}

	.lwrCtlDtlNmeBox {
		margin: -20px 0 30px;
	}
}

/*=========================================================

建設DX活用事例一覧

=========================================================*/

.lwrCasAra {
	padding: 100px 30px;
}

.lwrCasAra .casLst {
	margin: 0 -20px -20px;
}

.lwrCasAra .casLst li {
	width: calc(50% - 40px);
	margin: 0 20px 20px;
}

@media screen and (max-width:767px) {
	.lwrCasAra {
		padding: 30px 15px;
	}

	.lwrCasAra .casLst {
		display: block;
		margin: 0 0 -10px;
	}

	.lwrCasAra .casLst li {
		width: 100%;
		margin: 0 0 10px;
	}
}

/*=========================================================

建設DX活用事例詳細

=========================================================*/

.lwrCasDtlAra {
	padding: 100px 30px;
}

@media screen and (max-width:767px) {
	.lwrCasDtlAra {
		padding: 30px 15px;
	}	
}

/*=========================================================

新製品ニュース

=========================================================*/

.lwrNwsAra {
	padding: 100px 30px;
}

.lwrNwsLst li {
	display: flex;
	align-items: center;
}

.lwrNwsLst li:not(:last-child) {
	padding: 0 0 30px;
	margin: 0 0 30px;
	border-bottom: solid 1px #eee;
}

.lwrNwsLstImgBox {
	max-width: 150px;
	width: 100%;
	margin: 0 30px 0 0;
}

.lwrNwsLstImg {
	position: relative;
	overflow: hidden;
	border-radius: 6px;
}

.lwrNwsLstImg:before {
	content: "";
	display: block;
	padding-top: 100%;
}

.lwrNwsLstImg img {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.lwrNwsDtaBox {
	display: flex;
	align-items: center;
	margin: 0 0 15px;
}

.lwrNwsDta {
	display: inline-block;
	font-weight: 500;
	font-size: 1.4rem;
	line-height: 1.2;
	color: #828282;
	margin: 0 20px 0 0;
}

.lwrNwsTyp a {
	text-align: center;
	min-width: 100px;
	display: inline-block;
	font-weight: 500;
	font-size: 1.4rem;
	line-height: 1.2;
	color: #1668b3;
	padding: 2px 10px;
	box-sizing: border-box;
	background: #f8f8f8;
	border-radius: 50px;
}

.lwrNwsLstTtl {
	cursor: pointer;
	font-weight: 700;
    font-size: 2.4rem;
    line-height: 1.5;
}

.subClmAtcLst {
	font-weight: 500;
	font-size: 1.6rem;
	line-height: 1.4;
	margin: 0 0 50px;
}

.subClmAtcLst li:not(:last-child) {
	margin: 0 0 15px;
	padding: 0 0 15px;
	border-bottom: solid 1px #eee;
}

.subClmLst:not(.subClmMinLst) {
	font-weight: 500;
	font-size: 1.6rem;
	line-height: 1.2;
	margin: 0 0 50px;
}

.subClmLst li {
	padding: 10px 0px 10px 15px;
	background: url(../images/common/icn_arrow_rt_bl.png) right 15px center no-repeat #f8f8f8;
	background-size: 10px auto;
	border-radius: 1px;
}

.subClmLst li:not(:last-child,.subClmMinLst li:last-child) {
	margin: 0 0 2px;
}

.subClmAtcLst a:hover,
.subClmLst a:hover {
	color: #1668b3!important;
	transition: all 0.3s ease;
}

.subClmLstTtl {
	cursor: pointer;
}

.subClmLstTtl:hover {
	color: #1668b3!important;
	transition: all 0.3s ease;
}

.subClmMinLst li:not(:last-child) {
	border-bottom: solid 2px #fff;
}

.subClmBtnLst li:not(:last-child) {
	margin: 0 0 20px;
}

.subClmBtnLst li .cntSubBtnImg {
	max-width: 100px;
	margin: 0 15px 0 0;
}

.subClmBtnLst li .cntSubBtnTtl {
	font-size: 1.8rem;
}

.subClmBtnLst li .cntSubBtnTtl .minTxt {
	font-size: 1.4rem;
}

.subClmBtnLst li .cntSubBtnTtl .bigTxt {
	font-size: 2.2rem;
}

@media screen and (max-width:1040px) {
	.subClmBtnLst li .cntSubBtn a:after {
		top: calc(50% - 12.5px);
		right: 10px;
		width: 25px;
		height: 25px;
	}

	.subClmBtnLst li .logBtn a:after {
		background-size: 15px auto;
	}

	.subClmBtnLst li .pubBtn a:after {
		background-size: 15px auto;
	}

	.subClmBtnLst li .cntSubBtnImg {
		max-width: 80px;
		margin: 0 10px 0 0;
	}

	.subClmBtnLst li .cntSubBtnTtl {
		font-size: 1.6rem;
	}

	.subClmBtnLst li .cntSubBtnTtl .minTxt {
		font-size: 1.3rem;
	}

	.subClmBtnLst li .cntSubBtnTtl .bigTxt {
		font-size: 2.2rem;
	}
}

@media screen and (max-width:767px) {
	.lwrNwsAra {
		padding: 30px 15px;
	}

	.lwrNwsLst li {
		align-items: flex-start;
	}

	.lwrNwsLst li:not(:last-child) {
		padding: 0 0 15px;
		margin: 0 0 15px;
	}

	.lwrNwsLstImgBox {
		max-width: 80px;
		margin: 0 10px 0 0;
	}
	
	.lwrNwsDtaBox {
		display: block;
		margin: 0;
	}

	.lwrNwsDta {
		font-size: 1.3rem;
		margin: 0 0 7px;
	}

	.lwrNwsTyp {
		margin: 0 0 10px;
	}

	.lwrNwsTyp a {
		min-width: 80px;
		font-size: 1.3rem;
	}

	.lwrNwsLstTtl {
		font-size: 1.8rem;
		line-height: 1.4;
	}

	.subClmAtcLst {
		font-size: 1.5rem;
		margin: 0 0 30px;
	}

	.subClmLst:not(.subClmMinLst) {
		font-size: 1.5rem;
		margin: 0 0 30px;
	}

	.subClmLst li {
		padding: 10px;
		background: url(../images/common/icn_arrow_rt_bl.png) right 10px center no-repeat #f8f8f8;
		background-size: 10px auto;
	}
}

/*=========================================================

新製品ニュース詳細

=========================================================*/

.lwrNwsDtlAra {
	padding: 100px 30px;
}

.lwrNwsDtlAra .lwrNwsDtaBox {
	justify-content: flex-end;
	margin: -40px 0 60px;
}

@media screen and (max-width:767px) {
	.lwrNwsDtlAra {
		padding: 30px 15px;
	}

	.lwrNwsDtlAra .lwrNwsDtaBox {
		display: flex;
		justify-content: flex-end;
		margin: -20px 0 30px;
	}
}

/*=========================================================

特集記事

=========================================================*/

.lwrAtcAra {
	padding: 100px 30px;
}

.lwrAtcLst li:not(:last-child) {
	margin: 0 0 30px;
	padding: 0 0 30px;
	border-bottom: solid 1px #eee;
}

.lwrAtcLstDta {
	display: block;
	font-weight: 500;
	font-size: 1.6rem;
	line-height: 1.2;
	color: #828282;
	margin: 0 0 7px;
}

.lwrAtcLstTtl {
	font-weight: 700;
	font-size: 2.4rem;
	line-height: 1.3;
	color: #333!important;
}

.subClmNwsBox {
	margin: 0 0 50px;
	padding: 5px;
	background: #fff;
	border: solid 1px #eee;
	border-radius: 6px;
}

.subClmNwsInr {
	display: flex;
	align-items: center;
}

.subClmNwsImg {
	max-width: 90px;
	width: 100%;
	position: relative;
	margin: 0 15px 0 0;
	overflow: hidden;
	border-radius: 6px;
}

.subClmNwsImg:before {
	content: "";
	display: block;
	padding-top: 100%;
}

.subClmNwsImg img {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.subClmNwsTtl {
	font-weight: 700;
	font-size: 1.5rem;
	line-height: 1.2;
	color: #333!important;
}

.subClmBnrLst {
	margin: 0 0 20px;
}

.subClmBnrLst li:not(:last-child) {
	margin: 0 0 20px;
}

@media screen and (max-width:767px) {
	.lwrAtcAra {
		padding: 30px 15px;
	}
	
	.lwrAtcLst li:not(:last-child) {
		margin: 0 0 15px;
		padding: 0 0 15px;
	}

	.lwrAtcLstDta {
		font-size: 1.4rem;
		margin: 0 0 5px;
	}

	.lwrAtcLstTtl {
		font-size: 1.8rem;
	}

	.subClmNwsBox {
		margin: 0 0 30px;
	}

	.subClmNwsImg {
		max-width: 80px;
		margin: 0 10px 0 0;
	}
}

/*=========================================================

特集記事詳細

=========================================================*/

.lwrAtcDtlAra {
	padding: 100px 30px;
}

.lwrAtcDtlAra .lwrAtcLstDta {
	text-align: right;
	margin: -40px 0 60px;
}

@media screen and (max-width:767px) {
	.lwrAtcDtlAra {
		padding: 30px 15px;
	}

	.lwrAtcDtlAra .lwrAtcLstDta {
		margin: -20px 0 30px;
	}
}

/*=========================================================

必ずお読みください

=========================================================*/

.lwrRdmAra {
	padding: 100px 30px;
}

.lwrRdmTxt {
	font-weight: 400;
	font-size: 1.6rem;
	line-height: 1.8;
	margin: 0 0 80px;
}

.lwrRdmTxt a {
	font-weight: 700;
}

.lwrRdmLst {
	padding: 0 0 80px;
}

.lwrRdmLst dd:not(:last-child) {
	margin: 0 0 60px;
}

.lwrRdmLst dd .lwrRdmTxt,
.lwrRdmNbrLst li .lwrRdmTxt{
	margin: 0;
}

.lwrRdmNbrLst {
	margin: 0 0 80px;
	list-style: none;
	counter-reset: number 0;
}

.lwrRdmNbrLst li:not(:last-child) {
	margin: 0 0 30px;
}

.lwrRdmNbrLstTtl {
	position: relative;
	font-weight: 700;
	font-size: 2rem;
	line-height: 1.2;
	margin: 0 0 10px;
	padding: 0 0 0 30px;
}

.lwrRdmNbrLstTtl:before {
	counter-increment: number 1; 
	content: counter(number) " "; 
	position: absolute;
	top: 2px;
	left: 0;
	text-align: center;
	width: 20px;
	height: 20px;
	font-size: 1.6rem;
	color: #fff;
	box-sizing: border-box;
	background: #1668b3;
	border-radius: 50%;
}

.lwrRdmNbrLst li .lwrRdmTxt {
	padding: 0 0 0 30px;
}

.lwrRdmNme {
	text-align: right;
	font-weight: 700;
	font-size: 2rem;
	line-height: 1.2;
}

@media screen and (max-width:767px) {
	.lwrRdmAra {
		padding: 30px 15px;
	}

	.lwrRdmTxt {
		font-size: 1.5rem;
		line-height: 1.6;
		margin: 0 0 30px;
	}

	.lwrRdmLst {
		padding: 0 0 30px;
	}

	.lwrRdmLst dd:not(:last-child) {
		margin: 0 0 20px;
	}

	.lwrRdmNbrLst {
		margin: 0 0 30px;
	}

	.lwrRdmNbrLst li:not(:last-child) {
		margin: 0 0 15px;
	}

	.lwrRdmNbrLstTtl {
		font-size: 1.7rem;
		padding: 0 0 0 25px;
	}

	.lwrRdmNbrLstTtl:before {
		width: 16px;
		height: 16px;
		font-size: 1.3rem;
	}

	.lwrRdmNbrLst li .lwrRdmTxt {
		padding: 0 0 0 20px;
	}

	.lwrRdmNme {
		font-size: 1.6rem;
	}
}

/*=========================================================

カテゴリー

=========================================================*/

/* common */
.schMnAra {
	margin: 100px 0 0;
	padding: 20px 30px;
	background: #023a6d;
}

.schMnBox {
	display: flex;
	align-items: center;
	justify-content: center;
}

.schMnTtl {
	font-weight: 700;
	font-size: 2rem;
	line-height: 1.2;
	color: #fff;
	margin: 0 30px 0 0;
}

@media screen and (min-width:768px) and (max-width:1040px) {
	.schMnAra {
		margin: 80px 0 0;
	}
}

@media screen and (max-width:767px) {
	.schMnAra {
		margin: 60px 0 0;
		padding: 15px;
	}

	.schMnBox {
		display: block;
	}

	.schMnTtl {
		text-align: center;
		font-size: 1.6rem;
		margin: 0 0 10px;
	}

}

/*=========================================================

カテゴリー一覧

=========================================================*/

.schCtePopAra {
	padding: 100px 30px;
}

.schCtePopLst:not(.schCtePkzLst) {
	display: flex;
	margin: 0 -15px;
}

.schCtePopLst li:not(.schCtePkzLst li) {
	width: calc(25% - 30px);
	margin: 0 15px;
}

.schCtePopLstImg {
	position: relative;
	overflow: hidden;
	margin: 0 0 20px;
	border-radius: 8px;
}

.schCtePopLstImg:before {
	content: "";
	display: block;
	padding-top: 61.5%;
}

.schCtePopLstImg img {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.schCtePkzLst {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	font-weight: 700;
	font-size: 1.4rem;
	line-height: 1.3;
}

.schCtePkzLst li:not(:last-child) {
	position: relative;
	margin: 0 30px 10px 0;
}

.schCtePkzLst li:not(:last-child):after {
	content: "";
	position: absolute;
	top: 4px;
	right: -20px;
	width: 10px;
	height: 10px;
	background: url(../images/common/icn_arrow_rt_gl.png) center no-repeat;
	background-size: 10px auto;
}

.schCtePkzLst li:last-child {
	padding: 3px 10px;
	color: #fff;
	background: #1668b3;
	border-radius: 50px;
}

.schCtePkzLst a {
	transition: all  0.3s ease;
}

.schCtePkzLst a:link,
.schCtePkzLst a:visited {
	text-decoration: underline!important;
}

.schCtePkzLst li:last-child a:link,
.schCtePkzLst li:last-child a:visited,
.schCtePkzLst li:last-child a:hover,
.schCtePkzLst li:last-child a:active {
	color: #fff!important;
	text-decoration: none!important;
}

/* schCteAra */
.mtp {
	margin: 100px 0 0;
}

.schCteAra {
	padding: 100px 30px;
	background: url(../images/common/bg_category.png) top right no-repeat;
	background-size: 1000px auto;
}

.schCteAra .cntTtlEn,
.schCteAra .cntTtl {
	color: #fff;
}

.schCteLst li:not(.cteMinLst li,.schCteCntLst li,.cteMinLst li) {
	display: flex;
	overflow: hidden;
	background: #fff;
	border-radius: 10px;
	box-shadow: 0 3px 4px rgba(0,0,0,0.15);
}

.schCteLst li:not(:last-child) {
	margin: 0 0 50px;
}

.schCteLstImgBox {
	order: 1;
	max-width: 320px;
	width: 100%;
}


.schCteLstCntBox {
	order: 2;
	width: calc(100% - 320px);
	padding: 50px;
	box-sizing: border-box;
}

.schCteCntLst li {
	display: flex;
}

.schCteCntLst li:not(:last-child) {
	margin: 0 0 25px;
}

.schCteCntLstBtn {
	max-width: 220px;
	width: 100%;
	position: relative;
	font-weight: 700;
	font-size: 2rem;
	line-height: 1.3;
	margin: 0 30px 0 0;
	padding: 0 0 0 30px;
	box-sizing: border-box;
}

.schCteCntLstBtn:after {
	content: "";
	position: absolute;
	top: 3px;
	left: 0;
	width: 20px;
	height: 20px;
	background: url(../images/common/icn_arrow_rt_wt.png) center no-repeat #1668b3;
	background-size: 10px auto;
	border-radius: 50%;
}

.schCteCntLstBox {
	width: calc(100% - 250px);
}

.schCteCntLstBox .cteMinLst,
.schCteCntLstInr .cteMinLst {
	display: flex;
	flex-wrap: wrap;
}

.schCteCntLstBox .cteMinLst li,
.schCteCntLstInr .cteMinLst li {
	margin: 0 20px 0 0;
}

@media screen and (min-width:768px) and (max-width:1040px) {
	.schCtePopLst:not(.schCtePkzLst) {
		flex-wrap: wrap;
		margin: 0 -15px -30px;
	}

	.schCtePopLst li:not(.schCtePkzLst li) {
		width: calc(50% - 30px);
		margin: 0 15px 30px;
	}
	
	.schCteLst li:not(.cteMinLst li,.schCteCntLst li,.cteMinLst li) {
		display: block;
	}
	
	.schCteLstImgBox {
		max-width: 100%;
		height: 300px;
	}
	
	.schCteLstCntBox {
		width: 100%;
		padding: 30px;
	}	
}

@media screen and (max-width:767px) {
	.schCtePopAra {
		padding: 30px 15px;
	}
	
	.schCtePopLst:not(.schCtePkzLst) {
		flex-wrap: wrap;
		margin: 0 -5px -15px;
	}

	.schCtePopLst li:not(.schCtePkzLst li) {
		width: calc(50% - 10px);
		margin: 0 5px 15px;
	}

	.schCtePopLstImg {
		margin: 0 0 15px;
		border-radius: 6px;
	}

	.schCtePkzLst {
		font-size: 1.3rem;
	}

	.schCtePkzLst li {
		margin: 0 20px 10px 0!important;
	}

	.schCtePkzLst li:not(:last-child):after {
		right: -15px;
	}

	.schCtePkzLst li:last-child {
		padding: 2px 7px;
	}
	
	.mtp {
		margin: 30px 0 0;
	}

	.schCteAra {
		padding: 30px 15px;
		background-size: 350px auto;
	}

	.schCteLst li:not(.cteMinLst li,.schCteCntLst li,.cteMinLst li) {
		display: block;
		border-radius: 8px;
	}

	.schCteLst li:not(:last-child) {
		margin: 0 0 20px;
	}

	.schCteLstImgBox {
		max-width: 100%;
	}

	.schCteLstCntBox {
		width: 100%;
		padding: 15px;
	}

	.schCteCntLst li {
		display: block;
	}

	.schCteCntLst li:not(:last-child,.cteMinLst li) {
		margin: 0 0 15px;
		border-bottom: solid 1px #eee;
	}

	.schCteCntLstBtn {
		max-width: 100%;
		font-size: 1.8rem;
		margin: 0 0 15px;
		padding: 0 0 0 25px;
	}

	.schCteCntLstBtn:after {
		width: 16px;
		height: 16px;
		background-size: 8px auto;
	}

	.schCteCntLstBox {
		width: 100%;
	}

	.schCteCntLstBox .cteMinLst li,
	.schCteCntLstInr .cteMinLst li {
		margin: 0 15px 0 0;
	}
}

/*=========================================================

検索結果一覧

=========================================================*/

.schLstPgrCtr {
	display: flex;
	align-items: center;
	justify-content: flex-end;
}

.schLstPgrTypBox select {
	width: 200px;
	height: 45px;
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-weight: 700;
	font-size: 1.6rem;
	line-height: 1.2;
	color: #333!important;
	padding: 10px;
	box-sizing: border-box;
	background: #fff!important;
	border: solid 1px #eee;
	border-radius: 3px;
}

.schLstPgrBox {
	display: flex;
	align-items: center;
	justify-content: flex-end;
}

.schLstPgrBox table {
	font-weight: 700;
	font-size: 1.6rem;
	line-height: 1.2;
}

.schLstPgrBox table span {
	font-weight: 900;
	font-size: 4rem;
	color: #1668b3;
	margin: 0 10px 0 0;
}

.wp-pagenavi a,.current {
	text-align: center;
	width: 40px;
	height: 40px;
	display: inline-block;
	font-weight: 700;
	font-size: 2.2rem;
	line-height: 35px;
	color: #1668b3;
	margin: 0 3px;
	box-sizing: border-box;
	background: #fff;
	border: solid 1px #1668b3;
	border-radius: 50%;
}

.current {
	color: #fff;
	background: #1668b3;
}

.previouspostslink,
.nextpostslink {
	font-size: 1.6rem!important;
	background: #f8f8f8!important;
	border: solid 1px #f8f8f8!important;
}

.wp-pagenavi a:hover {
	color: #fff!important;
	background: #1668b3!important;
	border: solid 1px #1668b3!important;
	transition: all 0.3s ease;
}

/* schLstAra */
.schLstAra {
	padding: 50px 30px;
}

.schLst:not(.schAtcLst) {
	margin: 20px 0;
}

.schLst li:not(.schAtcLst li) {
	display: flex;
	padding: 20px;
	background: #fff;
	border: solid 1px #eee;
	border-radius: 10px;
}

.schLst li:not(:last-child) {
	margin: 0 0 30px;
}

.schLstCteCntLstBox {
	margin: -20px 0 60px;
	padding: 20px;
	background: #f8f8f8;
	border-radius: 6px;
}

.schLstImgBox {
	text-align: center;
	max-width: 320px;
	width: 100%;
	margin: 0 30px 0 0;
}

.schLstImg {
	position: relative;
	overflow: hidden;
	margin: 0 0 20px;
	border-radius: 10px;
}

.schLstImg:before {
	content: "";
	display: block;
	padding-top: 62.5%;
}

.schLstImg img {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.schChkBtn {
	font-weight: 500;
	font-size: 1.4rem;
	line-height: 1.2;
	margin: 0 0 20px;
}

.schChkBtn input {
	margin: 2px 5px 0 0;
}

.schChkBtn label {
	cursor: pointer;
}

.schReqBtn {
	text-align: center;
	max-width: 240px;
	font-weight: 700;
	font-size: 1.6rem;
	line-height: 1.2;
	margin: 0 auto;
}

.schReqBtn a {
	display: block;
	padding: 15px;
	background: #ff4200;
	border-radius: 4px;
}

.schReqBtn span {
	padding: 5px 0 5px 30px;
	background: url(../images/common/icn_document_wt.png) left no-repeat;
	background-size: 20px auto;
}

.schLstCntBox {
	width: calc(100% - 350px);
}

.schLstTtl {
	font-weight: 700;
	font-size: 3rem;
	line-height: 1.4;
	margin: 0 0 20px;
}

.schLstTxt {
	font-weight: 500;
	font-size: 1.6rem;
	line-height: 1.6;
	margin: 0 0 30px;
}

.schLstNmeBox {
	display: inline-block;
	margin: 0 0 50px;
	border: solid 1px #1668b3;
}

.schLstNmeInr {
	display: flex;
}

.schLstNme {
	font-weight: 500;
	font-size: 1.4rem;
	line-height: 1.2;
	padding: 3px 10px;
}

.schLstPrc {
	font-weight: 500;
	font-size: 1.4rem;
	line-height: 1.2;
	color: #fff;
	padding: 3px 10px;
	background: #1668b3;
}

.schAtcLst li:not(:last-child) {
	margin: 0 0 15px;
	padding: 0 0 15px;
	border-bottom: solid 1px #eee;
}

.schAtcLstBox {
	display: flex;
	align-items: start;
	width: 100%;
}

.schLstAtcTyp {
	min-width: 160px;
	text-align: center;
	display: inline-block;
	font-weight: 700;
	font-size: 1.4rem;
	line-height: 1.2;
	color: #fff;
	box-sizing: border-box;
	margin: 0 20px 0 0;
	padding: 7px 30px 7px 20px;
	border-radius: 50px;
}

.atcTyp01 {
	background: url(../images/common/icn_arrow_rt_wt.png) right 10px center no-repeat #02b6fb;
	background-size: 10px auto;
}

.atcTyp02 {
	background: url(../images/common/icn_arrow_rt_wt.png) right 10px center no-repeat #15c7bd;
	background-size: 10px auto;
}

.schLstAtcTxt {
	font-weight: 700;
	font-size: 1.4rem;
	line-height: 1.4;
	margin: 5px 0 0;
	color: #333;
	flex-grow: 1;
}

.schLstAtcTxt ul {
	width: 100%;
	display: block;
}

@media screen and (min-width:768px) and (max-width:1040px) {
	.schLstPgrBox {
		display: block;
	}
	
	.schLstPgrBox table {
		float: right;
		margin: 0 0 10px;
	}
	
	.wp-pagenavi {
		clear: both;
	}
	
	.schLstNmeInr {
		display: block;
	}

	.schAtcLstBox {
		display: block;
	}
	
	.schLstAtcTyp {
		margin: 0 0 5px;
	}
}

@media screen and (max-width:767px) {
	
	.schLstCteCntLstBox {
		margin: -15px 0 30px;
		padding: 15px 15px 5px;
	}
	
	.schLstPgrCtr {
		display: block;
	}
	
	.schLstPgrTypBox {
		position: relative;
		z-index: 2;
	}

	.schLstPgrTypBox:after {
		content: "▼";
		position: absolute;
		top: 15px;
		right: 10px;
		color: #333!important;
		z-index: 3;
	}
	
	.schLstPgrTypBox select {
		width: 100%;
		height: 45px;
	}

	.schLstPgrBox {
		display: block;
		margin: 0 0 15px;
	}

	.schLstPgrBox table {
		font-size: 1.4rem;
		margin: 0 auto 10px;
	}

	.schLstPgrBox table span {
		font-size: 2.6rem;
		margin: 0 5px 0 0;
	}
	
	.wp-pagenavi {
		text-align: center;
	}

	.wp-pagenavi a,.current {
		width: 30px;
		height: 30px;
		font-size: 1.6rem;
		line-height: 27px;
	}

	.previouspostslink,
	.nextpostslink {
		font-size: 1.3rem!important;
	}

	.schLstAra {
		padding: 30px 15px;
	}

	.schLst li:not(.schAtcLst li) {
		display: block;
		padding: 15px;
		border-radius: 8px;
	}

	.schLst li:not(:last-child) {
		margin: 0 0 20px;
	}

	.schLstImgBox {
		max-width: 100%;
		margin: 0 0 20px;
	}

	.schLstImg {
		margin: 0 0 20px;
		border-radius: 8px;
	}

	.schChkBtn {
		font-size: 1.3rem;
		margin: 0 0 15px;
	}

	.schReqBtn {
		max-width: 200px;
		font-size: 1.4rem;
	}

	.schReqBtn a {
		display: block;
		border-radius: 50px;
	}

	.schReqBtn span {
		padding: 5px 0 5px 25px;
		background-size: 15px auto;
	}

	.schLstCntBox {
		width: 100%;
	}

	.schLstTtl {
		font-size: 2rem;
		margin: 0 0 15px;
	}

	.schLstTxt {
		font-size: 1.5rem;
		margin: 0 0 20px;
	}

	.schLstNmeBox {
		display: block;
		margin: 0 0 30px;
	}

	.schLstNmeInr {
		display: block;
	}

	.schLstNme {
		font-size: 1.3rem;;
		padding: 3px 7px;
	}

	.schLstPrc {
		font-size: 1.3rem;
		padding: 3px 7px;
	}

	.schAtcLst li:not(:last-child) {
		margin: 0 0 10px;
		padding: 0 0 10px;
	}

	.schAtcLstBox {
		display: block;
	}

	.schLstAtcTyp {
		min-width: 100%;
		font-size: 1.3rem;
		margin: 0;
		padding: 8px 20px;
	}
}

/*=========================================================

カテゴリー詳細

=========================================================*/

.schDtlAra {
	padding: 50px 30px;
}

.schDtlCntBox {
	display: flex;
	margin: 0 0 50px;
}

.schDtlImgBox {
	max-width: 600px;
	width: 100%;
	margin: 0 40px 0 0;
}

.schDtlImgInr {
	position: relative;
	margin: 0 0 20px;
	overflow: hidden;
	border-radius: 10px;
}

.schDtlImg {
	position: relative;
	overflow: hidden;
	border-radius: 10px;
}

.schDtlImg:before {
	content: "";
	display: block;
	padding-top: 62.5%;
}

.schDtlImg img {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: contain;
}

.schDtlZomBtn {
	position: absolute;
	bottom: 0;
	right: 0;
}

.schDtlZomBtn {
	font-weight: 700;
	font-size: 1.2rem;
	line-height: 1.2;
	color: #fff!important;
	padding: 15px 20px 15px 40px;
	background: url(../images/common/icn_zoom_wt.png) left 15px center no-repeat rgba(0,0,0,0.5);
	background-size: 20px auto;
	border-radius: 6px;
}

.schDtlImgBox .schReqBtn {
	margin: 0;
}

.schDtlDtaBox {
	width: calc(100% - 640px);
}

.schDtlDtaTbl {
	width: 100%;
	border-top: solid 1px #eee;
}

.schDtlDtaTbl th {
	width: 200px;
	font-weight: 700;
	font-size: 1.8rem;
	line-height: 1.2;
	padding: 15px 15px 15px 0;
	border-bottom: solid 1px #eee;
	vertical-align: top;
}

.schDtlDtaTbl td {
	font-weight: 500;
	font-size: 1.6rem;
	line-height: 1.2;
	padding: 15px;
	border-bottom: solid 1px #eee;
}

.schDtlTxt {
	font-weight: 400;
	font-size: 1.5rem;
	line-height: 1.7;
	margin: 0 0 50px;
}

.schDtlInfBox {
	display: flex;
}

.schDtlCmpCtr {
	max-width: 400px;
	width: 100%;
	margin: 0 40px 0 0;
}

.schDtlCmpBox {
	border: solid 1px #1668b3;
}

.schDtlCmpTtl {
	text-align: center;
	font-weight: 500;
	font-size: 1.4rem;
	line-height: 1.2;
	color: #fff;
	padding: 7px 10px;
	background: #1668b3;
}

.schDtlCmpTtl a {
	color: #fff!important;
}

.schDtlCmpTtl a:hover {
	opacity: 0.6;
}

.schDtlCmpDtaBox {
	font-weight: 700;
	font-size: 1.4rem;
	line-height: 1.5;
	padding: 15px;
}

.schDtlCmpDtaBox table {
	width: 100%;
}

.schDtlCmpDtaBox th {
	font-weight: bold;
}

.schDtlCmpDtaBox td {
	word-break: break-all;
	padding-left: 1em;
	text-indent: -1em;
}

.schDtlAtcBox {
	width: calc(100% - 440px);
}

.schDtlDtaCat {
	overflow: hidden;	
}

.schDtlDtaCat:not(:first-child){
	margin-top: 10px;
}

.schDtlDtaCat li {
	position: relative;
	float: left;
	margin-left: 5px;
	line-height: 1.5;
	padding-right: 15px;
}

.schDtlDtaCat li:after {
	display: block;
	content: "＞";
	font-size: 10px;
	line-height: 10px;
	position: absolute;
	top: calc(50% - 5px);
	right: 0;
}


.schDtlDtaCat li:last-child {
	padding-right: 0;
}

.schDtlDtaCat li:last-child:after {
	display: none;
}

.schDtlAtcCtn {
	margin-top: 50px;
	font-size: 1.2rem;
	text-align: right;
}

@media screen and (max-width:1040px) {
	.schDtlCntBox {
		display: block;
		margin: 0 0 50px;
	}

	.schDtlImgBox {
		max-width: 600px;
		margin: 0 auto 50px;
	}
	
	.schDtlImgBox .schReqBtn {
		margin: 0 auto;
	}

	.schDtlDtaBox {
		width: 100%;
	}
}

@media screen and (max-width:767px) {
	.schDtlAra {
		padding: 30px 15px;
	}

	.schDtlCntBox {
		display: block;
		margin: 0 0 15px;
	}

	.schDtlImgBox {
		max-width: 100%;
		margin: 0 0 20px;
	}

	.schDtlImgInr {
		margin: 0 0 20px;
		border-radius: 8px;
	}

	.schDtlImg {
		border-radius: 8px;
	}

	.schDtlZomBtn {
		padding: 12px 15px 12px 35px;
		background: url(../images/common/icn_zoom_wt.png) left 10px center no-repeat rgba(0,0,0,0.5);
		background-size: 20px auto;
	}

	.schDtlDtaBox {
		width: 100%;
	}
	
	.schDtlDtaTbl {
		border: none;
	}

	.schDtlDtaTbl tr {
		display: block;
	}

	.schDtlDtaTbl th {
		width: 100%;
		display: block;
		font-size: 1.5rem;
		padding: 0 0 5px;
	}

	.schDtlDtaTbl td {
		display: block;
		font-size: 1.4rem;
		padding: 5px 0 15px;
		border: none;
	}

	.schDtlTxt {
		margin: 0 0 30px;
	}

	.schDtlInfBox {
		display: block;
	}

	.schDtlCmpCtr {
		max-width: 100%;
		margin: 0 0 30px;
	}

	.schDtlCmpTtl {
		font-size: 1.3rem;
		padding: 3px 7px;
	}

	.schDtlCmpDtaBox {
		font-size: 1.3rem;
		padding: 10px;
	}

	.schDtlAtcBox {
		width: 100%;
	}
}

/*=========================================================

フロートナビ

=========================================================*/

.fltFtrAra {
	margin: 0 0 80px;
}

.fltNavBox {
	width: 100%;
	height: 80px;
	position: fixed;
	bottom: 0;
	left: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	background: #f8f8f8;
	z-index: 190;
}

.fltNav {
	text-align: center;
	display: flex;
	font-weight: 700;
	font-size: 1.6rem;
	line-height: 1.2;
}

.fltNav li {
	width: 280px;
	margin: 0 10px;
}

.fltNav li a {
	width: 100%;
	display: block;
	padding: 15px;
	box-sizing: border-box;
	border-radius: 4px;
	box-shadow: 0 3px 4px rgba(0,0,0,0.15);
}

.fltNavDocBtn a {
	background: #ff4200;
}

.fltNavSftBtn a {
	background: #1668b3;
}

.fltNav li a:hover {
	color: #333!important;
	background: #ffbc00;
	transition: all 0.3s ease;
}

.fltNavDocBtn span {
	padding: 5px 0 5px 30px;
	background: url(../images/common/icn_document_wt.png) left no-repeat;
	background-size: 20px auto;
}

.fltNavDocBtn a:hover span {
	transition: all 0.3s ease;
	background: url(../images/common/icn_document_bk.png) left no-repeat;
	background-size: 20px auto;
}

.fltNavSftBtn span {
	padding: 5px 0 5px 30px;
	background: url(../images/common/icn_soft_wt.png) left no-repeat;
	background-size: 20px auto;
}

.fltNavSftBtn a:hover span {
	transition: all 0.3s ease;
	background: url(../images/common/icn_soft_bk.png) left no-repeat;
	background-size: 20px auto;
}

@media screen and (max-width:767px) {
	.fltFtrAra {
		margin: 0 0 60px;
	}

	.fltNavBox {
		height: 60px;
	}

	.fltNav {
		letter-spacing: -0.05em;
		font-size: 1.2rem;
	}

	.fltNav li {
		width: 115px;
		margin: 0 4px;
	}

	.fltNav li a {
		padding: 10px 7px;
		border-radius: 50px;
	}

	.fltNavDocBtn span {
		padding: 5px 0 5px 17px;
		background-size: 15px auto;
	}

	.fltNavDocBtn a:hover span {
		background-size: 15px auto;
	}

	.fltNavSftBtn span {
		padding: 5px 0 5px 20px;
		background-size: 15px auto;
	}

	.fltNavSftBtn a:hover span {
		background-size: 15px auto;
	}
}

/*=========================================================

TB

=========================================================*/

@media screen and (min-width:768px) and (max-width:1040px) {

	.pc   { display: none!important;}
	.pcsp { display: none!important;}
	.sp   { display: none!important;}
	
	.pctb { display: inline-block!important;}
	.tb   { display: inline-block!important;}
	.tbsp { display: inline-block!important;}

}

/*=========================================================

SP

=========================================================*/

@media screen and (max-width:767px) {

	.pc   { display: none!important;}
	.tb   { display: none!important;}
	.pctb { display: none!important;}

	.pcsp { display: inline-block!important;}
	.tbsp { display: inline-block!important;}
	.sp   { display: inline-block!important;}

	.opacity a:active {
		opacity: 0.50;
		filter: alpha(opacity=50);
		-ms-filter: "alpha(opacity=50)";
		-moz-opacity: 0.50;
		-khtml-opacity: 0.50;
		-webkit-transition: all 0.3s ease;
		-moz-transition: all 0.3s ease;
		-o-transition: all 0.3s ease;
		transition: all 0.3s ease;
		text-decoration: none!important;
	}

	a[href^="tel:"] {
		pointer-events: auto!important;
	}

	input[type="button"],input[type="text"],input[type="submit"],input[type="image"],input[type="date"],textarea, select {
		-webkit-appearance: none;
		border-radius: 0;
	}

}

/*=========================================================

Search Pages (New Design)

=========================================================*/

/* Container */
.srcCtr {
	max-width: 1200px;
	margin: 0 auto;
	padding: 30px 20px 60px;
}

/* Breadcrumb */
.srcBrdCrm {
	font-size: 0.875rem;
	color: #666;
	margin-bottom: 20px;
	padding: 10px 0;
	border-bottom: 1px solid #eee;
}
.srcBrdCrm a {
	color: #1668b3;
}
.srcBrdCrm a:hover {
	text-decoration: underline;
}

/* Page Title */
.srcPageTtl {
	font-size: 1.75rem;
	font-weight: bold;
	color: #333;
	margin-bottom: 30px;
	padding-left: 15px;
	border-left: 4px solid #1668b3;
}

/* Search Form Box */
.srcFrmBox {
	background: #f8f9fa;
	border-radius: 8px;
	padding: 25px;
	margin-bottom: 30px;
}
.srcFrm {
	max-width: 800px;
	margin: 0 auto;
}
.srcFrmInr {
	display: flex;
	gap: 10px;
	margin-bottom: 15px;
}
.srcFrmInr input[type="text"] {
	flex: 1;
	padding: 12px 15px;
	font-size: 1rem;
	border: 1px solid #ddd;
	border-radius: 6px;
	outline: none;
}
.srcFrmInr input[type="text"]:focus {
	border-color: #1668b3;
	box-shadow: 0 0 0 3px rgba(22, 104, 179, 0.1);
}
.srcFrmBtn {
	padding: 12px 30px;
	font-size: 1rem;
	font-weight: bold;
	color: #fff;
	background: #1668b3;
	border: none;
	border-radius: 6px;
	cursor: pointer;
	transition: background 0.3s ease;
}
.srcFrmBtn:hover {
	background: #125a9a;
}
.srcFrmOpt {
	display: flex;
	gap: 20px;
	justify-content: center;
	flex-wrap: wrap;
}
.srcFrmOpt label {
	display: flex;
	align-items: center;
	gap: 5px;
	font-size: 0.9375rem;
	color: #555;
	cursor: pointer;
}
.srcFrmOpt input[type="radio"] {
	width: 18px;
	height: 18px;
	accent-color: #1668b3;
}

/* Category List (Top Page Style) */
.srcCatBox {
	margin-bottom: 30px;
}
.srcCatTtl {
	font-size: 1.25rem;
	font-weight: bold;
	color: #333;
	margin-bottom: 15px;
	padding-bottom: 10px;
	border-bottom: 2px solid #1668b3;
}
.srcCatList {
	list-style: none;
	padding: 0;
	margin: 0;
}
.srcCatListGrid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
	gap: 10px;
}
.srcCatList li a {
	display: block;
	padding: 15px 20px;
	background: #fff;
	border: 1px solid #ddd;
	border-radius: 6px;
	color: #333;
	font-size: 1rem;
	transition: all 0.3s ease;
}
.srcCatList li a:hover {
	background: #1668b3;
	color: #fff;
	border-color: #1668b3;
}
.srcCatEven a { background: #fafafa; }
.srcCatOdd a { background: #fff; }
.srcCatEmpty {
	color: #666;
	padding: 20px;
	text-align: center;
}
.srcCatLink {
	text-align: center;
	margin-top: 20px;
}
.srcCatLink a {
	color: #1668b3;
	font-weight: bold;
}
.srcCatNav {
	margin-top: 30px;
	padding-top: 20px;
	border-top: 1px solid #eee;
}
.srcCatNav a {
	color: #1668b3;
}

/* Search Form (Additional) */
.srcFrmBoxMain {
	margin-bottom: 40px;
}
.srcFrmHelp {
	text-align: center;
	margin-top: 15px;
	font-size: 0.875rem;
}
.srcFrmHelp a {
	color: #1668b3;
}
.srcFrmHelp a:hover {
	text-decoration: underline;
}

/* Main Category (Index Page) */
.srcMainCat {
	margin-bottom: 30px;
}
.srcMainCatList {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 15px;
}
.srcMainCatList li a {
	display: block;
	padding: 20px 40px;
	background: #1668b3;
	color: #fff;
	font-size: 1.125rem;
	font-weight: bold;
	border-radius: 6px;
	text-align: center;
	transition: background 0.3s ease;
}
.srcMainCatList li a:hover {
	background: #125a9a;
	color: #fff;
}

/* Search Results Header */
.srcResHdr {
	display: flex;
	justify-content: space-between;
	align-items: center;
	flex-wrap: wrap;
	gap: 15px;
	margin-bottom: 20px;
	padding: 15px 20px;
	background: #f8f9fa;
	border-radius: 6px;
}
.srcResHdr .srcResTtl {
	font-size: 1.25rem;
	font-weight: bold;
	color: #333;
	margin: 0;
}
.srcResInfo {
	display: flex;
	gap: 20px;
	align-items: center;
	flex-wrap: wrap;
}
.srcResCnt {
	font-size: 1rem;
	color: #333;
}
.srcResCnt strong {
	color: #1668b3;
	font-size: 1.25rem;
}
.srcResSort {
	font-size: 0.875rem;
	color: #666;
}
.srcResSort a {
	color: #1668b3;
}
.srcResSort a:hover {
	text-decoration: underline;
}
.srcResAct {
	display: flex;
	gap: 10px;
}
.srcResActBtn {
	padding: 8px 16px;
	font-size: 0.875rem;
	color: #fff;
	background: #ffbc00;
	border: none;
	border-radius: 4px;
	cursor: pointer;
	transition: background 0.3s ease;
}
.srcResActBtn:hover {
	background: #e5a800;
}

/* Search Results List */
.srcResList {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(350px, 1fr));
	gap: 20px;
	margin-bottom: 30px;
}
.srcResItem {
	display: flex;
	gap: 15px;
	padding: 20px;
	background: #fff;
	border: 1px solid #ddd;
	border-radius: 8px;
	transition: box-shadow 0.3s ease;
}
.srcResItem:hover {
	box-shadow: 0 4px 12px rgba(0,0,0,0.1);
}
.srcResChk {
	flex-shrink: 0;
}
.srcResChk input[type="checkbox"] {
	width: 20px;
	height: 20px;
	accent-color: #1668b3;
}
.srcResImg {
	flex-shrink: 0;
	width: 120px;
}
.srcResImg img {
	width: 100%;
	height: auto;
	border-radius: 4px;
	border: 1px solid #eee;
}
.srcResBody {
	flex: 1;
	min-width: 0;
}
.srcResTtl {
	font-size: 1.125rem;
	font-weight: bold;
	margin: 0 0 8px;
}
.srcResTtl a {
	color: #333;
}
.srcResTtl a:hover {
	color: #1668b3;
}
.srcResCom {
	font-size: 0.875rem;
	color: #666;
	margin: 0 0 8px;
}
.srcResPrice {
	font-size: 0.9375rem;
	color: #c00;
	font-weight: bold;
	margin: 0 0 8px;
}
.srcResDesc {
	font-size: 0.875rem;
	color: #555;
	margin: 0;
	line-height: 1.5;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}
.srcResName {
	font-size: 1.125rem;
	font-weight: bold;
	margin: 0 0 10px;
	line-height: 1.4;
}
.srcResName a {
	color: #333;
}
.srcResName a:hover {
	color: #1668b3;
}
.srcResSub {
	display: block;
	font-size: 0.8125rem;
	font-weight: normal;
	color: #666;
}
.srcResMeta {
	margin-bottom: 10px;
	font-size: 0.875rem;
}
.srcResMeta .srcResCom {
	color: #555;
	margin-right: 15px;
}
.srcResMeta .srcResCom a {
	color: #1668b3;
}
.srcResMeta .srcResPrice {
	color: #c00;
	font-weight: bold;
}
.srcResAct .srcResBtn {
	display: inline-block;
	padding: 5px 12px;
	font-size: 0.75rem;
	font-weight: bold;
	color: #fff;
	border-radius: 4px;
	text-decoration: none;
	margin-right: 5px;
	transition: opacity 0.3s ease;
}
.srcResAct .srcResBtn:hover {
	opacity: 0.8;
}
.srcResBtnCat {
	background: #28a745;
}
.srcResBtnDemo {
	background: #17a2b8;
}
.srcResLinks {
	display: inline-flex;
	gap: 5px;
	flex-wrap: wrap;
	vertical-align: middle;
}
.srcResLink {
	display: inline-block;
	padding: 4px 10px;
	font-size: 0.75rem;
	border-radius: 3px;
	background: #eee;
	color: #555;
	text-decoration: none;
}
.srcResLink:hover {
	opacity: 0.8;
}
.srcResLinkPickup { background: #fff3cd; color: #856404; }
.srcResLinkExample { background: #d4edda; color: #155724; }
.srcResEmpty {
	grid-column: 1 / -1;
	text-align: center;
	padding: 60px 20px;
	color: #666;
}
.srcResEmpty ul {
	list-style: none;
	padding: 0;
	margin: 15px 0 0;
	text-align: left;
	display: inline-block;
}
.srcResEmpty ul li {
	padding: 5px 0 5px 20px;
	position: relative;
	font-size: 0.9375rem;
}
.srcResEmpty ul li::before {
	content: '・';
	position: absolute;
	left: 0;
}
.srcResNav {
	display: flex;
	justify-content: space-between;
	padding-top: 20px;
	border-top: 1px solid #eee;
}
.srcResNav a {
	color: #1668b3;
	font-size: 0.9375rem;
}
.srcResNav a:hover {
	text-decoration: underline;
}

/* Pagination */
.srcPager {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 10px;
	margin: 30px 0;
}
.srcPagerPrev,
.srcPagerNext {
	padding: 10px 20px;
	font-size: 0.9375rem;
	color: #1668b3;
	background: #fff;
	border: 1px solid #1668b3;
	border-radius: 4px;
	text-decoration: none;
	transition: all 0.3s ease;
}
.srcPagerPrev:hover,
.srcPagerNext:hover {
	background: #1668b3;
	color: #fff;
}
.srcPagerNums {
	display: flex;
	gap: 5px;
}
.srcPagerNum {
	display: inline-block;
	width: 36px;
	height: 36px;
	line-height: 36px;
	text-align: center;
	font-size: 0.9375rem;
	color: #333;
	background: #fff;
	border: 1px solid #ddd;
	border-radius: 4px;
	text-decoration: none;
	transition: all 0.3s ease;
}
.srcPagerNum:hover {
	border-color: #1668b3;
	color: #1668b3;
}
.srcPagerNum.active,
.srcPagerCur {
	background: #1668b3;
	border-color: #1668b3;
	color: #fff;
	font-weight: bold;
}
.srcPagerNum a {
	color: #333;
	text-decoration: none;
}
.srcPagerNum a:hover {
	color: #1668b3;
}
.srcPagerInfo {
	font-size: 0.875rem;
	color: #666;
}

/* Product Detail */
.srcDetail {
	background: #fff;
	border-radius: 8px;
	border: 1px solid #ddd;
	padding: 30px;
	margin-bottom: 30px;
}
.srcDetHdr {
	display: flex;
	gap: 30px;
	margin-bottom: 30px;
	padding-bottom: 30px;
	border-bottom: 1px solid #eee;
}
.srcDetImg {
	flex-shrink: 0;
	width: 280px;
}
.srcDetImg img {
	width: 100%;
	height: auto;
	border-radius: 6px;
	border: 1px solid #eee;
}
.srcDetInfo {
	flex: 1;
}
.srcDetTtl {
	font-size: 1.5rem;
	font-weight: bold;
	color: #333;
	margin: 0 0 15px;
	line-height: 1.4;
}
.srcDetSub {
	display: block;
	font-size: 0.875rem;
	font-weight: normal;
	color: #666;
	margin-bottom: 5px;
}
.srcDetCom {
	margin-bottom: 15px;
}
.srcDetComName {
	font-size: 1.125rem;
	font-weight: bold;
	color: #333;
	margin: 0 0 5px;
}
.srcDetComUrl,
.srcDetComTel,
.srcDetComFax {
	font-size: 0.875rem;
	color: #666;
	margin: 0 0 3px;
}
.srcDetComUrl a {
	color: #1668b3;
}
.srcDetPrice {
	font-size: 1.25rem;
	font-weight: bold;
	color: #c00;
	margin: 0;
}

/* Detail Sections */
.srcDetSecTtl {
	font-size: 1.125rem;
	font-weight: bold;
	color: #333;
	margin: 0 0 15px;
	padding: 10px 15px;
	background: #f8f9fa;
	border-left: 4px solid #1668b3;
}
.srcDetDesc {
	margin-bottom: 30px;
}
.srcDetDescBody {
	font-size: 1rem;
	line-height: 1.8;
	color: #333;
}

/* Spec Table */
.srcDetSpec {
	margin-bottom: 30px;
}
.srcDetSpecTbl {
	width: 100%;
	border-collapse: collapse;
}
.srcDetSpecTbl th,
.srcDetSpecTbl td {
	padding: 12px 15px;
	border: 1px solid #ddd;
	font-size: 0.9375rem;
}
.srcDetSpecTbl th {
	width: 150px;
	background: #f8f9fa;
	font-weight: bold;
	color: #333;
	text-align: left;
}
.srcDetSpecTbl td {
	background: #fff;
	color: #555;
}

/* Categories in Detail */
.srcDetCat {
	margin-bottom: 30px;
}
.srcDetCatList {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
}
.srcDetCatList li a {
	display: inline-block;
	padding: 8px 15px;
	font-size: 0.875rem;
	background: #eee;
	color: #333;
	border-radius: 4px;
	transition: all 0.3s ease;
}
.srcDetCatList li a:hover {
	background: #1668b3;
	color: #fff;
}

/* Action Buttons */
.srcDetAct {
	display: flex;
	gap: 15px;
	flex-wrap: wrap;
	margin-bottom: 30px;
}
.srcDetBtn {
	display: inline-block;
	padding: 15px 30px;
	font-size: 1rem;
	font-weight: bold;
	color: #fff;
	border-radius: 6px;
	text-align: center;
	text-decoration: none;
	transition: all 0.3s ease;
}
.srcDetBtnCat {
	background: #28a745;
}
.srcDetBtnCat:hover {
	background: #218838;
	color: #fff;
}
.srcDetBtnDemo {
	background: #17a2b8;
}
.srcDetBtnDemo:hover {
	background: #138496;
	color: #fff;
}
.srcDetBtnContact {
	background: #ffbc00;
	color: #333;
}
.srcDetBtnContact:hover {
	background: #e5a800;
	color: #333;
}

/* Related Links */
.srcDetLinks {
	margin-bottom: 30px;
}
.srcDetLinkList {
	list-style: none;
	padding: 0;
	margin: 0;
}
.srcDetLinkList li {
	margin-bottom: 10px;
}
.srcDetLink {
	display: inline-block;
	padding: 10px 20px;
	font-size: 0.9375rem;
	background: #f8f9fa;
	border: 1px solid #ddd;
	border-radius: 4px;
	color: #333;
	transition: all 0.3s ease;
}
.srcDetLink:hover {
	background: #1668b3;
	border-color: #1668b3;
	color: #fff;
}
.srcDetLinkPickup::before,
.srcDetLinkExample::before {
	margin-right: 8px;
}
.srcDetLinkPickup::before { content: '📄'; }
.srcDetLinkExample::before { content: '📋'; }

/* Navigation */
.srcDetNav,
.srcCmpNav,
.srcHelpNav {
	display: flex;
	justify-content: space-between;
	padding-top: 20px;
	border-top: 1px solid #eee;
}
.srcDetNav a,
.srcCmpNav a,
.srcHelpNav a {
	color: #1668b3;
	font-size: 0.9375rem;
}
.srcDetNav a:hover,
.srcCmpNav a:hover,
.srcHelpNav a:hover {
	text-decoration: underline;
}

/* Compare Table */
.srcCmpTbl {
	margin-bottom: 30px;
}
.srcCmpTable {
	width: 100%;
	border-collapse: collapse;
	background: #fff;
}
.srcCmpTable th,
.srcCmpTable td {
	padding: 15px;
	border: 1px solid #ddd;
	font-size: 0.9375rem;
	text-align: center;
	vertical-align: middle;
}
.srcCmpHdr {
	width: 120px;
	background: #1668b3;
	color: #fff;
	font-weight: bold;
}
.srcCmpProd {
	background: #f8f9fa;
	font-weight: bold;
}
.srcCmpProd a {
	color: #1668b3;
}
.srcCmpTable tbody th {
	background: #f8f9fa;
	font-weight: bold;
	text-align: left;
}
.srcCmpTable tbody td {
	background: #fff;
}
.srcCmpTable tbody td img {
	max-width: 100%;
	height: auto;
	border-radius: 4px;
}
.srcCmpDesc {
	font-size: 0.8125rem;
	text-align: left;
	line-height: 1.5;
}
.srcCmpEmpty {
	text-align: center;
	padding: 60px 20px;
	color: #666;
}
.srcCmpAct {
	text-align: center;
	margin-bottom: 30px;
}
.srcCmpBtn {
	display: inline-block;
	padding: 15px 40px;
	font-size: 1rem;
	font-weight: bold;
	color: #333;
	background: #ffbc00;
	border-radius: 6px;
	text-decoration: none;
	transition: background 0.3s ease;
}
.srcCmpBtn:hover {
	background: #e5a800;
	color: #333;
}

/* Help Page */
.srcHelp {
	background: #fff;
	border-radius: 8px;
	border: 1px solid #ddd;
	padding: 30px;
	margin-bottom: 30px;
}
.srcHelpSec {
	margin-bottom: 30px;
	padding-bottom: 30px;
	border-bottom: 1px solid #eee;
}
.srcHelpSec:last-child {
	margin-bottom: 0;
	padding-bottom: 0;
	border-bottom: none;
}
.srcHelpSec h2 {
	font-size: 1.25rem;
	font-weight: bold;
	color: #333;
	margin: 0 0 15px;
	padding-left: 15px;
	border-left: 4px solid #1668b3;
}
.srcHelpSec p {
	font-size: 1rem;
	line-height: 1.8;
	color: #555;
	margin: 0 0 15px;
}
.srcHelpSec ul {
	list-style: none;
	padding: 0;
	margin: 0;
}
.srcHelpSec ul li {
	padding: 10px 0 10px 20px;
	position: relative;
	font-size: 0.9375rem;
	color: #555;
	line-height: 1.6;
}
.srcHelpSec ul li::before {
	content: '•';
	position: absolute;
	left: 0;
	color: #1668b3;
	font-weight: bold;
}

/*=========================================================

Search Pages Responsive

=========================================================*/

@media screen and (max-width:1023px) {
	.srcResHdr {
		flex-direction: column;
		align-items: stretch;
	}
	.srcResSort {
		justify-content: center;
	}
	.srcResAct {
		justify-content: center;
	}
	.srcResList {
		grid-template-columns: 1fr;
	}
	.srcDetHdr {
		flex-direction: column;
	}
	.srcDetImg {
		width: 100%;
		max-width: 400px;
		margin: 0 auto;
	}
}

@media screen and (max-width:767px) {
	.srcCtr {
		padding: 20px 15px 40px;
	}
	.srcPageTtl {
		font-size: 1.375rem;
	}
	.srcFrmBox {
		padding: 15px;
	}
	.srcFrmInr {
		flex-direction: column;
	}
	.srcFrmBtn {
		width: 100%;
	}
	.srcCatListGrid {
		grid-template-columns: 1fr;
	}
	.srcMainCatList {
		flex-direction: column;
	}
	.srcMainCatList li a {
		padding: 15px 20px;
	}
	.srcResHdr {
		flex-direction: column;
		align-items: flex-start;
	}
	.srcResInfo {
		flex-direction: column;
		align-items: flex-start;
		gap: 10px;
	}
	.srcResItem {
		flex-direction: column;
		padding: 15px;
	}
	.srcResImg {
		width: 100%;
		max-width: 200px;
		margin: 0 auto;
	}
	.srcResMeta {
		display: flex;
		flex-direction: column;
		gap: 5px;
	}
	.srcResMeta .srcResCom {
		margin-right: 0;
	}
	.srcResAct {
		flex-wrap: wrap;
	}
	.srcPager {
		flex-wrap: wrap;
	}
	.srcPagerNums {
		order: 3;
		width: 100%;
		justify-content: center;
		margin-top: 10px;
	}
	.srcDetail {
		padding: 20px 15px;
	}
	.srcDetTtl {
		font-size: 1.25rem;
	}
	.srcDetSpecTbl th {
		width: 100px;
	}
	.srcDetAct {
		flex-direction: column;
	}
	.srcDetBtn {
		width: 100%;
	}
	.srcCmpTable {
		font-size: 0.8125rem;
	}
	.srcCmpTable th,
	.srcCmpTable td {
		padding: 10px 8px;
	}
	.srcHelp {
		padding: 20px 15px;
	}
	.schHlpSec {
		margin-bottom: 20px;
	}
	.schHlpSecTtl {
		font-size: 1.6rem;
	}
	.schHlpNavBox {
		flex-direction: column;
		gap: 10px;
	}
	.schHlpNavBox .cntBtn {
		width: 100%;
	}
}

/*======================================================
  Search Help Page
======================================================*/

.schHlpAra {
	padding: 60px 0;
}

.schHlpBox {
	background: #fff;
	border-radius: 10px;
	padding: 40px;
	box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
}

.schHlpSec {
	margin-bottom: 40px;
}

.schHlpSec:last-child {
	margin-bottom: 0;
}

.schHlpSecTtl {
	font-size: 1.8rem;
	font-weight: 700;
	color: #1668b3;
	margin-bottom: 15px;
	padding-bottom: 10px;
	border-bottom: 2px solid #1668b3;
}

.schHlpTxt {
	font-size: 1.4rem;
	line-height: 1.8;
	margin-bottom: 15px;
}

.schHlpLst {
	list-style: none;
	padding: 0;
	margin: 0;
}

.schHlpLst li {
	font-size: 1.4rem;
	line-height: 1.8;
	padding: 8px 0 8px 20px;
	position: relative;
}

.schHlpLst li:before {
	content: "";
	position: absolute;
	left: 0;
	top: 16px;
	width: 8px;
	height: 8px;
	background: #1668b3;
	border-radius: 50%;
}

.schHlpLst li strong {
	color: #1668b3;
}

.schHlpNavBox {
	display: flex;
	justify-content: center;
	gap: 20px;
	margin-top: 40px;
}

.schNoCondition {
	text-align: center;
	padding: 60px 20px;
}

.schNoCondition p {
	font-size: 1.6rem;
	color: #333;
}

.lwrCntAra {
	padding: 60px 0;
	width: 100%;
}

.lwrError p 	{
	font-size: 1.4rem;
	line-height: 1.8;
	margin-bottom: 15px;
	text-align: center;
}

.lwrError .cntBtn {
	margin-top: 60px;
}
