@charset "utf-8";

.s_inner { width: 750px; margin: 0 auto;}

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

/*--------------------------fv--------------------------*/
#fv { position: relative; background: url(../images/lineup/fv_bg.png) repeat-x left top / 1100px;}
#fv .title { display: flex; min-width: 1100px; margin-bottom: 10px;}
#fv .title .left { width: 37%; padding: 118px 0 60px; padding-left: max( ( 100% - 1100px ) / 2, 40px);}
#fv .title .left h2 { margin-bottom: 30px;}
#fv .title .fv { width: 63%; background: url(../images/produce/fv.png) no-repeat left bottom / cover; border-radius: 0 0 0 140px;}
#fv:before,
#fv:after { position: absolute; content: "";}
#fv:before { top: 0; left: 0; width: 386px; height: 100%; background: url(../images/lineup/fv_before.png) no-repeat left top / 100%;}
#fv:after { top: 400px; right: 0; width: 219px; height: 440px; background: url(../images/produce/fv_after.png) no-repeat right top / 100%;}

#fv .about { display: flex; justify-content: flex-end; align-items: flex-start; margin-bottom: 40px;}
#fv .about p { font-size: 16px; font-family: 'NotoSansJP-Light'; writing-mode: vertical-rl; line-height: 180%; padding: 65px 0 0 15px; padding-right: calc( ( 100% - 900px ) / 2);}

#fv .movie { width: 900px; margin: 0 auto 60px;}
#fv .movie .movie_wrapper { position: relative; width: 100%; padding-bottom: 56.25%; overflow: hidden;}
#fv .movie .movie_wrapper iframe { position: absolute; top: 0; left: 0; width: 100%; height: 100%;}

#introduction { padding: 48px 0 60px; background: url(../images/produce/introduction_bg_u.png) repeat-x left top / 1100px, url(../images/produce/introduction_bg_d.png) repeat-x left bottom / 1100px; text-align: center;}
#introduction h3 { margin-bottom: 30px;}
#introduction .slider { overflow: hidden; padding-bottom: 10px;}
#introduction .slider .slick-list { overflow: visible;}
#introduction .slider button { width: 16px; height: 24px; background: #00BB4C; z-index: 2;}
#introduction .slider button:before { display: none;}
#introduction .slider .slick-prev { left: calc( 50% - 400px ); clip-path: polygon(100% 0, 10% 50%, 100% 100%);}
#introduction .slider .slick-next { right: calc( 50% - 400px ); clip-path: polygon(0 0, 90% 50%, 0 100%);}

#introduction .slider .slide_item { width: 700px; border-radius: 10px; box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.16); background: #fff; margin-right: 80px;}
#introduction .slider .slide_item .areaname { width: 100%; padding: 19px 0 15px; background: #008337; border-radius: 10px 10px 0 0;}
#introduction .slider .slide_item .areaname h4 { font-size: 22px; color: #fff;}
#introduction .slider .slide_item .flex { display: flex; justify-content: center; align-items: flex-start; padding: 20px 66px 40px;}
#introduction .slider .slide_item .flex img { margin-right: 22px;}
#introduction .slider .slide_item .flex .text { text-align: left;}
#introduction .slider .slide_item .flex .text h5 { font-size: 16px; font-family: 'NotoSansJP-Bold'; line-height: 140%; letter-spacing: -0.025em; margin-bottom: 10px;}
#introduction .slider .slide_item .flex .text p { font-size: 14px; line-height: 140%; letter-spacing: -0.025em;}


/*--------------------------brand--------------------------*/

#brand { position: relative; background: #DBE873 url(../images/produce/brand_bg.png) no-repeat center / 707px; padding: 100px 0 190px;}
#brand:before,
#brand:after { position: absolute; content: ""; display: block;}
#brand:before { top: 63px; left: 0; width: 216px; height: 100%; background: url(../images/produce/brand_bg_l.png) no-repeat left top / 100%;}
#brand:after { top: 117px; right: 0; width: 163px; height: 100%; background: url(../images/produce/brand_bg_r.png) no-repeat right top / 100%;}
#brand .brand { width: 748px; margin: 0 auto;}
#brand .brand h3 { text-align: center; margin-bottom: 95px;}
#brand .brand .flex { display: flex; flex-flow: row-reverse; justify-content: space-between;}
#brand .brand .flex .right { display: flex; flex-flow: row-reverse;}
#brand .brand .flex h4 { font-size: 24px; font-family: 'NotoSansJP-Bold'; writing-mode: vertical-rl; line-height: 180%; color: #008337; margin-left: 1em; text-indent: 0.5em; margin-top: -0.5em;}
#brand .brand .flex h4 span { display: block; font-size: 14px;}
#brand .brand .flex p { font-size: 16px; font-family: 'NotoSansJP-Bold'; writing-mode: vertical-rl; line-height: 180%;}


