﻿@charset "utf-8";
html{
	-webkit-text-size-adjust: 100%;
}
body {
	font-family: "Noto Sans JP", sans-serif;
	font-size:min(1.8vw,18px);
	text-align:center;
	color:#000;
	line-height:2.1;
	font-feature-settings: "palt";
}

@media screen and (max-width:750px){
	body {
		font-size:4.2vw;
		line-height:1.7;
	}
}

.mincho{
  font-family: "Noto Serif JP", serif;
}

.en{
	font-family: "Montserrat", sans-serif;
}

a {
	color:#000;
	transition : opacity 0.4s;
	-webkit-transition : opacity 0.4s;
	opacity:1;
	outline:none;
}
a:hover {
	opacity: 0.7;
}

@media screen and (max-width:750px){
	a:hover {
		opacity: 1;
	}
}

img{
	max-width:100%;
	vertical-align:bottom;
}

.only_sp,
.only_sp_i,
.only_sp_f{
	display:none !important;
}

@media screen and (max-width:750px){
	.only_pc{
		display:none !important;
	}
	.only_sp{
		display:block !important;
	}
	.only_sp_i{
		display:inline-block !important;
	}
	.only_sp_f{
		display: -webkit-flex !important;
		display: flex !important;
	}
}

#wrapper{
}

.inner{
	max-width:1100px;
	width:94%;
	margin:auto;
}

@media screen and (max-width:750px){
	.inner{
		width:90%;
	}
}


/* 色関係 */
.bg_black{
  color:#fff;
  background-color:#111;
}
.yellow{
	color:#ffe537;
}
.bg_yellow{
	background-color:#ffe537;
}
.white{
	color:#fff;
}
.bg_green{
	color:#fff;
	background-color:#00cd4d;
}
.bg_red{
	color:#fff;
	background-color:#d20000;
}



/* 書式 */
.text_left{
	text-align:left !important;
}
.text_right{
	text-align:right !important;
}
.text_center{
	text-align:center !important;
}

.bold{
	font-weight:bold;
}
.heavy{
	font-weight:900;
}

.blc{
	display:block;
}
.parallel{
  clip-path:polygon(0.5em 0, 100% 0, calc(100% - 0.5em) 100%, 0 100%);
}
.shadow{
	box-shadow:0 0 10px rgba(0,0,0,0.1);
}


/* header */
header{
	width:100%;
	height:77px;
	padding-left:20px;
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: space-between;
	justify-content: space-between;
	-webkit-align-items: center;
	align-items: center;
	position:absolute;
	z-index:100;
}
header .head_logo{
	line-height:0;
	width:284px;
}
header .head_nav ul{
	display: -webkit-flex;
	display: flex;
	-webkit-align-items: center;
	align-items: center;
}
header .head_nav ul li:nth-child(n+2){
  margin-left:2em;
}
header .head_nav ul li a{
	font-size:15px;
	font-weight:bold;
	letter-spacing:0.04em;
}
header .head_nav ul li:last-child a{
	line-height:77px;
	display:block;
	padding:0 2.5em;
	font-size:18px;
	font-weight:900;
}
header .head_nav ul li:last-child a:after{
	content:'';
	display:inline-block;
	vertical-align:0.15em;
	width:0.4em;
	height:0.4em;
	margin-left:1em;
	border-top:1px solid;
	border-right:1px solid;
	transform:rotate(45deg);
}

@media screen and (max-width:1200px){
	header{
		height:50px;
		padding-left:15px;
	}
	header .head_logo{
		width:170px;
	}
	header .head_nav ul li:nth-child(n+2){
		margin-left:1em;
	}
	header .head_nav ul li a{
		font-size:12px;
	}
	header .head_nav ul li:last-child a{
		line-height:50px;
		padding:0 1.2em;
		font-size:13px;
	}
	header .head_nav ul li:last-child a:after{
		margin-left:0.5em;
	}
}


/* .cta */
.cta{
}
.cta h2{
	padding:0.1em 0 0.4em;
	line-height:1;
	font-weight:600;
	font-style:italic;
	background:url(../img/cta_h2.png) left center;
}
.cta h2 > span{
	display:inline-block;
}
.cta h2 > .large .large{
	line-height:0.7;
	font-size:5.9vw;
	vertical-align:-0.03em;
}
.cta h2 > .large .small{
	font-size:4.4vw;
}
.cta h2 > .large .middle{
	font-size:4.9vw;
}
.cta h2 > .small span{
	display:block;
	font-size:2.1vw;
	text-align:left;
	margin-left:1em;
}
.cta h2 > .small .large{
	font-size:2.3vw;
}

.cta_btn{
	display:inline-block;
	width:min(68%,680px);
	margin-top:min(5%,50px);
	font-size:min(3.6vw,36px);
	border-radius:0.3em;
	box-shadow:0 7px 0 #008432;
	overflow:hidden;
}
.cta_btn:hover{
	opacity:1;
	box-shadow:0 4px 0 #008432;
	transform:translateY(3px);
}
.cta_btn dl{
	display:flex;
}
.cta_btn dl dt{
	width:5em;
	line-height:1;
	font-size:min(1.9vw,19px);
	font-weight:900;
	font-style:italic;
	letter-spacing:0.08em;
	padding-left:0.08em;
	display:flex;
	justify-content:center;
	align-items:center;
	flex-direction: column;
}
.cta_btn dl dt .large{
	font-size:min(2.8vw,28px);
}
.cta_btn dl dt .middle{
	font-size:min(2.4vw,24px);
}
.cta_btn dl dd{
	line-height:2.8;
	flex:1;
	font-weight:900;
	letter-spacing:0.04em;
}
.cta_btn dl dd:after{
	content:'';
	display:inline-block;
	vertical-align:0.1em;
	width:0.3em;
	height:0.4em;
	margin-left:1em;
	background-color:#fff;
	clip-path:polygon(0 0,100% 50%,0 100%);
}

