@charset "UTF-8";
/* ==========================================================================
   common
========================================================================== */
@media print, screen and (min-width: 769px) {
.container{
	padding: 0 10px;
	max-width: 1200px;
	min-width: 1000px;
	position: relative;
	margin: 0 auto;
}
.textcontainer{
	position: relative;
	margin: 0 50px;
	width: calc(100% - 100px);
	max-width: 1080px;
	min-width: inherit;
}
.sp-dsp-block{display: none;}	
.contents-box{padding: 100px 0;}
.btn-col-2{
	display: flex;
	gap:16px;
	width: 564px;
	margin: 0 auto;
}
.btn-col-3{
	display: flex;
	gap:50px;
	width: 100%;
	margin: 80px auto 0;
}	
.btn-col-3>*{width: calc((100% - 100px) / 3);}	
.btn-col-3>* a{
	min-width: inherit;
	width: 100%!important;
}	
.link-btn{text-align: center;}
.link-btn + .ttl-h3,
.btn-col-2 + .ttl-h3{margin-top: 120px;}	
.col-2{
	display: flex;
	column-gap: 50px;
}
.col-2 img{
	max-width: 100%;
	width: 100%;
}
.col-2>*{width: calc((100% - 50px) / 2);}	
.link-btn + .col-2{margin-top: 100px;}	
}
@media only screen and (max-width: 768px) {
	.container{
		width: 92%;
		margin: 0 auto;
	}
	.textcontainer{
		width: 100%;
	}
	.sp-dsp-block{display: block;}	
	.contents-box{padding: 50px 0;}
	.btn-col-2,
	.link-btn{
		display: block;
		width: 80%;
		margin: 0 auto;
	}
	.btn-col-3{
		display: block;
		margin: 30px auto 0;
	}	
	.btn-col-3>*{width: 100%;}	
	.btn-col-3>* a{
		min-width: inherit;
		width: 100%!important;
	}	
	.btn-col-2>* + *,
	.btn-col-3>* + *{margin-top: 18px;}
	.link-btn + .ttl-h3,
	.btn-col-2 + .ttl-h3{margin-top: 70px;}	
	.col-2 img{
		max-width: 100%;
		width: 100%;
	}
	.col-2>* + *{margin-top: 36px;}	
	.link-btn + .col-2{margin-top: 50px;}
}

/* ==========================================================================
   parts
========================================================================== */
/* headding
-------------------------------------------------------------------------- */
.headdingContainer{
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	height: 460px;
	background-color: #ffce00;
}
.headdingBox{
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	text-align: center;
	height: 445px;
	background-image: url("../img/headding-pc.svg");
	background-position: center top, left top;
	background-repeat: no-repeat;
}
.headdingBox .headdingText{
	margin: 0 50px 50px 0;
}
.headdingBox .headdingText h1{
	max-width: 437px;
	margin: 0 0 36px;
}
.headdingBox .headdingText h1 img{
	max-width: 100%;
	width: 100%;
}
.headdingBox .headdingText p{
	font-size: 17px;
	font-weight: 600;
	line-height: 200%;
}

@media only screen and (max-width: 768px) {
 	.headdingContainer{height: 370px;}
	.headdingBox{
		height: 354px;
		width: 100%;
		margin-left: -10px;
		margin-right: -10px;
		overflow: hidden;
		background-image: url("../img/headding-sp.svg");
	}
	.headdingBox .headdingText{
		margin: 0 0 50px 0;
	}
	.headdingBox .headdingText h1{
		max-width: 192px;
		margin: 0 auto 18px;
	}
	.headdingBox .headdingText h1 img{

	}
	.headdingBox .headdingText p{
		font-size: 14px;
		line-height: 160%;
	}
}

/* link-ac
-------------------------------------------------------------------------- */
.link-ac{
	background-color: #fff;
	border: 2px solid #333333;
	border-radius: 6px;
	box-shadow: 0 6px 0 #ffce00;
	padding: 26px;
	display: flex;
	flex-wrap: wrap;
	gap: 20px 34px;
	align-items: center;
	justify-content: center;
	margin-top: -24px;
	position: relative;
	z-index: 1;
}
.link-ac li a{
	display: block;
	position: relative;
	font-size: 18px;
	font-weight: 700;
	color: #333333;
	padding: 0 24px 0 48px;
	transition: all .3s;
}
.link-ac li a:hover{text-decoration: underline;}
.link-ac li a::before{
	content: '';
	background: url("../img/ttl-icon01.svg") no-repeat;
	width: 42px;
	height: 32px;
	background-size: 42px auto;
	position: absolute;
	top: calc((100% - 32px) / 2);
	left: 0;
}
.link-ac li:nth-child(2) a::before{background: url("../img/ttl-icon02.svg") no-repeat;}
.link-ac li:last-child a::before{background: url("../img/ttl-icon03.svg") no-repeat;}
.link-ac li a::after{
	content: '';
	background: url("../img/link-ac-icon.svg") no-repeat;
	width: 16px;
	height: 8px;
	background-size: 16px auto;
	position: absolute;
	top: calc((100% - 8px) / 2);
	right: 0;
}
@media only screen and (max-width: 768px) {
	.link-ac li a{font-size: 16px;}
}

