@charset "utf-8";

/*
@media screen and (max-width: 599px){} phone-only
@media screen and (min-width: 600px){} tablet-portrait-up
@media screen and (min-width: 900px){} tablet-landscape-up
@media screen and (min-width: 1200px){} desktop-up
@media screen and (min-width: 1800px){} big-desktop-up
*/

@font-face {
	font-family: number;
	src: local('Helvetica');
	unicode-range: U+0021-003F;
}

:root {
	--key-font-color:#333;
	--key-font-link-color:#666;
	--key-font-hover-color:#990000;
	--key-font-reverse-color:#fff;
	--form-key-color:#ccc;
	--common-font-sans-serif:-apple-system, BlinkMacSystemFont,'Helvetica', sans-serif;
	--common-font-serif:number,'Sorts Mill Goudy', 'Noto Serif JP', "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
	--form-common-fontsize:1.0rem;
	--form-bacesmall-fontsize:1.4rem;
	--form-bace-fontsize:2.0rem;
	--common-blankspace:20px;
	--common-margin:calc(20px/2);
	--common-margin-x2:calc(40px/2);
	--common-margin-x3:calc(60px/2);
	--common-margin-x4:calc(80px/2);
	--common-margin-x5:calc(100px/2);
}

@media screen and (min-width: 900px){
	:root {
		--form-bacesmall-fontsize:1.8rem;
		--form-bace-fontsize:2.4rem;
		--common-blankspace:50px;
		--common-margin:20px;
		--common-margin-x2:40px;
		--common-margin-x3:60px;
		--common-margin-x4:80px;
		--common-margin-x5:100px;
	}
}

/*
var(--key-******)
calc(var(--common-******) * 1.5)
*/

@font-face { font-family: "Yu Gothic"; src: local("Yu Gothic Medium"); font-weight: 100; }
@font-face { font-family: "Yu Gothic"; src: local("Yu Gothic Medium"); font-weight: 200; }
@font-face { font-family: "Yu Gothic"; src: local("Yu Gothic Medium"); font-weight: 300; }
@font-face { font-family: "Yu Gothic"; src: local("Yu Gothic Medium"); font-weight: 400; }
@font-face { font-family: "Yu Gothic"; src: local("Yu Gothic Bold"); font-weight: bold; }
@font-face { font-family: "Helvetica Neue"; src: local("Helvetica Neue Regular"); font-weight: 100; }
@font-face { font-family: "Helvetica Neue"; src: local("Helvetica Neue Regular"); font-weight: 200; }

*{ margin:0; 	padding:0; 	border:0; }
*, *:after, *:before { -webkit-box-sizing: border-box; -moz-box-sizing: border-box; -ms-box-sizing: border-box; box-sizing: border-box; }
html,body { height: 100%; }
html { font-size: 62.5%; }
body{ width:100%; font-family:-apple-system, BlinkMacSystemFont,'Helvetica Neue',"游ゴシック", YuGothic,"ヒラギノ角ゴ ProN W3","Hiragino Kaku Gothic ProN", sans-serif; font-size:10px; font-size:1.0rem; line-height:1.6; color: var(--key-font-color); background-color:#fff; position: relative; left: 0; overflow-x: hidden; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; font-feature-settings: "palt" 1, "trad" 0;}
.font-serif{ font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; }

/*  */

a{ 	outline:none; 	-webkit-transition: all 0.3s ease; 	-moz-transition: all 0.3s ease; 	-o-transition: all 0.3s ease; 	transition: all  0.3s ease; }

a:link{color: var(--key-font-link-color);}
a:visited{color: var(--key-font-link-color);}
a:hover{color: var(--key-font-hover-color);}
a:active{color: var(--key-font-hover-color);}

::selection { background:var(--key-font-color); color:var(--key-font-reverse-color); text-shadow: none; }
::-moz-selection { background:var(--key-font-color); color:var(--key-font-reverse-color); text-shadow: none; }

a:link,a:visited,a:active{text-decoration:none;}
a:hover, a:active { outline: 0; text-decoration: underline; cursor: pointer;}
a:focus { outline:none; }
a img{border:none;text-decoration:none;}

a.fit { display: block; width: 100%; height: 100%; }

/* */

body{
	font-size: 16px;
}

/*  */

h1{font-size:2.4rem;}
h2{font-size:1.8rem;}
h3{font-size:1.4rem;}
h4{font-size:1.4rem;}
h5{font-size:1.2rem;}
h6{font-size:1.2rem;}

@media screen and (min-width: 768px){
	h1{font-size:3.6rem;}
	h2{font-size:3.0rem;}
	h3{font-size:2.4rem;}
	h4{font-size:1.8rem;}
	h5{font-size:1.4rem;}
	h6{font-size:1.2rem;}
}

h1,h2,h3,h4,h5,h6{
	margin: 0;
	margin-bottom: var(--common-blankspace);
	padding: 0;
}

/*  */

li{
	list-style-type: none;
}

/*  */

img{ width: 100%; max-width: 100%; height: auto; vertical-align:top;}
.img-responsive-overwrite { margin: 0 auto; }

figure { -webkit-margin-before: 0 !important; 	-webkit-margin-after: 0 !important; 	-webkit-margin-start: 0 !important; 	-webkit-margin-end: 0 !important; }

/* */

header{
	position: relative;
	width: 100%;
	text-align: center;
	padding: 15px;
	display: flex;
	justify-content:space-between;
	align-items:center;
	gap: 0 15px;
}

#logo{

}
@media screen and (min-width: 900px){
	#logo{
		width: 360px;
	}
}

