@charset "UTF-8";
/* ========================================
   contact.css - お問い合わせセクション専用
======================================== */

.contact-section {
    /* フォーム全体のフォントファミリー（ここを変えればフォーム内の文字が一括で切り替わる） */
    --contact-form-font: var(--font-serif);
    background-color: var(--color-bg-light);
    /* 左右パディングは消し（中身側で幅を管理）、上下は .section 相当のパディングを付ける */
    padding-top: var(--spacing-section);
    padding-bottom: var(--spacing-section);
    padding-left: 0;
    padding-right: 0;
}

/* ================================
   2列レイアウト（左：タイトル2 ／ 右：フォーム等8）
   1024px未満：縦積み（タイトル→中身）。中身は従来通り中央寄せ。
   1024px以上：2:8 のグリッド。左タイトルは縦書き・上揃え、右中身は左寄せ。
================================ */
.contact-layout {
    width: 90%;
    margin-left: auto;
    margin-right: auto;
    max-width: var(--section-width-md);
}

@media (min-width: 1024px) {
    .contact-layout {
        width: auto;
    }
}

@media (min-width: 576px) {
    .contact-layout {
        max-width: var(--section-width-xl);
        display: grid;
        grid-template-columns: 2fr 8fr;
        align-items: start;
        gap: 3rem;
    }
}

/* 576〜767px：タイトル列が狭いため 1:9 にして左をさらに細く、gap も詰める */
@media (min-width: 576px) and (max-width: 767.98px) {
    .contact-layout {
        grid-template-columns: 1fr 9fr;
        gap: 1.5rem;
    }
}

/* 左列タイトル：576px以上で縦書き・上揃え。
   共通 .title__header は中央寄せだが、ここでは列の上部に寄せる */
.contact-layout__title {
    margin-bottom: var(--spacing-lg);
}

@media (min-width: 576px) {
    .contact-layout__title {
        position: sticky;
        top: calc(var(--header-height) + 2rem);
        flex-direction: column;
        align-items: center;
        margin-bottom: 0;
        gap: 1rem;
    }

    /* 日本語見出し：縦書き（共通の1024px以上縦書きを踏襲しつつ明示化） */
    .contact-layout__title .title__ja {
        writing-mode: vertical-rl;
        text-orientation: upright;
        font-size: 1.9rem;
        letter-spacing: 0.2em;
        line-height: 1.5;
    }

    .contact-layout__title .title__en {
        margin-bottom: 0;
    }
}

/* 576〜767px：左列（1割）が狭いため、縦書きタイトルを一回り小さく */
@media (min-width: 576px) and (max-width: 767.98px) {
    .contact-layout__title .title__ja {
        font-size: 1.5rem;
        letter-spacing: 0.16em;
    }
}

/* 右列中身：576px以上ではリード・電話・フォームの中央寄せ（margin:auto）を左寄せに。
   フォームは読みやすさを保つため 768px 上限は維持 */
@media (min-width: 576px) {
    .contact-layout__body {
        min-width: 0;
        max-width: var(--section-width-md);
    }

    .contact-layout__body .contact-lead {
        margin-left: 0;
        margin-right: auto;
        text-align: left;
    }

    .contact-layout__body .contact-form-group {
        margin-left: 0;
        margin-right: auto;
        max-width: var(--section-width-md);
    }
}

.contact-lead {
    font-family: var(--font-serif);
    font-size: 0.95rem;
    line-height: 2;
    color: var(--color-text);
    text-align: center;
    margin: 0 auto 2.5rem;
}

@media (min-width: 768px) {
    .contact-lead {
        font-size: 1rem;
    }
}

/* ================================
   電話CTAボックス
================================ */
/* 電話カードの親：フォーム（.contact-form-group）と同じ max-width を持たせ、
   その領域の中でカード（.contact-tel-wrap）を中央配置する。
   フォームはベース680px→576px以上720pxなのでそれに揃える */
.contact-tel-outer {
    max-width: 680px;
    margin-left: auto;
    margin-right: auto;
}

@media (min-width: 576px) {
    .contact-tel-outer {
        max-width: var(--section-width-md);
    }
}