/* text
-------------------------------------------------------------------------- */
/* ttl-h2 */
.ttl-h2{
	text-align: center;
	font-size: 28px;
	position: relative;
	padding: 53px;
	font-weight: 700;
}
.ttl-h2::after{
	content: '';
	background: url("../img/ttl-icon01.svg") no-repeat;
	width: 53px;
	height: 40px;
	background-size: 53px auto;
	position: absolute;
	top: 0;
	left: calc((100% - 53px) / 2);
}
#ac02 .ttl-h2::after{background: url("../img/ttl-icon02.svg") no-repeat;}
#ac03 .ttl-h2::after{background: url("../img/ttl-icon03.svg") no-repeat;}

/* ttl-h3 */
.ttl-h3{
	font-size: 20px;
	font-weight: 700;
	line-height: 1.2;
	display: flex;
	align-items: center;
	margin-bottom: 40px;
	margin-top: 80px;
}
.ttl-h3 span{
	display: block;
	padding: 13px 20px;
	border-radius: 50px;
	background-color: #ffce00;
}

.ttl-h3:before,
.ttl-h3:after {
    content: "";
    height: 2px;
    flex-grow: 1;
    background-color: #333333;
}
.ttl-h3:before {margin-right: 1rem;}
.ttl-h3:after {margin-left: 1rem;}

/* lead */
.lead{
	font-size: 24px;
	font-weight: 700;
	line-height: 150%;
	text-align: center;
	margin-bottom: 50px;
}

/* text */
.text{
	font-size: 16px;
	line-height: 200%;
}

@media only screen and (max-width: 768px) {
	.ttl-h2{font-size: 24px;}
	.ttl-h3{
		font-size: 16px;
		margin-bottom: 26px;
		margin-top: 60px;
	}
	.ttl-h3 span{
		display: block;
		padding: 10px 20px;
	}
	.lead{
		font-size: 18px;
		line-height: 160%;
		text-align: left;
		margin-bottom: 26px;
	}
	.text{line-height: 180%;}
}


/* ac01
-------------------------------------------------------------------------- */
#ac01 .fr-banner{margin-top: 160px;}
#ac01 .ttl-h2 + .fr-banner{margin-top: 0;}
#ac01 .fr-banner a{
	display: block;
	width: 640px;
	margin: 0 auto;
	background-color: #D2D2AE;
	border-radius: 10px;
	padding: 10px;
	font-size: 24px;
	font-weight: 700;
	color: #333333;
	transition: all .3s;
}
#ac01 .fr-banner a:hover{
	color: #fff;
	opacity: .8;
	text-decoration: underline;
}
#ac01 .fr-banner a .col{
	display: flex;
	align-items: center;
	justify-content: space-between;
	border-radius: 10px;
	border: 2px solid #fff;
	padding: 30px 30px;
}
#ac01 .fr-banner a .col .link-text{
	padding-left: 42px;
	position: relative;
}
#ac01 .fr-banner a .col .link-text::before{
	content: '';
	background: url("../img/icon-arw.svg") no-repeat;
	background-size: cover;
	width: 32px;
	height: 32px;
	position: absolute;
	top: calc((100% - 32px) / 2);
	left: 0;
}
#ac01 .fr-banner a .col .link-img img{
	max-width: 265px;
	width: 100%;
}
#ac01 .link-btn{
	position: absolute;
	right: 0;
}

/* slider */
.sliderBox{max-width: calc(1200px + 210px)!important;}
.slider figure img{
	max-width: 100%;
	width: 100%;
	border-radius: 8px;
}
.slider a{transition: all .3s;}
.slider a:hover{opacity: .8;}
.slick-slide{padding: 0 25px;}
.slick-list::before{
	content: '';
	background: linear-gradient(90deg, rgba(255,255,255,1) 0%, rgba(255,255,255,0.3) 100%);
	width: 55px;
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	z-index: 1;
}
.slick-list::after{
	content: '';
	background: linear-gradient(-90deg, rgba(255,255,255,1) 0%, rgba(255,255,255,0.3) 100%);
	width: 55px;
	position: absolute;
	top: 0;
	bottom: 0;
	right: 0;
	z-index: 1;
}
.slick-slide .date{
	font-size: 14px;
	font-weight: 700;
	line-height: 1.2;
	color: #999;
	margin-top: 10px;
	margin-bottom: 12px;
}
.slick-slide .m-relationList-ttl{
	font-size: 16px;
	font-weight: 700;
	line-height: 160%;
	color: #333;
}