/*  */

article{
	width: 100%;
	margin: 0;
	margin-bottom: calc(var(--common-blankspace) * 2);
	text-align: center;
}

.no-margin{
	margin-bottom: 0;
}

article > section{
	width:90%;
	max-width: 780px;
	margin: 0 auto;
	text-align: left;
}

article > section h1{
	width: 80%;
	margin-left: auto;
	margin-right: auto;
}
@media screen and (min-width: 900px){
	article > section h1{
		width: 50%;
	}
}

article > section div,
article > section p,
article > section ul{
	margin-bottom: var(--common-blankspace);
}

/*  */

@media screen and (max-width: 899px){
	.standard{ background-image: url(../img/sp.jpg); }
	.okinawa{ background-image: url(../img/okinawa-sp.png); }
	.shizuoka{ background-image: url(../img/shizuoka-sp.png); }
	.ibaraki{ background-image: url(../img/ibaraki-sp.png); }
	article#fv{
		width: 100%;
		aspect-ratio: 1 / 1;
		background-color: transparent;
		background-repeat: no-repeat;
		background-position: center;
		background-size: cover;
		margin-bottom: 0;
	}
	
	article#fv section{
		width:90%;
		max-width: 780px;
		height: 100%;
		margin: 0 auto;
		text-align: left;
		position: relative;
	}
	#fv-1{
		width: 170px;
		position: absolute;
		top:20px;
		left: 0;
	}
	#fv-2{
		width: 140px;
		position: absolute;
		top:0;
		right: 0;
	}
	#fv-box{
		width: 100%;
		position: absolute;
		top:280px;
		left: 0;
	}
	#fv-3{
		margin-bottom: 0;
	}
	#fv-4{
		width: 25%;
		margin: 0 auto;
	}
	#fv-5{
		margin-bottom: 0;
	}
}
@media screen and (min-width: 900px){
	.standard{ background-image: url(../img/pc.jpg); }
	.okinawa{ background-image: url(../img/okinawa-pc.png); }
	.shizuoka{ background-image: url(../img/shizuoka-pc.png); }
	.ibaraki{ background-image: url(../img/ibaraki-pc.png); }
	article#fv{
		width: 100%;
		aspect-ratio: 16 / 10;
		background-color: transparent;
		background-repeat: no-repeat;
		background-position: center;
		background-size: cover;
		position: relative;
		margin-bottom: 0;
	}
	
	article#fv section{
		width:90%;
		max-width: 640px;
		margin: 0 auto;
		padding-top: var(--common-blankspace);
		text-align: left;
	}
	
	#fv-1{
		width: 360px;
		position: absolute;
		top:20px;
		left: 0;
	}
	#fv-2{
		width: 300px;
		position: absolute;
		top:0;
		right: 0;
	}
	#fv-box{
		width: 100%;
		height: 200px;
		position: absolute;
		bottom:-100px;
		left: 0;
		display: flex;
		flex-direction:row;
		flex-wrap:nowrap;
		justify-content:space-between;
		align-items:center;
		align-content:center;
	}
	#fv-3{
		flex: 0 1 44%;
	}
	#fv-4{
		flex: 0 1 10%;
	}
	#fv-5{
		flex: 0 1 44%;
	}
}

