@charset "utf-8";

html {
	-webkit-text-size-adjust: 100%;
}
body {
	font-family: "Noto Sans JP", sans-serif;
	font-size:16px;
	text-align:center;
	line-height:2.3;
	color:#333;
}

@media screen and (max-width:768px){
	body {
		line-height:1.8;
		font-size:3.4vw;
	}
}

.en{
	font-family: "Bebas Neue", sans-serif;
}

a {
	color:#333;
	-webkit-transition : opacity 0.4s;
	transition : opacity 0.4s;
	opacity:1;
	outline:none;
}
a:hover {
	opacity: 0.7;
}

img{
	max-width:100%;
}

.only_smart,
.only_smart_i{
	display:none !important;
}
@media screen and (max-width:768px){
	.only_pc{
		display:none !important;
	}
	.only_smart{
		display:block !important;
	}
	.only_smart_i{
		display:inline-block !important;
	}
}


/* 色 */
.bg_navy{
	color:#fff;
	background-color:#036eb7;
}
.blue{
	color:#0f82c3;
}
.bg_blue{
	color:#fff;
	background-color:#0f82c3;
}
.bg_sky{
	background-color:rgba(15,130,195,0.1);
}
.yellow{
	color:#ffe34d;
}

/* 書式 */
.bold{
	font-weight:bold;
}
.text_right{
	text-align:right;
}




#wrapper{
}


.inner{
	max-width:1000px;
	width:94%;
	margin:auto;
}


/* header */
header{
	width:100%;
}
header .inner{
	height:76px;
	display: -webkit-flex;
	-webkit-align-items: center;
	align-items: center;
}
header .inner .head_logo{
	width:340px;
	line-height:0;
}

@media screen and (max-width:768px){
	header .inner{
		height:50px;
	}
	header .inner .head_logo{
		width:220px;
	}
}


/* article */
article{
}


/* #mv */
#mv{
	padding:min(1.5%,15px) 0 min(4%,40px);
	background:#036eb7 url(../images/mv_bg.png)no-repeat center bottom;
	background-size:1920px auto;
	text-align:left;
	position:relative;
	overflow:hidden;
}
#mv .inner h1{
	line-height:1.1;
	font-size:min(6vw,60px);
	font-weight:900;
	font-style:italic;
	letter-spacing:0.05em;
}
#mv .inner h1 .small{
	display:block;
	line-height:2.5;
	font-size:min(3vw,30px);
}
#mv .inner h1 .middle{
	font-size:min(4.5vw,45px);
}
#mv .inner .point{
	display: -webkit-flex;
	display: flex;
}
#mv .inner .point li{
	line-height:1.5;
	margin:1em 0;
	padding:0 0.5em;
	font-size:min(2.5vw,25px);
	font-weight:bold;
	border:1px solid;
}
#mv .inner .point li:nth-child(n+2){
	margin-left:0.3em;
}
#mv .inner .cta_inner_mv {
	display: flex;
	flex-direction: row;
	align-items: center;
	gap: 32px; /* sm:gap-x-8 */
	/*padding: 0 16px; /* px-4 */
	position: relative;
	z-index: 3;
}
#mv .inner a{
	display:inline-block;
	width:min(360px,36vw);
}
#mv .inner .fig{
	width:min(48vw,503px);
	position:absolute;
	left:calc(50% + 80px);
	top:min(4%,40px);
}
@media screen and (max-width:768px){
	#mv{
		padding:1.5% 0 15%;
		background:#036eb7 url(../images/mv_bg_s.png)no-repeat center bottom -1px;
		background-size:110% auto;
	}
	#mv .inner h1{
		font-size:9.4vw;
		letter-spacing:0;
	}
	#mv .inner h1 .small{
		font-size:4.5vw;
	}
	#mv .inner h1 .middle{
		font-size:7vw;
	}
	#mv .inner .point li{
		font-size:4vw;
	}
	#mv .inner .cta_inner_mv{
		flex-direction: column; /* flex-col */
		gap: 12px; /* gap-3 */
	}
	#mv .inner a{
		width:85%;
		margin: 0 auto;
	}
	#mv .inner .fig{
		width:48%;
		left:62%;
		top:12%;
	}
}


/* .cont */
.cont{
	padding:min(5%,50px) 0;
}
.cont .tit .en{
	line-height:1.5;
	margin-bottom:0.8em;
	display:inline-block;
	border-bottom:3px solid;
	font-size:min(2.5vw,25px);
	font-weight:500;
}
.cont .tit .jp{
	line-height:1.7;
	display:block;
	font-size:min(3vw,40px);
	font-weight:900;
	padding-left:0.05em;
	letter-spacing:0.05em;
}

