@charset "utf-8";

html{
    visibility: hidden;
    transition: .1s;
}
html.wf-active{
visibility:visible;
}



*{
min-width: 0;
min-height: 0;
}



html,body{
    width: 100%;
}
@font-face {
font-family: 'Open Sans';
font-style: normal;
font-weight: 400;
src: local('Open Sans'), local('OpenSans'),
url(https://themes.googleusercontent.com/static/fonts/opensans/v8/cJZKeOuBrn4kERxqtaUH3T8E0i7KZn-EPnyo3HZu7kw.woff)
format('woff');
}

 *{
     box-sizing: border-box;
 }



body{
font-family: 'Noto Sans JP', sans-serif ,"ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS P Gothic", Verdana;
    line-height:1.5;
    font-size: 16px;
font-weight: 400;
font-style: normal;
    
}

h2,
h3,
h4,
h5,
h6,
strong{
    font-weight: 800;
}
th{
font-weight: 400;
}

a {
	color:#333;
	outline: none;
	text-decoration: none;
	
}

a:hover{
	transition: .2s;
	opacity:0.7;
}

img{
max-width: 100%;
height: auto;
width /***/:auto;
}


input, select, textarea {
    padding: 5px 10px;
	border: 1px solid #ccc;
	margin: 2px;
    background: #fff;

}


input[type=radio], input[type=checkbox] {
	margin:0 5px 0 0;
	width: auto;
}
label{
	display: inline-block;
}

.width100{
	width:100%;
}

.wrap{
	
}


.block{
	display: block;
}

.onlysp{
	display: none;
}
.none{
	display:none;
}

.uline{
    text-decoration: underline;
}


/* iOSでのデフォルトスタイルをリセット */
input[type="submit"],
input[type="button"] {
  border-radius: 0;
  -webkit-box-sizing: content-box;
  -webkit-appearance: button;
  appearance: button;
  border: none;
  box-sizing: border-box;
  cursor: pointer;
}
input[type="submit"]::-webkit-search-decoration,
input[type="button"]::-webkit-search-decoration {
  display: none;
}
input[type="submit"]::focus,
input[type="button"]::focus {
  outline-offset: -2px;
}





.wrap{
  
   overflow: hidden;
}
.home .wrap{

}

/*
#a01,
#a02,
#a03,
#a04,
#a05,
#a06,
#reserve,
#mw_wp_form_mw-wp-form-27{
   display: block;
   margin-top:-150px;
   padding-top:150px;
}*/
#mw_wp_form_mw-wp-form-24{
  display: block;
   margin-top:-150px;
   padding-top:150px;
}





 .mainbody{
	max-width:1000px;
	margin: 0 auto;
}
.mainbody2{
	max-width:1100px;
	margin: 0 auto;
}
 .contents {
  padding: 60px 0;
}
 
 Source Han Sans JP Regular{
 font-family: "source-han-sans-japanese", sans-serif;
font-weight: 400;
font-style: normal;
 } 
 Source Han Sans JP Bold{
 font-family: "source-han-sans-japanese", sans-serif;
font-weight: 700;
font-style: normal;
 }
DIN Condensed Regular{
font-family: "din-condensed", sans-serif;
font-weight: 400;
font-style: normal;
}
 Futura PT Demi{
  font-family: "futura-pt", sans-serif;
font-weight: 600;
font-style: normal;
 }

 

/*ヘッダー
------------------------------------------------*/
.headerwrap{
    background: #fff;
    
}



.header{
    height: 80px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.logo img{
    max-height: 47px;
}


.menubtn{
    display: none;
}











/*全体レイアウト
------------------------------------------------*/

/**スマホのメニュー***/
body .sidr{
background: #001749;
color:#fff;

}
.sidr a{
color: #fff;
}


#sidr-menu{

}
.spclose {
    text-align: right;
    padding: 10px 0;
    font-size: 200%;
   
}

.spnavi{
    padding: 0 0 20px 0;
}
.spnaviinfo {
    text-align: center;
}
.spnaviinfo h2{
    text-align: center;
  font-size: 14px;
  color: #fff;
  line-height: 120%;
  margin: 0 0 20px;
}
.spnaviinfo h2 img{
    max-height: 40px;
    margin: 0 0 10px;
}


.spnavi ul{

}

.spnavi ul a{
    color: #fff;
}
.spnavi li {
position: relative;
font-size: 14px;
}
.spnavi li:first-child a{
     border-top: 1px solid #fff;
}
.spnavi li a,
.spnavi li span{
    display: block;
    border-bottom: 1px solid #fff;
    padding: 10px 0;
}

.spnavi li a[target="_blank"]:after{
    display: inline-block;
    content: "";
    width: 20px;
    height: 12px;
    background: url("../img/icon_blank_white.png") no-repeat right center;
    background-size: 12px;
}

.videoWrap {
	margin-top: 50px!important;
}
video {
	width: 100%;
	height: auto;
	display: block;
}