@media screen and (max-width:750px){
	.cta{
		position:relative;
	}
	.cta h2{
		padding:0 0 1em;
		line-height:1.3;
		background-size:1em auto;
	}
	.cta h2 > .large .large{
		line-height:0;
		font-size:16.8vw;
		letter-spacing:-0.05em;
	}
	.cta h2 > .large .small{
		line-height:0;
		font-size:12vw;
		letter-spacing:-0.15em;
	}
	.cta h2 > .large .middle{
		font-size:14vw;
		display:block;
		letter-spacing:-0.05em;
	}
	.cta h2 > .small{
		display:block;
	}
	.cta h2 > .small span{
		display:inline;
		font-size:7.3vw;
		text-align:center;
		margin-left:0;
	}
	.cta h2 > .small .large{
		font-size:7.3vw;
	}

	.cta_btn{
		width:92%;
		margin-top:7%;
		font-size:6.1vw;
		border-radius:0.3em;
		box-shadow:0 1vw 0 #008432;
	}
	.cta_btn:hover{
		box-shadow:0 1vw 0 #008432;
		transform:none;
	}
	.cta_btn dl dt{
		width:5em;
		font-size:3.3vw;
	}
	.cta_btn dl dt .large{
		font-size:5vw;
	}
	.cta_btn dl dt .middle{
		font-size:4.3vw;
	}
	.cta_btn dl dd:after{
		margin-left:0.5em;
	}
}


/* #mv */
#mv{
	padding:min(6vw,120px) 0 0;
	position:relative;
	background:url(../img/mv_bg.png) left center;
	overflow:hidden;
}
#mv:before{
	content:'';
	display:block;
	width:100%;
	height:min(8vw,150px);
	background-color:#ffe537;
	position:absolute;
	top:0;
	left:0;
	transform:rotate(-12deg);
	transform-origin:left bottom;
}
#mv:after{
	content:'';
	display:block;
	width:100%;
	height:min(8vw,150px);
	background-color:#ffe537;
	position:absolute;
	bottom:0;
	right:0;
	transform:rotate(-12deg);
	transform-origin:right top;
	z-index:-1;
}

#mv .cont_wrapper{
	width:75%;
	margin:auto;
	display:flex;
	justify-content:space-between;
}
#mv .cont_wrapper .sec{
	width:62%;
	text-align:left;
}
#mv .cont_wrapper .sec h1 .sub_title{
	display:block;
}
#mv .cont_wrapper .sec h1 .sub_title .small{
	line-height:1.5;
	padding:0 1em;
	display:inline-block;
	font-size:1.45vw;
}
#mv .cont_wrapper .sec h1 .sub_title .large{
	margin-top:0.3em;
	line-height:1.3;
	display:block;
	font-size:1.92vw;
}
#mv .cont_wrapper .sec h1 .sub_title .large .en{
	font-size:2.5vw;
}
#mv .cont_wrapper .sec h1 .main_title{
	display:block;
	margin-top:0.3em;
	line-height:1.6;
	font-size:3.12vw;
	font-weight:900;
}
#mv .cont_wrapper .sec h1 .main_title > img{
	display:block;
	width:10.5em;
	margin-bottom:0.1em;
}
#mv .cont_wrapper .sec h1 .main_title .large{
	line-height:1.1;
	display:block;
	font-size:4.3vw;
	position:relative;
	white-space:nowrap;
}
#mv .cont_wrapper .sec h1 .main_title .large:before{
	content:'「';
	font-weight:200;
}
#mv .cont_wrapper .sec h1 .main_title .large:after{
	content:'」';
	font-weight:200;
}
#mv .cont_wrapper .sec h1 .main_title .large span{
	font-size:3.3vw;
}
#mv .cont_wrapper .sec h1 .main_title .large img{
	width:2.3em;
	position:absolute;
	bottom:100%;
	right:0;
	z-index:1;
}
#mv .cont_wrapper .sec section{
	margin-top:1.5%;
}
#mv .cont_wrapper .sec section h2{
	display:inline-block;
	font-size:1.69vw;
	font-style:italic;
	background:linear-gradient(transparent 60%, #dfdac7 60%, #dfdac7 80%, transparent 80%);
}
#mv .cont_wrapper .sec section p{
	margin-top:0.5em;
	line-height:1.8;
	font-size:1.15vw;
	font-weight:bold;
}
#mv .cont_wrapper .sec section p .large{
	line-height:1;
	font-size:1.38vw;
	font-weight:900;
}
#mv .cont_wrapper .fig{
	width:42%;
	margin-left:-4%;
	position:relative;
}
#mv .cont_wrapper .fig figcaption{
	line-height:1.7;
	padding:0.7em 0.3em;
	font-weight:bold;
	writing-mode: vertical-rl;
	text-align:left;
	clip-path:polygon(0 0.5em, 100% 0, 100% calc(100% - 0.5em), 0 100%);
	position:absolute;
	right:18%;
	bottom:1.5%;
}
#mv .cont_wrapper .fig figcaption .small{
	display:block;
	font-size:0.89vw;
	letter-spacing:0.02em;
}
#mv .cont_wrapper .fig figcaption .large{
	display:block;
	font-size:1.15vw;
	letter-spacing:0.02em;
}

