@charset "UTF-8";
/*==============================================================================

	title

==============================================================================*/
#title{
    background-image: url(../1_img/page-shop/title_sp.jpg);
}
@media all and (min-width: 769px) {
    #title{
        background-image: url(../1_img/page-shop/title_pc.jpg);
    }
}

/* 最初は非表示 */
.screen-section {
    opacity: 0;
    height: 0;
    overflow: hidden;
    transition: opacity 0.5s ease, height 0.5s ease;
}

.screen-section.active {
    opacity: 1;
    height: auto;
    overflow: visible;
}

/*デフォルトのサンクスメッセージを非表示*/
.wpcf7-response-output{
    display: none;
}

input.error, select.error, textarea.error {
    border: 2px solid red;
}

/*==============================================================================

	メディアの方へ

==============================================================================*/
@media all and (min-width: 769px) {
}



/*==============================================================================

	form

==============================================================================*/
#form{
    padding: 0 20px;
}
@media (min-width: 769px) {
    #form{
        padding: 0;
    }
}

/*================ イントロ ================*/
#form-wrap .form-intro{
    margin-bottom: 30px;
    
    & p{
        font-size: 1.4rem;
        text-align: left;

        & + p{
            margin-top: 5px;
        }
    }

    & .btn_wrap{
        margin-top: 30px;
    }
}

#form-wrap .input_area .form-intro{
    & p{
        &:last-child{

            & span{
                color: var(--color-main);
            }
        }
    }
}
#form-wrap .thanks_area .form-intro,
#form-wrap .confirm_area .form-intro{
    & p{
        &:first-child{
            font-size: 1.6rem;
            font-weight: var(--weight-bold);
        }
    }
}
#form-wrap .thanks_area .form-intro{
    margin-bottom: 0;

    & p,
    & .btn_wrap{
        text-align: center;
    }
    & .sub{
        margin-top: 25px;
    }
}
@media (min-width: 769px) {
    #form-wrap .form-intro{
        margin-bottom: 50px;

        & p{
            text-align: center;
        }

        & .btn_wrap{
            margin-top: 50px;
        }
    }
    #form-wrap .thanks_area .form-intro,
    #form-wrap .confirm_area .form-intro{
        & p{
            &:first-child{
                font-size: 2rem;
            }
        }
        & .sub{
            margin-top: 30px;
        }
    }
}
/*================ イントロ end ================*/



/* ================================================================================================================================================================
//
//  フォームの項目の設定
//
================================================================================================================================================================ */


.wpcf7-form-control-wrap {
    position: relative;
    display: block;
}
.wpcf7-form{
    text-transform: unset
}

/*================ 項目名 ================*/
#form-wrap .form-item-label{
    margin-bottom: 5px;
    display: flex;
    flex-direction: column;
    gap: 5px 10px;
    font-size: 1.4rem;
    font-weight: var(--weight-bold);
}
#form-wrap .form-item-label .form-item-label-required{
    padding-left: calc(0.75em + 10px);
    position: relative;
}
#form-wrap .form-item-label .form-item-label-required::before{
    content: "";
    width: 0.75em;
    position: absolute;
    left: 0;
    top: 0.7em;
    aspect-ratio: 1 / 1;
    background-color: var(--color-main);
    border-radius: 100%;
}
#form-wrap .form-item-label .form-item-label-sub{
    font-size: 80%;
}
@media (min-width: 769px) {
    #form-wrap .form-item-label{
        flex-direction: row;
        align-items: center;
    }
}
/*================ 項目名 end ================*/

/*================ カラムの設定 ================*/
#form-wrap .flex-wrap{
    display: flex;
    flex-direction: column;
    gap: 20px 0;
}
#form-wrap .flex-wrap + .flex-wrap{
    margin-top: 20px;
}
@media (min-width: 769px) {
    #form-wrap .flex-wrap{
        flex-direction: row;
        gap: 40px;
    }
    #form-wrap .flex-wrap + .flex-wrap{
        margin-top: 40px;
    }
    #form-wrap .flex-wrap.column-one > div{
        width: calc(50% - 10px);
    }
    #form-wrap .flex-wrap.column-one.w-100 > div{
        width: calc(100%);
    }
    #form-wrap .flex-wrap.column-two > div{
        width: calc((100% - 40px) / 2);
    }

}
/*================ カラムの設定 end ================*/


