@charset "UTF-8";
body{
    background-color: #0a0a0a!important;
}
.single-post{
    margin-top: 0!important;
    padding: 0!important;
}

/* ======= 共通 ======= */
.sub-tit{
    font-size: 14px;
    text-align: center;
}
.h2-tit{
    text-align: center;
}

/* 打消し */
.header-top-area,
.header-menu-area ul{
    padding: 0!important;
}
/* contact */
fieldset,
.screen-reader-response
.wpcf7-response-output{
    display: none;
}
input[type=text], input[type=password], input[type=date], input[type=datetime], input[type=email], input[type=number], input[type=search], input[type=tel], input[type=time], input[type=url], textarea, select, .search-edit{
    background-color: #1e1e1e!important;
    border: 1px solid #2a2a2a!important;
    color: #fff;
    border-radius: 5px;
    font-size: inherit;
    width: 100%;
    padding: 10px;
}
input[type=text]:focus,
input[type=password]:focus,
input[type=date]:focus,
input[type=datetime]:focus,
input[type=email]:focus,
input[type=number]:focus,
input[type=search]:focus,
input[type=tel]:focus,
input[type=time]:focus,
input[type=url]:focus,
textarea:focus,
select:focus,
.search-edit:focus{
    background-color: #1e1e1e !important;
    color: #fff !important;
    border: 1px solid #2a2a2a !important;
    outline: none !important;
    box-shadow: none !important;
}
input:-webkit-autofill,
input:-webkit-autofill:hover,
input:-webkit-autofill:focus,
textarea:-webkit-autofill,
textarea:-webkit-autofill:hover,
textarea:-webkit-autofill:focus,
select:-webkit-autofill,
select:-webkit-autofill:hover,
select:-webkit-autofill:focus {
    -webkit-text-fill-color: #fff !important;
    -webkit-box-shadow: 0 0 0 1000px #1e1e1e inset !important;
    box-shadow: 0 0 0 1000px #1e1e1e inset !important;
    background-color: #1e1e1e !important;
    border: 1px solid #2a2a2a !important;
}
.contact-block{
    max-width: 750px;
    margin: auto;
}
.mailform,
.contact-tel-block{
    background-color: #141414;
    border: 1px solid #2a2a2a;
    padding: 20px;
    margin-top: 50px;
}
.contact-tel-block{
    text-align: center;
}
.contact-tel-block a{
    display: block;
    color: #fff;
    font-size: 2em;
    margin: 0.5em 0;
}
.mailform-item{
    margin-bottom: 30px;
}
.mailform-tit{
    position: relative;
    font-size: 18px;
    border-bottom: 1px solid #2a2a2a;
    padding-left: 1.5em;
    padding-bottom: 1em;
}
.mailform-tit::before{
    position: absolute;
    content: "";
    width: 1em;
    height: 3px;
    left: 0;
    top: 30%;
    background-color: #1A6FE8;
}
.input-line{
    margin-bottom: 15px;
}
.input-line .label{
    margin-bottom: 10px;
}
.hissu,
.any{
    color: #fff;
    font-size: 12px;
    padding: 2px 5px 5px 5px;
    margin-left: 15px;
}
.hissu{
    background-color: #cc0000;
}
.any{
    color: rgba(255, 255, 255, 0.5);
    background-color: #2a2a2a;
}
input[type=submit].submit-btn-red{
    width: 100%;
    font-size: 16px;
    font-weight: bold;
    background: linear-gradient(-45deg, #990000 0%, #CC0000 100%);
    color: #ffffff;
    border: none;
    border-radius: 5px;
    padding: 20px 10px;
    margin-top: 20px;
}
.mailform-grid{
    display: grid;
    grid-template-columns: 150px 1fr;
    gap: 15px;
}

/* チェックボックス・ラジオボタンのデザイン */
.mailform .wpcf7-checkbox,
.mailform .wpcf7-radio {
    display: flex;
    flex-wrap: wrap;
    gap: 15px;
    margin-top: 10px;
}
.mailform .wpcf7-list-item{
    margin: 0;
}
.mailform .wpcf7-list-item label {
    display: block;
    border: 1px solid #2a2a2a;
    background: #1e1e1e;
    color: #fff;
    cursor: pointer;
    padding: 15px 20px;
}
.mailform .wpcf7-checkbox .wpcf7-list-item label,
.mailform .wpcf7-radio .wpcf7-list-item label {
    display: flex;
    align-items: center;
    gap: 15px;
    cursor: pointer;
    box-sizing: border-box;
}
.mailform .wpcf7-checkbox input[type="checkbox"],
.mailform .wpcf7-radio input[type="radio"] {
    appearance: none;
    -webkit-appearance: none;
    width: 20px;
    height: 20px;
    margin: 0;
    border: 2px solid #2a2a2a;
    background: #141414;
    position: relative;
    flex-shrink: 0;
}
.mailform .wpcf7-radio input[type="radio"]{
    border-radius: 50%;
}
.mailform .wpcf7-checkbox input[type="checkbox"]:checked,
.mailform .wpcf7-radio input[type="radio"]:checked {
    border-color: #0052CC;
    background-color: #0052CC;
}
.mailform .wpcf7-checkbox .wpcf7-list-item label:has(input[type="checkbox"]:checked),
.mailform .wpcf7-radio .wpcf7-list-item label:has(input[type="radio"]:checked) {
    border-color: #0052CC;
    background: #0f2238;
}
.mailform .wpcf7-checkbox input[type="checkbox"]:checked::after {
    content: "✓";
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    color: #fff;
    padding-top: 1px;
}
.mailform .wpcf7-radio input[type="radio"]:checked::after {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    width: 8px;
    height: 8px;
    background: #fff;
    border-radius: 50%;
    transform: translate(-50%, -50%);
    padding-top: 1px;
}

/* 条件分岐 */
.other-tx {
    display: none;
    margin-top: 10px;
}

/* 日時 */
.date-time-wrap {
    display: grid;
    grid-template-columns: 1fr 150px;
    gap: 15px;
    align-items: start;
}
.date-col input[type="date"],
.time-col select {
    width: 100%;
    box-sizing: border-box;
}

/* プラポリ */
.policy {
    background-color: #1e1e1e;
    border: 1px solid #2a2a2a;
    text-align: center;
    padding: 20px;
    margin-bottom: 2em;
}
.policy h2{
    font-size: 18px;
    margin-bottom: 0.5em;
}
.policy-check{
    text-align: center;
}
.policy a{
    color: #1A6FE8;
    text-decoration: underline;
}
.mailform .policy-check .wpcf7-list-item label{
    border: none;
    padding: 15px 0;
}

/* LINE */
.line-card{
    max-width: 300px;
    margin: 0 auto 30px auto;
}

/* サンクスページ */
.thanks-block{
    padding: 50px 0;
}
.top-btn{
    display: block;
    background-color: #c1192c;
    color: #fff;
    font-weight: bold;
    text-align: center;
    border-radius: 5px;
    padding: 25px 10px;
    margin-top: 30px;
}

/*1000px以上*/
@media screen and (max-width:1000px){
    .single-post{
        margin-top: 89px!important;
    }
    .reserve-block{
        padding: 30px 15px;
    }
    /* サンクスページ */
    .thanks-block{
        padding: 30px 15px;
    }
    .thanks-block .tx-center{
        text-align: left;
    }
    .top-btn{
        padding: 20px 10px;
    }
}

/*750px以上*/
@media screen and (max-width:750px){
    .mailform, .contact-tel-block{
        margin-top: 30px;
        padding: 15px;
    }
    .mailform-grid{
        display: block;
    }
    .date-time-wrap{
        grid-template-columns: 1fr;
    }
}

/*480px以上*/
@media screen and (max-width:480px){
    .mailform-tit{
        font-size: 14px;
    }
}