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

.grecaptcha-badge{
margin-bottom: 8.45rem;/*125*/
}

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

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

.bg_lightblue{
    background-color: #EBFCFC;
}

/*------------------------------------------*/
/*フォントサイズ*/
.f17{
    font-size: 106.3%;
}
.f18{
    font-size: 112.5%;
}
.f20{
    font-size: 125.0%;
}
.f22{
    font-size: 157.1%;
}
.f24{
    font-size: 150.0%;
}
.f25{
    font-size: 156.3%;
}

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

/*字間*/
.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;
}

/*文字位置*/
.center{
    text-align: center;
}

/*------------------------------------------*/
/*余白（marin）*/
.mt15{
    margin-top: 1.01rem;
}
.mt20{
    margin-top: 1.35rem;/*20*/
}
.mt25{
    margin-top: 1.69rem;/*25*/
}
.mt30{
    margin-top: 2.03rem;/*30*/
}
.mt35{
    margin-top: 2.36rem;/*35*/
}
.mt40{
    margin-top: 2.70rem;/*40*/
}
.mt45{
    margin-top: 3.04rem;/*45*/
}
.mt50{
    margin-top: 3.38rem;/*50*/
}
.mt55{
    margin-top: 3.72rem;/*55*/
}
.mt60{
    margin-top: 4.05rem;
}
.mt65{
    margin-top: 4.39rem;/*65*/
}
.mt70{
    margin-top: 4.73rem;/*70*/
}
.mt75{
    margin-top: 5.07rem;
}
.mt80{
    margin-top: 5.41rem;/*80*/
}
.mt85{
    margin-top: 5.74rem;
}
.mt90{
    margin-top: 6.08rem;/*90*/
}
.mt100{
    margin-top: 6.76rem;/*100*/
}
.mt110{
    margin-top: 9.80rem;
}
.mt120{
    margin-top: 8.11rem;
}
.mt130{
    margin-top: 8.78rem;
}
.mt140{
    margin-top: 9.46rem;
}
.mt145{
    margin-top: 9.46rem;
}

.mb30{
    margin-bottom: 2.03rem;/*30*/
}
.mb65{
    margin-bottom: 4.39rem;/*65*/
}
.mb70{
    margin-bottom: 4.73rem;
}
.mb80{
    margin-bottom: 5.41rem;/*80*/
}
.mb85{
    margin-bottom: 5.74rem;
}
.mb120{
    margin-bottom: 8.11rem;/*120*/
}
.mb140{
    margin-bottom: 9.46rem;/*140*/
}
.mb160{
    margin-bottom: 10.81rem;
}

/*------------------------------------------*/
/*余白（padding）*/
.pt25{
    padding-top: 1.69rem;/*25*/
}
.pt35{
    padding-top: 2.36rem;
}
.pt65{
    padding-top: 4.39rem;
}
.pt70{
    padding-top: 4.73rem;
}
.pt75{
    padding-top: 5.07rem;
}
.pt85{
    padding-top: 5.74rem;
}
.pt90{
    padding-top: 6.08rem;/*90*/
}
.pt100{
    padding-top: 6.76rem;
}
.pt115{
    padding-top: 7.77rem;
}

.pb30{
    padding-bottom: 2.03rem;/*30*/
}
.pb65{
    padding-bottom: 4.39rem;/*65*/
}
.pb70{
    padding-bottom: 4.73rem;/*70*/
}
.pb80{
    padding-bottom: 5.41rem;/*80*/
}
.pb85{
    padding-bottom: 5.74rem;
}
.pb95{
    padding-bottom: 6.42rem;
}
.pb100{
    padding-bottom: 6.76rem;/*100*/
}
.pb120{
    padding-bottom: 8.11rem;/*120*/
}
.pb130{
    padding-bottom: 8.78rem;
}
.pb135{
    padding-bottom: 9.12rem;
}
.pb140{
    padding-bottom: 9.46rem;/*140*/
}
.pb170{
    padding-bottom: 11.4rem;
}
.pb185{
    padding-bottom: 12.50rem;
}

/*------------------------------------------*/
/*横幅*/
.block_inner.w1000{
    max-width: 67.57rem;/*1000*/
    width: 100%;
    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.1em;
    text-align: center;
}
.block_inner h4.type01.blue{
    color: #0071B7;
}
.block_inner h4.type01.orange{
    color: #EC5A24;
}
.block_inner .imgtxts h4.type01 {
    text-align: left;
    letter-spacing: 0.06em;
    line-height: 160%;
}

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

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

.block01 .catchtxts{
    letter-spacing: 0.05em;
}

.block_inner .info{
    display: flex;
    align-items: center;
    height: 16.55rem;
    border: 1px solid #C7C7C7;
    box-sizing: border-box;
    background-color: #fff;
}

