@charset "utf-8";
/* CSS Document */

/*
* Prefixed by https://autoprefixer.github.io
* PostCSS: v8.4.14,
* Autoprefixer: v10.4.7
* Browsers: last 4 version
*/

*{
	margin:0;
	padding:0;
	-webkit-box-sizing:border-box;
	        box-sizing:border-box;
}

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

html{
	font-size:62.5%;
}

body{
	color:#323232;
	font-size:1.6rem;
	font-family: 'Noto Sans JP', sans-serif;
	font-weight:400;
	line-height:1.8;
}

h1,h2,h3,h4{
	font-weight:700;
	line-height:1.5;
}

.wrapper{
	width:100%;
	padding:0 20px;
}

.header{
	background-color:#ffffff;
	padding-top:12px;
	padding-bottom:12px;
}

.header h1{
	width:186px;
	margin:0 auto;
}

.header .header_sns_icon{
	display:none;
}

.main .key_visual{
	color:#ffffff;
	background-color:#3eb3a0;
	padding-top:45px;
	text-align:center;
}

.main .key_visual h2{
	font-size:2.4rem;
	margin-bottom:35px;
}

.main .key_visual .key_sentence{
	font-size:1.4rem;
	margin-bottom:35px;
}

.main .key_visual .key_bottun_box{
	display:-webkit-box;
	display:-ms-flexbox;
	display:flex;
	-webkit-box-pack:justify;
	    -ms-flex-pack:justify;
	        justify-content:space-between;
	width:340px;
	margin:0 auto 45px;
	font-size:1.4rem;
	font-family: 'Open Sans', sans-serif;
	letter-spacing:0.03em;
	line-height:40px;
	text-transform:uppercase;
}

.main .key_visual .key_bottun_box p{
	width:170px;
}

.main .key_visual .key_bottun_box .key_bottun_1{
	background-color:#ffffff;
	border-radius:5px;
}

.main .key_visual .key_bottun_box .key_bottun_1 a{
	color:#1aacd8;
	display:block;
}

.main .key_visual .key_bottun_box .key_bottun_2 a{
	color:#ffffff;
	display:block;
	text-decoration:underline;
	text-underline-offset:3px;
	text-decoration-thickness:2px;
}

.main .key_visual figure img{
	width:168px;
	height:217px;
	-o-object-fit:cover;
	   object-fit:cover;
	-o-object-position:50% 0;
	   object-position:50% 0;
}

.main .section1{
	background-color:#ffffff;
	padding:50px 0;
	text-align:center;
}

.main .section1 h3{
	font-size:2.0rem;
	letter-spacing:0.03em;
	margin-bottom:15px;
}

.main .section1 .wrapper > p{
	margin-bottom:30px;
}

.main .section1 .wrapper > p span::before{
	content:"\A";
	white-space:pre;
}

.main .section1 section{
	width:270px;
	margin:0 auto 35px;
}

.main .section1 .section1_contents3{
	margin-bottom:0;
}

.main .section1 section figure{
	width:90px;
	margin:0 auto 15px;
}

.main .section1 section h4{
	font-size:1.8rem;
	margin-bottom:26px;
	position:relative;
}

.main .section1 section h4::after{
	content:"";
	position:absolute;
	width:20px;
	height:2px;
	background-color:#323232;
	top:39px;
	left:calc(50% - 10px);
}

.main .section1 section p{
	font-size:1.4rem;
	text-align:left;
}

.main .section2{
	padding:50px 0;
	background-color:#f7f7f7;
}

.main .section2 figure{
	width:250px;
	margin:0 auto 20px;
}

.main .section2 .section2_contents h3{
	text-align:center;
	font-size:2.0rem;
	letter-spacing:0.03em;
	margin-bottom:15px;
}

.main .section2 .section2_contents p{
	width:300px;
	margin:0 auto;
}

.main .section3{
	padding:50px 0;
	background-color:#ffffff;
}

.main .section3 h3{
	font-size:2.0rem;
	text-align:center;
	margin-bottom:15px;
}

.main .section3 h3 span::before{
	content:"\A";
	white-space:pre;
}

.main .section3 p{
	width:300px;
	margin:0 auto;
}

.main .form_section{
	padding:50px 0;
	background-color:#27a6cf;
}

.main .form_section h3{
	font-size:2.0rem;
	text-align:center;
	margin-bottom:25px;
}

.main .form_section .form_contents{
	width:300px;
	margin:0 auto;
}

.main .form_section .form_contents .email_box{
	width:100%;
	margin-bottom:15px;
}