/*  */

#s0{
	padding: calc(var(--common-blankspace) * 2) 0;
	background-color: #D7F8FC;
	text-align: center;
}

#s0 section{
	width: 90%;
	max-width: 480px;
	margin: 0 auto;
}

#work-title{
	width: 100%;
}
#work-img{

}
#work-btn{
	max-width: 387px;
	margin: 0 auto;
}

/*  */

article.contact-block{
	border-top: dotted 2px #0AA0B1;
	border-bottom: dotted 2px #0AA0B1;
	background: url(../img/contact-bg.png) 0 0 repeat;
}
article.contact-block section{
	max-width: 320px;
}

article.contact-block section h1,
article.contact-block section div{
	margin-bottom: calc(var(--common-blankspace)/2);
}

article.contact-block section h1,
article.contact-block section h1 img{
	width:100%;
	max-width:100%;
}

article.contact-block section h1.contact-2{
	width:50%;
	max-width:50%;
	margin-top: calc(var(--common-blankspace)* -1);
}

article.contact-block ul{
	width:90%;
	max-width: 780px;
	margin: 0 auto;
	text-align: left;
	margin-bottom: var(--common-blankspace);
}
article.contact-block ul li{
	display: block;
}
article.contact-block ul li img{
	width: 100%;
}
@media screen and (min-width: 900px){
	article.contact-block ul li{
		display: inline;
	}

	article.contact-block ul li img{
		width: 49%;
	}
}
/*  */

article#s2 section .s2-title{
	text-align: center;
}
article#s2 section .s2-title img{
	width:50%;
	max-width:50%;
}
article#s2 section .yb{
	display: block;
	margin-bottom:var(--common-blankspace);
}

.yb {
	width: 100%;
	aspect-ratio: 16 / 9;
  }
  .yb iframe {
	width: 100%;
	height: 100%;
  }

article#s2 section .s2-check{
	padding-left: 40px;
	background: url(../img/s2-check.png) 0 5px no-repeat;
	background-size: 30px;
	font-weight: 700;
	font-size: var(--form-bace-fontsize);
}

article#s2 section p + p + p{
	margin-bottom:calc(var(--common-blankspace)* 2);
}

article#s2 section p:last-child{
	margin-bottom: calc(var(--common-blankspace)* 2);
}

/*  */

article#s3{}
article#s3 section{}

.s3-title{
	text-align: center;
}
.s3-title img{
	width:80%;
	max-width:80%;
}
@media screen and (min-width: 900px){
	.s3-title img{
		width:50%;
		max-width:50%;
	}
}
.text{
	font-size: var(--form-bace-fontsize);
	font-weight: 700;
}
.memo{

}

/*  */

article#option{
	padding: 5vw 0;
	background-size: auto auto;
background-color: rgba(255, 255, 255, 1);
background-image: repeating-linear-gradient(135deg, transparent, transparent 10px, rgba(112, 206, 218, 1) 10px, rgba(112, 206, 218, 1) 20px );
}
article#option section{
	background-color: #fff;
	padding:var(--common-blankspace);
}
@media screen and (min-width: 900px){
	article#option{
		padding: calc(var(--common-blankspace)* 2);
	}
}

/*  */

article#confidence{
	width: 100%;
	aspect-ratio: 255 / 89;
	position: relative;
}

article#confidence section{
	width: 100%;
	max-width: 100%;
}

article#confidence section #confidence-2{
	margin-top: calc(var(--common-blankspace)* -2);
	width: 90%;
}

@media screen and (min-width: 900px){
	article#confidence section #confidence-2{
		margin-top: 0;
		width: 50%;
	}
}

/*  */

article#s4 section ul{}

article#s4 section ul li{
	min-height: 100px;
	font-weight: 700;
	font-size: var(--form-bace-fontsize);
	margin-bottom: calc(var(--common-blankspace)/2) ;
	padding-left: 70px;
}

article#s4 section ul li:nth-child(1){
	background: transparent url(../img/s4-1.png) no-repeat 0 0 / 50px;
}
article#s4 section ul li:nth-child(2){
	background: transparent url(../img/s4-2.png) no-repeat 0 0 / 50px;
}
article#s4 section ul li:nth-child(3){
	background: transparent url(../img/s4-3.png) no-repeat 0 0 / 50px;
}
article#s4 section ul li:nth-child(4){
	background: transparent url(../img/s4-4.png) no-repeat 0 0 / 50px;
}

