/* ================================================
   WPFORMS — Brand Override Styles
   Overrides WPForms' own stylesheet to match the
   Norvella design system.
   ================================================ */

/* ── Labels ─────────────────────────────────────── */

.wpforms-form .wpforms-field-label,
.wpforms-form label.wpforms-field-label {
    display: block !important;
    font-family: var(--font-body) !important;
    font-size: 11px !important;
    font-weight: 600 !important;
    letter-spacing: 0.16em !important;
    text-transform: uppercase !important;
    color: var(--color-secondary) !important;
    margin-bottom: 12px !important;
    text-decoration: none !important;
    background: none !important;
    padding: 0 !important;
    border: none !important;
    line-height: 1.4 !important;
}

.wpforms-form .wpforms-required-label {
    color: var(--color-primary) !important;
    font-style: normal !important;
    margin-left: 2px !important;
}

/* ── All input types ────────────────────────────── */

.wpforms-form input[type="text"],
.wpforms-form input[type="email"],
.wpforms-form input[type="tel"],
.wpforms-form input[type="number"],
.wpforms-form input[type="url"],
.wpforms-form input[type="password"],
.wpforms-form input[type="date"],
.wpforms-form textarea,
.wpforms-form select {
    font-family: var(--font-body) !important;
    font-size: 15px !important;
    line-height: 1.5 !important;
    color: var(--color-text) !important;
    background: #fff !important;
    border: 1.5px solid rgba(0,0,0,0.15) !important;
    border-radius: 5px !important;
    padding: 13px 16px !important;
    width: 100% !important;
    box-shadow: none !important;
    outline: none !important;
    appearance: none !important;
    -webkit-appearance: none !important;
    height: auto !important;
    transition: border-color 0.2s ease, box-shadow 0.2s ease !important;
}

.wpforms-form input[type="text"]:focus,
.wpforms-form input[type="email"]:focus,
.wpforms-form input[type="tel"]:focus,
.wpforms-form input[type="number"]:focus,
.wpforms-form input[type="url"]:focus,
.wpforms-form input[type="password"]:focus,
.wpforms-form input[type="date"]:focus,
.wpforms-form textarea:focus,
.wpforms-form select:focus {
    border-color: var(--color-primary) !important;
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--color-primary) 15%, transparent) !important;
    outline: none !important;
}

.wpforms-form input::placeholder,
.wpforms-form textarea::placeholder {
    color: rgba(0,0,0,0.3) !important;
    font-size: 14px !important;
    font-family: var(--font-body) !important;
}

.wpforms-form textarea {
    resize: vertical !important;
    min-height: 130px !important;
}

/* ── Choices.js dropdown placeholder (matches input ::placeholder) ── */

/* Non-placeholder items get normal text color */
.wpforms-form .choices .choices__item {
    color: var(--color-text) !important;
}

/* Placeholder item specifically — light like ::placeholder */
.wpforms-form .choices .choices__item.choices__placeholder,
.wpforms-form .choices .choices__list .choices__item.choices__placeholder,
.wpforms-form .choices .choices__list--single .choices__item.choices__placeholder {
    color: rgba(0,0,0,0.2) !important;
    font-family: var(--font-body) !important;
    font-size: 14px !important;
    font-weight: 400 !important;
    opacity: 1 !important;
}

/* ── Choices.js dropdown list — override default browser blue ── */

/* Dropdown list items */
.wpforms-form .choices .choices__list--dropdown .choices__item,
.wpforms-form .choices .choices__list[aria-expanded] .choices__item {
    color: var(--color-text) !important;
    background: var(--color-background) !important;
}

/* Hovered / keyboard-focused item */
.wpforms-form .choices .choices__list--dropdown .choices__item--selectable.is-highlighted,
.wpforms-form .choices .choices__list[aria-expanded] .choices__item--selectable.is-highlighted {
    background: var(--color-secondary) !important;
    color: var(--color-text-light) !important;
}

/* Already selected item in the list */
.wpforms-form .choices .choices__list--dropdown .choices__item[aria-selected="true"],
.wpforms-form .choices .choices__list[aria-expanded] .choices__item[aria-selected="true"] {
    background: var(--color-surface) !important;
    color: var(--color-text) !important;
}

/* ── Select custom arrow ────────────────────────── */