/*フッター
------------------------------------------------*/
.footcontacttitle h2{
font-family: "futura-pt", sans-serif;
font-weight: 600;
font-style: normal;
font-size: 36px;
padding: 40px 0 20px;
text-align: center;
}
.footcontactbox{
	line-height: .8;
    display: flex;
    color: #fff;
}
.footmail{
    flex-basis: 50%;
    background: #ff921e;
}
.footmail dl{
    width: 100%;
    max-width: 500px;
    margin: 0 0 0 auto;
    text-align: center;
    padding: 30px;
}
.foottel{
     flex-basis: 50%;
    background: #35c4a8;
}
.foottel dl{
    width: 100%;
    max-width: 500px;
    text-align: center;
    padding: 30px;
}
.footcontactbox dt{
    font-size: 24px;
    padding: 0 0 20px;
    font-weight: 700;
}
.footcontactbox dt small{
    font-weight: 400;
    font-size: 80%;
}
.footmail dd a{
     font-weight: 700;
  display: inline-block;
  background: #fff;
  color: #ff921e;
  padding: 10px 20px;
  border-radius: 99px;
}
.footmail dd a:before {
    content: "";
    display: inline-block;
    height: 15px;
    width: 20px;
    background: url("../img/icon_mail.png") no-repeat center center;
    background-size:20px;
    margin: 0 10px 0 0 ;

}

.foottel dd a{
    color: #fff;
    font-family: "din-condensed", sans-serif;
  font-weight: 400;
  font-style: normal;
  font-size: 52px;
  background: url("../img/icon_tel.png") no-repeat left center;
  background-size: 30px;
  padding: 0 0 0 40px;
}
.footer dl{
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 20px 0;
}
.footer dt{
    flex-basis: 48%;
    text-align: right;
}
.footer dt img{
    max-height: 50px;
}
.footer dd{
    flex-basis: 48%;
}
.copyright{
    padding: 10px;
    border-top: 1px solid #ccc;
    font-size: 70%;
    text-align: center;
    
}





.sidefixbtn{
    position: fixed;
    right: 20px;
    top: 100px;
}
.sidefixbtn li{
    margin: 0 0 10px;
}


/*トップページ
------------------------------------------------*/
/**メインビジュアル**/
.mainvisual{
	height:900px;
	background: url("../img/top/main_bg.jpg") no-repeat top center;
	background-size: cover;
}
.mainWrap {
	position: relative;
	max-width: 935px;
	height: 100%;
	text-align: center;
}
.mainWrap .img {
	position: absolute;
	z-index: 1;
}
.mainWrap .img._01 {
	left: 0;
	right: 0;
	top: 13px;
	margin: 0 auto;
	-webkit-animation-delay: .4s!important;
	animation-delay: .4s!important;
}
.mainWrap .img._02 {
	left: 0;
	right: 0;
	bottom: 2px;
	margin: 0 auto;
	z-index: 2;
	-webkit-animation-delay: .8s!important;
	animation-delay: .8s!important;
}
.mainWrap .img._03 {
	left: 0;
	bottom: 75px;
	z-index: 3;
	-webkit-animation-delay: 1s!important;
	animation-delay: 1s!important;
}
.mainWrap .img._04 {
	right: 0;
	bottom: 75px;
	z-index: 4;
	-webkit-animation-delay: 1s!important;
	animation-delay: 1s!important;
}
.mainbtm {
	padding: 25px 0;
	font-size: 14px;
	line-height: 1.5
}
.mainbtm dt {
	font-size: 120%;
	font-weight: 600;
	margin-bottom: 5px;
}
.mainbtm .img {
	width: 251px;
	min-width: 251px;
	margin-left: 20px;
}
.mvtitle01{
    text-align: center;
    background: #2c419a;
    padding: 20px 0;
}
.mvtitle01 h2{
    font-size: 32px;
    color: #fff100;
    margin: 0 0 10px;
}
.mvtitle01 p{
font-size: 24px;
color: #fff;
font-weight: 700;
}
.mvtitle02{
    background: #ff921e;
    padding: 20px 0;
    color: #fff;
    text-align: center;
	position: relative;
}
.mvtitle02 h2{
	font-size: 45px;
	line-height: 1
}
.mvtitle02::after {
	content: "";
	display: block;
	position: absolute;
	left: 0;
	right: 0;
	top: 100%;
	margin: 0 auto;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 20px 15px 0 15px;
	border-color: #ff921e transparent transparent transparent;
	z-index: 1
}

