@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;}
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;font-weight: 900;}
h2.after{position: relative;margin: 10px 0;padding: 10px 0;}
h2.after:after{position: relative;content: "";height: 6px;width: 118px;bottom: -10px;display: block;text-align: center;background: url(../img/h2-ln.png) center 0 no-repeat;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: 10px 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 center no-repeat;background-size: cover;border-bottom: 12px solid #c8daf4;}
.fv .wmain{max-width: 1400px;}
.fv .wmain h2 img{width: 100%;}
/*reason
*********************/
.reason{padding: 60px 0;background: #f3f6fa;border-bottom: 10px solid #304482;}
.reason h2 .fn{font-size: 130%;position: relative;}
.reason h2 .lg{color: #293f86;font-size: 180%;position: relative; bottom: -5px;}
.reason ul{text-align: center;margin: 50px auto 0;display: flex;justify-content: space-between;background: #fff;padding: 15px;box-shadow: rgba(99, 99, 99, 0.2) 0px 2px 8px 0px;}
.reason li{margin: 0 5px;width: 18%;}
.reason li p{text-align: left;margin: 15px 0 0;letter-spacing: 0;}
.reason .ti{text-align: center;margin: 10px 0;font-weight: 900;color: #293f86;font-size: 18px;}

/*nayami
*********************/
.nayami{padding: 60px 0 0;background: url(../img/nayami-bg.jpg) center 0 no-repeat;background-size: cover;}
.nayami span{color: #ec1515;}
.nayami .ctn{margin: 30px auto;width: 90%;background: #fff;overflow: hidden;padding: 15px 15px 0;border-radius: 20px;}
.nayami .img{float: left;width: 30%;text-align: center;}
.nayami .txt{float: right;width: 70%;}
.nayami ul{padding: 15px 15px 0;}
.nayami li{padding: 6px 0 10px 50px;background: url(../img/nayami-ch.png) 0 10px no-repeat;border-bottom: 1px dashed #ef463f;margin: 0 0 10px;}
.nayami li p{font-size: 24px;letter-spacing: 0;font-weight: bold;line-height: 1.4em;}
.nayami .sub{padding: 35px 0;color: #fff;background: #0c6dd0;text-align: center;font-weight: 900;font-size: 30px;}

/*item
*********************/
.itemti h2{padding: 25px 0;color: #fff;background: #293f86;}
.item{background: #f3f3f3;}
.item h2{padding: 25px 0;color: #fff;background: #b49c5c;}
.item .wmain{padding: 40px 0;}
.item .ctn{padding: 40px;background: #fff;border-radius: 15px;width: 85%;margin: 0 auto;}
.item .bxti{overflow: hidden;margin: 0 auto 30px;}
.item .txt{float: left;width: 55%;}
.item .img{float: right;width: 40%;text-align: center;}
.item .ti{font-weight: 900;font-size: 30px;line-height: 1.4em;color: #ec1515;padding: 0 0 15px;margin: 0 0 15px;border-bottom: 3px solid #d1d1d1;position: relative;}
.item .ti span{color: #333;font-size: 85%}
.item .ti:after{content: ""; position: absolute;height: 3px;width: 25%;background: #ec1515;left: 0;bottom: -3px;}
.item .bx2{overflow: hidden;margin: 0 auto 30px;}
.item .bx3{overflow: hidden;margin: 0 auto 30px;}
.item .bx2 p{font-weight: bold;}
.item .tis{font-weight: 900;font-size: 20px; color: #ec1515;padding: 10px;background: #ffeef1;margin: 0 auto 20px;border-left: 4px solid #ec1515;}
.item .tiss{font-weight: 900;font-size: 20px;padding: 10px;background: #eee;margin: 0 auto 20px;border-left: 4px solid #ec1515;}
.item caption{font-weight: 900;color: #fff;text-align: center;padding: 10px;font-size: 18px;}
.item .bl{background: #394f95;}
.item .bk{background: #333;}
.item table{width: 100%;margin: 10px auto 0;}
.item th,.item td{padding: 10px 0;border-bottom: 1px dashed #ddd;}
.item td small{font-size: 70%;font-weight: normal;}
.item th{text-align: left;width: 60%;font-weight: normal;}
.item td{text-align: right;width: 40%;color: #ec1515;font-weight: 900;font-size: 18px;}
.item ul{display: flex;justify-content: space-between;margin: 10px auto 0;}
.item li{width: 48.5%;}
.item .sub{position: relative;font-weight: 900;color: #394f95;font-size: 24px;padding: 0 0 15px;margin: 35px 0 15px;border-bottom: 3px solid #d1d1d1;}
.item .sub:after{content: ""; position: absolute;height: 3px;width: 30%;background: #394f95;left: 0;bottom: -3px;}

/*item3
*********************/
.item3 h2{padding: 25px 0;color: #fff;background: #293f86;}
.item3 .wmain{padding: 60px 0;}
.item3 ul{display: flex;justify-content: space-between;text-align: center;margin: 0 auto 40px; flex-wrap: wrap;}
.item3 li{width: 32%;margin: 0 5px;}
.item3 .ti{font-weight: bold;font-size: 18px;margin: 15px auto 0;}
.item3 .ti span.red{color: #FF0004;;}
.item3 .tiss{font-weight: 900;font-size: 20px;padding: 10px;background: #eee;margin: 0 auto 20px;border-left: 4px solid #ec1515;}
span.red{color: #FF0004;;}
span.blue{color: #0600AF;}

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

/*flow
*********************/
.flow{overflow: hidden;padding: 60px 0;}
.flow h2 span{color: #293f86;}
.flow ul{overflow: hidden;text-align: center;margin: 30px auto 0;display: flex;justify-content: space-between;flex-wrap: wrap;width: 90%;}
.flow li{padding: 15px;background: #293f86;color: #fff; margin: 5px;width: 20%;position: relative;letter-spacing: 0;}
.flow .img{margin: 0 auto 15px;}
.flow li p{text-align: left;}

/*qa
*********************/
.qa{overflow: hidden;background:url(../img/qa-bg.png);}
.qa .wmain{padding: 60px 0;background: url(../img/qa-ar2.png) center 0 no-repeat;}
.qa h2 span{color: #293f86;}
.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 #434343;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 p.red{color: #EA0003; text-align: center;}
.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: 80px;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: #293F86; 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; }}

.mt20{
	margin-top: 20px;
}