@media screen and (max-width:750px){
	#mv{
		padding:7% 0 0;
		background-size:1em auto;
	}
	#mv:before{
		height:11vw;
	}
	#mv:after{
		height:11vw;
	}

	#mv .cont_wrapper{
		width:auto;
		display:block;
	}
	#mv .cont_wrapper .sec{
		width:auto;
		text-align:center;
	}
	#mv .cont_wrapper .sec h1 .sub_title{
		display:block;
	}
	#mv .cont_wrapper .sec h1 .sub_title .small{
		font-size:4.6vw;
	}
	#mv .cont_wrapper .sec h1 .sub_title .large{
		margin-top:0.3em;
		line-height:1.1;
		font-size:5.2vw;
	}
	#mv .cont_wrapper .sec h1 .sub_title .large .en{
		font-size:7.4vw;
	}
	#mv .cont_wrapper .sec h1 .main_title{
		line-height:1.3;
		margin-top:0.3em;
		font-size:9vw;
	}
	#mv .cont_wrapper .sec h1 .main_title > img{
		display:block;
		width:8.5em;
		margin:0 auto 0.05em;
	}
	#mv .cont_wrapper .sec h1 .main_title .large{
		display:block;
		font-size:9.2vw;
		position:static;
		white-space:nowrap;
	}
	#mv .cont_wrapper .sec h1 .main_title .large span{
		font-size:9.2vw;
	}
	#mv .cont_wrapper .sec section{
		margin-top:0;
	}
	#mv .cont_wrapper .sec section h2{
		line-height:1.3;
		display:inline;
		font-size:5.6vw;
		background:linear-gradient(transparent 60%, #dfdac7 60%);
	}
	#mv .cont_wrapper .sec section p{
		line-height:1.4;
		font-size:4vw;
	}
	#mv .cont_wrapper .sec section p .large{
		line-height:1;
		font-size:4.8vw;
	}
	#mv .cont_wrapper .fig{
		width:auto;
		margin-left:0;
		padding:0 9%;
		position:relative;
	}
	#mv .cont_wrapper .fig figcaption{
		line-height:1.7;
		padding:0.7em 0.3em;
		font-weight:bold;
		writing-mode: vertical-rl;
		text-align:left;
		clip-path:polygon(0 0.5em, 100% 0, 100% calc(100% - 0.5em), 0 100%);
		position:absolute;
		right:5%;
		bottom:9%;
	}
	#mv .cont_wrapper .fig figcaption .small{
		font-size:2.8vw;
	}
	#mv .cont_wrapper .fig figcaption .large{
		font-size:3.6vw;
	}
}


/* .cont */
.cont{
	padding:min(9%,90px) 0;
}
.cont .tit{
	font-size:min(5.8vw,58px);
}
.cont .tit:before{
	content:'';
	display:block;
	width:2.1em;
	height:0.13em;
	margin:auto;
	background-color:#ffe537;
}
.cont .tit .en{
	display:block;
	font-weight:600;
	letter-spacing:0.04em;
	text-indent:0.04em;
}
.cont .tit .jp{
	line-height:1;
	display:block;
	font-size:min(2.5vw,25px);
	letter-spacing:0.08em;
	text-indent:0.08em;
}


@media screen and (max-width:750px){
	.cont{
		padding:12% 0;
	}
	.cont .tit{
		font-size:11.3vw;
	}
	.cont .tit:before{
		content:'';
		display:block;
		width:2.1em;
		height:0.13em;
		margin:auto;
		background-color:#ffe537;
	}
	.cont .tit .jp{
		line-height:1.3;
		font-size:4.8vw;
	}
}


/* #cont1 */
#cont1{
}
#cont1 .program{
	margin-top:9%;
	display:flex;
	justify-content:space-between;
}
#cont1 .program li{
	width:min(30%,310px);
}
#cont1 .program li .num{
	line-height:1;
	display:block;
	margin-bottom:-0.7em;
	font-size:min(6.8vw,68px);
	font-weight:600;
	text-align:left;
}
#cont1 .program li .num:before{
	content:'PROGRAM';
	display:block;
	font-size:min(1.8vw,18px);
	font-weight:bold;
	color:#ffe537;
}
#cont1 .program li figure{
	position:relative;
}
#cont1 .program li figure:before{
	content:'';
	display:block;
	width:100%;
	height:100%;
	background:url(../img/cont1_bg.png)no-repeat;
	background-size:100%;
	position:absolute;
	top:0;
	left:0;
	z-index:-1;
	transform:translate(1em,1em);
}
#cont1 .program li section{
	margin-top:min(7%,70px);
	text-align:left;
}
#cont1 .program li section h3{
	display:inline-block;
	font-size:min(2.3vw,23px);
	letter-spacing:0.06em;
	background:linear-gradient(transparent 65%, #ffe537 65%, #ffe537 85%, transparent 85%);
}
#cont1 .program li section p{
	margin-top:1em;
	line-height:1.8;
	font-size:min(1.6vw,16px);
	letter-spacing:0.06em;
}

#cont1 .sec{
	margin-top:min(9%,90px);
	padding:min(4%,40px) min(5%,50px);
	border:1px solid;
	display:flex;
	justify-content:space-between;
	align-items:center;
	position:relative;
}
#cont1 .sec h3{
	width:10.5em;
	line-height:1.9;
	font-size:min(2.4vw,24px);
	letter-spacing:0.08em;
	text-indent:0.08em;
	position:absolute;
	top:0;
	left:50%;
	transform:translate(-50%,-50%);
}
#cont1 .sec figure{
	width:28%;
}
#cont1 .sec dl{
	width:63%;
	text-align:left;
}
#cont1 .sec dl dt{
	margin-bottom:0.3em;
	font-size:min(2.4vw,24px);
	font-weight:bold;
	letter-spacing:0.08em;
}
#cont1 .sec dl dd{
	letter-spacing:0.08em;
}
#cont1 .sec dl dd .large{
	line-height:1;
	font-size:min(2.5vw,25px);
}

