/*
 * page-contact.css  v3.0
 * お問い合わせページ — Contact Form 7対応スタイル
 *
 * CF7が出力するHTML構造:
 *   .wpcf7 > form.wpcf7-form
 *     p > label + span.wpcf7-form-control-wrap > input / select / textarea
 *     p > input.wpcf7-submit
 *   .wpcf7-response-output  （送信結果メッセージ）
 */

/* ============================================================
   CONTACT WRAP
   ============================================================ */
.contact-wrap {
    max-width: 680px;
    margin: 0 auto;
    padding: 72px 40px 100px;
}

.contact-lead {
    text-align: center;
    font-size: 14px;
    letter-spacing: 0.08em;
    line-height: 2.3;
    color: rgba(255,255,255,0.65);
    margin-bottom: 52px;
}

/* ============================================================
   TEL BOX
   ============================================================ */
.tel-box {
    border: 1px solid var(--border);
    background: var(--bg3);
    padding: 36px 40px;
    text-align: center;
    margin-bottom: 60px;
}
.tel-box .label {
    font-size: 10px;
    letter-spacing: 0.4em;
    color: var(--muted);
    margin-bottom: 12px;
}
.tel-box .number {
    font-size: 30px;
    letter-spacing: 0.15em;
    line-height: 1;
    margin-bottom: 4px;
}
.tel-box .number a { color: inherit; transition: color 0.2s; }
.tel-box .number a:hover { color: rgba(255,255,255,0.7); }
.tel-box .hours {
    font-size: 12px;
    color: var(--muted);
    letter-spacing: 0.08em;
    margin-top: 14px;
    line-height: 2;
}

/* ============================================================
   DIVIDER
   ============================================================ */
.divider {
    display: flex;
    align-items: center;
    gap: 16px;
    margin-bottom: 48px;
}
.divider::before,
.divider::after {
    content: "";
    flex: 1;
    border-top: 1px solid rgba(255,255,255,0.08);
}
.divider span {
    font-size: 11px;
    letter-spacing: 0.25em;
    color: var(--muted);
    white-space: nowrap;
}

/* ============================================================
   CF7ラッパー
   ============================================================ */
.cf7-wrap { }

/* CF7のデフォルトマージンリセット */
.cf7-wrap .wpcf7 { margin: 0; padding: 0; }

/* CF7 form のリセット */
.cf7-wrap .wpcf7-form { margin: 0; }

/* CF7が自動で入れる p タグをフォームの行として使う */
.cf7-wrap .wpcf7-form p {
    margin: 0 0 28px;
}
.cf7-wrap .wpcf7-form p:last-of-type { margin-bottom: 0; }

/* ============================================================
   ラベル
   ============================================================ */
.cf7-wrap .wpcf7-form p > label,
.cf7-wrap .wpcf7-form .cf7-label {
    display: block;
    font-size: 13px;
    letter-spacing: 0.1em;
    color: rgba(255,255,255,0.72);
    margin-bottom: 10px;
}

/* 必須・任意バッジ */
.cf7-wrap .req,
.cf7-wrap .opt {
    display: inline-block;
    font-size: 10px;
    letter-spacing: 0.08em;
    padding: 1px 6px;
    margin-left: 8px;
    line-height: 1.6;
    vertical-align: middle;
}
.cf7-wrap .req { color: var(--red);  border: 1px solid rgba(197,35,47,0.5); }
.cf7-wrap .opt { color: var(--muted); border: 1px solid rgba(255,255,255,0.15); }

/* ============================================================
   入力フィールド共通
   ============================================================ */
.cf7-wrap .wpcf7-form-control-wrap {
    display: block;
}

.cf7-wrap input[type="text"],
.cf7-wrap input[type="email"],
.cf7-wrap input[type="tel"],
.cf7-wrap select,
.cf7-wrap textarea {
    width: 100%;
    background: var(--input-bg);
    border: 1px solid var(--input-border);
    color: var(--text);
    font-family: 'Zen Old Mincho', serif;
    font-size: 15px;
    letter-spacing: 0.06em;
    padding: 14px 16px;
    outline: none;
    border-radius: 0;
    transition: border-color 0.2s, background 0.2s;
    appearance: none;
    -webkit-appearance: none;
}

.cf7-wrap input[type="text"]::placeholder,
.cf7-wrap input[type="email"]::placeholder,
.cf7-wrap input[type="tel"]::placeholder,
.cf7-wrap textarea::placeholder {
    color: rgba(255,255,255,0.18);
    font-size: 13px;
}

.cf7-wrap input[type="text"]:focus,
.cf7-wrap input[type="email"]:focus,
.cf7-wrap input[type="tel"]:focus,
.cf7-wrap select:focus,
.cf7-wrap textarea:focus {
    border-color: var(--input-focus);
    background: rgba(255,255,255,0.06);
}