.block_inner .info dl{
    width: 50%;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}
.block_inner .info dl:nth-child(1){
    position: relative;
}
.block_inner .info dl:nth-child(1)::after{
    content: '';
    width: 1px;
    height: 8.31rem;/*123*/
    background-color: #C7C7C7;
    position: absolute;
    top: 50%;
    right: 0;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);  
}
.block_inner .info dl:nth-child(1) dt{
}
.block_inner .info dl:nth-child(1) dt .tocontact:first-of-type{
    margin-bottom: 1.01rem;/*15*/
}
.block_inner .info dl:nth-child(1) dt .tocontact span{
    font-size: 112.5%;/*18*/
}
.block_inner .info dl:nth-child(1) dt .tocontact p{
    font-size: 243.8%;/*39*/
    line-height: 100%;
}
.block_inner .info dl:nth-child(1) dt a{
    pointer-events: none;
}
.block_inner .info dl:nth-child(1) dd{
    font-size: 112.5%;/*18*/
    color: #666666;
    margin-top: 0.68rem;/*10*/
}

.block_inner .info dl:nth-child(2){ 
}
.block_inner .info dl:nth-child(2) dt .link_btn{
    width: 24.32rem;/*360*/
    height: 5.74rem;/*85*/
}

.block_inner .info dl:nth-child(2) dt .link_btn a::after {
    content: '';
    display: inline-block;
    background: url(../images/contact/icon_link.png)no-repeat;
    background-size: contain;
    width: 1.69rem;/*25*/
    height: 0.95rem;/*14*/
    position: absolute;
    top: 2.36rem;/*35*/
    right: 2.03rem;/*30*/
    transition: 0.3s;
    z-index: 2;
}
.block_inner .info dl:nth-child(2) dt .link_btn a:hover::after {
    background: url(../images/contact/icon_linkh.png)no-repeat;
    background-size: contain;
}

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

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

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

.block02 .flow{
    border-bottom: 1px solid #AEAEAE;
    display: flex;
    justify-content: center;
    text-align: center;
}
.block02 .flow dl{
    margin: 0 0.61rem;/*9*/
    width: 13.04rem;/*193*/
    height: 2.97rem;/*44*/
    display: flex;
    justify-content: center;
    align-items: center;
    background-color: #E6E6E6;
}
.block02 .flow dl.current{
    background-color: #EC5A24;
    color: #fff;
}
.block02 .flow dl dt{
    padding-right: 1.01rem;/*15*/
}

/*ここからフォーム*/
.block02 .fromwrap{
    color: #353535;
}

.block02 .fromwrap dl{
    width: calc( 100% - 4.05rem );/*60*/
    margin: 0 auto;
    display: flex;
    align-items: baseline;
}
.block02 .fromwrap dl:not(:last-of-type){
    margin: 0 auto 3.38rem;/*50*/
}
/*テキストエリア*/
.block02 .fromwrap dl.txtarea {
    align-items: flex-start;
}

.block02 .fromwrap dl dt{
    width: 18.24rem;/*270*/
    display: flex;
    align-items: center;
}
.block02 .fromwrap dl dt .necessity{
    width: 3.18rem;/*47*/
    height: 2.57rem;/*38*/
    background-color: #EC2028;
    -webkit-border-radius: 5px;
    -moz-border-radius: 5px;
    border-radius: 5px;
    display: flex;
    align-items: center;
    justify-content: center;    
    color: #fff;
}
.block02 .fromwrap dl dt .necessity.not{
    background-color: #AEAEAE;
}

.block02 .fromwrap dl dt .label{
    width: calc( 100% - 4.53rem )/*47+20*/;
    padding-left: 1.35rem;/*20*/
}

.block02 .fromwrap dl dd{
    width: calc( 100% - 18.24rem );
    display: flex;
    align-items: center;
    position: relative;
}
.block02 .fromwrap dl dd .field{
    width: 100%;
}

/*注釈*/
.block02 .fromwrap dl dd .absotxt{
    position: absolute;
    top: 0.75rem;
    left: 54.3%;/*365*/
}

.block02 .fromwrap dl dd input[type=text],
.block02 .fromwrap dl dd input[type=tel],
.block02 .fromwrap dl dd input[type=email]{
    background-color: #F9F9F9;
    border: 1px solid #949494;
    box-sizing: border-box;
    width: 100%;
    height: 3.38rem;/*50*/
    padding: 0 1.08rem;/*16*/
	font-family: 'Noto Sans JP', sans-serif;
	font-weight: 500;
	font-style: normal;
	font-size: 1.08rem;/*16*/
	color: #000000;
}
.block02 .fromwrap dl dd input[type=text].p50,
.block02 .fromwrap dl dd input[type=tel].p50{
    width: 50%;
}
.block02 .fromwrap dl dd input[type=text].p40{
    width: 43.2%;
}
.block02 .fromwrap dl dd input[type=text].p10{
    width: 9.2%;
}
.block02 .fromwrap dl dd input[type=text].flexfull{
    width: calc( 100% - 9rem );
}
.block02 .fromwrap dl dd input[type=text].r80{
    width: 5.27rem;/*78*/
}