.topaboutwrap{
    background: url("../img/top/bg_about.jpg") no-repeat center center;
	background-size: cover;
}
.topaboutwrap .mainbody {
	background: #202d74 url("../img/top/about01_bg.png") top center no-repeat;
	background-size: 95% 100%;
}
.topaboutbox{
    max-width: 730px;
    margin: 0 auto;
    padding: 40px 0 30px;
	color: #fff;
	font-size: 22px;
	line-height: 1.4
}
.topaboutbox h2{
    text-align: center;
    color: #fff100;
    padding: 0 0 20px;
    font-size: 46px;
	line-height: 1.2;
	font-weight: 800
}
.topaboutbox h2 img{
    max-height: 66px;
    margin: -20px 0 0;
}
.topaboutbox .txt span {
	color: #fff100;
}
.anchor li {
	width: 32%;
	margin-right: 2%;
	margin-bottom: 15px;
}
.anchor li:nth-of-type(3n) {
	margin-right: 0;
}
.anchor li a {
	display: flex;
	align-items: center;
	font-size: 14px;
	color: #fff;
	background: #2c419a url("../img/top/arrow01.png") right 15px center no-repeat;
	background-size: 15.5px auto;
	padding: 10px 15px;
	min-height: 84px;
	line-height: 1.4
}
.anchor li .num {
	font-size: 11px;
	font-family: "din-condensed", sans-serif;
	font-weight: 400;
	font-style: normal;
	text-align: center;
	margin-right: 20px;
	line-height: 1.1
}
.anchor li .num big {
	display: block;
	font-size: 320%;
	letter-spacing: .025em;
	line-height: .8;
	margin-top: 5px;
}
.anchor li .txt strong {
	font-weight: 700;
	color: #fff100;
	font-size: 130%;
	display: block;
	line-height: 1.2
}

.conceptttl {
	text-align: center;
}
.conceptttl .eng {
	font-size: 24px;
	font-family: "din-condensed", sans-serif;
	font-weight: 400;
	line-height: 1;
	font-style: normal;
	color: #ff921e;
	margin-bottom: 10px;
}
.conceptttl .sub {
	line-height: 1.2;
	background: #ff921e;
	border-radius: 60px;
	color: #fff;
	font-size: 30px;
	padding: 5px;
	font-weight: 800;
	position: relative;
	max-width: 560px;
	margin: 0 auto 15px;
	letter-spacing: .05em;
	text-indent: .05em;
}
.conceptttl .sub::after {
	content: "";
	display: block;
	position: absolute;
	left: 0;
	right: 0;
	top: 100%;
	margin: 0 auto;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 10px 8px 0 8px;
	border-color: #ff921e transparent transparent transparent;
	z-index: 1
}
.conceptttl h2 {
	color: #2c419a;
	font-size: 46px;
	line-height: 1.2;
}
#concept01 {
	padding-top: 55px;
}
.abouttop {
	background: #fff4e8;
	border-top: 1px solid #fff;
	padding-bottom: 20px;
}
.abouttop .conceptttl {
	margin-top: -55px;
}
.aboutarea {
	background: #2b3e8f;
	color: #fff;
}
.aboutbox {
	position: relative;
	padding: 50px 230px;
	font-size: 22px;
	text-align: center;
	font-weight: 500
}
.aboutbox h3 {
	font-size: 38px;
	display: inline-block;
	color: #fff100;
	border-bottom: 4px solid #fff100;
	margin-bottom: 10px;
}
.aboutbox .img {
	position: absolute;
	bottom: 0;
}
.aboutbox .img._01 {
	left: 100px;
}
.aboutbox .img._02 {
	right: 45px;
}





.toppattern2wrap{
    background: #2c419a;
    padding: 30px 0;
}
.toppattern2box{
    text-align: center;
   
}
.toppattern2box h2{
    font-size: 32px;
    color: #fff100;
    padding: 0 0 30px;
}
.toppattern2box dl{
    display: flex;
    justify-content: center;
    align-items: center;
    background: #fff;
    padding: 30px 0;
    margin: 0 0 10px;
}
.toppattern2box dt{
    background: #2c419a;
    color: #fff;
    font-size: 22px;
    font-weight: 600;
    border-radius: 99px;
    padding: 10px 30px 15px;
    margin: 0 20px;
}
.toppattern2box h3{
    font-size: 32px;
    border-bottom: 7px solid #ff921e;
    padding: 0 0 10px;
    margin: 0 0px 5px;
}
.toppattern2box h3 strong{
    color: #ff921e;
}
.toppattern2box h3 strong big{
    font-size:80px;
}
.toppattern2box dd p{
    text-align: right;
    font-size: 12px;
}