/*================ input,textarea ================*/
#form input[type="date"] {
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    background-color: #e5e5e5;
}
#form input:not([type="radio"]):not([type="button"]):not([type="checkbox"]),
#form select,
#form textarea{
    padding: 10px 15px;
    width: 100%;
    height: 45px;
    font-size: 1.4rem;
    letter-spacing: 0.15em;
    line-height: 1.5;
    background-color: #fff;
    border: 1px solid var(--color-font);
    border-radius: 10px;
    box-shadow: unset;
}
#form input:focus,
#form select:focus,
#form textarea:focus{
    outline: 1px solid var(--color-main)!important;
    border-color: transparent!important;
    box-shadow: none;
}
#form textarea{
    height: 150px;
}
#form input::placeholder,
#form textarea::placeholder {
    color: #b2b2b2;
}
/*================ input,textarea end ================*/



/*================ radio ================*/
#form .wpcf7-radio{
    display: flex;
    gap: 10px;
}
#form .wpcf7-radio .wpcf7-list-item,
#form .wpcf7-radio .wpcf7-list-item label{
    margin: 0;
}
#form .wpcf7-radio .wpcf7-list-item input{
    display: none;
}
#form .wpcf7-radio .wpcf7-list-item .wpcf7-list-item-label {
    display: inline-block;
    padding: 8px 16px;
    border: 1px solid var(--color-accent);
    border-radius: 4px;
    cursor: pointer;
    user-select: none;
    transition: background-color 0.3s, border-color 0.3s;
    font-size: 1.4rem;
}
#form .wpcf7-radio input[type="radio"]:checked + .wpcf7-list-item-label {
    background-color: var(--color-main);
    color: white;
}
#form .wpcf7-radio .wpcf7-list-item-label:hover {
    border-color: var(--color-main);
}
/*================ radio end ================*/



/*================ radio circle ================*/
#form .form-radio_circle .wpcf7-radio{
    flex-direction: column;

    & .wpcf7-list-item{
        margin: 0;

        & label{
            margin: 0;
        }

        & input{
            display: none;
        }
        
        & .wpcf7-list-item-label {
            display: inline-block;
            padding: 0 0 0 1.4em;
            position: relative;
            border: none;
            cursor: pointer;
            user-select: none;
            transition: background-color 0.3s, border-color 0.3s;
            font-size: 1.4rem;


            &::before,
            &::after{
                content: "";
                width: 1em;
                aspect-ratio: 1 / 1;
                position: absolute;
                left: 0;
                top: 0.6em;
                border-radius: 50%;
            }

            &::before {
                border: 1px solid var(--color-font);
            }

            &::after {
                background-color: var(--color-font);
                opacity: 0;
                transform: scale(0.5);
                transition: 500ms;
            }
        }
        
        & input[type="radio"]:checked + .wpcf7-list-item-label {
            background-color: transparent;
            color: var(--color-font);

            &::after {
                opacity: 1;
            }
        }
    }
}
@media (min-width: 769px) {
    #form .form-radio_circle .wpcf7-radio{
        flex-direction: row;
        gap: 20px;
    }
}
/*================ radio end ================*/



/*================ checkbox ================*/
#form .wpcf7-checkbox{
    display: flex;
    gap: 10px;
}
#form .wpcf7-checkbox .wpcf7-list-item,
#form .wpcf7-checkbox .wpcf7-list-item label{
    margin: 0;
}
#form .wpcf7-checkbox .wpcf7-list-item label{
    display: flex;
    align-items: center;
    gap: 0 10px;
}
#form .wpcf7-checkbox input{
    margin: 0;
    appearance: none; /* ブラウザ独自の見た目をリセット */
    -webkit-appearance: none; /* Safari用 */
    -moz-appearance: none; /* Firefox用 */
    outline: unset;
    width: 20px;
    height: 20px;
    border: 1px solid var(--color-font);
    border-radius: 4px;
    cursor: pointer;
    vertical-align: middle;
    transition: background-color 0.3s, border-color 0.3s;
}
#form .wpcf7-checkbox input:checked {
    background: url(../1_img/base/icon-check.svg) var(--color-main);
    background-repeat: no-repeat;
    background-position: center;
    background-size: 80% auto;
}
/*================ checkbox end ================*/