@media screen and (max-width:750px){
	#cont1 .program{
		width:80%;
		margin-top:min(7%,70px);
		display:block;
	}
	#cont1 .program li{
		width:auto;
		margin-top:7%;
	}
	#cont1 .program li .num{
		margin-bottom:-0.7em;
		font-size:17vw;
	}
	#cont1 .program li .num:before{
		font-size:4.5vw;
	}
	#cont1 .program li figure:before{
		transform:translate(1em,1em);
	}
	#cont1 .program li section{
		margin-top:6%;
		text-align:center;
	}
	#cont1 .program li section h3{
		font-size:6vw;
		text-indent:0.06em;
	}
	#cont1 .program li section p{
		margin-top:0.5em;
		line-height:1.7;
		font-size:4.2vw;
		text-align:left;
	}
	
	#cont1 .sec{
		margin-top:12%;
		padding:12% 5% 9%;
		display:block;
		position:relative;
	}
	#cont1 .sec h3{
		width:10.5em;
		font-size:4.8vw;
	}
	#cont1 .sec figure{
		width:auto;
	}
	#cont1 .sec dl{
		width:auto;
		text-align:center;
		margin-top:9%;
	}
	#cont1 .sec dl dt{
		margin-bottom:0.5em;
		font-size:4.8vw;
		letter-spacing:0.08em;
		text-indent:0.08em;
	}
	#cont1 .sec dl dd{
		letter-spacing:0.05em;
		text-indent:0.05em;
		font-size:4.1vw;
		white-space:nowrap;
	}
	#cont1 .sec dl dd .large{
		line-height:1.3;
		font-size:5.8vw;
	}
}


/* #cont2 */
#cont2{
	padding-bottom:min(16%,160px);
	background:url(../img/cont2_bg.webp)no-repeat center top;
	background-size:cover;
}
#cont2 .tit .ja{
	display:block;
	line-height:2;
	margin-top:1em;
	font-size:min(3.4vw,35px);
	text-shadow:0 15px 15px rgba(0,0,0,0.15);
	letter-spacing:0.08em;
	padding-left:0.08em;
}
#cont2 .tit .ja .large{
	line-height:1;
	font-size:min(4.2vw,42px);
}
#cont2 .trouble{
	margin-top:min(5%,50px);
	display:flex;
	justify-content:space-between;
	flex-wrap:wrap;
}
#cont2 .trouble div{
	width:min(48%,530px);
	margin-top:min(4%,40px);
	padding:min(2.6%,26px) 0 min(2.8%,28px) min(3%,30px);
	background-color:#fff;
	position:relative;
}
#cont2 .trouble div dt{
	width:10em;
	line-height:1.8;
	font-size:min(1.6vw,16px);
	font-weight:bold;
	letter-spacing:0.08em;
	text-indent:0.08em;
	position:absolute;
	top:0;
	left:50%;
	transform:translate(-50%,-50%);
}
#cont2 .trouble div dd{
	line-height:1.8;
	padding-left:2.2em;
	letter-spacing:0.08em;
	text-align:left;
	position:relative;
}
#cont2 .trouble div dd:before{
	content:'';
	display:block;
	width:1.5em;
	height:0.9em;
	border-left:3px solid #ffe537;
	border-bottom:3px solid #ffe537;
	position:absolute;
	left:0;
	top:50%;
	transform:translateY(-50%) rotate(-40deg);
}
#cont2 .trouble div dd .large{
	line-height:1;
	font-size:min(1.8vw,20px);
	font-weight:bold;
}

@media screen and (max-width:750px){
	#cont2{
		padding-bottom:min(16%,160px);
		background:url(../img/cont2_bg_s.webp)no-repeat center top;
		background-size:cover;
	}
	#cont2 .tit .ja{
		display:block;
		line-height:1.8;
		margin-top:1em;
		font-size:6vw;
		text-shadow:none;
	}
	#cont2 .tit .ja .large{
		font-size:7.2vw;
	}
	#cont2 .trouble{
		margin-top:min(5%,50px);
		display:block;
	}
	#cont2 .trouble div{
		width:auto;
		margin-top:12%;
		padding:5% 0 5% 5%;
	}
	#cont2 .trouble div dt{
		width:9em;
		font-size:3.6vw;
	}
	#cont2 .trouble div dd{
		line-height:1.6;
		padding-left:2em;
		letter-spacing:0.08em;
		text-align:left;
		position:relative;
	}
	#cont2 .trouble div dd:before{
		content:'';
		display:block;
		width:1.2em;
		height:0.7em;
		border-left:2px solid #ffe537;
		border-bottom:2px solid #ffe537;
		position:absolute;
		left:0;
		top:50%;
		transform:translateY(-50%) rotate(-40deg);
	}
	#cont2 .trouble div dd .large{
		font-size:4.7vw;
	}
}



