/* Contact Form 7 — Komatani theme (uses :root vars from style.css) */

.main-content .wpcf7,
.wpcf7 {
    max-width: 640px;
    margin: 0 auto;
    text-align: left;
    font-family: "Noto Sans JP", sans-serif;
    color: var(--corp-ink, #1c2433);
}

.wpcf7-form {
    margin: 0;
    padding: 0;
}

.wpcf7-form > p {
    margin: 0 0 1.25rem;
}

.wpcf7-form label,
.wpcf7-form .wpcf7-form-control-wrap {
    display: block;
    width: 100%;
}

.wpcf7-form label .wpcf7-form-control-wrap {
    margin-top: 0.35rem;
}

.wpcf7-form label > .wpcf7-form-control-wrap:first-child {
    margin-top: 0;
}

/* ラベル文言（CF7 は <label> 内にテキスト＋コントロールを並べることが多い） */
.wpcf7-form label {
    font-size: 0.875rem;
    font-weight: 600;
    letter-spacing: 0.03em;
    color: var(--corp-ink, #1c2433);
}

.wpcf7-form input[type="text"],
.wpcf7-form input[type="email"],
.wpcf7-form input[type="tel"],
.wpcf7-form input[type="url"],
.wpcf7-form input[type="number"],
.wpcf7-form input[type="date"],
.wpcf7-form select,
.wpcf7-form textarea {
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
    margin: 0;
    padding: 0.65rem 0.85rem;
    font-family: inherit;
    font-size: 1rem;
    line-height: 1.5;
    color: var(--corp-ink, #1c2433);
    background: #fff;
    border: 1px solid var(--corp-border, #dfe3ea);
    border-radius: 4px;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.wpcf7-form textarea {
    min-height: 160px;
    resize: vertical;
}

.wpcf7-form input::placeholder,
.wpcf7-form textarea::placeholder {
    color: var(--corp-muted, #5c6573);
    opacity: 0.75;
}

.wpcf7-form input:hover,
.wpcf7-form select:hover,
.wpcf7-form textarea:hover {
    border-color: #c5cbd6;
}

.wpcf7-form input:focus,
.wpcf7-form select:focus,
.wpcf7-form textarea:focus {
    outline: none;
    border-color: var(--corp-accent, #8b2e14);
    box-shadow: 0 0 0 3px var(--corp-accent-soft, rgba(139, 46, 20, 0.12));
}

.wpcf7-form input:disabled,
.wpcf7-form select:disabled,
.wpcf7-form textarea:disabled {
    opacity: 0.65;
    cursor: not-allowed;
    background: var(--corp-surface, #f6f7f9);
}

/* 必須・任意の補助表示（フォーム側でクラスやspanを付けた場合に効く） */
.wpcf7-form .required,
.wpcf7-form .optional {
    font-size: 0.75rem;
    font-weight: 500;
    margin-left: 0.35em;
}

.wpcf7-form .required {
    color: var(--corp-accent, #8b2e14);
}

.wpcf7-form .optional {
    color: var(--corp-muted, #5c6573);
}

/* 送信ボタン */
.wpcf7-form input[type="submit"],
.wpcf7-form .wpcf7-submit {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 200px;
    margin-top: 0.5rem;
    padding: 0.85rem 1.75rem;
    font-family: inherit;
    font-size: 0.9375rem;
    font-weight: 600;
    letter-spacing: 0.08em;
    color: #fff;
    background: var(--corp-accent, #8b2e14);
    border: 1px solid transparent;
    border-radius: 4px;
    cursor: pointer;
    transition: background 0.2s ease, transform 0.15s ease, box-shadow 0.2s ease;
    box-shadow: 0 2px 8px rgba(28, 36, 51, 0.12);
}

.wpcf7-form input[type="submit"]:hover,
.wpcf7-form .wpcf7-submit:hover {
    background: #6f250f;
    box-shadow: 0 4px 14px rgba(28, 36, 51, 0.14);
}

.wpcf7-form input[type="submit"]:focus-visible,
.wpcf7-form .wpcf7-submit:focus-visible {
    outline: none;
    box-shadow: 0 0 0 3px var(--corp-accent-soft, rgba(139, 46, 20, 0.35));
}

.wpcf7-form input[type="submit"]:active,
.wpcf7-form .wpcf7-submit:active {
    transform: translateY(1px);
}

.wpcf7-form input[type="submit"]:disabled,
.wpcf7-form .wpcf7-submit:disabled {
    opacity: 0.55;
    cursor: not-allowed;
    transform: none;
    box-shadow: none;
}

/* スピナー（送信中） */
.wpcf7 .wpcf7-spinner {
    margin: 0 0 0 12px;
    vertical-align: middle;
}

/* チェックボックス・ラジオ（同意など） */
.wpcf7-form .wpcf7-list-item {
    margin: 0.35rem 0;
}

.wpcf7-form .wpcf7-list-item label {
    display: flex;
    align-items: flex-start;
    gap: 0.5rem;
    font-weight: 500;
    cursor: pointer;
}

.wpcf7-form input[type="checkbox"],
.wpcf7-form input[type="radio"] {
    width: auto;
    margin: 0.2rem 0 0;
    accent-color: var(--corp-accent, #8b2e14);
}

.wpcf7-form input[type="file"] {
    width: 100%;
    max-width: 100%;
    padding: 0.5rem 0;
    font-size: 0.875rem;
    cursor: pointer;
}

/* 検証エラー */
.wpcf7-form .wpcf7-not-valid {
    border-color: #b42318 !important;
    box-shadow: 0 0 0 2px rgba(180, 35, 24, 0.12);
}

.wpcf7-form .wpcf7-not-valid-tip {
    display: block;
    margin-top: 0.4rem;
    font-size: 0.8125rem;
    font-weight: 500;
    color: #b42318;
    line-height: 1.4;
}

/* フォーム全体のレスポンス枠 */
.wpcf7-response-output {
    margin: 1.25rem 0 0;
    padding: 0.85rem 1rem;
    font-size: 0.875rem;
    line-height: 1.6;
    border-radius: 4px;
    border: 1px solid transparent;
}

.wpcf7 form.sent .wpcf7-response-output,
.wpcf7 form .wpcf7-response-output.wpcf7-mail-sent-ok {
    color: #0f5132;
    background: #d1e7dd;
    border-color: #badbcc;
}

.wpcf7 form.invalid .wpcf7-response-output,
.wpcf7 form.unaccepted .wpcf7-response-output,
.wpcf7 form.payment-required .wpcf7-response-output,
.wpcf7 form .wpcf7-response-output.wpcf7-validation-errors {
    color: #842029;
    background: #f8d7da;
    border-color: #f5c2c7;
}

.wpcf7 form.failed .wpcf7-response-output,
.wpcf7 form.aborted .wpcf7-response-output,
.wpcf7 form.spam .wpcf7-response-output {
    color: #664d03;
    background: #fff3cd;
    border-color: #ffecb5;
}

/* スクリーンリーダー用（視覚的には隠す既定のまま尊重） */
.wpcf7 .screen-reader-response {
    position: absolute;
    overflow: hidden;
    clip: rect(1px, 1px, 1px, 1px);
    height: 1px;
    width: 1px;
    margin: 0;
    padding: 0;
    border: 0;
    word-wrap: normal !important;
}

/* reCAPTCHA 等が入る場合の余白 */
.wpcf7-form .wpcf7-recaptcha {
    margin: 1rem 0;
}

@media (max-width: 1120px) {
    .main-content .wpcf7,
    .wpcf7 {
        max-width: 100%;
    }

    .wpcf7-form input[type="submit"],
    .wpcf7-form .wpcf7-submit {
        width: 100%;
        min-width: 0;
    }
}