/* select カスタム矢印 */
.cf7-wrap .select-wrap,
.cf7-wrap .wpcf7-form-control-wrap:has(select) {
    position: relative;
}
.cf7-wrap .wpcf7-form-control-wrap:has(select)::after {
    content: "";
    pointer-events: none;
    position: absolute;
    right: 18px;
    top: 50%;
    width: 7px;
    height: 7px;
    border-right: 1px solid var(--muted);
    border-bottom: 1px solid var(--muted);
    transform: translateY(-65%) rotate(45deg);
}
.cf7-wrap select option { background: #1a1a1a; color: var(--text); }

/* textarea */
.cf7-wrap textarea {
    height: 160px;
    resize: vertical;
    line-height: 1.9;
}

/* ============================================================
   バリデーションエラー表示
   ============================================================ */
.cf7-wrap .wpcf7-not-valid {
    border-color: rgba(197,35,47,0.7) !important;
}
.cf7-wrap .wpcf7-not-valid-tip {
    display: block;
    font-size: 11px;
    color: rgba(197,35,47,0.9);
    letter-spacing: 0.06em;
    margin-top: 6px;
}

/* ============================================================
   プライバシーポリシー文
   ============================================================ */
.cf7-wrap .privacy-note {
    font-size: 11px;
    color: rgba(255,255,255,0.4);
    letter-spacing: 0.06em;
    line-height: 2;
    margin-bottom: 28px;
    padding: 20px 22px;
    border: 1px solid rgba(255,255,255,0.06);
    background: var(--bg3);
}

/* ============================================================
   同意チェックボックス
   ============================================================ */
.cf7-wrap .wpcf7-acceptance {
    display: flex;
    align-items: center;
    gap: 12px;
}
.cf7-wrap .wpcf7-acceptance input[type="checkbox"] {
    width: 18px;
    height: 18px;
    accent-color: var(--red);
    cursor: pointer;
    flex-shrink: 0;
}
.cf7-wrap .wpcf7-acceptance .wpcf7-list-item-label {
    font-size: 13px;
    color: rgba(255,255,255,0.65);
    letter-spacing: 0.06em;
    cursor: pointer;
}

/* ============================================================
   送信ボタン
   ============================================================ */
.cf7-wrap input[type="submit"],
.cf7-wrap .wpcf7-submit {
    display: block;
    width: 100%;
    max-width: 320px;
    margin: 32px auto 0;
    background: var(--red);
    color: #fff;
    font-family: 'Zen Old Mincho', serif;
    font-size: 15px;
    letter-spacing: 0.25em;
    padding: 18px 20px;
    border: none;
    cursor: pointer;
    transition: opacity 0.2s, transform 0.1s;
    border-radius: 0;
    -webkit-appearance: none;
}
.cf7-wrap input[type="submit"]:hover,
.cf7-wrap .wpcf7-submit:hover { opacity: 0.82; }
.cf7-wrap input[type="submit"]:active,
.cf7-wrap .wpcf7-submit:active { transform: scale(0.98); }

/* 送信中スピナー */
.cf7-wrap .wpcf7-spinner {
    display: inline-block;
    margin-left: 12px;
    vertical-align: middle;
}

/* ============================================================
   送信結果メッセージ
   ============================================================ */
.cf7-wrap .wpcf7-response-output {
    margin: 24px 0 0;
    padding: 14px 18px;
    font-size: 13px;
    letter-spacing: 0.06em;
    line-height: 1.8;
    border-radius: 0;
}
/* 送信成功 */
.cf7-wrap .wpcf7-mail-sent-ok {
    border: 1px solid rgba(100,200,100,0.4);
    background: rgba(100,200,100,0.08);
    color: rgba(150,255,150,0.85);
}
/* 送信失敗 */
.cf7-wrap .wpcf7-mail-sent-ng,
.cf7-wrap .wpcf7-aborted {
    border: 1px solid rgba(197,35,47,0.4);
    background: rgba(197,35,47,0.08);
    color: rgba(255,100,100,0.85);
}
/* バリデーションエラー */
.cf7-wrap .wpcf7-validation-errors,
.cf7-wrap .wpcf7-acceptance-missing {
    border: 1px solid rgba(255,180,0,0.4);
    background: rgba(255,180,0,0.06);
    color: rgba(255,200,80,0.85);
}

/* CF7設定前の案内メッセージ */
.cf7-notice {
    text-align: center;
    font-size: 13px;
    color: var(--muted);
    letter-spacing: 0.08em;
    padding: 32px;
    border: 1px solid var(--border);
    background: var(--bg3);
    line-height: 2;
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media screen and (min-width: 768px) and (max-width: 1023px) {
    .contact-wrap { padding: 56px 32px 80px; }
    .tel-box { padding: 28px 32px; }
    .tel-box .number { font-size: 26px; }
}

@media screen and (max-width: 767px) {
    .contact-wrap { padding: 40px 16px 80px; }

    .contact-lead {
        font-size: 13px;
        line-height: 2.2;
        margin-bottom: 40px;
        text-align: left;
    }

    .tel-box {
        padding: 24px 20px;
        margin-bottom: 44px;
    }
    .tel-box .number { font-size: 24px; letter-spacing: 0.1em; }
    .tel-box .number a {
        display: inline-block;
        padding: 8px 16px;
        border: 1px solid rgba(255,255,255,0.15);
        margin-top: 4px;
    }
    .tel-box .hours { font-size: 11px; }

    .divider { margin-bottom: 36px; }
    .divider span { font-size: 10px; letter-spacing: 0.15em; }

    /* フォーム */
    .cf7-wrap .wpcf7-form p { margin-bottom: 22px; }

    .cf7-wrap input[type="text"],
    .cf7-wrap input[type="email"],
    .cf7-wrap input[type="tel"],
    .cf7-wrap select,
    .cf7-wrap textarea {
        font-size: 16px; /* iOS zoom防止 */
        padding: 14px 14px;
    }

    .cf7-wrap textarea { height: 140px; }

    .cf7-wrap input[type="submit"],
    .cf7-wrap .wpcf7-submit {
        max-width: 100%;
        padding: 18px;
        font-size: 16px;
        margin-top: 24px;
    }

    .cf7-wrap .privacy-note { font-size: 11px; padding: 16px; }
}