/* #cont3 */
#cont3{
	background-color:#ffe537;
}
#cont3 .tit:before{
	background-color:#111;
}
#cont3 .tit .en{
	color:#fff;
}
#cont3 .tit .jp{
	color:#0e0e0e;
}
#cont3 .install{
	max-width:940px;
}
#cont3 .install div{
	margin-top:min(7%,70px);
	padding:min(7%,70px);
	background-color:#fff;
	position:relative;
}
#cont3 .install div dt{
	width:11em;
	font-size:min(2.6vw,26px);
	font-weight:bold;
	letter-spacing:0.08em;
	text-indent:0.08em;
	position:absolute;
	top:0;
	left:50%;
	transform:translate(-50%,-50%);
}
#cont3 .install div dt:after{
	content:'';
	display:block;
	width:1em;
	height:0.6em;
	background-color:#111;
	clip-path:polygon(0 0, 100% 0, 50% 100%);
	position:absolute;
	top:calc(100% - 1px);
	left:50%;
	transform:translateX(-50%);
}
#cont3 .install div dt span{
	display:block;
}
#cont3 .install div dd h3{
	font-size:min(3vw,30px);
	letter-spacing:0.08em;
	text-indent:0.08em;
}
#cont3 .install div dd h3 .small{
	line-height:1.6;
	display:block;
	margin-top:0.5em;
	font-size:min(2vw,20px);
}
#cont3 .install div figure{
	margin-top:3%;
}
#cont3 .install div:nth-child(3) figure img{
	width:min(90%, 600px);
}

@media screen and (max-width:750px){
	#cont3 .install{
		margin-top:12%;
	}
	#cont3 .install div{
		margin-top:10%;
		padding:9% 3% 7%;
	}
	#cont3 .install div dt{
		width:11em;
		line-height:2;
		font-size:4.4vw;
	}
	#cont3 .install div dd h3{
		font-size:4.6vw;
	}
	#cont3 .install div dd h3 .small{
		font-size:3.7vw;
	}
	#cont3 .install div:nth-child(3) dd h3 .small{
		text-align:left;
	}
	#cont3 .install div:nth-child(3) figure img{
		width:100%;
	}
}


/* #cont4 */
#cont4{
}
#cont4 .lead{
	margin-top:min(5%,50px);
	font-size:min(1.6vw,16px);
	letter-spacing:0.06em;
	padding-left:0.06em;
}
#cont4 .sec{
	margin-top:min(7%,70px);
	padding:min(7%,70px) min(5%,70px) min(5%,50px);
	border:1px solid;
	display:flex;
	justify-content:space-between;
	flex-direction:row-reverse;
	position:relative;
}
#cont4 .sec h3{
	width:12em;
	line-height:1.8;
	font-size:min(2.8vw,28px);
	letter-spacing:0.08em;
	text-indent:0.08em;
	position:absolute;
	top:0;
	left:50%;
	transform:translate(-50%,-50%);
}
#cont4 .sec figure{
	width:min(22%,220px);
	margin-top:-1em;
}
#cont4 .sec .cont_wrapper{
	width:min(72%,670px);
	text-align:left;
}
#cont4 .sec .cont_wrapper dl{
	line-height:1.8;
	display:flex;
	font-weight:bold;
	text-align:center;
}
#cont4 .sec .cont_wrapper dl dt{
	width:4.5em;
	letter-spacing:0.08em;
	text-indent:0.08em;
}
#cont4 .sec .cont_wrapper dl dd{
	padding:0 0.5em;
	letter-spacing:0.06em;
}
#cont4 .sec .cont_wrapper p{
	margin-top:1em;
	letter-spacing:0.08em;
}

@media screen and (max-width:750px){
	#cont4 .lead{
		margin-top:7%;
		padding:0 5%;
		font-size:4.2vw;
		text-align:left;
	}
	#cont4 .sec{
		margin-top:14%;
		padding:12% 5% 7%;
		display:block;
	}
	#cont4 .sec h3{
		width:12em;
		line-height:1.8;
		font-size:5.6vw;
	}
	#cont4 .sec figure{
		width:auto;
		margin-top:1em;
		padding:0 12%;
	}
	#cont4 .sec .cont_wrapper{
		width:auto;
	}
	#cont4 .sec .cont_wrapper dl{
		line-height:1.8;
		display:block;
	}
	#cont4 .sec .cont_wrapper dl dt{
		width:4.5em;
		float:left;
	}
	#cont4 .sec .cont_wrapper dl dd{
		margin-bottom:0.5em;
		padding:0 0 0 5em;
		text-align:left;
	}
	#cont4 .sec .cont_wrapper p{
		margin-top:1em;
		letter-spacing:0.08em;
	}
}


/* #cont5 */
#cont5{
	padding-top:0;
	background:url(../img/mv_bg.png) left center;
}
#cont5 h2{
	background:linear-gradient(105deg,#030303 23.4%,#ffe537 23.4%);
	display:flex;
}
#cont5 h2 .left{
	width:22%;
	padding:0.3em 0.5em 0.3em 0;
	display:block;
	font-size:min(4.5vw,50px);
	font-weight:600;
	font-style:italic;
	color:#fff;
	text-align:right;
	letter-spacing:-0.03em;
}
#cont5 h2 .left .large{
	line-height:1;
	font-size:min(7.8vw,86px);
	vertical-align:-0.08em;
}
#cont5 h2 .right{
	width:78%;
	padding:0.3em 0 0.3em 0.5em;
	display:block;
	font-size:min(4.5vw,50px);
	font-weight:900;
	font-style:italic;
	text-align:left;
	letter-spacing:-0.02em;
}
#cont5 h2 .right .large{
	margin-left:-0.15em;
	line-height:1;
	font-size:min(5.8vw,64px);
}
#cont5 h2 .right .large:before{
	content:'「';
	font-weight:200;
}
#cont5 h2 .right .large:after{
	content:'」';
	font-weight:200;
}
#cont5 .lead{
	margin-top:min(6%,60px);
	font-size:min(1.6vw,16px);
	letter-spacing:0.06em;
	text-indent:0.06em;
}
#cont5 .curriculum{
	margin-top:min(5%,50px);
}
#cont5 .curriculum div{
	margin-top:min(3%,30px);
	font-weight:bold;
	text-align:left;
	border:1px solid;
}
#cont5 .curriculum div dt{
	line-height:1.4;
	padding:1.8% 3%;
	display:flex;
	align-items:center;
}
#cont5 .curriculum div dt .num{
	padding:0 0.5em;
	font-size:min(2.5vw,25px);
	letter-spacing:0.08em;
	text-indent:0.08em;
}
#cont5 .curriculum div dt .title{
	flex:1;
	padding-left:1em;
	font-size:min(2.8vw,28px);
	letter-spacing:0.08em;
}
#cont5 .curriculum div dd{
	padding:2.2% 3%;
	font-size:min(2vw,20px);
	letter-spacing:0.08em;
	background-color:#fff;
}

