@charset "utf-8";
/* CSS Document */

.grecaptcha-badge{
margin-bottom: 110px;
}

.g-recaptcha{
	display: flex;
	justify-content: center;
	padding: 1.5em 0;
}


/*------------------------------------------*/
/*背景色*/
.bg_beige{
    background-color: #FFFCF3;
}

.bg_lightblue{
    background-color: #EBFCFC;
}

/*------------------------------------------*/
/*フォントサイズ*/
.f17{
    font-size: 1.3rem;
}
.f18{
    font-size: 1.5rem;
}
.f20{
    font-size: 1.5rem;
}
.f22{
    font-size: 1.5rem;
}
.f24{
    font-size: 1.4rem;
}

.spf12{
    font-size: 1.2rem;
}
.spf13{
    font-size: 1.3rem;
}
.spf14{
    font-size: 1.4rem;
}
.spf15{
    font-size: 1.5rem;
}
.spf16{
    font-size: 1.6rem;
}
.spf17{
    font-size: 1.7rem;
}
.spf18{
    font-size: 1.8rem;
}

/*行間*/
.lh175{
    line-height: 175%;
}

/*字間*/
.ls20{
    letter-spacing: 0.02em;
}
.ls40{
    letter-spacing: 0.04em;
}
.ls50{
    letter-spacing: 0.05em;
}
.ls100{
    letter-spacing: 0.1em;
}

/*テキスト色*/
.black{
    color: #000;
}
.gray{
    color: #333;
}

/*------------------------------------------*/
/*余白（marin）*/
.mt15{
    margin-top: 8px;
}
.mt20{
    margin-top: 10px;
}
.mt25{
    margin-top: 13px;
}
.mt30{
    margin-top: 15px;
}
.mt35{
    margin-top: 18px;
}
.mt40{
    margin-top: 20px;
}
.mt45{
    margin-top: 23px;
}
.mt50{
    margin-top: 25px;
}
.mt55{
    margin-top: 28px;
}
.mt60{
    margin-top: 30px;
}
.mt65{
    margin-top: 33px;
}
.mt70{
    margin-top: 35px;
}
.mt75{
    margin-top: 38px;
}
.mt80{
    margin-top: 40px;
}
.mt85{
    margin-top: 43px;
}
.mt90{
    margin-top: 45px;
}
.mt100{
    margin-top: 50px;
}
.mt110{
    margin-top: 55px;
}
.mt120{
    margin-top: 60px;
}
.mt130{
    margin-top: 65px;
}
.mt140{
    margin-top: 72px;
}
.mt145{
    margin-top: 70px;
}

.mb30{
    margin-bottom: 15px;
}
.mb65{
    margin-bottom: 33px;
}
.mb70{
    margin-bottom: 35px;
}
.mb80{
    margin-bottom: 40px;
}
.mb85{
    margin-bottom: 43px;
}
.mb120{
    margin-bottom: 60px;
}
.mb140{
    margin-bottom: 70px;
}
.mb160{
    margin-bottom: 80px;
}

/*------------------------------------------*/
/*余白（padding）*/
.pt25{
    padding-top: 13px;
}
.pt65{
    padding-top: 33px;
}
.pt70{
    padding-top: 35px;
}
.pt75{
    padding-top: 38px;
}
.pt85{
    padding-top: 43px;
}
.pt90{
    padding-top: 45px;
}
.pt100{
    padding-top: 50px;
}
.pt115{
    padding-top: 58px;
}

.pb30{
    padding-bottom: 15px;
}
.pb65{
    padding-bottom: 33px;
}
.pb70{
    padding-bottom: 35px;
}
.pb80{
    padding-bottom: 40px;
}
.pb85{
    padding-bottom: 43px;
}
.pb95{
    padding-bottom: 48px;
}
.pb100{
    padding-bottom: 50px;
}
.pb120{
    padding-bottom: 60px;
}
.pb130{
    padding-bottom: 65px;
}
.pb135{
    padding-bottom: 68px;
}
.pb140{
    padding-bottom: 70px;
}
.pb170{
    padding-bottom: 85px;
}
.pb185{
    padding-bottom: 93px;
}

