@import url(//fonts.googleapis.com/earlyaccess/notosansjapanese.css);
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;}
body{min-width: 1024px;}
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{min-width: 1024px;max-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: 5px;width: 70px;bottom: -10px;display: block;text-align: center;background: linear-gradient(135deg, #6ca5df 0%, #6ca5df 50%, #3b73aa 50%, #3b73aa 100%);margin: 0 auto;}

/*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{min-width: 1024px;max-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;}

/*reason
*********************/
.reason{padding: 60px 0;background: url(../img/reason-bg.jpg) center bottom no-repeat;background-size: cover;}
.reason ul{text-align: center;margin: 50px auto 0;display: flex;justify-content: space-between;}
.reason li{margin: 0 5px;width: 18%;}
.reason .ti{font-weight: bold;font-size: 20px;color: #d9232a;text-align: center;margin: 15px 0;}
.reason li p{text-align: left;}

/*grp
*********************/
.grp{background: url(../img/grp-bg.png);}
.grp .wmain{padding: 60px 0;background: url(../img/grp-ar.png) center 0 no-repeat;}
.grp h2{color: #4f85bb;}
.grp .ctn{text-align: center;margin: 40px auto 0;}

/*desc
*********************/
.desc{padding: 60px 0;background: url(../img/desc-bg.png);}
.desc h2 span{color: #d9242b;}
.desc .ctn{overflow: hidden;margin: 40px auto 0;}
.desc .img{float: right;width: 45%;text-align: center;}
.desc .txt{float: left;width: 50%;font-size: 20px;line-height: 2.4em;}

/*cta
*********************/
.cta{padding: 60px 0;background: url(../img/cta-bg.jpg) center 0 no-repeat;background-size: cover;}
.cta .ctn{overflow: hidden;margin: 0 auto;border-radius: 15px;}
.cta .inr{background: rgba(255, 255, 255, 0.9);padding: 30px 30px 10px;}
.cta ul{display: flex;justify-content: space-between;background: url(../img/cta-bg2.png);padding: 20px;}
.cta li{margin: 0 2px;}

/*option
*********************/
.option{padding: 60px 0;background: url(../img/option-bg.png);}
.option h2 span{color: #d9232a;}
.option ul{margin: 40px auto 0;display: flex;justify-content: center;flex-wrap: wrap;}
.option li{width: 22%;margin: 0 5px;background: #fff;border-radius: 15px;text-align: center;font-weight: 900;overflow: hidden;}
.option .ti{padding: 20px 0;background: #6ca5df;color: #fff;font-size: 22px;}
.option .prc{padding: 20px 0;font-size: 22px;letter-spacing: 0;}
.option .prc span{color: #d9232a;}
.option .prc small{font-size: 75%;}

/*jisseki
*********************/
.jisseki{padding: 60px 0;background: url(../img/jisseki-ar.png) center 0 no-repeat;}
.jisseki h2 span{color: #4f85bb;}
.jisseki ul{margin: 40px auto 0;display: flex;justify-content: center;text-align: center;}
.jisseki li{margin: 0 15px;width: 44%;}
.jisseki p{font-weight: bold;font-size: 22px;margin: 20px auto 0;line-height: 1.6em;letter-spacing: 0;}
.jisseki p span{font-weight: 900;font-size: 110%;color: #d9232a;}

/*voice
*********************/
.voice{padding: 60px 0;background: url(../img/voice-ar.png) center 0 no-repeat #edf2f7;}
.voice h2 span{color: #4f85bb;}
.voice ul{margin: 40px auto 0;display: flex;justify-content: center;}
.voice li{padding: 20px;background: #fff;border-radius: 10px;margin: 0 10px;width: 26%;}
.voice .img{text-align: center;}
.voice .ti{margin: 15px 0;font-weight: 900;color: #4f85bb;font-size: 18px;text-align: center;}

/*flow
*********************/
.flow{overflow: hidden;padding: 60px 0;}
.flow h2 span{color: #4f85bb;}
.flow ul{overflow: hidden;text-align: center;margin: 30px 0 0;display: flex;justify-content: space-between;}
.flow li{margin: 0 10px;width: 18%;position: relative;letter-spacing: 0;}
.flow li .ti{font-size: 18px;font-weight: bold;color: #4f85bb;text-align: center;margin: 10px 0;}
.flow li p{text-align: left;}

/*qa
*********************/
.qa{overflow: hidden;padding: 60px 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 #cea283;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: 60px 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 .lst{display: flex;justify-content: flex-start;flex-wrap: wrap;}
.contact .lst label{width: 28%;margin: 0 5px 5px 0;}
.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: #565656; 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; }}