@media screen and (max-width:750px){
	#cont5{
		background-size:1em auto;
	}
	#cont5 h2{
		background:linear-gradient(105deg,#030303 32%,#ffe537 32%);
		display:flex;
	}
	#cont5 h2 .left{
		width:30%;
		padding:0.3em 0.1em 0.3em 0;
		font-size:6.7vw;
		display:flex;
		justify-content:center;
		align-items:center;
		white-space:nowrap;
	}
	#cont5 h2 .left .large{
		font-size:11vw;
		margin-bottom:0.15em;
	}
	#cont5 h2 .right{
		width:70%;
		padding:0.3em 0 0.3em;
		font-size:6.7vw;
		text-align:center;
		white-space:nowrap;
	}
	#cont5 h2 .right .large{
		margin-left:-0.3em;
		font-size:8.5vw;
	}
	#cont5 .lead{
		margin-top:min(6%,60px);
		padding:0 5%;
		font-size:4.2vw;
		text-indent:0;
		text-align:left;
	}
	#cont5 .curriculum div{
		margin-top:5%;
	}
	#cont5 .curriculum div dt{
		line-height:1.4;
		padding:3% 5% 5%;
		justify-content:center;
		flex-direction:column;
	}
	#cont5 .curriculum div dt .num{
		padding:0 0.5em;
		font-size:5vw;
	}
	#cont5 .curriculum div dt .title{
		display:inline-block;
		padding:0.5em 0 0;
		font-size:5vw;
		letter-spacing:0.06em;
	}
	#cont5 .curriculum div dd{
		padding:5%;
		font-size:4.2vw;
	}
}


/* #cont6 */
#cont6{
	background-color:#fffde2;
}
#cont6 .profile{
	margin-top:min(7%,70px);
	padding:min(3%,30px) min(7%,70px);
	background-color:#fff;
	border:1px solid;
}
#cont6 .profile li{
	padding:min(4%,40px) 0;
	display:flex;
	justify-content:space-between;
}
#cont6 .profile li figure{
	width:min(25%,244px);
}
#cont6 .profile li section{
	width:min(68%,645px);
}
#cont6 .profile li section h3{
	line-height:1.5;
	font-size:min(2.3vw,23px);
	letter-spacing:0.06em;
	text-align:left;
}
#cont6 .profile li:last-child section h3 .small{
	display:block;
}
#cont6 .profile li section p{
	margin-top:0.5em;
	text-align:left;
}

@media screen and (max-width:750px){
	#cont6 .profile{
		margin-top:min(7%,70px);
		padding:min(3%,30px) min(7%,70px);
	}
	#cont6 .profile li{
		padding:9% 0;
		display:block;
	}
	#cont6 .profile li figure{
		width:62%;
		margin:auto;
	}
	#cont6 .profile li section{
		width:auto;
		margin-top:7%;
	}
	#cont6 .profile li section h3{
		line-height:1.5;
		font-size:4.2vw;
		letter-spacing:0.03em;
		padding-left:0.03em;
		text-align:center;
		white-space:nowrap;
	}
	#cont6 .profile li section h3 .small{
		display:block;
		font-size:3.4vw;
		margin-top:0.5em;
	}
	#cont6 .profile li:last-child section h3 .small{
		font-size:4.2vw;
	}
	#cont6 .profile li section p{
		margin-top:1em;
	}
}


/* #cont7 */
#cont7{
	background-color:#ffe537;
}
#cont7 .tit:before{
	background-color:#111;
}
#cont7 .tit .en{
	color:#fff;
}
#cont7 .tit .jp{
	color:#0e0e0e;
}
#cont7 .sec{
	max-width:940px;
	margin-top:min(8%,80px);
	padding:min(8%,80px) 0 min(5%,50px);
	font-weight:bold;
	background-color:#fff;
	position:relative;
}
#cont7 .sec h3{
	width:11.5em;
	font-size:min(2.6vw,26px);
	font-weight:bold;
	letter-spacing:0.08em;
	text-indent:0.08em;
	position:absolute;
	top:0;
	left:50%;
	transform:translate(-50%,-50%);
}
#cont7 .sec h3:after{
	content:'';
	display:block;
	width:1em;
	height:0.6em;
	background-color:#111;
	clip-path:polygon(0 0, 100% 0, 50% 100%);
	position:absolute;
	top:calc(100% - 1px);
	left:50%;
	transform:translateX(-50%);
}
#cont7 .sec h3 span{
	display:block;
}
#cont7 .sec .large{
	font-size:min(3vw,30px);
	letter-spacing:0.08em;
	text-indent:0.08em;
}
#cont7 .sec .xlarge{
	line-height:1;
	margin:0 0.1em;
	font-size:min(9vw,90px);
	letter-spacing:0;
	text-indent:0;
}
#cont7 .sec .enlarge{
	line-height:1.3;
	margin-right:0.1em;
	font-size:min(5.7vw,57px);
	font-weight:600;
	letter-spacing:0;
	text-indent:0;
}