.block02 .fromwrap dl dd textarea{
    background-color: #F9F9F9;
    border: 1px solid #949494;
    box-sizing: border-box;
    width: 100%;
    height: 15.54rem;/*230*/
    padding: 1.08rem;/*16*/
	font-family: 'Noto Sans JP', sans-serif;
	font-weight: 500;
	font-style: normal;
	font-size: 1.08rem;/*16*/
	line-height: 1.5;
	color: #000000;
}

/*注意事項あり*/
.block02 .fromwrap dl dd.comment{
    display: block;
}
.block02 .fromwrap dl dd.comment .commenttxt{
    font-size: 87.5%;/*14*/
    font-weight: 400;
    color: #575757;
}

/*ラジオボタン*/
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: 2.03rem;/*30*/
    height: 2.03rem;/*30*/
    border: 1px solid #000;
    box-sizing: border-box;
    -webkit-border-radius: 50%;
    -moz-border-radius: 50%;
    border-radius: 50%;
    background-color: #fff;
}

/*ラジオボタン複数*/
.block02 .fromwrap dl.radio dd ul li:not(:last-child){
    margin-bottom: 2.36rem;/*35*/
}
/*プライバシーポリシー*/
.block02 .fromwrap dl.agreement{
    align-items: normal;
}
.block02 .fromwrap dl.agreement dd{
    height: 3.38rem;/*50*/
    background-color: #F2F2F2;
	padding: 0 15px;
}
.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.png") no-repeat;
    background-size: contain;
    background-position: center;
    width: 1.42rem;/*21*/
    height: 1.01rem;/*15*/
    position: absolute;
    top: 0;
    bottom: 0;
    margin: auto;
    right: 0.88rem;/*13*/
    pointer-events: none;
}
.block02 .fromwrap dl.pulldown dd select{
    width: 100%;
    height: 3.38rem;/*50*/
    border: 1px solid #000;
    -webkit-border-radius: 10px;
    -moz-border-radius: 10px;
    border-radius: 10px;
    background-color: #fff;
    padding: 0 1.08rem;/*16*/
    position: relative;
	font-family: 'Noto Sans JP', sans-serif;
	font-weight: 500;
	font-style: normal;
	font-size: 100%;
	color: #000000;
}

/*注意書き*/
.block02 .fromwrap .notes{
	margin: 4.73rem auto 0;
	font-size: 120.0%;
    letter-spacing: 0.05em;
	color: #EC2028;
	text-align: center;
}

/**送信ボタン*/
.block02 .fromwrap .btns{
    width: 44.93rem;/*665*/
    margin: 4.73rem auto 0;/*70*/
    display: flex;
    justify-content: center;
}

.block02 .fromwrap .btns .send, .block02 .fromwrap .btns .back{
    width: 17.9rem;/*265*/
    height: 5.61rem;/*83*/
    display: flex;
    justify-content: center;
    align-items: center;
    position: relative;
    margin: 0 3.04rem;/*45*/
    -webkit-border-radius: 6px;
    -moz-border-radius: 6px;
    border-radius: 6px;    
    box-shadow: 0px 0px 5px 1px rgba(134,150,155,0.55);
    transition: all .5s ease;
    padding: 2px;
}
.block02 .fromwrap .btns .send{
    background: #ffffff;
}
.block02 .fromwrap .btns .back{
    background: #000;
}
.block02 .fromwrap .btns .send:hover{
    background: linear-gradient(90deg, rgba(240,171,30,1) 3%, rgba(232,6,0,1) 97%);
}
.block02 .fromwrap .btns .back:hover{
    background: #000;
}
.block02 .fromwrap .btns .send::after{
    content: '';
    display: inline-block;
    background: url(../images/top/large_link_ico@2x.png)no-repeat;
    background-size: contain;
    width: 5.41rem;
    height: 1.69rem;
    position: absolute;
    top: 1.22rem;
    right: -2.43rem;
    transition: 0.3s;
    z-index: 2;
}
.block02 .fromwrap .btns .send:hover::after{
	right: -3.04rem;/*-45*/
}
.block02 .fromwrap .btns .back::after{
    content: '';
    display: inline-block;
    background: url("../images/contact/icon_back.png")no-repeat,url("../images/contact/icon_backh.png")no-repeat;
    background-size: contain;
    width: 2.09rem;/*31*/
    height: 2.09rem;/*31*/
    position: absolute;
    top: 1.62rem;/*24*/
    right: 1.62rem;/*24*/
    transition: 0.3s;
    z-index: 2;
}
.block02 .fromwrap .btns .back:hover::after{
    background: url("../images/contact/icon_backh.png")no-repeat;
    background-size: contain;
}