@media screen and (max-width:768px){
	.cont{
		padding:7% 0;
	}
	.cont .tit .en{
		border-bottom:2px solid;
		font-size:min(2.5vw,25px);
		font-size:3.7vw;
	}
	.cont .tit .jp{
		font-size:min(4vw,40px);
		font-size:6vw;
	}
}


/* .cta - React版(Tailwind)と同じスタイル */
/* Desktop (sm: = 640px以上) */
.cta{
	padding: 16px 0; /* py-4 */
}
.cta.cta_mb{
	margin-bottom: 48px; /* sm:mb-12 */
}
.cta.cta_mt{
	margin-top: 48px; /* sm:mt-12 */
}
.cta .cta_inner{
	display: -webkit-flex;
	display: flex;
	-webkit-flex-direction: row;
	flex-direction: row; /* sm:flex-row */
	-webkit-align-items: center;
	align-items: center;
	-webkit-justify-content: center;
	justify-content: center;
	gap: 32px; /* sm:gap-x-8 */
	padding: 0 16px; /* px-4 */
}
.cta .cta_button{
	display: block;
	width: auto; /* sm:w-auto */
	max-width: 350px; /* sm:max-w-[350px] */
	line-height: 0;
}
.cta .cta_button img{
	width: 100%;
	height: auto;
}
.cta .cta_contact{
	display: -webkit-flex;
	display: flex;
	-webkit-align-items: center;
	align-items: center;
	-webkit-justify-content: center;
	justify-content: center;
	white-space: nowrap;
	color: #fff;
}
.cta .cta_phone{
	display: -webkit-flex;
	display: flex;
	-webkit-flex-wrap: nowrap;
	flex-wrap: nowrap;
	-webkit-align-items: center;
	align-items: center;
	-webkit-justify-content: center;
	justify-content: center;
	text-decoration: none;
	color: #fff;
}
.cta .cta_phone_icon{
	width: 24px;
	height: 24px;
}
.cta .cta_phone_number{
	font-family: "Bebas Neue", sans-serif;
	font-size: 40px; /* lg:text-[40px] */
	font-weight: 400;
	letter-spacing: 0.02em;
	padding-left: 4px; /* pl-1 */
	padding-top: 4px; /* pt-1 */
}
.cta .cta_hours{
	line-height: 1.3;
	text-align: left;
	font-size: 12px; /* sm:text-xs lg:text-xs */
	font-weight: 700; /* font-bold */
	color: #fff;
	padding-left: 12px; /* pl-3 */
}


@media screen and (min-width: 640px) and (max-width: 768px) {
	.cta .cta_inner{
		-webkit-flex-direction: column;
		flex-direction: column; /* flex-col */
		gap: 0px; /* gap-3 */
		padding: 0;
	}
}
/* Mobile (639px以下 = Tailwind sm: breakpoint未満) */
@media screen and (max-width:639px){
	.cta.cta_mb{
		margin-bottom: 24px; /* mb-6 */
	}
	.cta.cta_mt{
		margin-top: 24px; /* mt-6 */
	}
	.cta .cta_inner{
		-webkit-flex-direction: column;
		flex-direction: column; /* flex-col */
		gap: 12px; /* gap-3 */
	}
	.cta .cta_button{
		width: 70%; /* w-[70%] */
		max-width: 320px; /* max-w-[320px] */
	}
	.cta .cta_phone_number{
		font-size: 24px; /* text-2xl */
	}
	.cta .cta_hours{
		font-size: 10px; /* text-[10px] */
	}
}


/* #cont1 */
#cont1{
}
#cont1 .fig{
	margin-top:min(4%,40px);
}
#cont1 .title{
	line-height:2;
	margin-top:min(4%,40px);
	font-size:min(2.5vw,25px);
	padding-left:0.05em;
	letter-spacing:0.05em;
}
#cont1 .last{
	margin-top:min(3%,30px);
}

@media screen and (max-width:1024px){
	#cont1 .last .only_smart{
		display:block !important;
	}
}

@media screen and (max-width:768px){
	#cont1 .title{
		line-height:1.5;
		padding:0 3%;
		font-size:3.5vw;
		text-align:left;
	}
	#cont1 .last{
		padding:0 3%;
		text-align:left;
	}
	#cont1 .last .only_smart{
		display:none !important;
	}
}



