@charset "utf-8";

/* ---------------------------------------------------- */
/* cf7 */
/* ---------------------------------------------------- */
.screen-reader-response {
    display: none;
}

.horizontal .wpcf7-list-item {
    min-width: 190px;
    margin-bottom: 10px !important;
    margin-right: 10px !important;
}

.vertical .wpcf7-list-item {
    display: block !important;
    margin-left: 0 !important;
    margin-bottom: 10px !important;
}

.vertical .wpcf7-list-item:last-of-type {
    margin-bottom: 0 !important;
}

.wpcf7-form-control-wrap {
    position: relative;
}

.wpcf7-response-output {
    margin: 20px auto 0 !important;
    padding: 10px 20px !important;
    width: max-content;
    max-width: 100%;
    color: var(--co_2);
    font-size: 16px !important;
    font-weight: 700 !important;
    text-align: center;
    z-index: 2;
    border: none !important;
    background-color: red;
    border-radius: 20px;
}
/* .wpcf7-form-control-wrap[data-name="bukken"] .wpcf7-form-control > .wpcf7-list-item:nth-of-type(4)::before,
.wpcf7-form-control-wrap[data-name="bukken"] .wpcf7-form-control > .wpcf7-list-item:nth-of-type(6)::before {
    content: "ー";
    display: block;
}
.wpcf7-form-control-wrap[data-name="cat"] .wpcf7-form-control > .wpcf7-list-item label::after {
    display: inline-block;
    margin-left: 10px;
    font-size: 11px;
}
.wpcf7-form-control-wrap[data-name="cat"] .wpcf7-form-control > .wpcf7-list-item:nth-of-type(1) label::after {
    content: "※下の「来場希望日時」にご入力ください";
}
.wpcf7-form-control-wrap[data-name="cat"] .wpcf7-form-control > .wpcf7-list-item:nth-of-type(6) label::after {
    content: "※よろしければ下にご入力ください";
} */

@media (max-width: 999px) {
}

/* ---------------------------------------------------- */
/* tips */
/* ---------------------------------------------------- */
.wpcf7-not-valid-tip {
    position: absolute;
    left: 10px;
    bottom: -25px;
    padding: 5px 10px;
    color: var(--co_2) !important;
    font-size: 10px !important;
    font-weight: 700 !important;
    line-height: 1;
    white-space: nowrap;
    z-index: 2;
    background-color: red;
    border-radius: 20px;
}

/* .wpcf7-form-control-wrap[data-name="cat-1"] .wpcf7-not-valid-tip::before {
    content: "お問い合わせ内容を";
}

/* ---------------------------------------------------- */
/* cs_none */
/* ---------------------------------------------------- */
.form_input .cs_none_input {
    display: none !important;
}

.form_conf .cs_none_cnf {
    display: none !important;
}

.form_thx .cs_none_thx {
    display: none !important;
}

/* ---------------------------------------------------- */
/* sec_form_wrap */
/* ---------------------------------------------------- */
.sec_form_wrap {
    padding-top: 200px;
    padding-bottom: 100px;
}

.sec_form_wrap .ttl_1 {
    margin-bottom: 90px;
}
.sec_form_wrap .desc_1 {
    margin-bottom: 90px;
    font-size: 16px;
    line-height: 2;
}
.sec_form_wrap .desc_2 {
    margin-bottom: 60px;
    font-size: 16px;
    line-height: 2;
}

.sec_form_wrap .tel_1 {
    margin-bottom: 100px;
    padding: 70px 100px;
    max-width: max-content;
    background-color: var(--co_2);
    border-radius: 40px;
}

.sec_form_wrap .tel_1 .ttl_1 {
    margin-bottom: 20px;
    font-size: 20px;
    font-weight: 500;
}

.sec_form_wrap .tel_1 .num {
    display: flex;
    align-items: center;
    font-weight: 500;
    line-height: 1;
}
.sec_form_wrap .tel_1 .num > a {
    margin-right: 20px;
    font-family: var(--ff_go_2);
    font-size: 40px;
    letter-spacing: 0.05em;
}

.sec_form_wrap .tel_1 .num > span {
    transform: translateY(2px);
}