.main .form_section .form_contents .email_box input[type="email"]{
	width:100%;
	padding-left:1.0rem;
	line-height:40px;
	border:0;
	background-color:#ffffff;
	border-radius:5px;
}

.main .form_section .form_contents .submit_bottun{
	width:120px;
	margin:0 0 25px auto;
}

.main .form_section .form_contents .submit_bottun input[type="submit"]{
	width:100%;
	text-align:center;
	color:#27a6cf;
	font-family: 'Open Sans', sans-serif;
	font-weight:700;
	font-size:1.6rem;
	line-height:40px;
	border:0;
	border-radius:5px;
	background-color:#ffffff;
	text-transform:uppercase;
}

.main .form_section p{
	font-size:1.4rem;
	text-align:center;
}

.main .form_section p span::before{
	content:"\A";
	white-space:pre;
}

.footer{
	padding:50px 0;
	background-color:#ffffff;
	text-align:center;
}

.footer figure{
	margin-bottom:25px;
}

.footer figure img{
	width:60px;
}

.footer .app_store{
	width:180px;
	margin:0 auto 25px;
	line-height:1;
	color:#27a6cf;
	display:-webkit-box;
	display:-ms-flexbox;
	display:flex;
	-webkit-box-pack:justify;
	    -ms-flex-pack:justify;
	        justify-content:space-between;
	-webkit-box-align:center;
	    -ms-flex-align:center;
	        align-items:center;
}

.footer .app_store .app_store_icon{
	font-size:3.6rem;
}

.footer .app_store .app_store_text{
	font-size:1.2rem;
	font-weight:700;
	text-decoration:underline;
	text-underline-offset:1px;
}

.footer .footer_sns_icon{
	width:176px;
	margin:0 auto 25px;
	display:-webkit-box;
	display:-ms-flexbox;
	display:flex;
	-webkit-box-pack:justify;
	    -ms-flex-pack:justify;
	        justify-content:space-between;
}

.footer .footer_sns_icon p{
	width:4.6rem;
	line-height:4.6rem;
	text-align:center;
	border-radius:50%;
}

.footer .footer_sns_icon p a{
	color:#ffffff;
}

.footer .footer_sns_icon .facebook{
	display:block;
	background-color:#3f589a;
}

.footer .footer_sns_icon .twitter{
	display:block;
	background-color:#44b2ff;
}

.footer .footer_sns_icon .googleplus{
	display:block;
	background-color:#e24934;
}

.footer .copyright{
	line-height:1;
}

.footer .copyright small{
	font-size:1.2rem;
}

.footer small span{
	font-weight:700;
	color:#3eb3a0;
}


/*メディアクエリ*/