/* #cont2 */
#cont2{
}
#cont2 .inner{
	width:92%;
}
#cont2 .lead{
	margin-top:min(1.5%,15px);
}
#cont2 .fig1{
	margin-top:min(3%,30px);
}
#cont2 .feature{
	margin-top:min(3%,30px);
	text-align:left;
	font-feature-settings: "palt";
}
#cont2 .feature dt{
	line-height:1.8;
	margin-top:min(3%,30px);
	padding-left:1em;
	font-size:min(2.5vw,25px);
	font-weight:bold;
}
#cont2 .feature dd{
	margin-top:1em;
}
#cont2 .fig2{
	margin-top:min(2%,20px);
}

@media screen and (max-width:768px){
	#cont2 .inner{
		width:92%;
	}
	#cont2 .lead{
		padding:0 4%;
		text-align:left;
	}
	#cont2 .feature{
		margin-top:5%;
	}
	#cont2 .feature dt{
		margin-top:5%;
		font-size:3.7vw;
	}
	#cont2 .feature dd{
		margin-top:0.5em;
	}
	#cont2 .fig2{
		margin-top:5%;
	}
}


/* #cont3 */
#cont3{
	padding-top:min(9%,90px);
	overflow:hidden;
}


/* #cont3 .sec1 */
#cont3 .sec1{
	padding-right:min(50%,500px);
	text-align:left;
	font-feature-settings: "palt";
	position:relative;
}
#cont3 .sec1 .lead{
	margin-top:min(3%,30px);
}
#cont3 .sec1 .fig1{
	width:min(76%,760px);
	position:absolute;
	left:53%;
	bottom:0;
}

@media screen and (max-width:1280px){
	#cont3 .sec1 .fig1{
		width:min(58%,760px);
	}
}

@media screen and (max-width:768px){
	#cont3 .sec1{
		padding-right:0;
		position:static;
	}
	#cont3 .sec1 .fig1{
		width:auto;
		margin-top:5%;
		position:static;
		left:auto;
		bottom:auto;
	}
}


/* #cont3 .sec2 */
#cont3 .sec2{
	margin-top:min(5%,50px);
	display: -webkit-flex;
	display: flex;
	-webkit-align-items: flex-start;
	align-items: flex-start;
}
#cont3 .sec2 h2{
	line-height:2;
	width:min(23%,230px);
	padding:0.3em 0.8em;
	font-size:min(2.5vw,25px);
	text-align:left;
	white-space:nowrap;
	position:relative;
}
#cont3 .sec2 h2:after{
	content:'';
	display:block;
	width:1.2em;
	height:1.6em;
	background-color:#0f82c3;
	clip-path:polygon(0 0, 100% 50%, 0 100%);
	position:absolute;
	left:calc(100% - 1px);
	top:50%;
	z-index:1;
	transform:translateY(-50%);
}
#cont3 .sec2 .fig2{
	flex:1;
	padding:1.5% 3%;
}
#cont3 .sec2 .fig2 figcaption{
	margin-top:1em;
	text-align:left;
	font-feature-settings: "palt";
}

@media screen and (max-width:768px){
	#cont3 .sec2{
		display: block;
		text-align:left;
	}
	#cont3 .sec2 h2{
		display:inline-block;
		line-height:1.5;
		width:auto;
		padding:0.3em 0.8em;
		font-size:3.7vw;
	}
	#cont3 .sec2 h2:after{
		width:1.2em;
		height:1em;
		background-color:#0f82c3;
		clip-path:polygon(0 0, 100% 0, 50% 100%);
		position:absolute;
		left:1.5em;
		top:calc(100% - 1px);
		transform:translateY(0);
	}
	#cont3 .sec2 .fig2{
		flex:1;
		margin-top:2.5%;
		padding:3%;
	}
}