/**service01**/
.topservice01wrap{
    background: #ebf6fe;
}
.topservicetitle{
    text-align: center;
    color: #2c419a;
}
.topservicetitle._white{
    color: #fff;
}
.topservicetitle h2{
font-family: "din-condensed", sans-serif;
font-weight: 400;
font-style: normal;
font-size: 20px;
line-height: 150%;
margin: 0 0 20px;
}
.topservicetitle h2 strong{
    font-size: 48px;    
}
.topservicetitle h3{
    font-size: 32px;
    margin: 0 0 30px;
}
.topservicetitle p{
    color: #000;
}
.servicebox01{
    border: 5px solid #2c419a;
    border-radius: 10px;
    display: flex;
   
}
.serviceboxtitle{
    background: #2c419a;
    flex-basis: 18%;
    text-align: center;
    display: flex;
    align-items:  center;
    justify-content: center;
}
.service01list{
    flex-basis: 41%;
    border-left: 3px solid #2c419a;
}
.service01list dl{
    display: flex;
    align-items: center;
    justify-content: space-between;
    height: 85px;
    background: #fff;
    border-bottom: 3px dotted #2c419a;
}
.service01list dl:nth-child(even){
    background:  #ebf6fe;
}
.service01list dl:last-child{
    border: none;
}
.service01list dt{
    flex-basis: 34%;
    text-align: center;
    color:  #2c419a;
    font-weight: 700;
    line-height: 140%;
}
.service01list dd{
    flex-basis: 67%;
    line-height: 140%;
    font-weight: 600;
}
.service01list dd small{
    font-weight: 400;
}
/**service02**/
.topservice02wrap h3 + .txt {
	font-size: 22px;
	font-weight: 700;
	margin-bottom: 15px;
}
.servicebox02 dl{
    display: flex;
    justify-content: space-between;
    margin: 0 0 50px;
}
.servicebox02 dt{
    flex-basis: 48%;
}
.servicebox02 dd{
    flex-basis: 50%;
}

.service02slider{
    position: relative;
    max-width: 750px;
    margin: 0 auto 50px;
}

.service02slider .prev {
  position: absolute;
  top: 0%;
  bottom: 0;
  margin: auto;
  left: -3%;
  display: block;
  padding: 0;
  cursor: pointer;
  z-index: 90;
  height: 20px;
  width: 20px;
}
.service02slider .next {
  position: absolute;
  top: 0%;
  bottom: 0;
  margin: auto;
  right: -3%;
  display: block;
  padding: 0;
  cursor: pointer;
  z-index: 90;
  height: 20px;
  width: 20px;
}

/*service03**/
.topservice03wrap{
    background: url("../img/top/bg_service03.jpg") no-repeat top center;
    background-size: cover;
}
.topservice03wrap h2 {
	font-size: 34px;
	color: #fff;
	margin-bottom: 20px;
	text-align: center;
}
.servicebox03{
    background: #fff;
    padding: 50px 10px;
	margin-bottom: 40px;
}
.servicebox03 dl{
    display: flex;
    align-items: center;
    justify-content: center;
}
.servicebox03 dt{
    width: 215px;
	margin-right: 30px;
}
.servicebox03 dd{
}
.servicebox03 dd h2{
    font-size: 24px;
    color: #2c419a;
}
.servicebox03 dd h2 img{
    max-height: 75px;
	margin-right: 20px;
}
.servicebox03 dd p{

}
.blankbtn1{
    font-weight:700;
    display: inline-block;
    background: #ff921e;
    color: #fff;
    padding: 10px 20px;
    border-radius: 99px;
}
.blankbtn1:after{
    content: "";
    display: inline-block;
    height: 12px;
    width: 12px;
    background:url("../img/icon_blank_white.png") no-repeat center center;
    background-size: 12px;
    margin: 0 0 0 10px;
}

/**宅配あんしんポストがお悩みを解決！*/
.topsolutionwrap{
    background: #2c419a;
	position: relative;
}
.topsolutionwrap::after {
    content: "";
    display: block;
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    margin: 0 auto;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 30px 23px 0 23px;
    border-color: #fff transparent transparent transparent;
    z-index: 1;
}
.topsolutiontitle {
    text-align: center;
}
.topsolutiontitle h2{
  font-size: 28px;
  margin: 0 0 20px;
  letter-spacing: .1em;
  display: inline-block;
  padding: 0 50px;
  position: relative;
  color: #fff;
  line-height: 150%;
	font-weight: 600
}
.topsolutiontitle h2 strong{
    color: #fff100;
}
.topsolutiontitle h2::before {
  content: "";
  display: block;
  transform: rotate(-30deg);
  height: 100%;
  border-left: 2px solid #fff;
  position: absolute;
  left: 0;
  top: 0;
}
.topsolutiontitle  h2::after {
    content: "";
    display: block;
    transform: rotate(30deg);
    height: 100%;
    border-left: 2px solid #fff;
    position: absolute;
    right: 0;
    top: 0;
}
.topsolutionbox{
    background: #fff;
    border-radius: 20px;
    padding: 30px 10px;
	text-align: center;
}
.topsolutionbox img{
margin: 0 0 30px;
}
.topsolutionbox dl{
    display: flex;
    align-items: center;
    justify-content: space-between;
    background: #ebf6fe;
    margin: 0 -10px -30px;
    border-radius: 0 0 10px 10px;
    padding: 10px;
    color: #2c419a;
    font-weight: 700;
}
.topsolutionbox dt{
    flex-basis: 50%;
    font-size: 24px;
    text-align: center;
}
.topsolutionbox dd{
	text-align: left;
    flex-basis: 46%;
	line-height: 1.4;
    font-size: 22px;
}
.topsolutionbox li{
    background: url("../img/top/check01.png") no-repeat left center;
    background-size: 20px;
    padding: 0 0 0 25px;
    margin: 5px 0;
}