@media screen and (min-width: 900px){
	article#s4 section ul li:nth-child(1){
		background: transparent url(../img/s4-1.png) no-repeat 0 0 / 100px;
	}
	article#s4 section ul li:nth-child(2){
		background: transparent url(../img/s4-2.png) no-repeat 0 0 / 100px;
	}
	article#s4 section ul li:nth-child(3){
		background: transparent url(../img/s4-3.png) no-repeat 0 0 / 100px;
	}
	article#s4 section ul li:nth-child(4){
		background: transparent url(../img/s4-4.png) no-repeat 0 0 / 100px;
	}
}



article#s4 section ul li span{
	display: block;
}
article#s4 section ul li em{
	font-style: normal;
	background:linear-gradient(transparent 60%, #FFF16C 60%);
}
article#s4 section ul li small{
	display: block;
	font-size: var(--form-bacesmall-fontsize);
	color: #999999;
}
article#s4 section ul li:after {
	content: "";
	display: block;
	clear: both;
} 

/*  */

article#s5 section ul{
	display: flex;
	flex-wrap:wrap;
	gap: 0 10px;
}
article#s5 section ul li{
	flex: 0 1 calc(50% - 5px);
}
article#s5 section ul img{
	margin-bottom: calc(var(--common-blankspace)/2);
}
article#s5 section ul li p{
	font-size: var(--form-bacesmall-fontsize);
}

/*  */

article#s6 section{}
article#s6 ul{

}

article#s6 li{
	padding: calc(var(--common-blankspace)/2);
}
article#s6 li:nth-child(2n+1){
	background-color: #F4F4F4;
	font-weight: 700;
}
article#s6 li:nth-child(3),
article#s6 li:nth-child(7),
article#s6 li:nth-child(11),
article#s6 li:nth-child(15),
article#s6 li:nth-child(19){
	background-color: #FCF6EB;
}

article#s6 li span{
	display: block;
	width:90%;
	max-width: 780px;
	margin: 0 auto
	;
	text-align: left;
	vertical-align: middle;
}

article#s6 li small{
	display: block;
}

article#s6 li:nth-child(2n+1) span{
	min-height: 35px;
	display: block;
	background-image: url(../img/s6-1.png);
	background-size: 30px 35px;
	background-repeat: no-repeat;
	padding-left: 50px;
}

article#s6 li:nth-child(2n) span{
	min-height: 35px;
	display: block;
	background-image: url(../img/s6-2.png);
	background-size: 30px 35px;
	background-repeat: no-repeat;
	padding-left: 50px;
}

/*  */

aside{
	width:90%;
	max-width: 780px;
	margin: 0 auto;
	padding: var(--common-blankspace) 0;
}

aside #link{
	margin-bottom: var(--common-blankspace);
}
aside #link-title{
	width: 80px;
	margin: 0 auto;
}

aside ul{
	list-style-type: none;
	display: flex;
	flex-wrap:wrap;
	justify-content:center;
}
aside li{
	flex:0 1 49%;
	text-align: center;
	padding: 10px;
	border: solid 1px #ccc;
}
aside li a{
	text-decoration: none;
	width: 100%;
	display: block;
	padding: 10px;
	vertical-align: middle;
	line-height: 1.0;
}
aside li a:hover{
	text-decoration: none;
}
.icon{
	width: 16px;
}
footer{
	width:90%;
	max-width: 780px;
	margin: 0 auto;
	padding: var(--common-blankspace) 0 250px;
}
footer p{
	text-align: center;
	font-size: 10px;
}

#btn-fix{
	width: 100%;
	padding: 20px;
	background-color: #FDF8C6;
	position: fixed;
	bottom: 0;
}
#btn-fix span{
	max-width: 480px;
	display: flex;
	justify-content:space-between;
	align-items:center;
	align-content:center;
	margin: 0 auto;
}
#btn-fix div{
	flex: 0 1 32%;
}

#btn-1,
#btn-2,
#btn-3{
	display: block;
}
#btn-4{
	display: none;
}

@media screen and (min-width: 900px){
	#btn-fix span{
		justify-content:center;
	}
	#btn-1,
	#btn-2,
	#btn-3{
		display: none;
	}
	#btn-4{
		display: block;
	}
	#btn-fix div#btn-4{
		flex: 0 1 50%;
	}
}

