/*
 * WPForms Polish
 * ─────────────────────────────────────────────────────────────────────────────
 * Scoped enhancements for WPForms Pro. Applied via the .msk-styled-form
 * class added to the form's CSS Classes field in the WPForms builder.
 *
 * Loaded only on pages containing a WPForms block or shortcode.
 * No !important. Specificity comes from the .msk-styled-form scope.
 * ─────────────────────────────────────────────────────────────────────────────
 */


/* ── Container ─────────────────────────────────────────────────────────── */

.msk-styled-form {
    max-inline-size: 640px;
    margin-inline: auto;
}

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

.msk-styled-form .wpforms-field-label {
    font-size: var(--msk-font-size-base);
    font-weight: 600;
    margin-block-end: var(--msk-space-2);
    color: var(--msk-color-text-primary);
}

/* ── Text Inputs, Selects, Textareas ───────────────────────────────────── */

.msk-styled-form input[type="text"],
.msk-styled-form input[type="email"],
.msk-styled-form input[type="tel"],
.msk-styled-form input[type="url"],
.msk-styled-form input[type="number"],
.msk-styled-form input[type="date"],
.msk-styled-form select,
.msk-styled-form textarea {
    inline-size: 100%;
    padding: var(--msk-space-4) var(--msk-space-5);
    font-size: var(--msk-font-size-base);
    line-height: 1.5;
    border: 1px solid var(--msk-color-border);
    border-radius: var(--msk-radius-md);
    background: var(--msk-color-surface);
    color: var(--msk-color-text-primary);
    box-shadow: var(--msk-shadow-sm);
    transition: border-color var(--msk-duration-fast) var(--msk-ease-out),
                box-shadow   var(--msk-duration-fast) var(--msk-ease-out);
    box-sizing: border-box;
}

/* Focus state */
.msk-styled-form input[type="text"]:focus,
.msk-styled-form input[type="email"]:focus,
.msk-styled-form input[type="tel"]:focus,
.msk-styled-form input[type="url"]:focus,
.msk-styled-form input[type="number"]:focus,
.msk-styled-form input[type="date"]:focus,
.msk-styled-form select:focus,
.msk-styled-form textarea:focus {
    outline: none;
    border-color: var(--msk-color-accent);
    box-shadow: 0 0 0 3px color-mix(in oklch, var(--msk-color-accent) 20%, transparent);
}

/* ── Select Dropdown ───────────────────────────────────────────────────── */

.msk-styled-form select {
    cursor: pointer;
    appearance: none;
    background-image: url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23666' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");
    background-repeat: no-repeat;
    background-position: right var(--msk-space-4) center;
    background-size: 18px;
    padding-inline-end: calc(var(--msk-space-4) + 26px);
}

/* ── Textarea ──────────────────────────────────────────────────────────── */

.msk-styled-form textarea {
    min-block-size: 150px;
    resize: vertical;
}

/* ── Name Field (First / Last side by side) ────────────────────────────── */

.msk-styled-form .wpforms-field-name .wpforms-field-row {
    display: flex;
    gap: var(--msk-space-4);
}

.msk-styled-form .wpforms-field-name .wpforms-field-row .wpforms-field-row-block {
    flex: 1;
}

/* ── Submit Button ─────────────────────────────────────────────────────── */

.msk-styled-form .wpforms-submit-container {
    text-align: center;
    margin-block-start: var(--msk-space-6);
}

.msk-styled-form button[type="submit"],
.msk-styled-form .wpforms-submit {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: var(--msk-space-4) var(--msk-space-12);
    font-size: var(--msk-font-size-base);
    font-weight: 600;
    border: none;
    border-radius: var(--msk-radius-md);
    cursor: pointer;
    box-shadow: var(--msk-shadow-accent);
    transition:
        transform  var(--msk-duration-fast) var(--msk-ease-out),
        box-shadow var(--msk-duration-fast) var(--msk-ease-out);
}

.msk-styled-form button[type="submit"]:hover,
.msk-styled-form .wpforms-submit:hover {
    transform: translateY(-2px);
    box-shadow:
        var(--msk-shadow-accent),
        0 6px 20px color-mix(in oklch, var(--msk-color-accent) 30%, transparent);
}

.msk-styled-form button[type="submit"]:active,
.msk-styled-form .wpforms-submit:active {
    transform: translateY(0);
}

/* ── Error States ──────────────────────────────────────────────────────── */

.msk-styled-form .wpforms-error {
    border-color: #ef4444;
}

.msk-styled-form label.wpforms-error {
    color: #dc2626;
    font-size: var(--msk-font-size-xs);
    margin-block-start: var(--msk-space-1);
}

/* ── prefers-reduced-motion ─────────────────────────────────────────────
 * WCAG 2.3.3 — honour users' OS-level motion preference. The 0.01ms
 * duration cancels visible motion while still firing transitionend /
 * animationend events that JS handlers may listen for.
 */
@media ( prefers-reduced-motion: reduce ) {
    *,
    *::before,
    *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
        scroll-behavior: auto !important;
    }
}