/*------------------------------------------*/
/*横幅*/
.block_inner.w1000{
    width: 84.72%;/*610*/
    margin: 0 auto;
}

/*------------------------------------------*/
/*小見出し*/
.block_inner h3.type01{
    position: relative;
    padding: 0 0 0 1.35rem;/*20*/
    font-weight: 500;
    letter-spacing: 0.1em;
}
.block_inner h3.type01::before{
    content: '';
    display: block;
    background-color: #EC5A24;
    width: 0.34rem;/*5*/
    height: 0.14rem;/*2*/
    position: absolute;
    top: 50%;
    left: 0;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
}

.block_inner h3.type02{
    position: relative;
    letter-spacing: 0.1em;
}
.block_inner h3.type02::before{
    content: '';
    display: block;
    background: rgb(230,28,36);
    background: -moz-linear-gradient(90deg, rgba(230,28,36,1) 0%, rgba(218,225,81,1) 100%);
    background: -webkit-linear-gradient(90deg, rgba(230,28,36,1) 0%, rgba(218,225,81,1) 100%);
    background: linear-gradient(90deg, rgba(230,28,36,1) 0%, rgba(218,225,81,1) 100%);
    filter: progid:DXImageTransform.Microsoft.gradient(startColorstr="#e61c24",endColorstr="#dae151",GradientType=1);
    width: 100%;
    height: 2px;
    position: absolute;
    bottom: 0;
    left: 0;
}
.block_inner h3.type02 p{
    padding: 0 0 1.08rem 0;/*16*/
    color: #E2400E;
    font-weight: 500;
}

.block_inner h4.type01{
    font-weight: 500;
    letter-spacing: 0.06em;
    text-align: center;
}
.block_inner h4.type01.blue{
    color: #0071B7;
}
.block_inner h4.type01.orange{
    color: #EC5A24;
}

/*-----------------------------------------------------------*/

select {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
}

/*-----------------------------------------------------------*/
/*インフォメーション*/

.block01{
    position: relative;
}
.block01::after{
    content: '';
    display: block;
    width: 100%;
    height: 140px;
    background: url("../images/contact/img01sp.jpg") no-repeat;
    background-size: cover;
    background-position: center bottom;
    position: absolute;
    bottom: 0;
    left: 0;
    z-index: -1;
}

.block01 .catchtxts{
    line-height: 169%;
    letter-spacing: 0.1em;
}

.block_inner .info{
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    height: 280px;
    border: 1px solid #C7C7C7;
    box-sizing: border-box;
    background-color: #fff;
}

.block_inner .info dl{
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}

.block_inner .info dl:nth-child(1){
    border-bottom: 1px solid #C7C7C7;
    box-sizing: border-box;
    padding-bottom: 20px;
}
.block_inner .info dl:nth-child(1) dt{
}
.block_inner .info dl:nth-child(1) dt .tocontact:first-of-type{
    margin-bottom: 10px;
}
.block_inner .info dl:nth-child(1) dt .tocontact span{
    font-size: 14px;
}
.block_inner .info dl:nth-child(1) dt .tocontact p{
    font-size: 24px;
    line-height: 100%;
}
.block_inner .info dl:nth-child(1) dt a{
}
.block_inner .info dl:nth-child(1) dd{
    margin-top: 15px;
    font-size: 14px;
    color: #666666;
}

.block_inner .info dl:nth-child(2){
    padding-top: 20px;
}
.block_inner .info dl:nth-child(2) dt .link_btn{
    width: 265px;
    height: 62px;
}
.block_inner .info dl:nth-child(2) dt .link_btn a{
    font-size: 1.7rem;
}
.block_inner .info dl:nth-child(2) dt .link_btn a::after {
    content: '';
    display: inline-block;
    background: url("../images/contact/icon_link@2x.png")no-repeat;
    background-size: contain;
    width: 16px;
    height: 8px;
    position: absolute;
    top: 50%;
    right: 20px;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);    
    z-index: 2;
}