#cont7 .sec .middle{
	font-size:min(2.7vw,27px);
	letter-spacing:0.08em;
	text-indent:0.08em;
}
#cont7 .sec .small{
	margin-top:0.5em;
	font-size:min(1.9vw,19px);
	letter-spacing:0.08em;
	padding-left:0.08em;
}
#cont7 .caution{
	margin-top:0.7em;
	font-size:min(2.3vw,23px);
	font-weight:bold;
	letter-spacing:0.08em;
	text-indent:0.08em;
}

#cont7 #cont7_2{
	padding:min(7%,70px) 0;
}
#cont7 #cont7_2 h3:after{
	background-color:#d20000;
}
#cont7 #cont7_2 picture{
	display:block;
	padding:min(4%,40px) min(5%,50px) 0;
}

@media screen and (max-width:750px){
	#cont7 .sec{
		margin-top:15%;
		padding:18% 0 12%;
	}
	#cont7 .sec h3{
		width:11.5em;
		font-size:5.2vw;
		line-height:2;
	}
	#cont7 .sec .large{
		font-size:4.2vw;
	}
	#cont7 .sec .xlarge{
		font-size:12.8vw;
	}
	#cont7 .sec .enlarge{
		display:block;
		line-height:1.1;
		margin:0.1em 0 0;
		font-size:9vw;
	}

	#cont7 .sec .middle{
		margin-top:1.2em;
		font-size:4.2vw;
	}
	#cont7 .sec .small{
		margin-top:0.5em;
		padding:0 5.5%;
		font-size:4.2vw;
		text-align:left;
	}
	#cont7 .caution{
		margin-top:1em;
		font-size:4.2vw;
		text-indent:-0.5em;
	}

	#cont7 #cont7_2{
		padding:12% 0 9%;
	}
}


/* #cont8 */
#cont8{
	background:url(../img/mv_bg.png) left center;
}
#cont8 h2{
	font-size:min(2.7vw,27px);
}
#cont8 h2 img{
	width:20.5em;
}
#cont8 h2 .small{
	line-height:2.4;
	display:block;
	letter-spacing:0.04em;
	text-indent:0.04em;
}
#cont8 h2 .large{
	line-height:1.8;
	margin-top:0.5em;
	padding:0 1.6em;
	display:inline-block;
	font-size:min(3vw,30px);
}
#cont8 .fig{
	margin-top:min(4%,40px);
}
#cont8 .fig figcaption{
	line-height:1;
	display:inline-block;
	padding:0 1em;
	font-size:min(2.5vw,25px);
	font-weight:bold;
	position:relative;
}
#cont8 .fig figcaption:before{
	content:'';
	display:block;
	width:1px;
	height:1.4em;
	border-left:1px solid;
	position:absolute;
	left:0;
	bottom:-0.15em;
	transform:rotate(-45deg);
}
#cont8 .fig figcaption:after{
	content:'';
	display:block;
	width:1px;
	height:1.4em;
	border-right:1px solid;
	position:absolute;
	right:0;
	bottom:-0.15em;
	transform:rotate(45deg);
}
#cont8 .fig img{
	display:block;
	width:min(21%,213px);
	margin:min(1.5%,15px) auto 0;
}
#cont8 h3{
	margin-top:min(1.5%,15px);
}
#cont8 h3 span{
display:inline-block;
	font-size:min(3vw,30px);
	font-style:italic;
	background:linear-gradient(transparent 60%, #dfdac7 60%, #dfdac7 80%, transparent 80%);
}

@media screen and (max-width:750px){
	#cont8{
		background-size:1em auto;
	}
	#cont8 h2{
		font-size:5.3vw;
	}
	#cont8 h2 img{
		width:17em;
	}
	#cont8 h2 .small{
		line-height:2.4;
	}
	#cont8 h2 .large{
		line-height:1.8;
		margin-top:0.5em;
		padding:0 1.6em;
		display:inline-block;
		font-size:5.6vw;
	}
	#cont8 .fig{
		margin-top:min(4%,40px);
	}
	#cont8 .fig figcaption{
		line-height:1.5;
		display:inline-block;
		padding:0 1em;
		font-size:4.6vw;
		font-weight:bold;
		position:relative;
	}
	#cont8 .fig figcaption:before{
		height:3em;
		bottom:-0.15em;
		transform:rotate(-30deg);
	}
	#cont8 .fig figcaption:after{
		height:3em;
		bottom:-0.15em;
		transform:rotate(30deg);
	}
	#cont8 .fig img{
		width:42%;
		margin-top:3%;
	}
	#cont8 h3 span{
		display:inline;
		font-size:5.6vw;
		font-style:italic;
		background:linear-gradient(transparent 60%, #dfdac7 60%);
	}
}


