@import url(//fonts.googleapis.com/earlyaccess/notosansjapanese.css);
/*
font-family: "游明朝体", "YuMincho", "游明朝", "Yu Mincho", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN W3", HiraMinProN-W3, "ヒラギノ明朝 ProN", "Hiragino Mincho ProN", "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho",Georgia, serif;
font-family: Noto Sans Japanese,Noto Sans JP,"ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", arial, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", Sans-Serif;
*/
html,
body {margin: 0px;margin-bottom: 0px;margin-right: auto;margin-left: auto;font-size: 16px;color: #333;
font-family: Noto Sans Japanese,Noto Sans JP,"ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", arial, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", Sans-Serif;
line-height: 1.6em;-webkit-font-smoothing: antialiased;letter-spacing: 1px; background: #FFF;}
article,aside,details,figcaption,figure,footer,header,hgroup,
menu,nav,section {display: block;margin: 0px;padding: 0px;}
p,td,div,dl,dt,dd,ul,ol,li,h1,h2,h3,h4 {margin: 0px;padding: 0px;list-style: none;}
table , td, th {border-collapse: collapse;}
img {border: 0px; font-size: 0; line-height: 0;vertical-align:bottom; max-width: 100%;transition: 0.5s;height: inherit;}

a,img {transition: 0.5s;text-decoration: none;}
a:hover img {opacity: 0.7;filter: alpha(opacity=70);-ms-filter: "alpha(opacity=70)";}
.wmain{width: 1200px; margin: 0 auto; overflow: hidden;}
.left{float: left}
.right{float: right;}
.pc{display: inline-block;}
.sp{display: none;}
.center{text-align: center;}
h2{text-align: center;font-size: 40px;line-height: 1.4em;letter-spacing: 0;font-weight: 900;text-shadow: 0px 3px 3px rgba(0,0,0,0.35);}
.nos{text-shadow: none;}

/*header
*********************/
.header{overflow: hidden;margin: 0 auto 1px;-webkit-box-shadow: 0px 0px 5px 0px rgba(0,0,0,0.1);
-moz-box-shadow: 0px 0px 5px 0px rgba(0,0,0,0.1);box-shadow: 0px 0px 5px 0px rgba(0,0,0,0.1);}
.header .wmain{padding: 5px 0 10px;}
.header .hti {padding: 5px 0 3px;}
.header .hti h1{ width: 1200px;margin: 0 auto;  font-weight: normal; font-size: 14px;}
.header .logo{margin: 0;}
.header .head-cta{overflow: hidden; position: relative;}
.header ul{text-align: right; overflow: hidden;letter-spacing: 0;font-size: 0;}
.header .head-cta ul li{display: inline-block;*zoom: 1;*display: inline; vertical-align: top; margin: 0 2px;}

/*fv
*********************/
.fv{overflow: hidden;background: url(../img/fv-bg.jpg) center 0 no-repeat;background-size: cover;}

/*cpn
*********************/
.cpn{background: url(../img/cpn-bg.png);}
.cpn .wmain{text-align: center;padding: 40px 0;}
.cpn h2{background: url(../img/cpn-tibg.jpg) center 0 no-repeat;background-size: cover;padding: 25px 0;color: #fff;}
.cpn .ctn{margin: 40px auto 0;width: 70%;background: #fff;border-radius: 10px;border: 4px solid #fff000;}
.cpn .ti{font-weight: 900;font-size: 36px;padding: 25px 0;background: #fff000;}
.cpn .inr{padding: 30px;font-size: 18px;line-height: 1.8em;}

/*cta
*********************/
.cta{background: url(../img/fv-bg.jpg) center 0 no-repeat;background-size: cover;}
.ctabtm{padding: 10px;background: #fbffbf;text-align: center;}
.ctabtm li{display: inline-block;*zoom: 1;*display: inline; vertical-align: top; margin: 0 2px;}

/*reason
*********************/
.reason{background: url(../img/reason-bg.png);}
.reason h2{padding: 25px 0;background: url(../img/reason-tibg.jpg) center 0 no-repeat;background-size: cover;color: #fff;}
.reason h2 span{color: #fff600;}
.reason .wmain{padding: 40px 0;}
.reason ul{text-align: center;}
.reason li{display: inline-block;*zoom: 1;*display: inline; vertical-align: top; margin: 0 4px;width: 18%;}
.reason .ti{text-align: center;margin: 15px 0;font-weight: 900;font-size: 18px;line-height: 1.4em;color: #ff5800;}
.reason li p{text-align: left;letter-spacing: 0;}

/*est
*********************/
.est{background: url(../img/est-bg.png);}
.est h2{padding: 25px 0;background: url(../img/est-tibg.jpg) center 0 no-repeat;background-size: cover;color: #fff;}
.est h2 span{color: #fff600;}
.est .wmain{padding: 40px 0;text-align: center;}
.est .center{font-size: 18px;line-height: 2em;}
.est .tbl{margin: 30px auto 0;}

/*price
*********************/
.price{padding: 40px 0;background: url(../img/price-bg.jpg) center 0 no-repeat;background-size:cover;background-attachment: fixed;}
.price h2{color: #fff;}
.price ul{text-align: center;margin: 30px auto;background: #fff;border: 4px solid #3d9eee;padding: 35px 20px 20px;}
.price li{display: inline-block;*zoom: 1;*display: inline; vertical-align: top; margin: 0 8px 15px;}
.price .ti{font-weight: 900;font-size: 28px;line-height: 1.8em;color: #fdff6c;margin: 25px 0 0;}

/*payment
*********************/
.payment{padding: 40px 0;}
.payment h2{color: #2473d3;}
.payment .center{margin: 30px auto;font-size: 18px;line-height: 1.8em;}
.payment .tbl{text-align: center;margin: 0 auto;width: 65%;padding: 10px auto 0;background: #fff;}

/*voice
*********************/
.voice{padding: 40px 0;background:#e0f5ff;}
.voice h2{color: #3b82d9;}
.voice ul{margin: 30px auto 0;width: 75%;}
.voice li{padding: 20px;background: #fff;border: 1px dashed #3b82d9;overflow: hidden;border-radius: 10px;margin: 0 0 15px;}
.voice .img{float: left;width: 20%;text-align: center;}
.voice .txt{float: right;width:77%;}
.voice .ti{font-weight: 900;font-size: 18px;line-height: 1.4em;color: #3b82d9;margin: 0 0 15px;}

/*map
*********************/
.map{padding: 40px 0;}
.map ul{text-align: center;font-size: 0;letter-spacing: 0;margin: 0 auto;width: 90%;background: #fff;}
.map li{display: inline-block;*zoom: 1;*display: inline; vertical-align: top; margin: 0;}
.map .lm img{border-top-left-radius: 8px;border-bottom-left-radius: 8px;border: 1px solid #3b82d9;}
.map .rm img{border-top-right-radius: 8px;border-bottom-right-radius: 8px;border: 1px solid #3b82d9;}

/*flow
*********************/
.flow{overflow: hidden;padding: 40px 0;color: #fff;background: url(../img/flow-bg.jpg) center 0 no-repeat;background-size: cover;}
.flow ul{overflow: hidden;text-align: center;margin: 30px 0 0;}
.flow li{display: inline-block;*zoom: 1;*display: inline; vertical-align: top; margin: 0 10px;width: 16%;position: relative;letter-spacing: 0;}
.flow li:after{content: "";position: absolute;width:26px;height: 41px;background: url(../img/flow-ar.png) center no-repeat;background-size: contain;top: 50px;right: -25px;}
.flow li:last-child:after{display: none;}
.flow li .ti{font-size: 18px;line-height: 1.4em;font-weight: bold;color: #fff;text-align: center;margin: 10px 0;}
.flow li p{text-align: left;}

/*qa
*********************/
.qa{overflow: hidden;padding: 40px 0;background:url(../img/qa-bg.png);}
.qa h2{color: #1b66c1;}
.qa ul{width: 85%;margin: 30px auto 0;}
.qa ul li{overflow: hidden;margin: 0 0 15px;}
.qa ul li .q{background: url(../img/qa-ar.png) right 15px center no-repeat #1b66c1;padding: 2px 5px;cursor: pointer;}
.qa ul li .q p{background: url(../img/qa-q.png) 5px 6px no-repeat;padding: 12px 0 12px 50px;font-size: 17px;color: #fff;}
.qa ul li .a{padding: 10px 15px;display: none;}
.qa ul li .a p{background: url(../img/qa-a.png) 0 8px no-repeat;padding: 12px 0 12px 40px;font-size: 16px;line-height: 1.6em;}
.qa ul li .a.open{display: block;}

/*contact
*********************/
.contact{padding: 40px 0;}
.contact .sub{color: #ff6c00; text-align: center; font-size: 16px; line-height: 1.4em; margin: 10px 0;font-weight: bold;}
.contact .mailform {padding: 10px; color: #222; width: 65%; margin: 10px auto 0;}
.contact table {text-align: left;width: 100%;border-collapse: collapse;border-spacing: 0; margin: 0 0 20px}
.contact table th, .contact table td {padding: 15px 0; vertical-align: middle;}
.contact table th {font-weight: normal;font-size: 16px;text-align: left;width: 35%;position: relative;}
.contact table td {width: 75%; padding: 10px 30px;}
.contact .form-text, .contact .form-textarea {width: 100%;height: 45px;border: 1px solid #D6D6D6; background: #fff;
padding: 3px;box-sizing: border-box;-webkit-appearance: none;border-radius: 4px;font-size: 14px;}
.contact .form-textarea {height: 120px;}
input[type="submit"], input[type="button"] {cursor: pointer;}
.contact table th:before {content: '';position: absolute;right: 15px;top: 0;
bottom: 0;margin: auto 0;width: 38px;height: 24px; background-size: cover;}
.contact table th.hissu:before {background: url(../img/contact-hissu.png) no-repeat;}
.contact table th.nini:before {background: url(../img/contact-nini.png) no-repeat;}

.contact input[type=radio]{display: inline-block;margin-right: 6px;}
.contact input[type=radio] + label{position: relative;display: inline-block;
margin-right: 20px;font-size: 16px;line-height: 30px;cursor: pointer;}
.contact input[type=radio]{display: none;margin: 0;}
.contact input[type=radio] + label{padding: 0 0 0 24px;}
.contact input[type=radio] + label::before{content: "";
position: absolute;top: 50%;left: 0;-moz-box-sizing: border-box;box-sizing: border-box;
display: block;width: 18px;height: 18px;margin-top: -9px;background: #FFF;}
.contact input[type=radio] + label::before {border: 1px solid #999;border-radius: 30px;}
.contact input[type=radio]:checked + label::after{
content: "";position: absolute;top: 50%;-moz-box-sizing: border-box;
box-sizing: border-box;display: block;left: 5px;width: 8px;
height: 8px;margin-top: -4px;background: #ff2900;border-radius: 8px;}
.contact input[type=radio]:checked + label{color:#ff2900; font-weight: bold;}
.contact input[type=radio]:checked  + label::before {border: 1px solid #ff2900;}

.confirm table th,.confirm table td {border-bottom: 1px dotted #CCC;}
.form-btn-conf {background: url(../img/contact-confirm.png) center no-repeat; background-size: contain;}
.form-btn-back {background: url(../img/contact-back.png) center no-repeat; background-size: contain;}
.form-btn-send {background: url(../img/contact-send.png) center no-repeat; background-size: contain;}
.form-btn {width: 290px;height: 50px;text-align: center;line-height: 50px;border: none;
border-radius: 5px;-webkit-appearance: none;text-indent: -999px;}
.form-btn:hover{opacity: 0.7;filter: alpha(opacity=70);-ms-filter: "alpha(opacity=70)";transition: 0.5s;}
.mail-btn li {display: inline-block; *display: inline; *zoom: 1; vertical-align: top;}

.contact .footer p{font-weight:normal;}
.contact .footer p span{font-weight:bold;}
.copyright{text-align: center; padding: 15px; font-size:12px;}

.contact .cfm {background: #FFF;padding: 10px 10px;text-align: center;font-size: 16px;
line-height: 2em; margin: 0; color: #333;}
.contact .thx {padding: 50px;text-align: center;font-size: 16px;
line-height: 2em; margin: 0; color: #000;}
.contact .thx p{ color: #222;font-weight:normal;}
.contact .btn-tosite {background-color: #555;border: none;color: white;padding: 10px 25px;
text-align: center;text-decoration: none;display: inline-block;font-size: 14px;margin: 50px 2px 0;
cursor: pointer;border-radius: 4px;font-weight: bold;}
.contact .s{font-size: 11px; color: #999;}

#formWrap{text-align: center;}
.formwrap{padding: 20px; margin: 20px 0;}
.error,.error_messe{color: red;}
.bold{font-size: 16px; font-weight: bold;}

#contact .footer p{font-weight:normal;}
#contact .footer p span{font-weight:bold;}
.copyright{text-align: center; padding: 15px; font-size:12px;}

#contact .thx {background: #FFF;padding: 50px;text-align: center;font-size: 16px;
line-height: 2em; margin: 0; color: #000;}
#contact .thx p{ color: #222;font-weight:normal;}
#contact .btn-tosite {background-color: #555;border: none;color: white;padding: 10px 25px;
text-align: center;text-decoration: none;display: inline-block;font-size: 14px;margin: 50px 2px 0;
cursor: pointer;border-radius: 4px;font-weight: bold;}

#contact.confirm p{color: #222; font-weight: normal; font-size: 16px;}
#contact.confirm .error,#contact.confirm .error_messe{color: red;}
#formWrap{text-align: center;}
.formwrap{padding: 20px; margin: 20px 0;}
.cln{border-top: 1px solid #eee; }

.terms-block {margin-bottom: 30px;padding: 15px;background: #eee;}
.terms-block p {margin-bottom: 0;margin: 0 0 10px;}
.terms-block p.center strong{font-weight: bold;font-size: 17px;border: none;}
.terms-block p strong{font-weight: bold;border-bottom: 1px dotted #ddd; display: block;margin: 0 0 5px;padding: 0 0 5px;}
.terms-block .terms-inner {height: 180px;margin-top: 10px;margin-bottom: 15px;padding: 15px;overflow-y: scroll;line-height: 1.7;font-size: 12px;background: #fff;border: 1px solid #ccc;}
.terms-block ol + p {margin-top: 25px;padding-top: 25px;border-top: 1px solid #ddd;}
.input-block p {margin-bottom: 0;line-height: 1.5;}
.terms-block .acceptance {text-align: center;font-size: 20px;}

/*footer
*********************/
.footer{padding: 40px 0 0; background: #f7f7f7;  text-align: center;}
.footer h2{font-size:18px; line-height:1.8em; position: relative; margin: 0 0 15px; padding: 0 0 15px;}
.footer h2:after {position: absolute;content: "";height: 1px;background: #ddd;width: 100px;bottom: 0;left: 0;right: 0;margin: 0 auto;}
.footer span{font-weight: bold;}
.copyright{padding: 14px 0;text-align: center; font-size: 14px; background: #1b66c1; margin: 40px 0 0;color: #fff;}
.gotop{position: fixed; bottom: 0; right: 0; z-index:2;}
.reflection {
    height      :100%;
    width       :30px;
    position    :absolute;
    top         :-180px;
    left        :0;
    background-color: #fff;
    opacity     :0;
    transform: rotate(45deg);
    animation: reflection 3s ease-in-out infinite;
    -webkit-transform: rotate(45deg);
    -webkit-animation: reflection 3s ease-in-out infinite;
    -moz-transform: rotate(45deg);
    -moz-animation: reflection 3s ease-in-out infinite;
    -ms-transform: rotate(45deg);
    -ms-animation: reflection 3s ease-in-out infinite;
    -o-transform: rotate(45deg);
    -o-animation: reflection 3s ease-in-out infinite;
}
 
@keyframes reflection {
    0% { transform: scale(0) rotate(45deg); opacity: 0; }
    80% { transform: scale(0) rotate(45deg); opacity: 0.5; }
    81% { transform: scale(4) rotate(45deg); opacity: 1; }
    100% { transform: scale(50) rotate(45deg); opacity: 0; }
}
@-webkit-keyframes reflection {
    0% { -webkit-transform: scale(0) rotate(45deg); opacity: 0; }
    80% { -webkit-transform: scale(0) rotate(45deg); opacity: 0.5; }
    81% { -webkit-transform: scale(4) rotate(45deg); opacity: 1; }
    100% { -webkit-transform: scale(50) rotate(45deg); opacity: 0; }
}
@-moz-keyframes reflection {
    0% { -moz-transform: scale(0) rotate(45deg); opacity: 0; }
    80% { -moz-transform: scale(0) rotate(45deg); opacity: 0.5; }
    81% { -moz-transform: scale(4) rotate(45deg); opacity: 1; }
    100% { -moz-transform: scale(50) rotate(45deg); opacity: 0; }
}
@-ms-keyframes reflection {
    0% { -ms-transform: scale(0) rotate(45deg); opacity: 0; }
    80% { -ms-transform: scale(0) rotate(45deg); opacity: 0.5; }
    81% { -ms-transform: scale(4) rotate(45deg); opacity: 1; }
    100% { -ms-transform: scale(50) rotate(45deg); opacity: 0; }
}
@-o-keyframes reflection {
    0% { -o-transform: scale(0) rotate(45deg); opacity: 0; }
    80% { -o-transform: scale(0) rotate(45deg); opacity: 0.5; }
    81% { -o-transform: scale(4) rotate(45deg); opacity: 1; }
    100% { -o-transform: scale(50) rotate(45deg); opacity: 0; }
}

/*****************************************************************
max-width 1215
******************************************************************/
@media screen and (max-width: 1215px) {
.wmain,.header .hti h1{width: 98%;}
.header .logo{width: 30%;}
.header .head-cta{width: 65%;}
.header .head-cta ul li{width: 43%;}
.ctabtm li{width: 48%;vertical-align: middle;}
.price li{width: 48%}
.payment .tbl{width: 90%;}
.map li{width: 50%;}
.map li:last-child{width: 48%;}
.contact .mailform,.qa ul,.voice ul{width: 95%;}
}
/*****************************************************************
max-width 888
******************************************************************/
@media screen and (max-width: 888px) {
h2{font-size: 30px;}
.cta .wmain{background-size: 250px;}
.est .center,.payment .center{font-size: 16px;}
.price li{width: 45%}
.price .ti{font-size: 22px;}
.flow li .ti{font-size: 16px;}
.cpn .ctn{width: 90%;}
.cpn .ti{font-size: 30px;}
.cpn .inr{font-size: 16px;}
}
/*****************************************************************
max-width 590
******************************************************************/
@media screen and (max-width: 590px) {
html,body{font-size: 14px;}
.wmain,.header .hti h1{width: 95%;}
h2{font-size: 23px;letter-spacing: 0;}
.sp{display: block;}
.pc{display: none;}
.fv{background: none;text-align: center;}
.fv .wmain{width: 100%;}
.desc p{letter-spacing: 0;text-align: left;}
.header .hti h1{font-size: 11px;text-align: center;line-height: 1.4em;}
.header .logo{width: 100%;overflow: hidden;text-align: center;margin: 0;}
.header .logo img{width: 160px;}
.header .head-cta{width: 100%;position: fixed;bottom: 0;left: 0;background: #fffeac;padding: 8px 0;border-top: 1px solid #ddd;z-index: 9;}
.header .head-cta ul li{width: 48%;vertical-align: middle;}
.header .head-cta ul{text-align: center;}
.header .head-cta ul li.tx{font-size: 14px;}
.cpn .wmain{padding: 25px 0;}
.cta {background-position: 0 0;}
.cta .wmain{background: none;}
.ctabtm li{width: 100%;margin: 0 0 5px;}
.reason {background: #eee;}
.reason li{width: 90%;padding: 10px;overflow: hidden;background: #fff;margin: 0 0 15px;}
.reason .img{float: left;width: 20%;}
.reason .txt{float: right;width: 78%;}
.reason .ti{text-align: left;margin: 0 0 10px;}
.price li{width: 100%;margin: 0 0 25px;}
.price .ti{font-size: 17px;}
.voice li{width: 90%;padding: 10px;overflow: hidden;}
.voice .img{float: none;width: 15%;margin: 0 auto;}
.voice .txt{float: none;width: 100%;margin: 15px 0 0;}
.voice .ti{text-align: center;margin: 0 0 10px;}
.payment .tbl{padding: 10px;}
.map li,.map li:last-child{width: 100%;}
.map .rm img,.map .lm img{border-radius: inherit;}
.flow{padding: 30px 0 15px;}
.flow li .img{float: left;width: 30%;}
.flow li .txt{float: right;width: 65%;}
.flow li .ti{text-align: left;margin: 0 0 10px;min-height: inherit;font-size: 18px;}
.flow li:after{top: inherit;right: 0;bottom: 0;left: 0;margin: 0 auto;-webkit-transform: rotate(90deg);transform: rotate(90deg);height: 30px;}
.flow li{width: 90%;overflow: hidden;margin: 0 auto 25px;padding: 0 0 25px;}
.qa ul li .q p{font-size: 14px;padding:12px 30px 12px 50px; }
.qa ul li .a p{font-size: 14px;}
.contact table th,.contact table td{width: 100%;overflow: hidden;display: block;padding: 0;}
.contact table th{padding: 5px 0;background: #f5f5f5;}
.contact table td{margin: 0 0 10px;padding: 0 0 10px;border-bottom: 1px dotted #ddd;}
.footer h2{font-size: 16px!important;}
.footer{font-size: 12px;line-height: 1.4em;}
.copyright{margin: 20px 0 60px;font-size: 10px;line-height: 1.4em;}
.gotop{bottom:65px;width: 38px;}
p.confirm{margin: 0 0 30px;}
.mail-btn li{display: block;margin: 0 0 3px;}
.cpn .ti{font-size: 20px;}
.cpn .inr{font-size: 14px;}
}

@media screen and (max-width: 375px) {
}