@media screen and (min-width:769px){
	
	.main .section1 .wrapper > p span::before, .main .section3 h3 span::before, .main .form_section p span::before{
		white-space:nowrap; 
	}
	
	body{
		line-height:1.5;
	}
	
	h1,h2,h3,h4{
		line-height:1.3;
	}
	
	.wrapper{
		width:100%;
		padding:0 30px;
	}
	
	.header{
		padding:64px 0;
	}
	
	.header .wrapper{
		display:-webkit-box;
		display:-ms-flexbox;
		display:flex;
		-webkit-box-pack:justify;
		    -ms-flex-pack:justify;
		        justify-content:space-between;
	}
	
	.header h1{
		width:242px;
		margin:0;
	}
	
	.header .header_sns_icon{
		width:176px;
		text-align:center;
		display:-webkit-box;
		display:-ms-flexbox;
		display:flex;
		-webkit-box-pack:justify;
		    -ms-flex-pack:justify;
		        justify-content:space-between;
		-webkit-box-align:center;
		    -ms-flex-align:center;
		        align-items:center;
	}
	
	.header .header_sns_icon p{
		width:4.6rem;
		line-height:4.6rem;
		border-radius:50%;
	}
	
	.header .header_sns_icon p a{
		color:#ffffff;
	}

	.header .header_sns_icon .facebook{
		display:block;
		background-color:#3f589a;
	}

	.header .header_sns_icon .twitter{
		display:block;
		background-color:#44b2ff;
	}

	.header .header_sns_icon .googleplus{
		display:block;
		background-color:#e24934;
	}
	
	.main .key_visual{
		padding:0;
	}
	
	.main .key_visual .wrapper{
		display:-webkit-box;
		display:-ms-flexbox;
		display:flex;
		-webkit-box-pack:justify;
		    -ms-flex-pack:justify;
		        justify-content:space-between;
	}
	
	.main .key_visual .key_visual_left{
		padding:155px 0;
	}
	
	.main .key_visual .key_visual_left h2{
		font-size:3.6rem;
		letter-spacing:0.03em;
		text-align:left;
		line-height:5.6rem;
		margin-bottom:30px;
	}
	
	.main .key_visual .key_visual_left > p{
		font-size:1.6rem;
		text-align:left;
		line-height:1.8;
		letter-spacing:0.075em;
		margin-bottom:30px;
	}
	
	.main .key_visual .key_visual_left .key_bottun_box{
		width:422px;
		line-height:50px;
		margin:0;
	}
	
	.main .key_visual .key_visual_left .key_bottun_box p{
		width:216px;
		font-size:1.6rem;
	}
	
	.main .key_visual figure{
		width:285px;
		-ms-flex-item-align:end;
		    align-self:flex-end;
	}
	
	.main .key_visual figure img{
		width:100%;
		height:100%;
	}
	
	.main .section1{
		padding:105px 0;
	}
	
	.main .section1 .wrapper h3{
		font-size:2.7rem;
		margin-bottom:20px;
	}
	
	.main .section1 .wrapper > p{
		margin-bottom:85px;
	}
	
	.main .section1 .section1_box{
		display:-webkit-box;
		display:-ms-flexbox;
		display:flex;
		-webkit-box-pack:justify;
		    -ms-flex-pack:justify;
		        justify-content:space-between;
	}
	
	.main .section1 .section1_box section{
		width:31.034%;
		margin-bottom:0;
	}
	
	.main .section1 .section1_box section h4{
		line-height:1.5;
	}
	
	.main .section1 .section1_box section figure{
		margin-bottom:30px;
	}
	
	.main .section1 .section1_box section figure img{
		width:60px;
		height:60px;
	}
	
	.main .section2{
		padding:105px 0;
	}
	
	.main .section2 .wrapper{
		display:-webkit-box;
		display:-ms-flexbox;
		display:flex;
		-webkit-box-pack:justify;
		    -ms-flex-pack:justify;
		        justify-content:space-between;
	}
	
	.main .section2 figure{
		width:405px;
		margin:0;
	}
	
	.main .section2 figure img{
		width:100%;
		height:100%;
	}
	
	.main .section2 .section2_contents{
		width:370px;
		-ms-flex-item-align:center;
		    -ms-grid-row-align:center;
		    align-self:center;
	}
	
	.main .section2 .section2_contents h3{
		text-align:left;
		font-size:2.7rem;
		margin-bottom:20px;
	}
	
	.main .section2 .section2_contents p{
		width:100%;
		margin:0;
		font-size:1.8rem;
	}
	
	.main .section3{
		padding:105px 0;
	}
	
	.main .section3 h3{
		font-size:2.7rem;
		margin-bottom:29px;
	}
	
	.main .section3 p{
		width:88%;
	}
	
	.main .form_section{
		padding:105px 0;
	}
	
	.main .form_section h3{
		font-size:2.7rem;
		margin-bottom:40px;
	}
	
	.main .form_section .form_contents{
		width:540px;
		margin-bottom:30px;
		display:-webkit-box;
		display:-ms-flexbox;
		display:flex;
		-webkit-box-pack:justify;
		    -ms-flex-pack:justify;
		        justify-content:space-between;
	}
	
	.main .form_section .form_contents .email_box{
		width:373px;
		margin:0;
	}
	
	.main .form_section .form_contents .email_box input[type="email"]{
		line-height:50px;
		font-size:1.6rem;
	}
	
	.main .form_section .form_contents .submit_bottun{
		width:150px;
		margin:0;
	}
	
	.main .form_section .form_contents .submit_bottun input[type="submit"]{
		font-size:2.0rem;
		line-height:50px;
	}
	
	.main .form_section p{
		font-size:1.6rem;
	}
	
	.footer{
		padding:85px 0;
	}
	
	.footer .wrapper{
		display:-webkit-box;
		display:-ms-flexbox;
		display:flex;
		-webkit-box-pack:justify;
		    -ms-flex-pack:justify;
		        justify-content:space-between;
		-webkit-box-align:center;
		    -ms-flex-align:center;
		        align-items:center;
	}
	
	.footer figure, .footer .app_store, .footer .footer_sns_icon, .footer small{
		margin:0;
	}
	
	.footer figure{
		width:60px;
	}
	
	.footer .footer_sns_icon{
		-webkit-box-ordinal-group:2;
		    -ms-flex-order:1;
		        order:1;
	}
	
}

/*メディアクエリ*/

@media screen and (min-width:931px){
	
	.wrapper{
		width:930px;
		padding:0 30px;
		margin:0 auto;
	}
	
}