footer{
	padding:min(5%,50px) 0;
}
footer dl{
	display:flex;
	justify-content:center;
	flex-wrap:wrap;
}
footer dl dt{
	width:100%;
	margin-bottom:min(3%,30px);
}
footer dl dt img{
	width:min(37%,378px);
}
footer dl dd{
	padding:0 1em;
	font-size:min(1.4vw,14px);
	letter-spacing:0.08em;
	text-indent:0.08em;
}
footer .copy{
	margin-top:min(5%,50px);
	font-size:min(1.2vw,12px);
	letter-spacing:0.08em;
	text-indent:0.08em;
}

@media screen and (max-width:750px){
	footer{
		padding:12% 0;
	}
	footer dl{
		display:block;
	}
	footer dl dt{
		width:100%;
		margin-bottom:min(3%,30px);
	}
	footer dl dt img{
		width:65%;
	}
	footer dl dd{
		padding:0.1em 0;
		font-size:3.7vw;
	}
	footer .copy{
		margin-top:12%;
		font-size:3.1vw;
	}
}


/* #bottom_nav */
#bottom_nav{
	width:100%;
	background-color:rgba(0,0,0,0.75);
	position:fixed;
	z-index:99;
	right:0;
	bottom:-300px;
	-webkit-transition: bottom 0.8s;
	transition: bottom 0.8s;
}
#bottom_nav .inner{
	max-width:824px;
	display:flex;
	justify-content:space-between;
}
#bottom_nav .inner > dt{
	width:min(32%,248px);
	position:relative;
}
#bottom_nav .inner > dt img{
	width:100%;
	position:absolute;
	bottom:0;
	left:0;
}
#bottom_nav .inner .line{
	line-height:1;
	width:min(66%,548px);
	padding:min(1.5%,12px) 0;
}
#bottom_nav .inner .line .cta_btn{
	line-height:1;
	width:100%;
	margin-top:0;
	font-size:min(3.6vw,31px);
}
#bottom_nav .inner .line .cta_btn dl dt{
	font-size:min(1.7vw,15px);
}
#bottom_nav .inner .line .cta_btn dl dt .large{
	font-size:min(2.6vw,26px);
}
#bottom_nav .inner .line .cta_btn dl dt .middle{
	font-size:min(2.3vw,23px);
}

@media screen and (max-width:750px){
	#bottom_nav .inner{
		display:block;
		width:92%;
	}
	#bottom_nav .inner .line{
		line-height:1;
		width:100%;
		padding:3% 0;
	}
	#bottom_nav .inner .line .cta_btn{
		line-height:1;
		width:100%;
		margin-top:0;
		font-size:6.1vw;
	}
	#bottom_nav .inner .line .cta_btn dl dt{
		font-size:3.3vw;
	}
	#bottom_nav .inner .line .cta_btn dl dt .large{
		font-size:5vw;
	}
	#bottom_nav .inner .line .cta_btn dl dt .middle{
		font-size:4.3vw;
	}
}


/* fadein */
.fadein {
	opacity : 0.01;
	-webkit-transform : translate(0, 70px);
	transform : translate(0, 70px);
	-webkit-transition-property: transform,opacity;
	transition-property : transform,opacity;
	-webkit-transition-duration: 1s;
	transition-duration : 1s;
}
.fadein_0 {
	opacity : 0.01;
	-webkit-transform : translate(0, 0);
	transform : translate(0, 0);
	-webkit-transition-property: transform,opacity;
	transition-property : transform,opacity;
	-webkit-transition-duration: 2s;
	transition-duration : 2s;
}


.delay1 {
	-webkit-transition-property: transform,opacity;
	transition-property : transform,opacity;
	-webkit-transition-duration: 1s;
	transition-duration : 1s;
	-webkit-transition-delay: 0.2s;
	transition-delay : 0.2s;
}
.delay2 {
	-webkit-transition-property: transform,opacity;
	transition-property : transform,opacity;
	-webkit-transition-duration: 1s;
	transition-duration : 1s;
	-webkit-transition-delay: 0.4s;
	transition-delay : 0.4s;
}
.delay3 {
	-webkit-transition-property: transform,opacity;
	transition-property : transform,opacity;
	-webkit-transition-duration: 1s;
	transition-duration : 1s;
	-webkit-transition-delay: 0.6s;
	transition-delay : 0.6s;
}
.delay4 {
	-webkit-transition-property: transform,opacity;
	transition-property : transform,opacity;
	-webkit-transition-duration: 1s;
	transition-duration : 1s;
	-webkit-transition-delay: 0.8s;
	transition-delay : 0.8s;
}
.delay5 {
	-webkit-transition-property: transform,opacity;
	transition-property : transform,opacity;
	-webkit-transition-duration: 1s;
	transition-duration : 1s;
	-webkit-transition-delay: 1.0s;
	transition-delay : 1.0s;
}
.delay6 {
	-webkit-transition-property: transform,opacity;
	transition-property : transform,opacity;
	-webkit-transition-duration: 1s;
	transition-duration : 1s;
	-webkit-transition-delay: 1.2s;
	transition-delay : 1.2s;
}

.fadein.scrollin,
.fadein_0.scrollin{
	opacity : 1;
	-webkit-transform : translate(0, 0);
	transform : translate(0, 0);
}

/* popup */
.popup {
	-webkit-transform : scale(0);
	transform : scale(0);
	-webkit-transform-origin:left bottom;
	transform-origin:left bottom;
	-webkit-transition-property: transform;
	transition-property : transform;
	-webkit-transition-duration: 0.4s;
	transition-duration : 0.4s;
	-webkit-transition-timing-function: cubic-bezier(.17,.67,.68,1.34);
	transition-timing-function: cubic-bezier(.17,.67,.68,1.34);
}
.popup.scrollin {
	-webkit-transform : scale(1);
	transform : scale(1);
}