.contact-tel-wrap {
    position: relative;
    max-width: 460px;
    margin: 0 auto 3rem;
}

.contact-tel-wrap::before {
    content: '';
    position: absolute;
    bottom: -0.6rem;
    right: -0.6rem;
    width: 100%;
    height: 100%;
    background-color: var(--color-accent);
    z-index: 0;
    opacity: 0.18;
    pointer-events: none;
}

.contact-tel-box {
    position: relative;
    z-index: 1;
    text-align: center;
    padding: calc(20px + 0.8rem) 1.5rem 1.5rem;
    background-color: var(--color-surface);
    border: 2px solid var(--color-primary);
    box-shadow: var(--shadow-md);
}

.contact-tel-box__badge {
    display: inline-block;
    font-family: var(--font-heading);
    font-size: 0.78rem;
    font-weight: 700;
    color: #fff;
    letter-spacing: 0.08em;
    background-color: var(--color-primary);
    padding: 0.25rem 0.9rem;
    position: absolute;
    top: -0.75rem;
    left: 50%;
    transform: translateX(-50%);
    white-space: nowrap;
}

.contact-tel-box__label {
    font-size: 0.85rem;
    color: var(--color-text-light);
    margin-bottom: 0.5rem;
}

.contact-tel-box__number {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    font-family: var(--font-family);
    font-size: 1.85rem;
    font-weight: 700;
    color: var(--color-primary);
    margin-bottom: 0.375rem;
    transition: opacity 0.2s;
}

.contact-tel-box__number:hover {
    opacity: 0.8;
}

.contact-tel-box__hours {
    font-size: 0.8rem;
    color: var(--color-text-light);
}

/* ================================
   フォーム
================================ */
.contact-form-group {
    max-width: 680px;
    margin: 0 auto;
    background-color: var(--color-surface);
    border: 1.5px solid var(--color-border);
    box-shadow: var(--shadow-sm);
    overflow: hidden;
}

.contact-form {
    padding: 2rem 1.5rem 1.75rem;
    /* フォーム内の文字を一括でフォント指定（個別未指定の要素も継承させる） */
    font-family: var(--contact-form-font);
}

@media (min-width: 576px) {
    .contact-form {
        padding: 2.5rem 2.25rem 2rem;
    }
}

/* honeypot 非表示 */
.form-honeypot {
    position: absolute;
    left: -9999px;
    width: 1px;
    height: 1px;
    overflow: hidden;
}

.form-group {
    margin-bottom: 1.5rem;
}

/* 768px以上：ラベルと入力欄を横並び（ラベル左・入力右）。768px未満は縦並びのまま。
   form 自体を grid（max-content 1fr）にし、各 form-group を display:contents で透過させて
   すべての label / 入力欄を form 直下の単一 grid のセルとして扱う。
   こうすると grid が 1列目を「全ラベル中の最長内容幅」に自動で揃える（見積もり不要）。
   honeypot / form-submit は全幅セル（grid-column:1/-1）に配置する */
@media (min-width: 768px) {
    .contact-form {
        display: grid;
        grid-template-columns: max-content 1fr;
        align-items: start;
        column-gap: 1.25rem;
        /* 行間：form-group ごとの margin-bottom 代わりに row-gap で一括管理 */
        row-gap: 1.5rem;
    }

    /* form-group を透過：中身（label / 入力 / error）を form の grid セルに直接並べる */
    .form-group {
        display: contents;
    }

    .form-group .form-label {
        grid-column: 1;
        white-space: nowrap;
        margin-bottom: 0;
        padding-top: 0.85rem;
    }

    .form-group .form-input,
    .form-group .form-textarea,
    .form-group .form-radio-group {
        grid-column: 2;
        min-width: 0;
    }

    /* ラジオグループは選択肢の高さに合わせて上揃え（ラベルの上パディングと揃える） */
    .form-group .form-radio-group {
        padding-top: 0.85rem;
    }

    /* エラー文（JSが追加）：右列（入力欄の下）に配置。row-gap 分上に離れるのを詰める */
    .form-group .form-error {
        grid-column: 2;
        margin-top: -1.1rem;
    }

    /* honeypot（非表示）・送信ボタンは全幅セルに */
    .contact-form .form-honeypot,
    .contact-form .form-submit {
        grid-column: 1 / -1;
    }

    /* 送信ボタンエリア：中央寄せ（align-items:center）を右寄せに */
    .contact-form .form-submit {
        align-items: flex-end;
    }
}