.sec_form_wrap .box_1 {
    padding: 70px 100px;
    max-width: max-content;
    background-color: var(--co_2);
    border-radius: 40px;
}
.sec_form_wrap .box_1 .ttl_1 {
    margin-bottom: 20px;
    font-size: 20px;
    font-weight: 500;
}
@media (max-width: 999px) {
    .sec_form_wrap {
        padding-top: 90px;
        padding-bottom: 50px;
    }
    .sec_form_wrap .ttl_1 {
        margin-bottom: 60px;
    }
    .sec_form_wrap .desc_1 {
        margin-bottom: 50px;
        font-size: 13px;
    }
    .sec_form_wrap .desc_2 {
        margin-bottom: 40px;
        font-size: 13px;
    }

    .sec_form_wrap .tel_1 {
        margin-bottom: 50px;
        padding: 30px 20px;
        border-radius: 20px;
    }

    .sec_form_wrap .tel_1 .ttl_1 {
        margin-bottom: 20px;
        font-size: 15px;
    }

    .sec_form_wrap .tel_1 .num {
        display: block;
    }
    .sec_form_wrap .tel_1 .num > a {
        display: block;
        margin-right: 0;
        margin-bottom: 10px;
        font-size: 30px;
    }

    .sec_form_wrap .tel_1 .num > span {
        display: block;
        font-size: 11px;
    }

    .sec_form_wrap .box_1 {
        padding: 30px 15px;
        border-radius: 20px;
    }
    .sec_form_wrap .box_1 .ttl_1 {
        margin-bottom: 20px;
        font-size: 15px;
    }
}

/* ---------------------------------------------------- */
/* cs_form_input */
/* ---------------------------------------------------- */
.cs_form_input {
    margin-top: 60px;
}
.cs_form_input .hr_1 {
    margin: 50px 0;
    border-top: 1px solid var(--co_3);
}

.cs_form_input > table {
    position: relative;
    width: 100%;
}

.cs_form_input > table > tbody > tr > th {
    position: relative;
    padding-bottom: 50px;
    padding-right: 40px;
    width: 265px;
    white-space: nowrap;
    font-size: 16px;
    font-weight: 500;
}
.cs_form_input > table > tbody > tr > th > span {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-top: 12px;
}
.cs_form_input > table > tbody > tr > th > span.pd1 {
    padding-top: 0;
}
.cs_form_input > table > tbody > tr.req > th > span::after {
    content: "必須";
    display: block;
    padding: 5px 10px;
    color: var(--co_2);
    font-size: 14px;
    background-color: var(--co_3);
    border-radius: 5px;
}
.cs_form_input > table > tbody > tr > th > i {
    display: block;
    width: max-content;
    margin-top: 10px;
    margin-left: auto;
    margin-right: 0;
    text-indent: -1em;
    font-size: 12px;
    font-style: normal;
    text-align: left;
    white-space: wrap;
}

.cs_form_input > table > tbody > tr > td {
    padding-bottom: 50px;
    vertical-align: top;
}
.cs_form_input > table > tbody > tr > td .line {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
}

.cs_form_input > table > tbody > tr > td .line + .line {
    margin-top: 15px;
}

.cs_form_input > table > tbody > tr > td .line > * {
    /* flex: auto; */
    /* width: auto; */
}

.cs_form_input > table > tbody > tr > td .line > * + * {
    margin-left: 10px;
}

.cs_form_input .line_name_1 {
    width: 200px !important;
}

.cs_form_input .line_name_2 {
    position: relative;
    width: 120px !important;
}

.cs_form_input .line_name_1 > span,
.cs_form_input .line_name_2 > span {
    font-size: 11px;
}

.cs_form_input .unit_1 {
    display: flex;
    align-items: center;
    padding: 12px 0;
}

.cs_form_input .caption_1 {
    margin-top: 5px;
    font-size: 11px;
}

.cs_form_input * + .caption_1 {
    margin-top: 5px;
}

.cs_form_input .caption_1 + * {
    margin-top: 5px;
}

.cs_form_input .btn_zip {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 200px;
    height: 60px;
    font-size: 14px;
    color: var(--co_2);
    text-align: center;
    text-decoration: none;
    background-color: var(--co_1);
    border-radius: 40px;
    cursor: pointer;
}
@media (min-width: 1000px) {
    .cs_form_input > table > tbody > tr.tb_b_high > td {
        padding-bottom: 40px;
    }
}
@media (max-width: 999px) {
    .cs_form_input {
        margin-top: 30px;
    }
    .cs_form_input .hr_1 {
        margin: 30px 0;
    }
    .cs_form_input > table,
    .cs_form_input > table > tbody,
    .cs_form_input > table > tbody > tr,
    .cs_form_input > table > tbody > tr > th,
    .cs_form_input > table > tbody > tr > td {
        display: block;
        width: 100%;
    }

    .cs_form_input > table > tbody > tr > th {
        padding: 0;
        padding-bottom: 10px;
        font-size: 14px;
        text-align: left;
    }
    .cs_form_input > table > tbody > tr > th > span {
        justify-content: flex-start;
    }
    .cs_form_input > table > tbody > tr.req > th > span::after {
        margin-left: 15px;
        font-size: 12px;
    }
    .cs_form_input > table > tbody > tr > th > i {
        margin-top: 5px;
        width: auto;
        font-size: 10px;
        text-indent: 0;
    }
    .cs_form_input > table > tbody > tr > td {
        padding: 0;
        padding-bottom: 20px;
    }
    .cs_form_input > table > tbody > tr > td .line > * + * {
        margin-left: 5px;
    }
    .cs_form_input .line_name_1,
    .cs_form_input .line_name_2 {
        margin-bottom: 10px;
        width: 100% !important;
    }
    .cs_form_input .unit_1 {
        font-size: 12px;
    }
    .cs_form_input .line_name_1 + *,
    .cs_form_input .line_name_2 + * {
        margin-left: 0 !important;
    }

    .cs_form_input .caption_1 {
        font-size: 11px;
    }
    .cs_form_input .btn_zip {
        width: 140px;
        font-size: 11px;
    }
}