/**VOICE**/
.topvoicewrap{
    background: #eef6fe;
}
.topvoicetitle{
    background: url("../img/top/bg_voicetitle.jpg") no-repeat center center;
    background-size: cover;
    padding: 92px 0;
    text-align: center;
    margin: 0 0 50px;
}
.topvoicetitle h2{
    font-size: 36px;
    color: #fff;
}
.topvoicetitle h2:after{
    content: ".......";
    color: #ff921e;
    display: block;
    font-size: 30px;
    letter-spacing: .1em;
}
.topvoicebox dl{
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin: 0 3% 20px;
}
.topvoicebox dl:nth-child(1){
    flex-direction: row-reverse;
}
.topvoicebox dt{
    flex-basis: 80%;
    padding: 20px;
    border-radius: 10px;
    background: #2c419a;
    border: 3px solid #2c419a;
    color: #fff;
    position: relative;
}
.topvoicebox dl:nth-child(2) dt{
    background: #fff;
    color: #000;
}
.topvoicebox dl:nth-child(1) dt:after{
     content: "";
  position: absolute;
  top: 50%;
  left: -30px;
  margin-top: -15px;
  border-style: solid;
  border-color: transparent #2c419a transparent transparent;
  border-width: 0 30px 30px 0;
}
.topvoicebox dl:nth-child(2) dt:before{
    content: "";
  position: absolute;
  top: 50%;
  right: -30px;
  margin-top: -15px;
  border-style: solid;
  border-color: transparent transparent transparent  #2c419a;
  border-width: 0 0 30px 30px;
}
.topvoicebox dl:nth-child(2) dt:after{
    content: "";
  position: absolute;
  top: 50%;
  right: -23px;
  margin-top: -12px;
  border-style: solid;
  border-color: transparent transparent transparent  #fff;
  border-width: 0 0 30px 30px;
}


.topvoicebox dd{
    flex-basis: 15%;
    text-align: center;
}
.topvoicebox dd img{
    max-height: 150px;
}
.title01 {
    text-align: center;
    margin: 0 0 45px;
}
.title01 h2{
    font-size: 36px;
	line-height: 1
}
.title01._white h2{
    color: #fff;
}
.title01 h2:after{
    content: ".......";
    color: #ff921e;
    display: block;
    font-size: 30px;
	height: 10px;
    letter-spacing: .1em;
	line-height: .8
}
.featuremenu {
    display: flex;
    flex-wrap: wrap;
}
.featuremenu a{
    display:block;
    flex-basis: 31%;
    margin: 0 1% 20px;
    background: #2c419a url("../img/top/arrow01.png") no-repeat 96% center;
    background-size: 15px;
    color: #fff;
    padding: 10px;
}
.featuremenu dl{
    display: flex;
    align-items: center;
}
.featuremenu dt {
  font-family: "din-condensed", sans-serif;
  font-weight: 400;
  font-style: normal;
  font-size: 25px;
  padding: 5px;
  background: #fff;
  color:  #2c419a;
  flex-basis: 10%;
}
.featuremenu dd{
    font-size: 22px;
    font-weight: 700;
    text-align: center;
    flex-basis: 90%;
}

/**feature**/


.featurebox{
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    align-items: center;
    max-width: 1000px;
    margin: 0 auto 80px; 
}
.featurebox:nth-child(even){
    flex-direction: row-reverse;
}
.featurecont{
    flex-basis: 47%;
    position: relative;
}



.fleatureimg{
    flex-basis: 50%;
    position: relative;
     height: 540px;
}
.fleatureimg:after{
   display: block;
content: "";
height: 100%;
width: 1080px;
position: absolute;
top: 0;

}

._01 .fleatureimg:after{
background: url("../img/top/bg_feature01.png") no-repeat left center;
background-size: cover;
left: 0;
}
._02 .fleatureimg{
    height: 300px;
}
._02 .fleatureimg:after{
background: url("../img/top/bg_feature02.png") no-repeat right center;
background-size: cover;
right:  0;
}

.feat3wrap{
    background: url("../img/top/bg_feature03.png") no-repeat top center;
    background-size: cover;

}
._03 .fleatureimg{
    height: 270px;
    margin-bottom: 30px;
}
._03 .fleatureimg:after{
background: url("../img/top/feature03.png") no-repeat left center;
background-size: cover;
width: 620px;
left:  0;
}
._04 .fleatureimg{
    height: 360px;
}
._04 .fleatureimg:after{
background: url("../img/top/bg_feature04.png") no-repeat right center;
background-size: cover;
right:  0;
}
.feat04box{
    margin-left: 155px;
}
.feat04img{
    position: absolute;
    bottom: -30px;
    left: -220px;
    z-index: 10;
}
._05 .fleatureimg{
    height: 320px;
}
._05 .fleatureimg:after{
background: url("../img/top/bg_feature05.png") no-repeat left center;
background-size: cover;
left:  0;
}
._06 .fleatureimg{
    height: 360px;
}
._06 .fleatureimg:after{
background: url("../img/top/bg_feature06.png") no-repeat right center;
background-size: cover;
right:  0;
}