.wpforms-form select {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23999' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E") !important;
    background-repeat: no-repeat !important;
    background-position: right 14px center !important;
    padding-right: 44px !important;
    cursor: pointer !important;
}

/* ── Field wrapper spacing ──────────────────────── */

.wpforms-form .wpforms-field {
    margin-bottom: 32px !important;
    padding: 0 !important;
}

/* ── Phone — intl-tel-input ─────────────────────── */

.wpforms-field-phone .iti {
    width: 100% !important;
    display: block !important;
}

.wpforms-field-phone .iti input[type="tel"] {
    padding-left: 60px !important;
}

.wpforms-field-phone .iti__selected-country {
    background: transparent !important;
    border: none !important;
    border-right: 1.5px solid rgba(0,0,0,0.12) !important;
    padding: 0 10px !important;
    height: 100% !important;
}

.wpforms-field-phone .iti__selected-country:hover {
    background: rgba(0,0,0,0.04) !important;
}

/* ── Two-column layout rows ─────────────────────── */

.wpforms-field-layout-rows .wpforms-layout-row {
    display: flex !important;
    gap: 20px !important;
    align-items: flex-end !important;
    margin-bottom: 20px !important;
}

.wpforms-field-layout-rows .wpforms-layout-row:last-child {
    margin-bottom: 0 !important;
}

.wpforms-field-layout-rows .wpforms-layout-column {
    flex: 1 !important;
    min-width: 0 !important;
}

.wpforms-field-layout-rows .wpforms-layout-column .wpforms-field {
    margin-bottom: 0 !important;
}

/* ── Error states ───────────────────────────────── */

.wpforms-form input.wpforms-error,
.wpforms-form textarea.wpforms-error,
.wpforms-form select.wpforms-error {
    border-color: #b94040 !important;
    box-shadow: 0 0 0 3px rgba(185,64,64,0.1) !important;
}

.wpforms-form label.wpforms-error {
    font-family: var(--font-body) !important;
    font-size: 12px !important;
    font-weight: 400 !important;
    letter-spacing: 0 !important;
    text-transform: none !important;
    color: #b94040 !important;
    margin-top: 5px !important;
    display: block !important;
    background: none !important;
    padding: 0 !important;
    border: none !important;
}

/* ── Submit button ──────────────────────────────── */

.wpforms-form .wpforms-submit-container {
    margin-top: 8px !important;
    padding: 0 !important;
}

.wpforms-form .wpforms-submit,
.wpforms-form button[type="submit"] {
    display: block !important;
    width: 100% !important;
    font-family: var(--font-body) !important;
    font-size: 12px !important;
    font-weight: 600 !important;
    letter-spacing: 0.2em !important;
    text-transform: uppercase !important;
    color: var(--color-secondary) !important;
    background: var(--color-primary) !important;
    border: 2px solid var(--color-primary) !important;
    border-radius: 5px !important;
    padding: 16px 48px !important;
    cursor: pointer !important;
    text-align: center !important;
    transition: background 0.25s ease, color 0.25s ease, border-color 0.25s ease !important;
    height: auto !important;
    line-height: 1.4 !important;
    box-shadow: none !important;
}

.wpforms-form .wpforms-submit:hover,
.wpforms-form button[type="submit"]:hover {
    background: var(--color-secondary) !important;
    border-color: var(--color-secondary) !important;
    color: var(--color-text-light) !important;
}

.wpforms-form .wpforms-submit:disabled {
    opacity: 0.55 !important;
    cursor: not-allowed !important;
}

/* ── Confirmation message ───────────────────────── */

.wpforms-confirmation-container-full,
.wpforms-confirmation-container {
    background: color-mix(in srgb, var(--color-primary) 8%, transparent) !important;
    border: 1px solid var(--color-primary) !important;
    border-radius: 8px !important;
    padding: 32px 36px !important;
    font-family: var(--font-body) !important;
    font-size: 16px !important;
    line-height: 1.75 !important;
    color: var(--color-secondary) !important;
    text-align: center !important;
    box-shadow: none !important;
}

/* ================================================
   RESPONSIVE
   ================================================ */

@media (max-width: 600px) {
    .wpforms-field-layout-rows .wpforms-layout-row {
        flex-direction: column !important;
        gap: 22px !important;
    }

    .wpforms-form .wpforms-submit,
    .wpforms-form button[type="submit"] {
        font-size: 11px !important;
        padding: 14px 32px !important;
    }
}
