@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;
font-family: "ヒラギノ角ゴ 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.8em;-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.6em;letter-spacing: 0;}
h2.after{position: relative;margin: 10px 0;padding: 10px 0;}
h2.after:after{position: relative;content: "";height: 6px;width: 154px;bottom: -10px;display: block;text-align: center;background: url(../img/h2-ln.png) center 0 no-repeat;margin: 0 auto;}
h2.after.af2:after{background: url(../img/h2-ln2.png) center 0 no-repeat;}
h2 span{color: #ff5571;}

/*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);border-top: 4px solid #ffacba;}
.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: 15px 0 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;}

/*nayami
*********************/
.nayami{padding: 40px 0;background: url(../img/nayami-bg.jpg) center 0 no-repeat;background-size: cover;}

/*reason
*********************/
.reason{padding: 40px 0;background: url(../img/reason-bg.png);}
.reason ul{margin: 30px auto 0;display: flex;justify-content: center;}
.reason li{display: inline-block;margin: 0 3px;width: 18.7%;overflow: hidden;border-radius: 5px;background: #fff;}
.reason .img{text-align: center;}
.reason .ti{font-weight: 900;font-size: 18px;color: #ff5571;text-align: center;margin: 0 0 15px;}
.reason .ti small{font-weight: normal;color: #333;font-size: 75%;}
.reason .txt{padding: 15px;}
.reason li p{text-align: left;}

/*cta
*********************/
.cta{padding: 10px 0 60px;background: url(../img/cta-bg.jpg) center 0 no-repeat;background-size: cover;}
.cta ul{margin: 25px auto 0;text-align: center;}
.cta li{display: inline-block;}

/*desc
*********************/
.desc{padding: 40px 0;background: url(../img/desc-bg.png);}
.desc .ctn{padding: 20px;margin:30px auto 0;text-align: center;width: 70%;background: url(../img/desc-inr.png);}
.desc .inr{background: #fff;padding: 0 20px 10px;}
.desc .inr img{display: block;margin: 0 auto 20px;}

/*office
*********************/
.office{padding: 40px 0;}
.office h2{padding: 25px 0;color: #fff;background: #ff5571;}
.office .wmain{padding: 60px 0 40px;background: url(../img/office-ar.png) center 0 no-repeat;}
.office .ctn{padding: 15px 10px;background: #fff;border: 1px solid #dddddd;margin: 0 auto;width: 85%;}
.office ul{display: flex;justify-content: center;}
.office li{display: inline-block;margin: 10px;width: 100%;text-align: center;}
.office .ti{font-weight: 900;font-size: 20px;line-height: 1.4em;margin: 0 0 15px;color: #ff5571;}
.gmap{width: 100%;margin: 20px 0;}
.ggmap {position: relative;padding-bottom: 50%;padding-top: 30px;height: 0;overflow: hidden;}
.ggmap iframe,
.ggmap object,
.ggmap embed {position: absolute;top: 0;left: 0;width: 100%;height: 100%;}

/*flow
*********************/
.flow{overflow: hidden;padding: 40px 0;background: url(../img/flow-bg.png);}
.flow ul{margin: 30px auto 0;width: 95%;}
.flow li{background: #fff;border-radius: 6px;border: 1px solid #f4c8cf;padding: 15px;overflow: hidden;margin: 0 auto 15px;}
.flow .img{float: left;width: 26%;}
.flow .txt{float: right;width: 70%;}
.flow .ti{font-weight: 900;font-size: 20px;color: #3d68a8;line-height: 1.4em;margin: 0 0 15px;}
.flow li span{color: #ff5571;}

/*qa
*********************/
.qa{overflow: hidden;padding: 40px 0;background:url(../img/qa-bg.png);}
.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 #315da8;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: #ff5571; 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: #315da8; 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: 31%;}
.header .logo{margin: 5px 0 0;}
.reason .ti{font-size: 16px;letter-spacing: 0;}
.cta li{width: 32%;}
.desc .ctn{width: 85%;}
.reason ul{display: block;}
.reason li{overflow: hidden;margin: 0 auto 15px;width: 85%;display: block;padding: 15px;}
.reason .img{float: left;width: 25%;}
.reason .txt{float: right;width: 70%;padding: 0;}
.reason .ti{text-align: left;margin: 0 0 10px;}
.reason .ti br{display: none;}
}
/*****************************************************************
max-width 888
******************************************************************/
@media screen and (max-width: 888px) {
h2{font-size: 30px;}
.cta{padding: 30px 0;}
.contact .mailform,.qa ul{width: 95%;}
}
/*****************************************************************
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%;}
.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: 220px;}
.header .head-cta{width: 100%;position: fixed;bottom: 0;left: 0;background: #fffeac;padding: 8px 0 20px;border-top: 1px solid #ddd;z-index: 9;}
.header .head-cta ul li{width: 32%;vertical-align: middle;}
.header .head-cta ul{text-align: center;}
.reason li .img{float: none;width: 100%;}
.reason li .txt{float: none;width: 100%;}
.reason .ti{text-align: center;}
.cta h2{background: #3b62a1;}
.cta ul{padding: 15px;background: #3b62a1;margin: 0 auto;}
.cta li{width: 100%;margin: 0 auto 5px;}
.desc .ctn{width: 90%;padding: 10px;}
.desc .inr{padding: 0 10px;}
.office .ctn{border: none;background: none;width: 100%;padding: 0;}
.office ul{display: block;}
.office li{display: block;margin: 0 auto 25px;width: 85%;padding: 15px;border: 1px solid #ddd;background: #fff;}
.office .wmain{padding: 50px 0 10px;}
.flow .img{float: none;width: 100%;text-align: center;}
.flow .txt{float: none;width: 100%;}
.flow .ti{text-align: center;margin: 15px 0;font-size: 16px;}
.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:60px;width: 38px;}
p.confirm{margin: 0 0 30px;}
.mail-btn li{display: block;margin: 0 0 3px;}
}

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