.featurecont p{
	line-height: 1.6;
    padding: 0 0 20px;
}

.maxclass{
    flex-basis: 100%;
}
.feattitle h2{
    display: flex;
	align-items: center;
	line-height: 1;
    margin: 0 0 20px;
}
.feattitle h2 span{
font-family: "din-condensed", sans-serif;
  font-weight: 600;
  font-style: normal;
  font-size: 20px;
  color: #2c419a;
  display: flex;
  align-items: center;
}
.feattitle h2 span big{
    font-size: 64px;
    padding: 0 30px 0 10px;
}
.feattitle h2 strong{
    font-size: 30px;
}

.maxclass{
    display: flex;
    justify-content: space-between;
    padding: 10px 0;
}
.maxclass dl{
    flex-basis: 50%;
    display: flex;
    align-items: center;
}
.maxclass dt{
    background: #2c419a;
    font-size: 24px;
    font-weight: 700;
    color: #fff;
    padding: 10px 20px 15px;
    margin: 0  20px 0 0;  
}
.feat01cap{
    flex-basis: 48%;
}
.feat06box{
    display: flex;
    justify-content: space-between;
}
.feat06box dl{
    flex-basis: 32%;
    background: #2c419a;
    text-align: center;
    color: #fff;
    padding: 20px 0;
}
.feat06box dt{
    font-size: 20px;
    font-weight: 700;
    padding: 0 0 10px;
}
.feat06box dd{
    line-height: 120%;
}
.feat06box dd sup {
	font-size: 60%;
}

/**スペック***/
.topspecwrap{
    background: #eef6fe;
}
.specimg dl{
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin: 0 0 50px;
}
.specimg dt{
    flex-basis: 50%;
    text-align: center;
}
.specimg dt img{
    max-height: 340px;
}

.specimg dd{
flex-basis: 50%;
}

.specslider{
    position: relative;
    max-width: 420px;
    margin: 0 auto;
}

.specslider .prev {
  position: absolute;
  top: 0%;
  bottom: 0;
  margin: auto;
  left: -10%;
  display: block;
  padding: 0;
  cursor: pointer;
  z-index: 90;
  height: 20px;
  width: 20px;
}
.specslider .next {
  position: absolute;
  top: 0%;
  bottom: 0;
  margin: auto;
  right: -10%;
  display: block;
  padding: 0;
  cursor: pointer;
  z-index: 90;
  height: 20px;
  width: 20px;
}

.topspecbox{
    background: #fff;
    padding: 30px;
}
.specdata{
    display: flex;
    justify-content: space-between;
    margin: 0 0 40px;
}
.specdata table{
    flex-basis: 49%;
    border-collapse: collapse;
}
.specdata th,
.specdata td{
    padding: 5px 10px;
    border-bottom: 1px solid #2c419a;
    font-size: 14px;
}
.specdata th{
    background: #2c419a;
    color: #fff;
    border-color: #fff;
    text-align: left;
}
.specdata tr:last-child th,
.specdata tr:last-child td{
    border: none;
}
.specseat dl{
    display: flex;
    justify-content:space-around;
	align-items: center;
    padding: 0 0 40px;
}
.specseat dt{
    flex-basis: 48%;
	display: flex;
	justify-content: space-between;
}
.specseat dt .img {
	width: 128px;
	min-width: 128px;
	margin-left: 25px;
}
.specseat dd{
    flex-basis: 50%;
}
.specseat h3{
    font-size: 18px;
    padding: 0 0 5px;
}

.specseat ul{
    display: flex;
    align-items: center;
    justify-content: center;
}
.specseat li{
    flex-basis: 49%;
    display: flex;
    align-items: center;
    justify-content: space-between;
}
.specseat li span{
    flex-basis: 60%;
}
.specseat li strong{
    flex-basis: 35%;
}

.downloadbtn01 {
  font-weight: 700;
  display: inline-block;
  border:3px solid #2c419a;
  color: #2c419a;
  padding: 10px 40px;
  border-radius: 99px;
}
.downloadbtn01:after {
  content: "";
  display: inline-block;
  height: 12px;
  width: 12px;
  background: url("../img/top/download.png") no-repeat center center;
    background-size: auto;
  background-size: 12px;
  margin: 0 0 0 10px;
}