.purchase_box { padding: 70px 0; }



@media only screen and (max-width: 768px){
	
	.s_inner { width: 90%;}
	
	/*--------------------------fv--------------------------*/
	#fv { }
	#fv .title { display: flex; flex-flow: column-reverse; min-width: auto;}
	#fv .title .left { width: 90%; padding: 10px 0; margin: 0 auto; }
	#fv .title .left h2 { margin-bottom: 20px;}
	#fv .title .left h2 img { width: 240px; height: auto;}
	#fv .title .fv { width: 100%; padding: 20vw; background: url(../images/produce/fv.png) no-repeat right bottom / 90%; border-radius: 0;}
	#fv:before { top: 0; left: 0; width: 130px; height: 240px;}
	#fv:after { top: 130px; right: 0; width: 90px; height: 180px; background: url(../images/produce/fv_after.png) no-repeat right top / 100%;}
	
	#fv .about { display: flex; flex-flow: column-reverse; justify-content: flex-end; align-items: flex-start; margin-bottom: 40px;}
	#fv .about p { font-size: 14px; line-height: 160%; padding: 15px 0 30px; margin: 0 auto;}
	#fv .about img { width: 100%; height: auto;}
	#fv .movie { width: 90%; margin-bottom: 30px;}

	#introduction { padding: 48px 0 30px;}
	#introduction h3 { margin-bottom: 30px;}
	#introduction h3 img { width: 280px;}
	#introduction .slider { }
	#introduction .slider button { width: 16px; height: 24px;}
	#introduction .slider .slick-prev { left: 2%;}
	#introduction .slider .slick-next { right: 2%;}

	#introduction .slider .slide_item { width: 80vw; border-radius: 10px; box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.16); background: #fff; margin-right: 2%;}
	#introduction .slider .slide_item .areaname { padding: 19px 0 15px;}
	#introduction .slider .slide_item .areaname h4 { font-size: 22px; color: #fff;}
	#introduction .slider .slide_item .flex { display: block; padding: 20px 25px 40px;}
	#introduction .slider .slide_item .flex img { width: 100%; height: auto; margin: 0 auto 10px;}
	#introduction .slider .slide_item .flex .text { text-align: left;}
	#introduction .slider .slide_item .flex .text h5 { font-size: 14px; line-height: 140%; margin-bottom: 10px;}
	#introduction .slider .slide_item .flex .text p { font-size: 12px; line-height: 140%;}


	/*--------------------------brand--------------------------*/
	
	#brand { background: #DBE873 url(../images/produce/brand_bg.png) no-repeat center 130px / 300px; padding: 50px 0;}
	#brand:before,
	#brand:after { position: absolute; content: ""; display: block;}
	#brand:before { top: 153px; width: 82px; height: 280px;}
	#brand:after { top: 187px; width: 54px; height: 230px;}
	#brand .brand { width: 90%;}
	#brand .brand h3 { text-align: center; margin-bottom: 25px;}
	#brand .brand h3 img { width: 200px;}
	#brand .brand .flex { display: block;}
	#brand .brand .flex .right { display: block; flex-flow: row-reverse;}
	#brand .brand .flex h4 { width: 100%; font-size: 20px; line-height: 180%; color: #008337; margin: 0 auto 30px; padding-right: 10%;}
	#brand .brand .flex h4 span { display: block; font-size: 14px;}
	#brand .brand .flex p { font-size: 14px; font-family: 'NotoSansJP-Bold'; writing-mode: horizontal-tb; line-height: 180%;}
	
	
	.purchase_box { padding: 40px 0; width: 90%; margin: 0 auto;}


	
}