*{margin:0;padding:0;box-sizing: border-box;}
html{margin:0;padding:0;height:100%;}
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;}
fieldset{border:0;}
.clear{margin:0;padding:0;height:0;clear:both;}
body {margin:0;padding:0;font-size:12px;background:#fff;color:#666;background-size: cover;font-family:sans-serif;}
/*Header
--------------------------------------------------------------------------------------------------------------*/
#top{width:100%;overflow:hidden;}
#top h1{height:44px;background-repeat:no-repeat;background-position:center top;background-size:275px 40px;overflow:hidden;}
#top h1 span{padding:44px 0 0 0;display:block;}
.logo{background-image:url(../images/logo.png);}
.logo-3ban{background-image:url(../images/logo-3ban.png);}
.logo-4ban{background-image:url(../images/logo-4ban.png);}
.logo-5ban{background-image:url(../images/logo-5ban.png);}
.logo-6ban{background-image:url(../images/logo-6ban.png);}
.logo-7ban{background-image:url(../images/logo-7ban.png);}
.logo-8ban{background-image:url(../images/logo-8ban.png);}
.logo-10ban{background-image:url(../images/logo-10ban.png);}
.logo-11ban{background-image:url(../images/logo-11ban.png);}

/*RegButton
--------------------------------------------------------------------------------------------------------------*/
.reg_btn{padding:10px;text-align:center;clear:both;background:rgba(255,255,255,0.9);}
.reg_btn a{margin:0 auto;width:300px;height:44px;display:block;background:url(../images/btn_regbtn.png) no-repeat 0 0 #600;background-size:300px 44px;overflow:hidden;}
.reg_btn a span{padding:44px 0 0 0;display:block;}
.fixed {position: fixed;top:0;width: 100%;z-index: 10000;}

.reg_btn_n {padding:15px 10px 25px;background:#ddd;}
.reg_btn_n p {text-align: center; font-size:13px; margin-bottom:5px;}
.reg_btn_n a {display:block; width:100%; height:0; padding-top:16%; background:url(../images/regbtn02.png) no-repeat 0 0; background-size:cover; border-radius: 5px; box-shadow: 0 3px 0 0 #a43c00; text-indent: 120%; overflow: hidden; white-space: nowrap;}

/*Main
--------------------------------------------------------------------------------------------------------------*/
.contents{margin:0;padding:0; position:relative;}
.contents article img{width:100%;display:block;}
.rewrap .contents article p {font-size:14px; line-height:1.6em; color:#444;}

.intro{width:100%;height:128px;position:relative;}
.intro li{width:100%;text-align:center;}
.intro img{margin:0 auto;width:320px;}
.intro_sub{padding:10px 0;background:#900;}
.intro_sub img{width:100%;}
.award{padding:10px 0;background:#600;}
.award img{width:100%; display:block; max-width: 320px; margin:0 auto;}

.rewrap .intro_sub p {margin:10px; text-align: center; color:#fff; font-family:HiraMinProN-W6,"HG明朝E",serif; font-weight:bold; font-size:14px;}
.rewrap .intro_sub img {display: block; max-width:320px; margin:0 auto;}

figure.intro_img img{width:100%; display: block;}

.heading{padding:0 0 10px 0;}
.heading h1{height:60px;overflow:hidden;background-image:url(../images/bg_heading.jpg);background-repeat:no-repeat;background-size:320px 420px;border-bottom:1px solid #ddd;}
.heading h1 span{padding:60px 0 0 0;display:block;}
.hd_01{background-position:0 0;}
.hd_02{background-position:0 -60px;}
.hd_03{background-position:0 -120px;}
.hd_04{background-position:0 -180px;}
.hd_05{background-position:0 -240px;}
.hd_06{background-position:0 -300px;}
.hd_07{background-position:0 -360px;}

.sub_heading{padding:0 0 20px 0;}
.sub_heading h1{height:30px;line-height:30px;overflow:hidden;background-repeat:no-repeat;background-image:url(../images/bg_subheading.png);background-size:470px 120px;}
.sub_heading h1 span{padding:30px 0 0 0;display:block;}
.subhd_01{background-position:0 0;}
.subhd_02{background-position:0 -30px;}
.subhd_03{background-position:10px -60px;}
.subhd_04{background-position:10px -90px;}

.rewrap .sub_heading {padding:10px 0 15px ;}

.main{background:url(../images/bg_main.jpg) no-repeat center -240px;background-size:cover;}
.main article p{padding:0 10px 10px 10px;line-height:20px;}
.main article p span{font-size:20px;color:#333;}
.main article figure{padding:0 0 20px 0;}
.main article figure img{display:block;}


.about article{padding:10px;}
.about article p{padding:110px 0 0 0;}
.about_01{background:url(../images/bg_about01.jpg) no-repeat 0 40px;background-size:310px 120px;}
.about_02{background:url(../images/bg_about02.jpg) no-repeat 0 40px;background-size:310px 120px;}

.rewrap .about article {background-size:contain !important;}
.rewrap .about article p {padding:38% 0 0 0 ;}

.prof article{margin:0;padding:10px;border-bottom:1px solid #ddd;position:relative;}
.prof article:nth-child(even){float:left;}
.prof article:nth-child(odd){float:right;}
.prof article figure{width:120px;height:120px;background-position:center;position:absolute;top:10px;left:10px;background-size:cover;overflow:hidden;border-radius:8px;}
.prof article dl{padding:0 0 10px 130px;line-height:25px;}
.prof article dt{width:40%;float:left;text-align:center;color:#999;font-size:12px;border-bottom:1px solid #bbb;}
.prof article dd{width:60%;float:left;text-align:center;border-bottom:1px solid #ddd;}
.prof article p{padding:10px 0 0 0;clear:both;}
.prof article footer{padding:10px 0;}
.prof article footer a{width:100%;height:44px;display:block;overflow:hidden;background:url(../images/btn_prof2.png) no-repeat center top #000;background-size:300px 44px;}
.prof article footer a span{padding:44px 0 0 0;display:block;}

.circle article{margin:0;padding:10px;border-bottom:1px solid #ddd;position:relative;text-align:center;}
.circle article figure{margin:0 auto;width:100%;height:140px;background-position:center;background-size:cover;overflow:hidden;border-radius:8px;}
.circle article dl{padding:10px 0 0 0;width:100%;line-height:25px;text-align:center;}
.circle article dt{width:40%;float:left;color:#999;border-bottom:1px solid #bbb;}
.circle article dd{width:60%;float:left;text-align:center;border-bottom:1px solid #ddd;}
.circle article p{padding:10px 0;clear:both;text-align:left;}
.circle article footer{padding:10px 0;}
.circle article footer a{width:100%;height:44px;display:block;overflow:hidden;background:url(../images/btn_circle.png) no-repeat center top #000;background-size:300px 44px;}
.circle article footer a span{padding:44px 0 0 0;display:block;}

.data article{padding:0 10px;text-align:center;}
.data article figure{margin:0 auto;width:280px;height:280px;background-position:center;background-size:cover;overflow:hidden;border-radius:8px;}
.data article header{padding:10px 0;line-height:20px;font-size:14px;text-align:left;}
.data article p{padding:0 0 10px 0;text-align:left;}

.rewrap .data article header {color:#0e4944; padding:10px 0 5px; font-size:15px; font-weight: bold;}
.rewrap .data article p {padding:10px 0 15px ;}
.rewrap .data article figure {margin:0 auto 10px;}

.navi article{padding:0 10px;text-align:center;}
.navi article figure{margin:0 auto;width:100%;height:120px;background-position:center;background-size:cover;overflow:hidden;border-radius:8px;}
.navi article header{padding:10px 0;line-height:20px;font-size:14px;text-align:left;}
.navi article p{padding:0 0 10px 0;text-align:left;}

.rewrap .navi article header {color:#0e4944; padding:10px 0 5px; font-size:15px; font-weight: bold;}
.rewrap .navi article p {padding:10px 0 15px ;}
.rewrap .navi article figure {margin:0 auto 10px;}

.faq article{border-bottom:1px solid #ddd;}
.faq article header{padding:10px;line-height:20px;border-bottom:1px solid #ddd;}
.faq article header h3{font-size:14px;}
.faq article header h3 span{color:#069;font-family:times,serif;font-size:18px;}
.faq article p{padding:10px;}
.faq article p span{color:#903;font-family:times,serif;font-size:18px;}

.general .heading{margin:0;padding:0;}
.general .heading h2{padding:10px;line-height:20px;font-size:14px;background:#333;color:#fff;}
.general article{padding:10px;}
.general article h3{color:#900;font-size:14px;line-height:30px;}
.general article p{padding:10px;border:1px solid #ddd;line-height:1.4em;}
/*--------------------------------
form
--------------------------------*/
.remaining{
    margin: 0 auto;
    padding: 4px;
    height: 32px;
    max-width: 750px;
    background: #540000;
    z-index: 9999;
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    text-align: center;
    color: white;
    transition: 0.2s;
    font-size: 16px;
}
.remaining .progress{
    width: 0%;
    height: 32px;
    display: block;
    background: #990000;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    transition: 0.2s;
}
.remaining p{
	position: absolute;
	top: 4px;
	left: 4px;
	right: 4px;
	bottom: 4px;
}
.remaining span{
	color: white;
}
.remaining.fix{
	top: 0;
}
.remaining + .header,
.menu.mt{
	margin-top: 32px;
}
.notice-box{
    margin: 24px 16px;
    padding: 8px;
    background: #f29b76;
    text-align: center;
    color: white;
}
.remaining + .form-wrapper{
    margin-top: 48px;
}
.form-wrapper{
	margin-top: 16px;
    padding: 0 16px 32px;
}
.form-wrapper .primary-heading {
    margin-bottom: 32px;
    padding: 8px;
    background: #333333;
    text-align: center;
    color:  white;
}
.form-box{
	margin-bottom: 32px;
}
.form-label,
.secondary-heading{
	margin-bottom: 8px;
	display: block;
	font-size: 16px;
	font-weight: bold;
}
input[type=text],
input[type=tel],
input[type=password],
select,
textarea{
	padding: 8px;
	width: 100%;
	height: 60px;
	background: #fff;
	position: relative;
	font-size: 16px;
	border: solid 1px #dfdfdf;
}
textarea{
	resize: vertical;
	height: inherit;
}
select{
	padding: 8px 20px 8px 8px;
	height: 60px;
	background: url(../images/icon-select.webp) no-repeat right center / 20px, #fff;
	border: 1px solid #ddd;
	color: black;
}
select:focus{
	background: url(../images/icon-select.webp) no-repeat right center / 20px, #ffffe5;
}
.radio-box{
	display: flex;
}
.regular-radio{
	display: none;
}
.radio-label{
	width: 50%;
	line-height: 58px;
}
.radio-label-text{
	background: #fff;
	display: block;
	transition: .3s;
	text-align: center;
	border: 1px solid #ddd;
	box-sizing: border-box;
	color: black;
	font-size: 16px;
}
.radio-label:nth-of-type(1) .radio-label-text{
	border-radius: 4px 0 0 4px;
	border-right: 0;
}
.radio-label:nth-of-type(2) .radio-label-text{
	border-radius: 0 4px 4px 0;
}
.regular-radio:checked + .radio-label-text{
	background: #eb739f;
	color: #fff;
}
.regular-checkbox{
	margin-bottom: 5px;
	padding: 5px;
	display: block;
	background: #eee;
	font-size: 18px;
	border: 1px solid #eb739f;
}
.regular-checkbox input:checked + .check-label{
	color: #eb739f;
}
.form-msg,
.alert-msg{
	font-size: 14px;
}
.form-box .form-msg{
	margin: 8px 0 0 0;
	line-height: 1.3;
	text-align: center;
}
.error{
	margin: 8px 0 0;
	padding: 4px;
	background: #ff6d6d;
	font-size: 14px;
	color: #fff;
	text-align: center;
}
.form-item{
	position: relative;
}
.form-border{
	margin: 0 auto;
	width: 100%;
	height: 2px;
	background: #ddd;
	position: absolute;
	right: 0;
	bottom: 0;
	left: 0;
	transform-origin: center;
}
input[type=text]:focus + .form-border::after,
input[type=tel]:focus + .form-border::after,
input[type=password]:focus + .form-border::after,
textarea:focus + .form-border::after{
	margin: 0 auto;
	width: 0%;
	height: 2px;
	content: "";
	background: #eb739f;
	position: absolute;
	right: 0;
	bottom: 0;
	left: 0;
	z-index: 2;
	transform-origin: center;
	animation: fade-border .3s ease .1s forwards;
}
@keyframes fade-border{
	0%{width: 0%;opacity: 0;}
	100%{width: 100%;opacity: 1;}
}
.entry-btn .btn-area{
    margin: 0 0 32px;
}
.entry-btn .regist-btn.active{
	background: #900;
	pointer-events: auto;
}
.entry-btn .regist-btn{
	width: 100%;
	display: block;
	color: #fff;
	text-align: center;
	padding: 15px;
	border-radius: 10px;
	font-size: 18px;
	font-weight: bold;
	background: #666666;
	pointer-events: none;
	border: none;
}
.entry-btn .regist-btn::before{
	box-shadow: none;
}
.entry-btn .regist-btn::after{
    border-left: solid 16px #666;
}
.ymd-box{
	column-gap: 8px;
}
.ymd-box,
.area-box{
	display: flex;
	justify-content: space-between;
}
.ymd-box select{
	flex-shrink: 1;
}
.area-box select,
.area-box .sub-area{
	width: calc(50% - 4px);
}
.area-box .sub-area select{
	width: 100%;
	flex-shrink: 0;
}
.general-parts .note {
    margin-bottom: 32px;
    font-size: 16px;
}

/*Footer
--------------------------------------------------------------------------------------------------------------*/
#footer{background:#111;clear:both;position:relative;}
.gnav li{height:44px;line-height:44px;border-top:1px solid rgba(255,255,255,0.1);border-bottom:1px solid rgba(0,0,0,0.2);}
.gnav li a{padding:0 10px;color:#fff;font-size:12px;display:block;background:url(../images/icon_arrow.png) no-repeat right;background-size:30px 44px;}
#footer small{padding:8px 0;font-size:12px;line-height:14px;color:#666;background:url(../images/icon_u19.png) no-repeat left #fff;background-size:60px 60px;text-align:center;display:block;clear:both;}
#footer aside{padding:10px 0;text-align:center;}
#footer aside img{display:block;width:100%;}
.btn_top{width:44px;height:30px;display:block;background:url(../images/icon_arrow_top.png) no-repeat right;background-size:44px 30px;position:absolute;right:7px;bottom:7px;}

#pr {display:none;}
/*rule_popup */

/*close_btn */
a.close_btn {position:fixed; bottom:0; display:block; line-height:50px; width:100%; text-align:center; color:#fff; font-size:16px; background-color:rgba(153,0,0,0.8);}

/* mother bar */
#mother{width:100%; height:40px; background:url(../images/mother_bg.png) repeat-x 0 0;}
#mother h1{display:block; margin:0 10px; color:#fff; line-height:40px; text-indent:-9999px; height:40px; background-position:left top;background-size:auto 40px;overflow:hidden;}

/* 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);}

.lpprtitle{background: #000!important; color: #fff;}
#lppr a{background: #eee}

/* campaign */
#campaign h3{color: #f4ba00;background: url(../images/i.gif) no-repeat 0 1px;}
#campaign h4 {border:0; font-size:14px; color:#069; text-indent:0; }
#campaign h5 {font-weight:normal; font-size:12px;color:#069;}
#campaign p{border:0 !important;}
.cam_msg {font-size:11px; color:#aaa; padding:0;}
#campaign strong {font-weight:bold; color:#f00;}
.camMenu { margin-bottom:10px;}
.camMenu dt { font-weight:bold; font-size:16px; margin:5px 0;}
.camMenu dt:before{content:"▼"; color:#714769;}
.camMenu dd {margin-bottom:10px;}
.camMenu table {border-collapse:collapse; width:270px; color:#000;}
.camMenu table th{text-align:center; background:#ccc; width:90px; border:1px solid #aaa;}
.camMenu table td{text-align:right; width:90px; background:#fff; border:1px solid #aaa; padding-right:10px; box-sizing:border-box;}
.camMenu table tr td:last-child{background:#ff0;}

#campaign_btn {position:absolute; top: 70px; right: 0; z-index: 10; }
#campaign_btn a {width:80px; height:80px; display:block; background:url(../images/cam_btn.png) no-repeat 0 0; text-indent:120%; overflow:hidden; white-space:nowrap; background-size:contain;}

.rewrap #campaign_btn {top:-10px;}

/* reg-modal */
.reg-open{
    cursor: pointer;
}
.modal-overlay{
    background: rgba(0,0,0,0.5);
    width: 100vw;
    height: 100vh;
    position: fixed;
    top: 0;
    left: 0;
    cursor: pointer;
    opacity: 0;
    z-index: -1;
    transition: all .3s;
}
.modal-overlay.active{
    opacity: 1;
    z-index: 4;
}
.reg-modal{
    width: 90%;
    background: #fff;
    padding: 20px;
    text-align: center;
    position: fixed;
    top: 50%;
    left: 0;
    right: 0;
    margin: auto;
    transform: translateY(-40%);
    opacity: 0;
    z-index: -1;
    transition: all .3s;
}
.reg-modal.active{
    opacity: 1;
    z-index: 5;
    transform: translateY(-50%);
}
.branch-text{
    color: #333333;
    font-size: 20px;
    font-weight: bold;
    margin: 0 0 20px;
}
.branch-btn{
    display: block;
    font-size: 18px;
    line-height: 50px;
    background: #900;
    color: #fff;
    margin: 0 0 20px;
    transition: all .3s;
    font-weight: bold;
}

/* clearfix各バージョン */
.clearfix:after {
	content: ".";
	display: block;
	height: 0;
	clear: both;
	visibility: hidden;
}
.clearfix {
	display: inline-table;
	min-height: 1%;
}
/* Hides from IE-mac \*/
* html .clearfix { height: 1%; }
.clearfix { display: block; }
/* End hide from IE-mac */

/* clearfix各バージョンここ */