.toprease {
	background: #2c419a;
}
.toprease .conceptttl .eng,.toprease .conceptttl h2 {
	color: #fff;
}
.toprease .conceptttl .sub {
	background: #fff;
	color: #2c419a;
	max-width: 400px;
}
.toprease .conceptttl .sub::after {
	border-color: #fff transparent transparent transparent;
}
.reasewrap {
	background: #fff;
	margin-top: 70px;
	padding: 20px 50px 40px;
	position: relative;
	border-radius: 20px;
}
.reasewrap .icon {
	text-align: center;
	position: absolute;
	left: 0;
	right: 0;
	top: -60px;
	z-index: 1;
	margin: 0 auto;
}
.reasettl {
	font-size: 25px;
	font-weight: 800;
	color: #ff921e;
	line-height: 1.1;
	margin-bottom: 15px;
}
.reasettl .sub {
	padding-bottom: 10px;
}
.reasettl h3 {
	font-size: 54px;
	margin-left: 5px;
}
.reasettl h3 big {
	font-size: 180%;
	font-weight: 600;
	vertical-align: -.05em
}
.reasettl + .txt {
	font-size: 22px;
	margin-bottom: 30px;
	font-weight: 600;
	text-align: center;
}
.reaseobox dl {
	flex-basis: 49%;
}
.reaseobox dt {
	width: 100px;
	min-width: 100px;
	margin-right: 10px;
}
.reaseobox dd {
	font-size: 21px;
	font-weight: 800;
	line-height: 1.2
}
.reaseobox dd span {
	font-size: 150%;
	color: #2c419a;
}
.reaseobox dd span big {
	font-size: 250%;
}
.reaseobox dd strong {
	font-size: 30px;
}
.reaseobox dd small {
	font-size: 14px;
	font-weight: 500;

}
.reaseobox dl._01 dd span {
	display: inline-block;
	margin-top: -2.75em;
	line-height: .8
}

/****/
.topflowwrap{
    background: #2c419a;
}
.topflowwrap .conceptttl .eng {
	color: #fff;
}
.topflowwrap .conceptttl .sub {
	max-width: 470px;
}
.topflowwrap .conceptttl .sub span {
	display: block;
	margin-top: -30px;
}
.topflowwrap .conceptttl h2 {
	color: #fff;
}

.flowtitle01{
    text-align: center;
    color: #fff;
	margin-top: 20px;
}
.flowtitle01 h3{
    font-size: 26px;
}
.flowtitle01 h3 strong{
    color: #ff921e;
}
.flowtitle01 h4{
    font-size: 20px;
	font-weight: 500
}

.topflowbox{
    display: flex;
    justify-content: space-between;
    padding: 70px 0 0;
}
.topflowbox dl{
    flex-basis: 22%;
    background: #fff;
    text-align: center;
    padding: 20px;
    position: relative; 
}
.topflowbox dl:after{
  content: "";
  display: block;
  position: absolute;
  left: 107%;
  top: 0;
  bottom: 0;
  margin: auto 0;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 10px 0 10px 10px;
  border-color: transparent transparent transparent #ff921e;
}
.topflowbox dl:last-child:after{
    display: none;
}
.topflowbox dt{
  font-family: "din-condensed", sans-serif;
  font-weight: 400;
  font-style: normal;
  font-size: 36px;
  background: #2c419a;
  border-radius: 99px;
  color: #fff;
  width: 50px;
  height: 50px;
  display: flex;
  align-items: center;
  justify-content: center;
  position: absolute;
  top: -40px;
  left: 0;
  right: 0;
  margin: auto;
}
.topflowbox h3{
    font-size: 22px;
	font-weight: 600;
    margin: 0 0 10px;
    height: 60px;
    display: flex;
    align-items: center;
    justify-content: center;
}
.topflowbox p {
	text-align: left;
}
.topmaintenance {
	background: #eef6fe;
}
.topmaintenance .mainbody {
	max-width: 1200px;
}
.maintettl {
	background: #ff921e;
	padding: 10px;
	margin-top: 65px;
}
.topmaintenance .conceptttl {
	margin-top: -65px;
}
.topmaintenance .conceptttl .eng {
	color: #2c419a
}
.topmaintenance .conceptttl .sub {
	font-size: 28px;
	color: #fff;
	max-width: 725px;
	background: #2c419a;
}
.topmaintenance .conceptttl .sub::after {
	border-color: #2c419a transparent transparent transparent;
}
.topmaintenance .conceptttl h2 {
	color: #fff;
}
.maintearea {
	background: #fff;
	padding: 15px 100px 40px;
}
.maintearea .txt {
	font-size: 22px;
	font-weight: 700;
	margin-bottom: 20px;
	text-align: center;
}
.maintetbl {
}
.maintetbl table {
	padding: 0;
	border-collapse: separate;
  border-spacing: 0;
	width: 100%;
	font-size: 18px;
	font-weight: 500;
	border: 3px solid #2c419a;
	border-radius: 20px;
}
.maintetbl th,
.maintetbl td {
	padding: 5px 25px;
	border:1px solid #2c419a;
	font-weight: 700;
}
.maintetbl td {
	height: 66px
}
.maintetbl th {
	color: #fff;
	background: #2c419a;
	border-bottom-width: 2px;
}
.maintetbl thead th {
	text-align: center;
	padding: 5px 0;
}
.maintetbl thead th:first-of-type {
	border-bottom-color: #fff;
}
.maintetbl .bg-orange {
	background: #ff921e
}
.maintetbl .bg-grey {
	background: #ebf6fe;
	color: #000;
}
.maintetbl tbody tr:nth-of-type(even) {
	background: #fff4e8;
}
.maintetbl tbody tr:nth-of-type(even) td:last-of-type {
	background: #f1f1f1;
	text-align: center;
}
.maintetbl tbody th {
	text-align: left;
	border-top-color: #fff;
	border-bottom-color: #fff;
	border-width: 1px;
	border-top: none;
}
.maintetbl tbody th.dots {
	border-style: dotted;
	border-width: 2px;
	border-top: none;
}
.maintetbl td span {
	color: #ff921e;
}
.maintetbl td img {
	display: block;
	margin: 0 auto;
}
.maintetbl thead th:first-of-type {
	border-radius: 16px 0 0 0;
}
.maintetbl thead th:last-of-type {
	border-radius: 0 16px 0 0;
}
.maintetbl tbody tr:last-of-type th {
	border-radius: 0 0 0 10px;
	border: 2px solid #2c419a;
}
.maintetbl tbody tr:last-of-type td:last-of-type {
	border-radius: 0 0 16px 0;
}
.maintetbl + .note {
	font-size: 14px;
	margin-top: 10px;
}
.changettl {
	background: #ff921e;
	padding: 20px 0;
}
.topchange .conceptttl .eng {
	color: #fff;
}
.topchange .conceptttl .sub {
	background: #fff;
	color: #2c419a;
	max-width: 450px;
}
.topchange .sub::after {
	border-color: #fff transparent transparent transparent;
}
.topchange .conceptttl h2 {
	color: #fff;
}
.topchange .txt {
	text-align: center;
	padding: 30px 0;
	font-size: 26px;
	font-weight: 700
}
.baWrap {
	max-width: 550px;
	margin: 30px auto 80px;
}
.baWrap dl {
	position: relative;
	width: 43%;
	max-width: 350px;
	text-align: center;
}
.baWrap dl:first-of-type::after {
	content: "";
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 45px 0 45px 30px;
	border-color: transparent transparent transparent #2c4196;
	display: block;
	position: absolute;
	right: -24%;
	top: 33%;
}
.baWrap dd {
	margin-top: 20px;
	border: 2px solid #2c4196;
	color: #2c4196;
	border-radius: 90px;
	padding: 5px;
	font-size: 20px;
	font-weight: 700;
	line-height: 1.2;
}
.baWrap dl:nth-child(2) dd {
	background: #2c4196;
	color: #fff;
}
.faqwrap dt {
	background: #2c419a url("../img/top/question.png") center left 36px no-repeat;
	background-size: auto 25px;
	border-radius: 90px;
	font-size: 22px;
	font-weight: 700;
	color: #fff;
	position: relative;
	padding: 5px 40px 5px 85px;
}
.faqwrap dt {
	margin-top: 60px;
}
.faqwrap dd {
	position: relative;
	padding: 5px 40px 0 85px;
	margin-top: 15px;
}
.faqwrap dd::before {
	content: "";
	display: block;
	width: 45px;
	height: 45px;
	background: #ff921e url("../img/top/answer.png") center center no-repeat;
	background-size: auto 23px;
	border-radius: 50%;
	position: absolute;
	top: 0;
	left: 25px;
}