/* #cont3 .sec3 */
#cont3 .sec3{
	margin-top:min(5%,50px);
	text-align:left;
}
#cont3 .sec3 h2{
	display:inline-block;
	line-height:2;
	margin-bottom:1em;
	padding:0.3em 0.8em;
	font-size:min(2.5vw,25px);
	white-space:nowrap;
	position:relative;
}
#cont3 .sec3 h2:after{
	content:'';
	display:block;
	width:1.2em;
	height:1em;
	background-color:#0f82c3;
	clip-path:polygon(0 0, 100% 0, 50% 100%);
	position:absolute;
	left:1.5em;
	top:calc(100% - 1px);
	z-index:1;
}
#cont3 .sec3 .point{
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: space-between;
	justify-content: space-between;
}
#cont3 .sec3 .point li{
	width:31%;
	padding:2.2%;
}
#cont3 .sec3 .point li h3 .en{
	display:block;
	line-height:0.8;
	font-size:min(5.7vw,57px);
	font-weight:500;
	color:rgba(29,121,184,0.3);
}
#cont3 .sec3 .point li h3 .jp{
	font-size:min(2.4vw,25px);
	white-space:nowrap;
}
#cont3 .sec3 .point li p{
	margin-top:0.8em;
	font-feature-settings: "palt";
}
#cont3 .sec3 .point li .caution{
	display:block;
	line-height:1.8;
	padding-left:1em;
	text-indent:-1em;
	font-size:min(1.4vw,14px);
}

@media screen and (max-width:768px){
	#cont3 .sec3 h2{
		line-height:1.5;
		width:auto;
		padding:0.3em 0.8em;
		font-size:3.7vw;
	}
	#cont3 .sec3 .point{
		display: block;
	}
	#cont3 .sec3 .point li{
		width:auto;
	padding:5%;
	}
	#cont3 .sec3 .point li:nth-child(n+2){
		margin-top:3%;
	}
	#cont3 .sec3 .point li h3 .en{
		font-size:8.5vw;
	}
	#cont3 .sec3 .point li h3 .jp{
		font-size:4vw;
	}
	#cont3 .sec3 .point li figure{
		margin-top:0.3em;
	}
	#cont3 .sec3 .point li .caution{
		font-size:2.6vw;
	}
}


/* #cont4 */
#cont4{
}
#cont4 .interview{
	text-align:left;
}
#cont4 .interview div{
	margin-top:min(5%,50px);
	font-size:min(2.5vw,25px);
}
#cont4 .interview div dt{
	padding-left:2.5em;
	font-weight:bold;
	position:relative;
}
#cont4 .interview div dt:before{
	content:'Q';
	width:1.2em;
	height:1.2em;
	line-height:1.3em;
	font-family: "Bebas Neue", sans-serif;
	font-size:min(3.8vw,38px);
	font-weight:500;
	text-align:center;
	color:#fff;
	background-color:#0f82c3;
	border-radius:50%;
	position:absolute;
	left:0;
	top:0.1em;
}
#cont4 .interview div dd{
	padding-left:2.5em;
	position:relative;
}
#cont4 .interview div dd:before{
	content:'A';
	width:1.2em;
	height:1.2em;
	line-height:1.3em;
	font-family: "Bebas Neue", sans-serif;
	font-size:min(3.8vw,38px);
	font-weight:500;
	text-align:center;
	color:#fff;
	background-color:#989898;
	border-radius:50%;
	position:absolute;
	left:0;
	top:0.1em;
}
#cont4 .interview div dd p{
	font-size:16px;
	font-feature-settings: "palt";
}

@media screen and (max-width:768px){
	#cont4 .interview div{
		margin-top:3%;
		font-size:3.7vw;
	}
	#cont4 .interview div dt:before{
		font-size:5.6vw;
	}
	#cont4 .interview div dd{
		margin-top:0.3em;
	}
	#cont4 .interview div dd:before{
		font-size:5.6vw;
	}
	#cont4 .interview div dd p{
		font-size:3.4vw;
	}
}