.form-label {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-family: var(--contact-form-font);
    font-weight: 700;
    font-size: 0.875rem;
    color: var(--color-title);
    margin-bottom: 0.6rem;
}

.form-label__required,
.form-label__optional {
    font-size: 0.68rem;
    font-weight: 700;
    padding: 0.12rem 0.5rem;
    order: -1;
    flex-shrink: 0;
    letter-spacing: 0.05em;
}

.form-label__required {
    background-color: var(--color-accent);
    color: #fff;
}

.form-label__optional {
    background-color: var(--color-border);
    color: var(--color-text-light);
}

.form-input,
.form-textarea {
    width: 100%;
    padding: 0.8rem 1rem;
    border: 1.5px solid var(--color-border);
    font-size: 1rem;
    font-family: var(--contact-form-font);
    color: var(--color-text);
    background-color: #fff;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
    outline: none;
    -webkit-appearance: none;
    appearance: none;
}

.form-input:focus,
.form-textarea:focus {
    border-color: var(--color-accent);
    box-shadow: 0 0 0 3px rgba(127, 197, 192, 0.22);
}

.form-group.is-error .form-input,
.form-group.is-error .form-textarea {
    border-color: #f08080;
    background-color: #fff5f5;
}

.form-textarea {
    /* 右下のリサイズグリップ（斜線）を出さないため resize を無効化 */
    resize: none;
    min-height: 160px;
    line-height: 1.8;
}

.form-radio-group {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem 1.25rem;
}

.form-radio {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    cursor: pointer;
    font-size: 0.95rem;
    color: var(--color-text);
}

.form-radio input[type="radio"] {
    width: 1.05rem;
    height: 1.05rem;
    accent-color: var(--color-accent);
    cursor: pointer;
}

.form-error {
    display: flex;
    align-items: center;
    gap: 0.375rem;
    font-size: 0.8rem;
    color: #b55a5a;
    margin-top: 0.4rem;
}

.form-error i {
    font-size: 0.875rem;
    flex-shrink: 0;
}

.form-submit {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1rem;
    margin-top: 2rem;
}

.form-submit__note {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    font-size: 0.8rem;
    color: var(--color-text-light);
    text-align: center;
}

.form-submit__note i {
    color: var(--color-accent);
}

/* 送信ボタン：共通ボタン（.btn .btn--cut .btn--primary）を適用。
   サイズは共通 btn の値を使うが、切り替え境界だけ 1024px に揃える。
   共通 btn は 576px 以上で通常サイズになるため、送信ボタンは
   ベース（～1023px）でミニサイズ（共通 btn ベース小サイズ相当）に揃え、
   1024px 以上で通常サイズ（共通 btn 576px以上相当）に戻す。
   紙飛行機アイコンがあるため、共通ボタンの矢印（span::after）は非表示 */
.form-submit__btn>span::after {
    content: none;
}

/* ベース（～1023px）：ミニサイズ（共通 btn のベース小サイズの値を使用）。
   共通 btn の 576px以上通常サイズを打ち消す */
.form-submit__btn {
    padding: 0.7rem 1.8rem;
    font-size: 0.85rem;
}

/* 1024px以上：通常サイズ（共通 btn 576px以上と同値）に戻す */
@media (min-width: 1024px) {
    .form-submit__btn {
        padding: 0.9rem 2.4rem;
        font-size: 0.95rem;
    }
}

/* #contact のスクロール位置調整は common.css の scroll-padding-top に一本化（ここでは指定しない） */

/* ================================
   プライバシーポリシーアコーディオン
   （フォームグループ内：上ボーダーでフォームと区切る）
================================ */
.contact-form-group .privacy-policy-accordion {
    border-top: 1px solid var(--color-border);
}