/*--------------------------------------------------*/
/*お問い合わせフォーム*/

.hidden-fields-container{
	display: none;
}

.block02 .flow{
    border-bottom: 1px solid #AEAEAE;
    display: flex;
}
.block02 .flow dl{
    margin: 0 5px;
    width: calc( 100% / 3 - 30px );
    background-color: #E6E6E6;
    padding: 10px 15px;
}
.block02 .flow dl.current{
    background-color: #EC5A24;
    color: #fff;
}

/*ここからフォーム*/
.block02 .fromwrap{
    width: 100%;
    margin: 0 auto;
    color: #353535;
}

.block02 .fromwrap dl{
}
.block02 .fromwrap dl:not(:last-of-type){
    margin-bottom: 23px;
}

.block02 .fromwrap dl dt{
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
}
.block02 .fromwrap dl dt .necessity{
    width: 39px;
    height: 25px;
    background-color: #EC2028;
    -webkit-border-radius: 4px;
    -moz-border-radius: 4px;
    border-radius: 4px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.3rem;
    color: #fff;
}
.block02 .fromwrap dl dt .necessity.not{
    background-color: #AEAEAE;
}

.block02 .fromwrap dl dt .label{
    width: calc( 100% - 49px );
    font-size: 1.4rem;
}

.block02 .fromwrap dl dd{
    width: 100%;
    margin-top: 10px;
    position: relative;
}
.block02 .fromwrap dl dd .field{
    width: 100%;
}

/*textに単位をつける*/
.block02 .fromwrap dl dd .field span.unit{
    display: inline-block;
    padding-left: 12px;
}
/*注釈*/
.block02 .fromwrap dl dd .absotxt{
    position: absolute;
    right: 0;
    top: -32px;
    font-size: 1.1rem;
}

.block02 .fromwrap dl dd input[type=text],
.block02 .fromwrap dl dd input[type=tel],
.block02 .fromwrap dl dd input[type=email]{
    background-color: #fff;
    border: 1px solid #949494;
    box-sizing: border-box;
    width: 100%;
    height: 40px;
    padding: 0 5px;
}
.block02 .fromwrap dl dd input[type=text].p50,
.block02 .fromwrap dl dd input[type=tel].p50{
    width: 100%;
}
.block02 .fromwrap dl dd input[type=text].p40{
    width: 100%;
}
.block02 .fromwrap dl dd input[type=text].p10{
    width: 13.89%;/*100*/
}
.block02 .fromwrap dl dd input[type=text].flexfull{
    width: 100%;
}
.block02 .fromwrap dl dd input[type=text].r80{
    width: 63px;
}
/*inputを並べた時に余白をつける*/
.block02 .fromwrap dl dd input[type=text].flex{
    width: 40%;
    margin-left: 5px;
}
.block02 .fromwrap dl dd textarea{
    background-color: #fff;
    border: 1px solid #949494;
    box-sizing: border-box;
    width: 100%;
    height: 150px;
    padding: 5px;
}

/*注意書きあり*/
.block02 .fromwrap dl.example dd{
    padding-bottom: 20px;
}

/*注意事項あり*/
.block02 .fromwrap dl dd.comment{
    display: block;
}
.block02 .fromwrap dl dd.comment .commenttxt{
    font-size: 1.4rem;
    color: #575757;
}

/*プライバシーポリシー*/
.block02 .fromwrap dl.agreement{
    align-items: normal;
}
.block02 .fromwrap dl.agreement dd{
	width: calc( 100% - 20px );
    height: 45px;
    background-color: #F2F2F2;
	padding: 0 10px;
    display: flex;
    align-items: center;
    font-size: 1.3rem;
    color: #000;
}
.block02 .fromwrap dl.agreement dd a{
    text-decoration: underline;
    font-weight: 400;
}