/* #cont5 */
#cont5{
}
#cont5 .application{
	margin-top:min(5%,50px);
	padding:0 3%;
}
#cont5 .application li{
	margin-top:min(1.8%,18px);
}
#cont5 .application li a{
	display:block;
	padding:0.8em 2em;
	font-size:min(2vw,20px);
	font-weight:bold;
	text-align:left;
	background:url(../images/cont5_arrow.png)no-repeat right 1em center;
	background-size:0.9em auto;
	border-radius:0.5em;
	box-shadow:inset 0 0 6px #ccc;
}
#cont5 .application li a .application_desc{
	display:block;
	font-size:min(1.4vw,14px);
	line-height:2;
	font-weight:normal;
	color:#666;
	padding-top: 0.8em;
}
#cont5 .application li.application_with_image a{
	display: -webkit-flex;
	display: flex;
	-webkit-flex-direction: column;
	flex-direction: column;
	-webkit-align-items: flex-start;
	align-items: flex-start;
}
#cont5 .application li.application_with_image .application_balloon{
	display: inline-block;
	background-color: #ffe34d;
	color: #1d79bf;
	font-size: min(1.6vw, 16px);
	font-weight: bold;
	padding: 0.15em 1.5em;
	border-radius: 50px;
	margin-bottom: 10px;
	position: relative;
}
#cont5 .application li.application_with_image .application_balloon::after{
	content: "";
	position: absolute;
	bottom: -8px;
	left: 24px;
	border-width: 8px 8px 0 8px;
	border-style: solid;
	border-color: #ffe34d transparent transparent transparent;
}
#cont5 .application li.application_with_image .application_inner{
	display: -webkit-flex;
	display: flex;
	-webkit-align-items: center;
	align-items: center;
	gap: min(2%, 20px);
	width: 100%;
}
#cont5 .application li.application_with_image .application_image{
	-webkit-flex-shrink: 0;
	flex-shrink: 0;
	width: 124px;
	margin: 0;
}
#cont5 .application li.application_with_image .application_image img{
	width: 100%;
	height: auto;
	display: block;
}
#cont5 .application li.application_with_image .application_content{
	-webkit-flex: 1;
	flex: 1;
}

@media screen and (max-width:768px){
	#cont5 .application{
		padding:0;
	}
	#cont5 .application li a{
		padding:1em 1.5em;
		font-size:3.2vw;
	}
	#cont5 .application li a .application_desc{
		font-size:2.8vw;
	}
	#cont5 .application li.application_with_image a{
		-webkit-align-items: center;
		align-items: center;
	}
	#cont5 .application li.application_with_image .application_balloon{
		font-size: 2.5vw;
		padding: 0.25em 1.2em;
	}
	#cont5 .application li.application_with_image .application_balloon::after{
		left: 50%;
		-webkit-transform: translateX(-50%);
		transform: translateX(-50%);
		bottom: -6px;
		border-width: 6px 6px 0 6px;
	}
	#cont5 .application li.application_with_image .application_inner{
		-webkit-flex-direction: column;
		flex-direction: column;
		gap: 10px;
	}
	#cont5 .application li.application_with_image .application_image{
		width: 40%;
		max-width: 124px;
	}
}




/* footer */
footer{
	padding:min(15%,150px) 0 min(5%,50px);
}
footer .foot_logo img{
	width:340px;
}

footer .copy{
	margin-top:min(5%,50px);
	padding:1em 0;
	font-size:11px;
	letter-spacing:0.05em;
	text-indent:0.05em;
	color:#666;
}

@media screen and (max-width:768px){
	footer{
		padding:15% 0 5%;
	}
	footer .foot_logo img{
		width:min(62%,340px);
	}
	footer .copy{
		margin-top:9%;
		font-size:2.5vw;
	}
}


/* top_top */
#topbtn{
	width:50px;
	line-height:50px;
	font-family:sans-serif;
	font-size:18px;
	border-radius:50%;
	color:#fff;
	background-color:rgba(0,0,0,0.5);
	position:fixed;
	z-index:90;
	right:30px;
	bottom:-150px;
	-webkit-transition: bottom 0.8s;
	-moz-transition: bottom 0.8s;
	-ms-transition: bottom 0.8s;
	transition: bottom 0.8s;
}
@media screen and (max-width:768px){
	#topbtn{
		width:40px;
		line-height:40px;
		right:20px;
	}
}


/* fadein */
.fadein {
	opacity : 0;
	-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;
	-webkit-transform : translate(0, 0);
	transform : translate(0, 0);
	-webkit-transition-property: transform,opacity;
	transition-property : transform,opacity;
	-webkit-transition-duration: 1s;
	transition-duration : 1s;
}
.fadein_l {
	opacity : 0;
	-webkit-transform : translate(-100px, 0);
	transform : translate(-100px, 0);
	-webkit-transition-property: transform,opacity;
	transition-property : transform,opacity;
	-webkit-transition-duration: 1s;
	transition-duration : 1s;
}
.fadein_r {
	opacity : 0;
	-webkit-transform : translate(100px, 0);
	transform : translate(100px, 0);
	-webkit-transition-property: transform,opacity;
	transition-property : transform,opacity;
	-webkit-transition-duration: 1s;
	transition-duration : 1s;
}
.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;
}

.fadein.scrollin,
.fadein_0.scrollin,
.fadein_l.scrollin,
.fadein_r.scrollin{
	opacity : 1;
	-webkit-transform : translate(0, 0);
	transform : translate(0, 0);
}