.block02 .fromwrap .btns .send p, .block02 .fromwrap .btns .back p{
	width: 100%;
	height: 100%;
}

.block02 .fromwrap .btns .send input{
    width: 100%;
    height: 100%;
    font-size: 125.0%;/*20*/
    letter-spacing: 0.1em;
    font-weight: 500;
    color: #fff;
    background: linear-gradient(90deg, rgba(240,171,30,1) 3%, rgba(232,6,0,1) 97%);
    -webkit-border-radius: 6px;
    -moz-border-radius: 6px;
    border-radius: 6px;
    padding: 0;    
}
.block02 .fromwrap .btns .back input{
    width: 100%;
    height: 100%;
    background: #fff;
    -webkit-border-radius: 6px;
    -moz-border-radius: 6px;
    border-radius: 6px;
    padding: 0;    
    
    font-size: 125.0%;/*20*/
    letter-spacing: 0.1em;
    font-weight: 500;
}

.block02 .fromwrap .btns input:hover{
    transition: all .5s ease;
}
.block02 .fromwrap .btns .send input:hover{
    background: #fff;
    color: #E55523;
}    
.block02 .fromwrap .btns .back input:hover{
    background: #000;
    color: #fff;
}

/*ここまで*/


/*確認画面*/
.block02 #form-tbl{
    width: 41.55rem;/*615*/
    margin: 0 auto;
}
.block02 #form-tbl table{
    width: 100%;
}
.block02 #form-tbl table tr th{
    width: 40%;
    text-align: left;
    padding-bottom: 2.36rem;/*35*/
}
.block02 #form-tbl table tr td{
    width: 60%;
    padding-bottom: 2.36rem;/*35*/
}
.block02 #form-tbl table tr td span.msg{
    color: #EC2028;
}

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

.block03 .lists dl{
    line-height: 162%;
}
.block03 .lists dl:not(:last-of-type){
    margin-bottom: 2.03rem;/*30*/
}
.block03 .lists dl dt{
    font-size: 120.0%;
    letter-spacing: 0.05em;
    font-weight: 700;
    margin-bottom: 0.34rem;/*5*/
}
.block03 .lists dl dd:not(:first-of-type){
    margin-top: 1em;
}
.block03 .lists dl dd a{
    text-decoration: underline;
}

.block03 .tool dl dt{
    padding-bottom: 1.15rem;/*17*/
    border-bottom: 1px solid #AEAEAE;
    text-align: center;
}
.block03 .tool dl dd{
    padding-top: 1.15rem;/*17*/
    line-height: 181%;
}

/*--------------------------------------------------*/
.screen-reader-response p, .wpcf7-response-output{
	disolay: flex;
	align-items: center;
	margin: 20px auto;
	text-align: center;
}

/*--------------------------------------------------*/
/*色別*/

/*YELLOW*/
html.pageYellow .block01::after {
    background: none;
}
html.pageYellow .block_inner .info {
    background: none;
}
html.pageYellow .block02 .flow dl{
    background: none;
}
html.pageYellow .block02 .flow dl.current{
    background-color: #EC5A24;
}
html.pageYellow .block02 .fromwrap dl.agreement dd {
    background: none;
}
html.pageYellow .fromwrap input, html.pageYellow .fromwrap select, html.pageYellow .fromwrap textarea{
    background-color: rgba(255,255,255,0.00) !important;
}

/*BLACK*/
html.pageBlack .block01::after {
    background: none;
}
html.pageBlack .block_inner .info {
    background: none;
}
html.pageBlack .block02 .flow dl{
    background: none;
}
html.pageBlack .block02 .flow dl.current{
    background-color: #EC5A24;
}
html.pageBlack .block02 .fromwrap dl.agreement dd {
    background: none;
}
html.pageBlack .fromwrap input, html.pageBlack .fromwrap select, html.pageBlack .fromwrap textarea{
    background-color: rgba(255,255,255,0.00) !important;
}

/*BLUE*/
html.pageBlue .block01::after {
    background: none;
}
html.pageBlue .block_inner .info {
    background: none;
}
html.pageBlue .block02 .flow dl{
    background: none;
}
html.pageBlue .block02 .flow dl.current{
    background-color: #EC5A24;
}
html.pageBlue .block02 .fromwrap dl.agreement dd {
    background: none;
}
html.pageBlue .fromwrap input, html.pageBlue .fromwrap select, html.pageBlue .fromwrap textarea{
    background-color: rgba(255,255,255,0.00) !important;
}

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