/*================ select ================*/
.wpcf7-form-control-wrap:has(> .wpcf7-select){
    position: relative;
}
.wpcf7-form-control-wrap:has(> .wpcf7-select)::after{
    content:"";
    width: 10px;
    aspect-ratio: 1 / 1;
    position: absolute;
    right: 20px;
    top: 50%;
    transform: translateY(-50%) rotate(135deg);
    border-top: 2px solid var(--color-main);
    border-right: 2px solid var(--color-main);
}
#form .wpcf7-select{
    /* デフォルトの矢印を消す */
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    /* 見た目の調整 */
    padding-right: 50px; /* 矢印と文字が重ならないように右余白を確保 */
}
/*================ checkbox end ================*/



/*================ input[type="button"] ================*/
.button-wrap{
    margin-top: 50px;
    width: 100%;
    text-align: center;
    display: flex;
    justify-content: center;
    gap: 20px;
}
.button-wrap .confirm-button-wrap{
    width: 100%;
}
.button-wrap .confirm-button-wrap p{
    width: 100%;
    max-width: 100%;
    display: inline-block;
    text-align: center;
    background-color: var(--color-font);
    line-height: 1.6;
    border-radius: 60px;
    position: relative;
    transition: 500ms;

    &::after{
        content: "";
        display: block;
        position: absolute;
        top: 50%;
    }
    &::after {
        width: 10px;
        height: 10px;
        top: 50%;
        right: 18px;
        border-bottom: 2px solid #fff;
        border-right: 2px solid #fff;
        transform: translateY(-50%) rotate(-45deg);
    }
}
.button-wrap .confirm-button-wrap.back p{
    background-color: var(--color-sub);

    &::before{
        right: unset;
        left: 10px;
    }
    &::after {
        right: unset;
        left: 18px;
        transform: translateY(-50%) rotate(135deg);
    }
}
.button-wrap .confirm-button-wrap p:hover{
	opacity: 0.6;
    color: #fff;
}
.button-wrap .confirm-button-wrap p input{
    width: 100%;
    padding: 15px 0 17px;
    display: block;
    border-radius: 0;
    background: unset;
    border: unset;
    font-size: 1.4rem;
    font-weight: var(--weight-bold);
    color: #fff;
}
.wpcf7-spinner{
    display: none;
}
@media (min-width: 769px) {
    .button-wrap{
        margin-top: 100px;

        & .confirm-button-wrap {
            width: 320px;
        }
    }
}
/*================ input[type="button"] end ================*/



/*================ プライバシーポリシー ================*/
.privacy-poricy{
    margin-top: 40px;
    text-align: center;

    & a{
        margin-right: 7px;
        padding-right: 15px;
        display: inline-block;
        position: relative;
        color: var(--color-font);
        text-decoration: underline;
        
        &::after {
            content: "";
            margin-top: 2px;
            width: 12px;
            position: absolute;
            top: 50%;
            right: 0;
            aspect-ratio: 1 / 1;
            transform: translateY(-50%);
            background-image: url(../1_img/base/icon-window.svg);
            background-size: 100% auto;
        }
    }

    & .wpcf7-form-control{
        margin-top: 15px;
        justify-content: center;
    }
}
@media (min-width: 769px) {
    .privacy-poricy{
        margin-top: 80px;
    }
}
/*================ プライバシーポリシー end ================*/


/*================ エラーメッセージ ================*/
.wpcf7-not-valid-tip {
    display: none !important;
}
#form .confirm-error-message,
#form .error-message{
    margin-top: 5px;
    color: var(--color-red);
    font-weight: var(--weight-bold);
}
/*================ エラーメッセージ end ================*/



/*==============================================================================

	確認画面

==============================================================================*/
.confirm_area span[class^="confirm_form_"] {
    font-size: 1.6rem;
    font-weight: var(--weight-medium);
}