@media only screen and (max-width: 768px) {
	#ac01 .fr-banner{margin-top: 60px;}
	#ac01 .ttl-h2 + .fr-banner{margin-top: 0;}
	#ac01 .fr-banner a{
		width: 100%;
		padding: 8px;
		font-size: 20px;
	}
	#ac01 .fr-banner a .col{
		display: flex;
		flex-direction: column-reverse;
		align-items: flex-start;
		padding: 13px;
	}
	#ac01 .fr-banner a .col .link-text{
		margin: 34px 0;
	}
	#ac01 .fr-banner a .col .link-img img{max-width: 100%;}
	.sliderBox{
		max-width: inherit!important;
		width: 100%!important;
	}
	.slider figure img{
		max-width: 100%;
		width: 100%;
	}
	.slick-slide{padding: 0 10px;}
	.slick-list::before,
	.slick-list::after{
		width: 20px;
	}
	.slick-slide .m-relationList-ttl{font-size: 15px;}
	#ac01 .link-btn{
		position: static;
		margin-top: 100px;
	}
}

/* ac02
-------------------------------------------------------------------------- */
#ac02{background-color: #f5f5ed;}
#ac02 .glance-banner{margin-bottom: 100px;}
#ac02 .glance-banner a{
	display: block;
	width: 960px;
	height: 300px;
	margin: 0 auto;
	background: url("../img/glance-banner-img.svg") no-repeat;
	background-size: contain;
	background-position: right 100px top;
	background-color: #ffce00;
	border-radius: 10px;
	padding: 10px;
	color: #333333;
	transition: all .3s;
}
#ac02 .glance-banner a:hover{opacity: .8;}
#ac02 .glance-banner a .link-text{
	display: flex;
	flex-direction: column;
	justify-content: center;
	height: 280px;
	border-radius: 10px;
	border: 2px solid #fff;
	padding: 38px 34px;
}
#ac02 .glance-banner a .link-text p{
	width: 380px;
	font-size: 16px;
	line-height: 200%;
}
#ac02 .glance-banner a .link-text .ttl{
	font-size: 24px;
	font-weight: 700;	
	padding-left: 42px;
	line-height: 1.2;
	position: relative;
	margin-bottom: 26px;
}
#ac02 .glance-banner a:hover .link-text .ttl{
	color: #fff;
	text-decoration: underline;
}
#ac02 .glance-banner a .link-text .ttl::before{
	content: '';
	background: url("../img/icon-arw-circle.svg") no-repeat;
	background-size: 32px 32px;
	width: 32px;
	height: 32px;
	position: absolute;
	top: calc((100% - 32px) / 2);
	left: 0;
}

/* beyond-area */
#ac02 .beyond-area{
	width: 880px;
	margin: 60px auto 0;
	text-align: center;
}
#ac02 .beyond-area img{
	max-width: 100%;
	width: 100%;
}
#ac02 .beyond-area .ttl{margin-bottom: 10px;}
#ac02 .beyond-area .ttl span{display: block;}
#ac02 .beyond-area .ttl span:first-child{
	font-size: 16px;
	font-weight: 700;
	line-height: 140%;
}
#ac02 .beyond-area .ttl span:nth-child(2){
	font-size: 56px;
	font-weight: 400;
	line-height: 1.2;
	color: #a48c00;
}
#ac02 .beyond-area .ttl span:last-child,
#ac02 .beyond-area .ttl02{
	font-size: 19px;
	font-weight: 700;
	margin-top: 10px;
}
#ac02 .beyond-area .img-box01{
	width: 812px;
	margin: 0 auto 46px;
}
#ac02 .beyond-area .img-box02{
	width: 880px;
	margin: 26px auto 62px;
}
#ac02 .img-box03{
	margin: 26px auto 62px;
}
#ac02 .img-box04{
	width: 800px;
	margin: 26px auto 62px;
}
@media only screen and (max-width: 768px) {
	#ac02 .glance-banner{margin-bottom: 50px;}
	#ac02 .glance-banner a{
		width: 100%;
		height: inherit;
		padding: 8px;
		background-size: auto 200px;
		background-position: center top;
	}
	#ac02 .glance-banner a .link-text{
		display: block;
		height: inherit;
		padding: 20px;
	}
	#ac02 .glance-banner a .link-text p{
		width: 100%;
		font-size: 15px;
	}
	#ac02 .glance-banner a .link-text .ttl{
		font-size: 20px;
		margin-top: 180px;
		margin-bottom: 20px;
	}
	#ac02 .beyond-area{
		width: 100%;
		margin: 30px 0 0;
	}
	#ac02 .beyond-area .ttl{margin-bottom: 10px;}
	#ac02 .beyond-area .ttl span{display: block;}
	#ac02 .beyond-area .ttl span:first-child{font-size: 7px;}
	#ac02 .beyond-area .ttl span:nth-child(2){font-size: 24px;}
	#ac02 .beyond-area .ttl span:last-child{font-size: 9px;}
	#ac02 .beyond-area .ttl02{font-size: 12px;}
	#ac02 .beyond-area .img-box01{
		width: 100%;
		margin: 0 auto 38px;
	}
	#ac02 .beyond-area .img-box02,
	#ac02 .img-box03,
	#ac02 .img-box04{
		width: 100%;
		margin: 16px auto 36px;
	}
}