/* ---------------------------------------------------- */
/* input */
/* ---------------------------------------------------- */
.cs_form_input *::placeholder {
    color: var(--co_3);
    opacity: 0.3;
}

.cs_form_input .input input {
    padding: 15px;
    margin: 0;
    width: 100%;
    color: var(--co_3);
    font-size: 16px;
    background-color: var(--co_2);
    border: 1px solid var(--co_3);
    -webkit-appearance: none;
}

.cs_form_input .input.w1 {
    width: 100%;
}

.cs_form_input .input.w2 {
    width: 400px;
}
.cs_form_input .input.w3 {
    width: 200px;
}
.cs_form_input .input.w4 {
    width: 120px;
}

.cs_form_input .input textarea {
    padding: 15px;
    padding-bottom: 40px;
    width: 100%;
    height: 150px;
    background-color: var(--co_2);
    border: 1px solid var(--co_3);
    -webkit-appearance: none;
    color: var(--co_3);
    font-size: 16px;
    resize: none;
}
/* datepicker */
.cs_form_input .datepicker {
    position: relative;
    z-index: 2;
}
.cs_form_input .datepicker input {
    position: relative;
    padding: 15px;
    width: 140px;
    font-size: 16px;
    background-color: var(--co_2);
    border: 2px solid var(--co_10);
    border-radius: 40px;
}

.cs_form_input .datepicker::after {
    content: "";
    position: absolute;
    right: 15px;
    top: 50%;
    transform: translateY(-50%);
    display: block;
    width: 15px;
    height: 15px;
    background-image: url(../img/datepicker_1.svg);
    background-position: center;
    background-size: contain;
    background-repeat: no-repeat;
}

/* 日曜日を赤 */
.ui-datepicker td.sun a {
    color: red !important;
    font-weight: bold;
}

/* 土曜日を青 */
.ui-datepicker td.sat a {
    color: blue !important;
    font-weight: bold;
}

/* number */
.cs_form_input input[type="number"]::-webkit-outer-spin-button,
.cs_form_input input[type="number"]::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

.cs_form_input input[type="number"] {
    -moz-appearance: textfield;
}

/* select */
.cs_form_input .select {
    flex: none;
    position: relative;
    display: block;
    background-color: var(--co_4);
}
.cs_form_input.bg_2 .select {
    border-color: var(--co_2);
}

.cs_form_input .select::after {
    content: "";
    position: absolute;
    right: 15px;
    top: 23px;
    display: block;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 8px 6px 0 6px;
    border-color: #7d7d7d transparent transparent transparent;
}

.cs_form_input .select select {
    position: relative;
    /* outline: none; */
    -moz-appearance: none;
    text-indent: 0.01px;
    text-overflow: "";
    vertical-align: middle;
    font-size: inherit;
    color: inherit;
    -webkit-appearance: button;
    -moz-appearance: button;
    appearance: button;
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    padding: 15px 40px 15px 20px;
    border: none;
    color: var(--co_1);
    font-size: 16px;
    width: 100%;
    border-radius: 0;
    background-color: transparent;
    cursor: pointer;
    z-index: 2;
}

.cs_form_input .select select option {
    background-color: var(--co_2);
    color: #3e3a39;
}

.cs_form_input .select select::-ms-expand {
    display: none;
}

.cs_form_input .select select:-moz-focusring {
    color: transparent;
    text-shadow: 0 0 0 #828c9a;
}

/* checkbox */
.input_check {
    font-size: 16px;
}
.input_check label {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
}
.input_check input {
    display: none;
}