/*コンテンツ
------------------------------------------------*/





/*********************************/
/* PC用のスタイル記述ここから */
/*********************************/
/*@media print, screen and (min-width: 769px) {*/
@media print, screen and (min-width: 621px) {	
img {
    image-rendering: -webkit-optimize-contrast;
}




.gnavi{
	display: block!important;
}


.leftbox{
	display:inline-block;
	float:left;
	padding:0px 10px 0px 0;
}
.rightbox{
	display:inline-block;
	float:right;
	padding:0px 0 0px 10px;
}




}





/*********************************/
/* タブレット用のスタイル記述 */
/*********************************/
/*@media screen and (max-width: 768px) {*/
@media only screen and (min-device-width: 768px) and (max-device-width: 1024px) {



}
/*********************************/
/* スマートフォン用のスタイル記述 */
/*********************************/
@media screen and (max-width: 620px) {



.slick-slider {
    touch-action: pan-y;
}


a:hover{
	opacity:1;
}



.wrap,
.home .wrap{

}

.mainbody,
.mainbody2,
.header .mainbody{
	margin:0 auto;
	width:auto;
}

/*
#a01,
#a02,
#a03,
#a04,
#a05,
#a06,
#reserve,
#mw_wp_form_mw-wp-form-27{
   display: block;
   margin-top:-70px;
   padding-top:70px;
}
*/
.contents{
    padding: 30px 0;
}
	.feattitle h2 span big {
		font-weight: 400;
	}


/*ヘッダー
------------------------------------------------*/






/*フッター
------------------------------------------------*/







/*トップページ
------------------------------------------------*/
/**メインビジュアル**/





/*コンテンツ
-----------------------------------------------*/


















/**お問い合わせ***/



.onlypc{
	display:none;
}
.onlysp{
	display: block;
}



.spblock{
	display: block;
}

}





/*safariのみ**/
_::-webkit-full-page-media, _:future, :root .contacttel dd{
  
}


/*ieのみ*/
@media all and (-ms-high-contrast: none) {


}