#ac02 .performance-area .ttl02{
	text-align: center;
	font-size: 19px;
	font-weight: 700;
	margin-top: 40px;
}
@media only screen and (max-width: 768px) {#ac02 .performance-area .ttl02{font-size: 12px;}}
/* ac03
-------------------------------------------------------------------------- */
#ac03 .ttl{
	position: relative;
	margin-bottom: 40px;
}
#ac03 .ttl .num{
	display: block;
	width: auto;
	height: 70px;
}
#ac03 .ttl .num img{
	max-width: 100%;
	width: 100%;
	width: auto;
	height: 70px;
}
#ac03 .ttl .text{
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	left: 20px;
	z-index: 1;
	font-size: 24px;
	font-weight: 700;
}
#ac03 .boder-box{
	font-size: 14px;
	line-height: 180%;
	border-top: 2px solid #bdccd4;
	border-bottom: 2px solid #bdccd4;
	margin-top: 30px;
	padding: 12px 0;
}
#ac03 .link-btn{
	margin-top: 20px;
	text-align: left;
}

@media only screen and (max-width: 768px) {
	#ac03 .ttl{
		text-align: center;
		margin-bottom: 20px;
	}
	#ac03 .ttl .text{
		left: 50%;
		transform: translateY(-50%) translateX(-50%);
		font-size: 18px;
		width: 100%;
	}
 #ac03 .link-btn{
		margin-top: 30px;
		text-align: left;
	}
}

/* ac04
-------------------------------------------------------------------------- */
#ac04{background-color: #f5f5ed;}
#ac04 .ttl{
	font-size: 24px;
	font-weight: 700;
	line-height: 1.2;
	text-align: center;
}

@media only screen and (max-width: 768px) {
 	#ac04 .ttl{font-size: 18px;}
}


/* reatef-box
-------------------------------------------------------------------------- */
.reatef-box{
	background-color: #f5f5ed;
	padding: 40px;
	border-radius: 10px;
}
.reatef-box .ttl{
	font-size: 24px;
	line-height: 1.2;
	font-weight: 700;
	padding-left: 60px;
	position: relative;
	margin-bottom: 50px;
}
.reatef-box .ttl::before{
	content: '';
	background: url("../img/related-icon.svg") no-repeat;
	background-size: contain;
	position: absolute;
	left: 0;
	top: calc(50% - 24px);
	width: 48px;
	height: 48px;
}
.reatef-box .col{
	display: flex;
	column-gap: 50px;
}
.reatef-box .col>*{
	width: calc((100% - 50px) / 2);
	position: relative;
	font-size: 16px;
	line-height: 200%;
}
.reatef-box .col>*:first-child::after{
	content: '';
	border-left: 1px dashed #333333;
	position: absolute;
	top: 0;
	bottom: 0;
	right: -25px;
}
.reatef-box p:first-child{
	margin-bottom: 20px;
}
.m-relationList-ttl a{
	color: #333;
	transition: all .3s;
}
.m-relationList-ttl a:hover{opacity: .8;}
.related-list .m-relationList-ttl{margin-bottom: 5px;}

@media only screen and (max-width: 768px) {
	.reatef-box{padding: 30px 20px;}
	.reatef-box .ttl{margin-bottom: 30px;}
	.reatef-box .col{display: block;}
	.reatef-box .col>*{	width: 100%;}
	.reatef-box .col>* + *{margin-top: 40px;}
	.reatef-box .col>*:first-child::after{content: none;}
}