.input_check input + span {
    padding-left: 28px;
    display: inline-block;
    position: relative;
}
.input_check input + span::after,
.input_check input + span::before {
    content: "";
    display: block;
    position: absolute;
    top: 0;
}
.input_check input + span::before {
    border: 1px solid var(--co_3);
    background-color: var(--co_2);
    height: 20px;
    width: 20px;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
}
.input_check input + span::after {
    content: "";
    display: none;
    position: absolute;
    top: 50%;
    left: 7px;
    width: 7px;
    height: 16px;
    transform: translateY(-50%) rotate(40deg);
    border-bottom: 3px solid var(--co_3);
    border-right: 3px solid var(--co_3);
}
.input_check input:checked + span::after {
    display: block;
}

/* radio */
.input_radio {
    font-size: 16px;
}
.input_radio input {
    display: none;
}

.input_radio input + span {
    padding-left: 28px;
    display: inline-block;
    position: relative;
}
.input_radio input + span::after,
.input_radio input + span::before {
    content: "";
    display: block;
    position: absolute;
    top: 0;
}
.input_radio input + span::before {
    border: 2px solid var(--co_10);
    background-color: var(--co_2);
    height: 20px;
    width: 20px;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    border-radius: 100%;
}
.input_radio input + span::after {
    border: none;
    background-color: var(--co_3);
    height: 12px;
    width: 12px;
    left: 4px;
    top: 50%;
    transform: translateY(-50%);
    display: none;
    border-radius: 100%;
}
.input_radio input:checked + span::after {
    display: block;
}

.input_dummy {
    position: fixed;
    left: -200vw;
    top: -200vh;
}

@media (max-width: 999px) {
    .cs_form_input .input.w1 {
        width: 100%;
    }

    .cs_form_input .input.w2 {
        width: 100%;
    }
    .cs_form_input .input.w3 {
        width: calc(50% - 5px);
    }
    .cs_form_input .input.w4 {
        width: 100px;
    }
    .input_check {
        font-size: 13px;
    }
    .input_radio {
        font-size: 13px;
    }
    .cs_form_input .datepicker input {
        width: 120px;
        font-size: 13px;
    }
    .cs_form_input .select select {
        font-size: 13px;
    }
}

/* ---------------------------------------------------- */
/* cs_form_privacy_wrap */
/* ---------------------------------------------------- */
.cs_form_privacy_wrap {
    margin-top: 40px;
}
.cs_form_privacy_wrap .ttl {
    margin-bottom: 30px;
    font-size: 16px;
    font-weight: 500;
    text-align: center;
}
.cs_form_privacy_wrap .desc {
    padding: 20px;
    height: 250px;
    border: 1px solid var(--co_7);
    overflow-y: scroll;
}

@media (max-width: 999px) {
    .cs_form_privacy_wrap {
        margin-top: 20px;
    }
    .cs_form_privacy_wrap .ttl {
        margin-bottom: 20px;
        font-size: 11px;
    }
    .cs_form_privacy_wrap .desc {
        padding: 15px;
        height: 200px;
    }
    .cs_form_privacy_wrap .desc {
        font-size: 10px;
    }
}

/* ---------------------------------------------------- */
/* cs_form_submit_wrap */
/* ---------------------------------------------------- */
.cs_form_submit_wrap {
    /* margin-top: 50px; */
    display: flex;
    justify-content: center;
}
.cs_submit_1 {
    position: relative;
    width: 550px;
}

.cs_submit_1 input {
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 0 20px;
    width: 100%;
    height: 80px;
    color: var(--co_2);
    font-size: 18px;
    font-weight: 500;
    line-height: 1.2;
    text-align: center;
    text-decoration: none;
    background-color: var(--co_4);
    border-radius: 40px;
    -webkit-appearance: none;
    transition: 0.3s ease-in-out;
}

.cs_submit_1::after {
    content: "";
    position: absolute;
    right: 50px;
    top: 50%;
    display: block;
    width: 10px;
    height: 10px;
    border-top: 1px solid var(--co_2);
    border-right: 1px solid var(--co_2);
    transition: 0.3s ease-in-out;
    transform: translateY(-50%) rotate(45deg);
}

.cs_submit_1.btn_back::after {
    right: auto;
    left: 20px;
    transform: translateY(-50%) scaleX(-1);
}

.cs_submit_1 .wpcf7-spinner {
    display: none;
}
.cs_submit_1.btn_send {
    order: 3;
}

@media (min-width: 1000px) {
    .cs_submit_1:hover input {
        background-color: var(--co_6);
    }
}

@media (max-width: 999px) {
    .cs_form_submit_wrap {
        /* margin-top: 40px; */
        flex-wrap: wrap;
    }

    .cs_form_submit_wrap .btn_send {
        margin-bottom: 20px;
        order: -1;
    }
    .cs_submit_1 {
        width: 100%;
    }
    .cs_submit_1 input {
        height: 60px;
        font-size: 16px;
    }
}