/*プルダウン*/
.block02 .fromwrap dl.pulldown dd .field{
    display: flex;
    align-items: center;
}
.block02 .fromwrap dl.pulldown dd p{
    width: 100%;
    position: relative;
}
.block02 .fromwrap dl.pulldown dd p::after{
    content: "";
    display: block;
    background: url("../images/contact/icon_circle@2x.png") no-repeat;
    background-size: contain;
    background-position: center;
    width: 13px;
    height: 11px;
    position: absolute;
    top: 0;
    bottom: 0;
    margin: auto;
    right: 18px;
    pointer-events: none;
}
.block02 .fromwrap dl.pulldown dd select{
    width: 100%;
    height: 40px;
    border: 1px solid #000;
    -webkit-border-radius: 5px;
    -moz-border-radius: 5px;
    border-radius: 5px;
    background-color: #fff;
    font-size: 1.4rem;
    padding: 0 10px;
    position: relative;
}

/*ラジオボタン*/
dl.agreement dd .wpcf7-radio, dl.agreement dd .wpcf7-radio label{
	display: flex;
    align-items: center;
}
 dl.agreement dd .wpcf7-radio label{
	gap: 0 10px;
}
.wpcf7-radio input[type=radio]{
    width: 26px;
    height: 26px;
    border: 1px solid #000;
    box-sizing: border-box;
    -webkit-border-radius: 50%;
    -moz-border-radius: 50%;
    border-radius: 50%;
    background-color: #fff;
}

/*注意書き*/
.block02 .fromwrap .notes{
	margin: 45px auto 0;
    letter-spacing: 0.05em;
	color: #EC2028;
	text-align: center;
}

/**送信ボタン*/
.block02 .fromwrap .btns{
    width: 51.39%;/*370*/
    margin: 45px auto 0;
}
.block02 .fromwrap .btns div:not(:first-child){
    margin: 15px auto 0;
}

.block02 .fromwrap .btns .send p, .block02 .fromwrap .btns .back p{
    width: 100%;
    height: 57px;
    position: relative;
}
.block02 .fromwrap .btns .send p::after{
    content: '';
    display: inline-block;
    background: url(../images/top/large_link_ico@2x.png)no-repeat;
    background-size: contain;
    width: 52px;
    height: 14px;
    position: absolute;
    top: 13px;
    right: -21px;
    z-index: 2;
}
.block02 .fromwrap .btns .back p::after{
    content: '';
    display: inline-block;
    background: url("../images/contact/icon_back@2x.png")no-repeat;
    background-size: contain;
    width: 16px;
    height: 16px;
    position: absolute;
    top: 19px;
    right: 12px;
    z-index: 2;
}

.block02 .fromwrap .btns .send input, .block02 .fromwrap .btns .back input{
    width: 100%;
    height: 100%;
    -webkit-border-radius: 6px;
    -moz-border-radius: 6px;
    border-radius: 6px;    
    box-shadow: 0px 0px 5px 1px rgba(134,150,155,0.55);
    border: 2px solid #fff;
    box-sizing: border-box;
    font-size: 1.4rem;
    font-weight: 500;
    letter-spacing: 0.1em;
}
.block02 .fromwrap .btns .send input{
    background: rgb(240,171,30);
    background: linear-gradient(90deg, rgba(240,171,30,1) 0%, rgba(232,6,0,1) 100%);    
    -webkit-border-radius: 6px;
    -moz-border-radius: 6px;
    border-radius: 6px;    
    color: #fff;
}    
.block02 .fromwrap .btns .back input{
    background-color: #fff;
    color: #000;
    border: 1px solid #000;
    box-sizing: border-box;
}    

/*確認画面*/
.block02 #form-tbl{
    width: 100%;
    margin: 0 auto;
}
.block02 #form-tbl table{
    width: 100%;
}
.block02 #form-tbl table th, .block02 #form-tbl table td{
    display: block;
    width: 100%;
}

