/* ==========================================================================
   Contact Page - CF7 Form Styling & Fixes
   Page: /contact/ (ID 118)
   
   Fixes:
   1. Hidden fields container (fieldset) appearing as half-visible field at top
   2. Empty wpcf7-response-output div visible as a styled box at bottom
   3. Clean form field styling consistent with site design
   ========================================================================== */

/* --- Fix #1: Hidden fields container must never be visible --- */
.page-id-118 .wpcf7 .hidden-fields-container,
.page-id-118 .wpcf7 fieldset.hidden-fields-container {
    display: none !important;
    height: 0 !important;
    overflow: hidden !important;
    visibility: hidden !important;
    margin: 0 !important;
    padding: 0 !important;
    border: none !important;
}

/* --- Fix: Screen reader response should not take visual space --- */
.page-id-118 .wpcf7 .screen-reader-response {
    position: absolute !important;
    width: 1px !important;
    height: 1px !important;
    overflow: hidden !important;
    clip: rect(0, 0, 0, 0) !important;
    border: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* --- Fix #2: Response output must be hidden until form state changes --- */
.page-id-118 div.wpcf7-response-output,
.page-id-118 .wpcf7 div.wpcf7-response-output,
.page-id-118 .wpcf7 .wpcf7-form .wpcf7-response-output {
    display: none !important;
    margin: 0 !important;
    padding: 0 !important;
    border: none !important;
    height: 0 !important;
    overflow: hidden !important;
}

/* Show response output only after form interaction
   Woodmart uses :before pseudo-element for icon (positioned at left:24px)
   so padding-inline-start must be >= 65px to avoid text/icon overlap */
.page-id-118 .wpcf7 form.sent .wpcf7-response-output,
.page-id-118 .wpcf7 form.invalid .wpcf7-response-output,
.page-id-118 .wpcf7 form.unaccepted .wpcf7-response-output,
.page-id-118 .wpcf7 form.spam .wpcf7-response-output,
.page-id-118 .wpcf7 form.failed .wpcf7-response-output,
.page-id-118 .wpcf7 form.aborted .wpcf7-response-output {
    display: block !important;
    height: auto !important;
    overflow: visible !important;
    margin-top: 15px !important;
    padding-block: 18px !important;
    padding-inline: 65px 30px !important;
    border: none !important;
    border-radius: var(--wd-brd-radius, 6px) !important;
}

/* --- Form field styling --- */
.page-id-118 .wpcf7-form label {
    display: block;
    font-family: 'Raleway', sans-serif;
    font-weight: 500;
    font-size: 0.95em;
    color: var(--e-global-color-primary, #14213D);
    margin-bottom: 0.5em;
}

.page-id-118 .wpcf7-form input[type=text],
.page-id-118 .wpcf7-form input[type=email],
.page-id-118 .wpcf7-form textarea {
    width: 100%;
    padding: 12px 15px;
    border: 1px solid rgba(0, 0, 0, 0.15);
    border-radius: 6px;
    font-family: 'Raleway', sans-serif;
    font-size: 0.95em;
    color: #333;
    background: #fff;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
    box-sizing: border-box;
}

.page-id-118 .wpcf7-form input[type=text]:focus,
.page-id-118 .wpcf7-form input[type=email]:focus,
.page-id-118 .wpcf7-form textarea:focus {
    border-color: var(--e-global-color-accent, #C8A96E);
    box-shadow: 0 0 0 2px rgba(200, 169, 110, 0.15);
    outline: none;
}

.page-id-118 .wpcf7-form textarea {
    min-height: 150px;
    resize: vertical;
}

.page-id-118 .wpcf7-form p {
    margin-bottom: 1em;
}

/* Submit button - matches site accented button design */
.page-id-118 .wpcf7-form input[type="submit"],
.page-id-118 div.wpcf7 input[type="submit"] {
    display: inline-block;
    padding: 14px 45px;
    font-family: 'Raleway', sans-serif;
    font-size: 1em;
    font-weight: 600;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    cursor: pointer;
    transition: all 0.3s ease;
    margin-top: 0.5em;
    background-color: var(--btn-accented-bgcolor, #CDA355) !important;
    color: var(--btn-accented-color, #fff) !important;
    border: none !important;
    border-radius: var(--btn-accented-brd-radius, 35px) !important;
    box-shadow: var(--btn-accented-box-shadow, none);
}

.page-id-118 .wpcf7-form input[type="submit"]:hover,
.page-id-118 div.wpcf7 input[type="submit"]:hover {
    background-color: var(--btn-accented-bgcolor-hover, #b8903d) !important;
    color: var(--btn-accented-color-hover, #fff) !important;
    box-shadow: 0 4px 12px rgba(205, 163, 85, 0.35);
    transform: translateY(-1px);
}

.page-id-118 .wpcf7-form input[type="submit"]:active,
.page-id-118 div.wpcf7 input[type="submit"]:active {
    transform: translateY(0);
    box-shadow: none;
}

/* Turnstile CAPTCHA spacing */
.page-id-118 .cf7-cf-turnstile {
    margin: 1em 0;
}

/* Validation error tips */
.page-id-118 .wpcf7-not-valid-tip {
    font-size: 0.85em;
    margin-top: 4px;
}

.page-id-118 .wpcf7-form input.wpcf7-not-valid,
.page-id-118 .wpcf7-form textarea.wpcf7-not-valid {
    border-color: #e74c3c;
}