.privacy-policy-accordion__header {
    width: 100%;
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1rem 1.5rem;
    background-color: var(--color-bg-cream);
    border: none;
    cursor: pointer;
    font-family: inherit;
    transition: background-color 0.3s ease;
}

.privacy-policy-accordion__header:hover {
    background-color: var(--color-accent-light);
}

.privacy-policy-accordion__title {
    font-family: var(--contact-form-font);
    font-size: 0.95rem;
    font-weight: 700;
    color: var(--color-primary);
    letter-spacing: 0.06em;
}

/* +/−アイコン */
.privacy-policy-accordion__icon {
    width: 18px;
    height: 18px;
    position: relative;
    flex-shrink: 0;
}

.privacy-policy-accordion__icon::before,
.privacy-policy-accordion__icon::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    background-color: var(--color-accent-dark);
    transition: transform 0.3s ease, opacity 0.3s ease;
}

.privacy-policy-accordion__icon::before {
    width: 2px;
    height: 14px;
    transform: translate(-50%, -50%);
}

.privacy-policy-accordion__icon::after {
    width: 14px;
    height: 2px;
    transform: translate(-50%, -50%);
}

.privacy-policy-accordion__header[aria-expanded='true'] .privacy-policy-accordion__icon::before {
    transform: translate(-50%, -50%) scaleY(0);
    opacity: 0;
}

.privacy-policy-accordion__content {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.4s ease;
}

.privacy-policy-accordion__content[hidden] {
    display: block;
    max-height: 0;
}

.privacy-policy-accordion__content:not([hidden]) {
    max-height: 280px;
    overflow-y: auto;
}

.privacy-policy-accordion__text {
    padding: 1.5rem;
    background-color: var(--color-surface);
    font-family: var(--contact-form-font);
    font-size: 0.8rem;
    line-height: 1.85;
    color: var(--color-text);
    letter-spacing: 0.04em;
}

.privacy-policy-accordion__text p {
    margin-bottom: 0.75rem;
}

.privacy-policy-accordion__text ul {
    list-style: disc;
    padding-left: 1.5rem;
    margin-bottom: 0.75rem;
}

.privacy-policy-accordion__text ul li {
    margin-bottom: 0.25rem;
}

.privacy-policy-accordion__text strong {
    color: var(--color-accent);
}

/* ================================
   送信完了ポップアップ（thanks.php）
================================ */
.form-success-popup {
    display: none;
    position: fixed;
    inset: 0;
    z-index: 9999;
    align-items: center;
    justify-content: center;
    padding: 1.5rem;
}

.form-success-popup.is-active {
    display: flex;
}

.form-success-popup__overlay {
    position: absolute;
    inset: 0;
    background-color: rgba(28, 36, 32, 0.65);
    -webkit-backdrop-filter: blur(3px);
    backdrop-filter: blur(3px);
    cursor: pointer;
}

.form-success-popup__content {
    position: relative;
    z-index: 1;
    background-color: #fff;
    padding: 3rem 2rem 2.5rem;
    max-width: 420px;
    width: 100%;
    text-align: center;
    box-shadow: var(--shadow-lg);
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1rem;
}

.form-success-popup__icon {
    width: 4rem;
    height: 4rem;
    background-color: var(--color-accent);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.75rem;
    flex-shrink: 0;
}

.form-success-popup__title {
    font-family: var(--font-heading);
    font-size: 1.4rem;
    font-weight: 700;
    color: var(--color-title);
    letter-spacing: 0.05em;
}

.form-success-popup__message {
    font-size: 0.92rem;
    color: var(--color-text-light);
    line-height: 1.9;
}

.form-success-popup__button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-top: 0.5rem;
    padding: 0.875rem 2.5rem;
    background-color: var(--color-primary);
    color: #fff;
    font-family: var(--font-heading);
    font-size: 0.95rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    transition: background-color 0.25s ease, transform 0.25s ease;
}

.form-success-popup__button:hover {
    background-color: var(--color-primary-dark);
    transform: translateY(-1px);
}