.block02 #form-tbl table tr th{
    text-align: left;
    padding-bottom: 10px;
}
.block02 #form-tbl table tr td{
    padding-bottom: 20px;
}
.block02 #form-tbl table tr td span.msg{
    color: #EC2028;
}

/*--------------------------------------------------*/

/*送信ボタン*/
.sendbtns{
    margin: 34px auto 59px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 0 15px;
}

.sendbtns input[type=submit], .sendbtns input[type=button]{
    cursor: pointer;
    border: 0;
    width: 176px;
    height: 52px;
    -webkit-border-radius: 10px;
    -moz-border-radius: 10px;
    border-radius: 10px;    
    font-size: 14px;
    color: #fff;
    letter-spacing: 0.1em;
    font-weight: bold;
    position: relative;
    box-shadow: 0px 0px 15px 1px rgba(167,183,193,0.35);
}
.sendbtns .back input[type=submit], .sendbtns .back input[type=button]{
    color: #000;
}

.sendbtns .next, .sendbtns .back{
    margin: 5px auto;
    position: relative;
}
.sendbtns .next::after, .sendbtns .back::after{
    content: '';
    display: block;
    background: url("../image/contact/icon_arrowsp.png") no-repeat;
    background-size: contain;
    width: 23px;
    height: 23px;
    position: absolute;
    top: 0;
    bottom: 0;
    margin: auto;
}
.sendbtns .next::after{
    right: 15px;
}
.sendbtns .back::after{
    background: url("../image/contact/icon_arrow2.png") no-repeat;
    background-size: contain;
    transform: scale(-1, 1);
    right: auto;
    left: 8px;
}

.sendbtns input[type=submit]{
    background-color: #000;
}
.sendbtns input[type=button]{
    background-color: #fff;
    border: 1px solid #000;
    box-sizing: border-box;
}

/*--------------------------------------------------*/
/*確認画面*/

.steplists.margin{
    margin: 35px auto 0;    
}

#form_wrap .infotxt{
    width: 100%;
    margin: 35px auto 0;    
    text-align: center;
    font-size: 14px;
}

#form-tbl{
    width: calc( 100% - 24px );
    margin: 30px auto 0;    
}

#form-tbl table{
    width: 100%;
    font-size: 14px;
}
#form-tbl table tr{
    display: block;
    border-bottom: 1px solid #949494;
    padding: 20px 0;
}
#form-tbl table tr th{
    display: block;
    width: 100%;
    text-align: left;
    margin-bottom: 10px;
}
#form-tbl table tr td{
    display: block;
    width: 100%;
}
#form-tbl table tr td .msg{
    color: #E81C24;
}

/*--------------------------------------------------*/
/*個人情報保護方針*/

.block03 .lists dl{
    font-size: 1.3rem;
    line-height: 156%;
}
.block03 .lists dl:first-of-type{
    margin-top: 23px;
}
.block03 .lists dl:not(:last-of-type){
    margin-bottom: 23px;
}
.block03 .lists dl dt{
    font-size: 1.4rem;
    letter-spacing: 0.05em;
    font-weight: 700;
    margin-bottom: 5px;
}
.block03 .lists dl dd:not(:first-of-type){
    margin-top: 1em;
}
.block03 .lists dl dd a{
    text-decoration: underline;
}

.block03 .tool dl{
    font-size: 1.3rem;
}
.block03 .tool dl dt{
    padding-bottom: 10px;
    border-bottom: 1px solid #AEAEAE;
    text-align: center;
}
.block03 .tool dl dd{
    padding-top: 10px;
    line-height: 156%;
}

/*--------------------------------------------------*/
/*--------------------------------------------------*/
/*--------------------------------------------------*/
/*--------------------------------------------------*/
/*--------------------------------------------------*/
/*--------------------------------------------------*/
/*--------------------------------------------------*/
/*--------------------------------------------------*/
/*--------------------------------------------------*/
/*--------------------------------------------------*/