*{margin:0;padding:0;box-sizing: border-box;}
html{margin:0;padding:0;}
header, footer, aside, nav, section,article,time,figure,label{display: block;}
h1,h2,h3,h4,h5{font-weight:normal;}
ul,ol{list-style:none;}
a{outline:none;text-decoration:none;}
a img{border:0;}
img{width:100%;display:block;}
fieldset{border:0;}
.clear{margin:0;padding:0;height:0;clear:both;}
body{margin:0;padding:0;font-size:21px;background:#f0f0f0;color:#666;font-family:sans-serif;-webkit-text-size-adjust:100%;}
.wrap{background-image:url(../images/bg.jpg);background-size:contain;}

@media screen and (min-width: 751px) {
.wrap{margin:auto;width:750px;background:#fff;}
}
@media screen and (max-width: 750px) {
.wrap{width:100%;background:#fff;}
}

/*Header
--------------------------------------------------------------------------------------------------------------*/
header h1 {line-height:50px;}
header h1 a {display:block; width:100%; height:100%; text-indent: 120%; overflow: hidden; white-space: nowrap;}
header.logo-3ban h1 a {background:url(../images/logo-3ban.png) no-repeat center center; background-size:contain;}
header.logo-4ban h1 a {background:url(../images/logo-4ban.png) no-repeat center center; background-size:contain;}
header.logo-5ban h1 a {background:url(../images/logo-5ban.png) no-repeat center center; background-size:contain;}
header.logo-6ban h1 a {background:url(../images/logo-6ban.png) no-repeat center center; background-size:contain;}
header.logo-7ban h1 a {background:url(../images/logo-7ban.png) no-repeat center center; background-size:contain;}
header.logo-8ban h1 a {background:url(../images/logo-8ban.png) no-repeat center center; background-size:contain;}
/*Main
--------------------------------------------------------------------------------------------------------------*/
#top {width:100%; height:0; padding-top:93%; background:url(../images/top_img.jpg) no-repeat 0 0; background-size:cover;}
#top h2,article#top p {display:none;}

article h2 img {display:block; width: 100%; height:auto;}
#a01 ul {padding:0 2% 2%; width:100%; box-sizing: border-box;}
#a01 ul li {float:left; width:32%; margin-right:2%; transition: .5s;}
#a01 ul li:nth-of-type(3) {margin-right:0;}
.s_scroll {opacity:0; margin-top: 50px;}

#a02 { position:relative;}
.phone {width:55%; height:0; padding-top:99%; margin:5% auto; background:url(../images/phone.png) no-repeat center center; background-size:contain;}
.movie {position:absolute; top: 10%; left: 29%; width: 42%; height: 59%; background:url(../images/main03.gif) no-repeat center center; background-size:cover; transform: rotate(6deg);}
#a02 ul li { width:35%;position:absolute;  transition: .5s;}
#a02 ul li img {width:100%; height: auto;}
#a02 ul li:nth-of-type(1) {top:8%; left:5%;}
#a02 ul li:nth-of-type(2) {top:20%; right:5%;}
#a02 ul li:nth-of-type(3) {top:43%; left:5%;}
#a02 ul li:nth-of-type(4) {top:55%; right:5%;}

.reg_btn {width:100%; height:0; padding-top:29%; position:relative; background:url(../images/reg_btn.png) no-repeat 0 0; background-size:contain; margin:0 auto 5%;}
.reg_btn a {display:block; width:100%; height:100%; text-indent:120%; overflow: hidden; white-space: nowrap;position:absolute; top:0; left:0;}

#a03 {background:url(../images/girl_bg.jpg) no-repeat center bottom; background-size:contain;}
#a03 ul {position:relative; width:100%; height:0; padding-top:140%;}
#a03 ul li {width:100%; position:absolute; left:0; transition: .5s;}
#a03 ul li img {width:100%; height:auto;}
#a03 ul li:nth-of-type(1) {top:0; }
#a03 ul li:nth-of-type(2) {top:31%; }
#a03 ul li:nth-of-type(3) {top:64%; }

#a04 {padding:5% 0;}

/*Form
--------------------------------------------------------------------------------------------------------------*/
.form{background:#f5f5f5;}
.form .heading{padding:0;overflow:hidden;border-bottom:1px solid #eee;}
.form .heading h1{padding:0 10px;height:40px;line-height:40px;font-size:16px;overflow:hidden;background:#f69;color:#fff;}

.form header h2{padding:0 10px;height:40px;line-height:40px;background:#fda900;color:#000;font-size:14px;}

.form fieldset{padding:10px 10px 0 10px;position:relative;}
.form fieldset label{width:120px;height:40px;line-height:40px;background:#666;color:#fff;text-align:center;position:absolute;top:15px;left:10px;}
.form fieldset p{padding:5px 0 0 120px;}
.form .error{margin:5px 0 0 0;padding:5px;text-align:center;background:#ffe5e5;color:#f33;}
.form input[type="text"],.form input[type="password"],.form textarea,.form select
{padding:10px;width:100%;font-size:14px;line-height:18px;color:#666;border:1px solid #ddd;-webkit-appearance:none;border-radius:0;}
.form textarea{height:120px;}
.form select{background:url(../images/icon_select.png) no-repeat right #fff;background-size:40px 40px;}
.form p span{padding:10px;line-height:20px;float:left;}
.regular-radio{display:none;}
.form fieldset p .regular-radio + label{margin:2px 5px;padding:10px;width:36px;height:36px;line-height:0;border-radius:50%;-webkit-appearance:none;background-color:#fafafa;border:1px solid #ddd;display:inline-block;position:relative;float:left;top:0;left:0;}
.regular-radio:checked + label:after{content:' ';width:20px;height:20px;border-radius:50%;position:absolute;top:7px;left:7px;background:#99a1a7;}
.entery_btn{padding:10px;}
.entery_btn button{width:100%;height:60px;line-height:60px;text-align:center;border:0;background:#f69;color:#fff;background-image:linear-gradient(rgba(255,255,255,0.1),rgba(255,255,255,0));font-size:16px;}

.form .msg,.alert{padding:10px;text-wrap:suppress;}
.form p a{color:#ff3c81;}
.form input[type="text"].qtr{width:50%;float:left;}
.entery_btn p{padding:0 0 10px 0;}

#sa h3{padding:10px;}
#sa .form p span{float:none; padding:0;}

.juyo { background:rgba(255,0,0,0.1); border:1px dotted #f00 !important; padding:8px !important; box-sizing:border-box; margin:10px;}
.form .msg span,.form .juyo span{float:none; padding:0;}
.form .juyo{margin:10px 10px 0;}
/*--------------------------------
Footer
--------------------------------*/
.footer{
	padding: 4%;
	text-align: center;
	background: #ff4787;
	color: #fff;
}
.gnav-list{
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
}
.gnav-item{
	width: 33%;
	text-align: center;
}
.nav-link{
	padding: 4% 0;
	color: #fff;
	display: block;
	font-size: .9em;
	text-decoration: underline;
}
.copy{
	padding: 4% 0;
	font-size: .9em;
	line-height: 1.2;
}
/*mother
--------------------------------------------------------------------------------------------------------------*/
#mother h1 {text-indent:120%; overflow:hidden; white-space:nowrap;}

/* karamail button */
#mailButton li{display:block; width:50%; float:left;}
#mailButton li a{display:block; text-align:center; font-size:180%; padding:15px 0; text-decoration:none; color:#fff; font-weight:bold; border:1px solid #ccc;}
#mailButton li.male a{border-radius:10px 0 0 10px; -webkit-border-radius:10px 0 0 10px; -moz-border-radius:10px 0 0 10px; border-color:#006cff; text-shadow:0 -1px 1px #006cff;
background: -webkit-gradient(linear, left top, left bottom, from(#5d93ff), color-stop(0.49, #117cff), color-stop(0.5, #026dc7), to(#004c8d) );
background: -moz-linear-gradient(top, #5d93ff, #117cff 49%, #026dc7 50%, #004c8d);}
#mailButton li.female a{border-radius:0 10px 10px 0; -webkit-border-radius:0 10px 10px 0; -moz-border-radius:0 10px 10px 0; border-color:#fd1a5a; text-shadow:0 -1px 1px #fd1a5a;
background: -webkit-gradient(linear, left top, left bottom, from(#ff8ca7), color-stop(0.49, #ff577f), color-stop(0.5, #ff3363), to(#ff0c45) );
background: -moz-linear-gradient(top, #ff8ca7, #ff577f 49%, #ff3363 50%, #ff0c45);}
#mailButton li.male a:hover,#mailButton li.male a:active{border-color:#006cff; text-shadow:0 -1px 1px #107cff;
background: -webkit-gradient(linear, left top, left bottom, from(#6da3ff), color-stop(0.49, #218cff), color-stop(0.5, #127dd7), to(#105c9d) );
background: -moz-linear-gradient(top, #6da3ff, #218cff 49%, #127dd7 50%, #105c9d);}
#mailButton li.female a:hover,#mailButton li.female a:active{border-color:#fd1a5a; text-shadow:0 -1px 1px #ff2a6a;
background: -webkit-gradient(linear, left top, left bottom, from(#ff9cb7), color-stop(0.49, #ff678f), color-stop(0.5, #ff4373), to(#ff1c55) );
background: -moz-linear-gradient(top, #ff9cb7, #ff678f 49%, #ff4373 50%, #ff1c55);}
#mailButton li.single-btn{
	width: 90%;
	margin:0 auto;
	float: none;
}
#mailButton li.single-btn a{
	background: #f69;
}

.lpprtitle{
display: block;
background: #835523;
color: #fff;
font-weight: bold;
padding: 7px;
-box-shadow: 0 1px 1px rgba(255, 255, 255, 0.1) inset, 0 -1px 1px rgba(0, 0, 0, 0.2) inset;
-webkit-box-shadow: 0 1px 1px rgba(255, 255, 255, 0.1) inset, 0 -1px 1px rgba(0, 0, 0, 0.2) inset;
-moz-box-shadow: 0 1px 1px rgba(255, 255, 255, 0.1) inset, 0 -1px 1px rgba(0, 0, 0, 0.2) inset;
}

#lppr a{
display:block;
background:#fdf6e4;
border-bottom:1px solid #7d3a0e;
padding:7px;
font-size:14px;
text-decoration:none;
color:#7d3a0e;
}

.clearfix:after {
    content:" ";
    display:block;
    clear:both;
}

/*--------------------------------
Header
--------------------------------*/
.sub-top{
	position: relative;
	text-align: center;
	background: url(../images/bg_content.webp) no-repeat center top / cover;
}
.sub-top .logo{
	padding: 0;
	height: 120px;
}
.logo-link{
	padding: 4%;
	height: 120px;
	display: block;
}

.content-img{
	width: 100%;
	height: 100%;
	object-fit: contain;
}
.content01{
	padding:0 4% 4%;
	background: url(../images/bg_content.webp) no-repeat center top / cover;
}
.btn-row{
	padding: 4%;
}
.content-head{
	padding: 4% 0;
}
.general .heading{
	margin: 4% 0;
	text-align: center;
}
.general .heading-txt{
	position: relative;
	font-weight: bold;
}
.general-item{
	padding: 0 0 8%;
}
.general .general-item{
	padding: 0 8% 8%;
}
.sub-head,.general-item h3{
	margin: 0 0 4%;
	padding: 2% 0;
	color: #ff4787;
	font-size: 1.1em;
	font-weight: bold;
	border-bottom: 4px solid #ddd;
}
.general-item h4{
	margin: 0 0 4%;
	padding: 2% 0;
	color: #7ecef4;
	font-size: 1.1em;
}
.general-txt{
	padding: 0 0 4%;
	font-size: 1em;
	line-height: 1.8;
}
.general .general-txt, .general .general-item p{
	font-size: .9em;
	line-height: 1.8;
}
.hl-txt{
	color: #ffcc00;
}
.wrap .lpprtitle{
	margin: 10px;
}
@media screen and (max-width:767px) {
	/*--------------------------------
	global element
	--------------------------------*/
	body{
		font-size: 16px;
	}
	/*--------------------------------
	Header
	--------------------------------*/
	.sub-top .logo{
		height: 80px;
	}
	.logo-link{
		height: 80px;
	}
	/*--------------------------------
	Contents
	--------------------------------*/
	/*--------------------------------
	Button
	--------------------------------*/
	/*--------------------------------
	Footer
	--------------------------------*/
	.footer{
		padding: 4% 0;
	}
	.gnav-item{
		width: 100%;
		border-bottom: 1px solid rgba(0,0,0,.1);
	}
	.nav-link{
		padding: 4% 0;
	}
	.copy{
		padding: 4% 0;
		font-size: .8em;
	}
}
@media screen and (max-width:320px) {
	/*--------------------------------
	global element
	--------------------------------*/
	body{
		font-size: 14px;
	}
}