/**
 * MinucciForms - Premium Form Design System
 * Floating labels, micro-interactions & Prestige theme
 * Version: 2.2.0
 *
 * Note: Specificite renforcee pour contrer Elementor CSS
 * v2.2.0 : Anti-spam sans cookie (honeypot) + texte alternatif RGPD du
 *          Cookie Wall - reCAPTCHA et Cookie Wall desactives par defaut
 * v2.1.1 : Fix : 12 variables --minucci-* utilisees mais absentes de :root
 *          (fonds erreur/succes, ombres, easings, durees) - les etats et
 *          animations du style par defaut sont reactives
 * v2.1.0 : Styles Moderne Clair & Moderne Sombre (carte arrondie, champs
 *          boxes, focus ring accessible, palettes AA pilotees par variables)
 * v1.6.7 : Style Prestige aligne sur DA Constantin-Vallet (Premium & Editorial)
 *          - Palette exacte DA : Bleu Petrole #2A3B4C, Greige #EBEBE6, Blanc casse #F5F5F5
 *          - Bouton Pillule Ghost/Outline (border-radius: 50px)
 *          - Typographie Serif/Sans-Serif hierarchy
 *          - Validation muted (pas de vert vif)
 *          - Espacement genereux (min 20-24px)
 */

/* ==========================================================================
   CSS Variables - Apple Design System
   ========================================================================== */

:root {
    /* Tally.so-like Colors */
    --minucci-primary: #000000;
    --minucci-primary-dark: #333333;
    --minucci-primary-light: rgba(0, 0, 0, 0.05);
    --minucci-success: #30D158;
    --minucci-success-light: rgba(48, 209, 88, 0.10);
    --minucci-error: #FF453A;
    --minucci-error-light: rgba(255, 69, 58, 0.08);
    --minucci-text: #000000;
    --minucci-text-secondary: #666666;
    --minucci-placeholder: #999999;
    --minucci-border: #E0E0E0;
    --minucci-border-light: #EEEEF0;
    --minucci-border-focus: #000000;
    --minucci-separator: #ECECEF;
    --minucci-bg: #FFFFFF;
    --minucci-bg-elevated: #FFFFFF;
    --minucci-white: #FFFFFF;

    /* Ombres */
    --minucci-shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.06);
    --minucci-shadow-xl: 0 24px 64px rgba(0, 0, 0, 0.20);
    --minucci-shadow-error: 0 0 0 4px rgba(255, 69, 58, 0.15);

    /* Tally-style spacing - optimisé pour légèreté */
    --minucci-radius-sm: 4px;
    --minucci-radius-md: 6px;
    --minucci-radius-lg: 8px;
    --minucci-radius-2xl: 20px;
    --minucci-spacing-field: 16px;
    --minucci-spacing-button: 24px;

    /* Transitions */
    --minucci-ease-smooth: cubic-bezier(0.25, 0.1, 0.25, 1);
    --minucci-ease-out: cubic-bezier(0.25, 0.46, 0.45, 0.94);
    --minucci-ease-spring: cubic-bezier(0.34, 1.56, 0.64, 1);
    --minucci-duration-fast: 200ms;
    --minucci-duration-normal: 300ms;
    --minucci-duration-slow: 400ms;
}

/* ==========================================================================
   Base Styles (spécificité renforcée)
   ========================================================================== */

.elementor-widget-minucci-form .minucci-form,
.minucci-form.minucci-form {
    position: relative !important;
    z-index: 1 !important;
    width: 100% !important;
    box-sizing: border-box !important;
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif !important;
    -webkit-font-smoothing: antialiased !important;
    -moz-osx-font-smoothing: grayscale !important;
    text-rendering: optimizeLegibility !important;
    background: transparent !important;
    color: var(--minucci-text) !important;
}

.minucci-form.minucci-form *,
.minucci-form.minucci-form *::before,
.minucci-form.minucci-form *::after {
    box-sizing: border-box !important;
}

.minucci-form.minucci-form .minucci-form-inner {
    transition: filter var(--minucci-duration-slow) var(--minucci-ease-smooth),
        opacity var(--minucci-duration-slow) var(--minucci-ease-smooth),
        transform var(--minucci-duration-slow) var(--minucci-ease-smooth) !important;
}

/* ==========================================================================
   Cookie Wall - Locked State
   ========================================================================== */

/* Base : formulaire verrouille (commun aux deux modes) */
.minucci-form.minucci-form.is-locked .minucci-form-inner {
    pointer-events: none !important;
    user-select: none !important;
}

/* ---------- Mode Sans Flou : formulaire 100% visible ---------- */
.minucci-form.minucci-form.is-locked.minucci-blur-none .minucci-form-inner {
    filter: none !important;
    opacity: 1 !important;
}

/* ---------- Mode Flou : skeleton shimmer + animations ---------- */

/* Animation flottante sur les champs */
.minucci-form.minucci-form.is-locked.minucci-blur-active .minucci-field {
    animation: minucci-float 3s ease-in-out infinite !important;
    opacity: 1 !important;
}

.minucci-form.minucci-form.is-locked.minucci-blur-active .minucci-field:nth-child(1) { animation-delay: 0s !important; }
.minucci-form.minucci-form.is-locked.minucci-blur-active .minucci-field:nth-child(2) { animation-delay: 0.15s !important; }
.minucci-form.minucci-form.is-locked.minucci-blur-active .minucci-field:nth-child(3) { animation-delay: 0.3s !important; }
.minucci-form.minucci-form.is-locked.minucci-blur-active .minucci-field:nth-child(4) { animation-delay: 0.45s !important; }
.minucci-form.minucci-form.is-locked.minucci-blur-active .minucci-field:nth-child(5) { animation-delay: 0.6s !important; }
.minucci-form.minucci-form.is-locked.minucci-blur-active .minucci-field:nth-child(6) { animation-delay: 0.75s !important; }

@keyframes minucci-float {
    0%, 100% { transform: translateY(0px) scale(1); opacity: 0.7; }
    50% { transform: translateY(-4px) scale(1.01); opacity: 0.85; }
}

.minucci-form.minucci-form.is-locked.minucci-blur-active .minucci-field input,
.minucci-form.minucci-form.is-locked.minucci-blur-active .minucci-field textarea,
.minucci-form.minucci-form.is-locked.minucci-blur-active .minucci-field select {
    background: linear-gradient(110deg,
            rgba(227, 227, 235, 0.9) 0%,
            rgba(248, 248, 250, 0.95) 25%,
            rgba(255, 255, 255, 1) 50%,
            rgba(248, 248, 250, 0.95) 75%,
            rgba(227, 227, 235, 0.9) 100%) !important;
    background-size: 200% 100% !important;
    animation: minucci-shimmer 2s ease-in-out infinite !important;
    color: transparent !important;
    border-bottom-color: rgba(0, 0, 0, 0.15) !important;
    box-shadow: none !important;
}

.minucci-form.minucci-form.is-locked.minucci-blur-active .minucci-field input::placeholder,
.minucci-form.minucci-form.is-locked.minucci-blur-active .minucci-field textarea::placeholder {
    color: transparent !important;
}

.minucci-form.minucci-form.is-locked.minucci-blur-active .minucci-label {
    color: rgba(142, 142, 147, 0.8) !important;
    background: none !important;
    -webkit-text-fill-color: rgba(142, 142, 147, 0.8) !important;
    animation: minucci-label-pulse 2s ease-in-out infinite !important;
}

@keyframes minucci-label-pulse {
    0%, 100% { opacity: 0.6; }
    50% { opacity: 0.85; }
}

.minucci-form.minucci-form.is-locked.minucci-blur-active .minucci-submit {
    background: linear-gradient(110deg,
            rgba(200, 200, 210, 0.8) 0%,
            rgba(220, 220, 230, 0.9) 25%,
            rgba(240, 240, 245, 1) 50%,
            rgba(220, 220, 230, 0.9) 75%,
            rgba(200, 200, 210, 0.8) 100%) !important;
    background-size: 200% 100% !important;
    animation: minucci-shimmer 2s ease-in-out infinite, minucci-pulse 2.5s ease-in-out infinite !important;
    color: transparent !important;
    box-shadow: none !important;
}

@keyframes minucci-pulse {
    0%, 100% { transform: scale(1); opacity: 0.7; }
    50% { transform: scale(1.015); opacity: 0.9; }
}

.minucci-form.minucci-form.is-locked.minucci-blur-active .minucci-consent-wrapper {
    opacity: 0.75 !important;
    animation: minucci-float 3.2s ease-in-out infinite 0.9s !important;
}

.minucci-form.minucci-form.is-locked.minucci-blur-active .minucci-consent-checkmark {
    background: linear-gradient(110deg,
            rgba(232, 232, 237, 0.9) 0%,
            rgba(248, 248, 250, 0.95) 50%,
            rgba(232, 232, 237, 0.9) 100%) !important;
    background-size: 200% 100% !important;
    animation: minucci-shimmer 2s ease-in-out infinite !important;
    border-color: rgba(0, 0, 0, 0.15) !important;
}

@keyframes minucci-shimmer {
    0% { background-position: 200% center; }
    100% { background-position: -200% center; }
}

/* Cookie Overlay - Apple Glassmorphism */
.minucci-form.minucci-form .minucci-cookie-overlay {
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 0 !important;
    background: rgba(249, 249, 251, 0.12) !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    transition: opacity 0.3s ease, backdrop-filter 0.3s ease !important;
    z-index: 10 !important;
}

@keyframes minucci-overlay-in {
    from {
        opacity: 0;
        backdrop-filter: blur(0px);
        -webkit-backdrop-filter: blur(0px);
    }

    to {
        opacity: 1;
        backdrop-filter: none;
        -webkit-backdrop-filter: none;
    }
}

/* Cookie Content Card - iOS Modal Style */
.minucci-form.minucci-form .minucci-cookie-content {
    background: rgba(255, 255, 255, 0.92) !important;
    backdrop-filter: blur(40px) saturate(180%) !important;
    -webkit-backdrop-filter: blur(40px) saturate(180%) !important;
    border-radius: 20px !important;
    padding: 48px 40px !important;
    text-align: center !important;
    max-width: 480px !important;
    width: auto !important;
    height: auto !important;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.12), 0 1px 0 rgba(255, 255, 255, 0.8) inset !important;
    animation: minucci-card-in var(--minucci-duration-slow) var(--minucci-ease-spring) !important;
    transform-origin: center center !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    border: 1px solid rgba(255, 255, 255, 0.5) !important;
}

@keyframes minucci-card-in {
    0% {
        opacity: 0;
        transform: scale(0.88) translateY(24px);
    }

    100% {
        opacity: 1;
        transform: scale(1) translateY(0);
    }
}

.minucci-form.minucci-form .minucci-cookie-icon {
    margin-bottom: 20px !important;
    animation: minucci-bounce-in 0.7s var(--minucci-ease-spring) 0.15s both !important;
}

@keyframes minucci-bounce-in {
    0% {
        opacity: 0;
        transform: scale(0.2) rotate(-15deg);
    }

    50% {
        transform: scale(1.15) rotate(5deg);
    }

    70% {
        transform: scale(0.95) rotate(-2deg);
    }

    100% {
        opacity: 1;
        transform: scale(1) rotate(0deg);
    }
}

.minucci-form.minucci-form .minucci-cookie-icon img,
.minucci-form.minucci-form .minucci-cookie-icon svg {
    filter: drop-shadow(0 8px 16px rgba(139, 69, 19, 0.2)) !important;
    transition: transform var(--minucci-duration-normal) var(--minucci-ease-spring) !important;
}

.minucci-form.minucci-form .minucci-cookie-content:hover .minucci-cookie-icon img,
.minucci-form.minucci-form .minucci-cookie-content:hover .minucci-cookie-icon svg {
    transform: scale(1.08) rotate(5deg) !important;
}

.minucci-form.minucci-form .minucci-cookie-title {
    font-size: 1.375rem !important;
    font-weight: 600 !important;
    color: var(--minucci-text) !important;
    margin: 0 0 10px 0 !important;
    letter-spacing: -0.025em !important;
    animation: minucci-fade-up 0.5s var(--minucci-ease-out) 0.2s both !important;
    line-height: 1.3 !important;
}

.minucci-form.minucci-form .minucci-cookie-text {
    font-size: 0.9375rem !important;
    color: var(--minucci-text-secondary) !important;
    line-height: 1.55 !important;
    margin: 0 0 28px 0 !important;
    animation: minucci-fade-up 0.5s var(--minucci-ease-out) 0.25s both !important;
}

@keyframes minucci-fade-up {
    from {
        opacity: 0;
        transform: translateY(12px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* Cookie Accept Button - iOS Primary Button */
.minucci-form.minucci-form .minucci-cookie-accept {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 8px !important;
    padding: 15px 28px !important;
    width: 100% !important;
    max-width: 260px !important;
    background: #000000 !important;
    /* Force Black */
    color: #FFFFFF !important;
    border: none !important;
    border-radius: var(--minucci-radius-md) !important;
    font-size: 1.0625rem !important;
    font-weight: 600 !important;
    font-family: inherit !important;
    cursor: pointer !important;
    transition: all var(--minucci-duration-fast) var(--minucci-ease-smooth) !important;
    animation: minucci-fade-up 0.5s var(--minucci-ease-out) 0.3s both !important;
    position: relative !important;
    overflow: hidden !important;
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.2) !important;
    line-height: 1.4 !important;
}

.minucci-form.minucci-form .minucci-cookie-accept:hover {
    filter: brightness(0.92);
    transform: scale(1.02) translateY(-1px) !important;
    box-shadow: 0 8px 24px rgba(0, 122, 255, 0.4) !important;
}

.minucci-form.minucci-form .minucci-cookie-accept:active {
    transform: scale(0.97) !important;
    box-shadow: 0 2px 8px rgba(0, 122, 255, 0.3) !important;
}

/* Cookie Wall Hidden State */
.minucci-form.minucci-form:not(.is-locked) .minucci-cookie-overlay {
    display: none !important;
    opacity: 0 !important;
    pointer-events: none !important;
}

/* Cookie Wall Exit Animation */
.minucci-form.minucci-form .minucci-cookie-overlay.is-hiding {
    animation: minucci-overlay-out var(--minucci-duration-normal) var(--minucci-ease-smooth) forwards !important;
}

.minucci-form.minucci-form .minucci-cookie-overlay.is-hiding .minucci-cookie-content {
    animation: minucci-card-out var(--minucci-duration-normal) var(--minucci-ease-smooth) forwards !important;
}

@keyframes minucci-overlay-out {
    to {
        opacity: 0;
        backdrop-filter: blur(0px);
        -webkit-backdrop-filter: blur(0px);
    }
}

@keyframes minucci-card-out {
    to {
        opacity: 0;
        transform: scale(0.92) translateY(-16px);
    }
}

/* ==========================================================================
   Fields Layout
   ========================================================================== */

.minucci-form.minucci-form .minucci-fields-wrapper {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: var(--minucci-spacing-field) !important;
}

.minucci-form.minucci-form .minucci-field {
    width: 100% !important;
    position: relative !important;
    margin: 0 !important;
}

.minucci-form.minucci-form .minucci-field-width-50 {
    width: calc(50% - 8px) !important;
}

@media (max-width: 600px) {
    .minucci-form.minucci-form .minucci-fields-wrapper {
        gap: 14px !important;
    }

    .minucci-form.minucci-form .minucci-field-width-50 {
        width: 100% !important;
    }
}

/* ==========================================================================
   reCAPTCHA Badge
   ========================================================================== */

.minucci-form.minucci-form .minucci-field-recaptcha {
    display: flex !important;
    align-items: center !important;
}

.minucci-form.minucci-form .minucci-recaptcha-badge {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    padding: 14px 18px !important;
    background: var(--minucci-bg) !important;
    border: 1.5px solid var(--minucci-border-light) !important;
    border-radius: var(--minucci-radius-md) !important;
    width: 100% !important;
}

.minucci-form.minucci-form .minucci-recaptcha-icon {
    flex-shrink: 0 !important;
}

.minucci-form.minucci-form .minucci-recaptcha-text {
    font-size: 0.875rem !important;
    color: var(--minucci-text-secondary) !important;
    font-weight: 500 !important;
}

/* ==========================================================================
   Floating Labels - Apple Style
   ========================================================================== */

.minucci-form.minucci-form .minucci-label {
    position: absolute !important;
    left: 16px !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    font-size: 0.9375rem !important;
    font-weight: 400 !important;
    color: var(--minucci-text-secondary) !important;
    pointer-events: none !important;
    transition: all var(--minucci-duration-fast) var(--minucci-ease-smooth) !important;
    transform-origin: left center !important;
    z-index: 1 !important;
    background: transparent !important;
    padding: 0 4px !important;
    margin: 0 0 0 -4px !important;
    line-height: 1.4 !important;
}

/* Label for textarea - different positioning */
.minucci-form.minucci-form .minucci-field-textarea .minucci-label {
    top: 18px !important;
    transform: translateY(0) !important;
}

/* Floating state - when focused or has value */
.minucci-form.minucci-form .minucci-field.is-floating .minucci-label,
.minucci-form.minucci-form .minucci-field input:focus~.minucci-label,
.minucci-form.minucci-form .minucci-field textarea:focus~.minucci-label,
.minucci-form.minucci-form .minucci-field input:not(:placeholder-shown)~.minucci-label,
.minucci-form.minucci-form .minucci-field textarea:not(:placeholder-shown)~.minucci-label,
.minucci-form.minucci-form .minucci-field select:focus~.minucci-label,
.minucci-form.minucci-form .minucci-field select:not([data-empty="true"])~.minucci-label {
    top: 0 !important;
    transform: translateY(-50%) scale(0.82) !important;
    color: var(--minucci-primary) !important;
    font-weight: 500 !important;
    background: var(--minucci-bg-elevated) !important;
}

.minucci-form.minucci-form .minucci-field-textarea.is-floating .minucci-label,
.minucci-form.minucci-form .minucci-field-textarea textarea:focus~.minucci-label,
.minucci-form.minucci-form .minucci-field-textarea textarea:not(:placeholder-shown)~.minucci-label {
    top: -10px !important;
    transform: translateY(0) scale(0.82) !important;
}

/* Error state label */
.minucci-form.minucci-form .minucci-field.has-error .minucci-label,
.minucci-form.minucci-form .minucci-field.has-error input:focus~.minucci-label,
.minucci-form.minucci-form .minucci-field.has-error textarea:focus~.minucci-label {
    color: var(--minucci-error) !important;
}

/* Success state label */
.minucci-form.minucci-form .minucci-field.is-valid .minucci-label {
    color: var(--minucci-success) !important;
}

.minucci-form.minucci-form .minucci-required {
    color: var(--minucci-error) !important;
    margin-left: 2px !important;
    font-weight: 500 !important;
}

/* ==========================================================================
   Input Fields - Premium iOS Style
   ========================================================================== */

.minucci-form.minucci-form .minucci-field input,
.minucci-form.minucci-form .minucci-field textarea,
.minucci-form.minucci-form .minucci-field select {
    width: 100% !important;
    padding: 8px 0 8px 0 !important;
    /* Underline style padding */
    font-family: inherit !important;
    font-size: 1rem !important;
    /* Optimized for readability */
    color: var(--minucci-text) !important;
    background: transparent !important;
    border: none !important;
    border-bottom: 1px solid var(--minucci-border) !important;
    border-radius: 0 !important;
    outline: none !important;
    transition: border-color var(--minucci-duration-fast) ease !important;
    -webkit-appearance: none !important;
    appearance: none !important;
    line-height: 1.5 !important;
    margin: 0 !important;
    min-height: 0 !important;
    height: auto !important;
}

/* Ellipse quand le champ n'a pas le focus : signale que le texte continue (le navigateur la retire automatiquement pendant l'édition) */
.minucci-form.minucci-form .minucci-field input:not(:focus) {
    text-overflow: ellipsis !important;
}

.minucci-form.minucci-form .minucci-field textarea {
    resize: vertical !important;
    min-height: 120px !important;
    padding-top: 18px !important;
}

.minucci-form.minucci-form .minucci-field 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='%238E8E93' 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;
}

/* Placeholder - invisible by default for floating label effect */
.minucci-form.minucci-form .minucci-field input::placeholder,
.minucci-form.minucci-form .minucci-field textarea::placeholder {
    color: transparent !important;
    transition: color var(--minucci-duration-fast) var(--minucci-ease-smooth) !important;
}

/* Show placeholder when focused */
.minucci-form.minucci-form .minucci-field input:focus::placeholder,
.minucci-form.minucci-form .minucci-field textarea:focus::placeholder {
    color: var(--minucci-placeholder) !important;
}

/* Outside Labels - Static Positioning */
.minucci-form.minucci-form.minucci-label-outside .minucci-label {
    position: static !important;
    transform: none !important;
    display: inline-block !important;
    margin-bottom: 6px !important;
    margin-left: 0px !important;
    pointer-events: auto !important;
    font-size: 0.875rem !important;
    font-weight: 500 !important;
    color: var(--minucci-text) !important;
    background: transparent !important;
}

.minucci-form.minucci-form.minucci-label-outside .minucci-field input::placeholder,
.minucci-form.minucci-form.minucci-label-outside .minucci-field textarea::placeholder {
    color: var(--minucci-placeholder) !important;
    opacity: 1 !important;
}


/* Hover State */
.minucci-form.minucci-form .minucci-field input:hover:not(:focus),
.minucci-form.minucci-form .minucci-field textarea:hover:not(:focus),
.minucci-form.minucci-form .minucci-field select:hover:not(:focus) {
    border-bottom-color: var(--minucci-text-secondary) !important;
    background: transparent !important;
}

/* Focus State - iOS Glow */
/* Focus State - Tally underline */
.minucci-form.minucci-form .minucci-field input:focus,
.minucci-form.minucci-form .minucci-field textarea:focus,
.minucci-form.minucci-form .minucci-field select:focus {
    background: transparent !important;
    border-bottom-color: var(--minucci-border-focus) !important;
    box-shadow: none !important;
}

/* Filled State */
.minucci-form.minucci-form .minucci-field input:not(:placeholder-shown),
.minucci-form.minucci-form .minucci-field textarea:not(:placeholder-shown) {
    background: transparent !important;
    border-bottom-color: var(--minucci-border) !important;
}

/* Error State */
.minucci-form.minucci-form .minucci-field.has-error input,
.minucci-form.minucci-form .minucci-field.has-error textarea,
.minucci-form.minucci-form .minucci-field.has-error select {
    border-color: var(--minucci-error) !important;
    background: var(--minucci-error-light) !important;
    animation: minucci-shake 0.5s var(--minucci-ease-out) !important;
}

.minucci-form.minucci-form .minucci-field.has-error input:focus,
.minucci-form.minucci-form .minucci-field.has-error textarea:focus,
.minucci-form.minucci-form .minucci-field.has-error select:focus {
    box-shadow: var(--minucci-shadow-error), var(--minucci-shadow-sm) !important;
}

.minucci-form.minucci-form .minucci-field-error {
    display: flex !important;
    align-items: center !important;
    gap: 6px !important;
    font-size: 0.75rem !important;
    font-weight: 500 !important;
    color: var(--minucci-error) !important;
    margin-top: 6px !important;
    min-height: 1.25em !important;
    opacity: 0 !important;
    transform: translateY(-4px) !important;
    transition: all var(--minucci-duration-fast) var(--minucci-ease-smooth) !important;
}

.minucci-form.minucci-form .minucci-field.has-error .minucci-field-error {
    opacity: 1 !important;
    transform: translateY(0) !important;
}

/* Valid State with Checkmark */
.minucci-form.minucci-form .minucci-field.is-valid input,
.minucci-form.minucci-form .minucci-field.is-valid textarea,
.minucci-form.minucci-form .minucci-field.is-valid select {
    border-color: var(--minucci-success) !important;
    background: var(--minucci-success-light) !important;
    padding-right: 48px !important;
}

.minucci-form.minucci-form .minucci-field.is-valid::after {
    content: '' !important;
    position: absolute !important;
    right: 16px !important;
    top: 50% !important;
    width: 22px !important;
    height: 22px !important;
    background: var(--minucci-success) !important;
    border-radius: 50% !important;
    transform: translateY(-50%) scale(0) !important;
    animation: minucci-check-pop 0.35s var(--minucci-ease-spring) forwards !important;
    box-shadow: 0 2px 8px rgba(48, 209, 88, 0.3) !important;
}

.minucci-form.minucci-form .minucci-field.is-valid::before {
    content: '' !important;
    position: absolute !important;
    right: 22px !important;
    top: calc(50% - 1px) !important;
    width: 5px !important;
    height: 10px !important;
    border: 2.5px solid white !important;
    border-top: none !important;
    border-left: none !important;
    transform: translateY(-50%) rotate(45deg) scale(0) !important;
    z-index: 1 !important;
    animation: minucci-check-mark 0.25s var(--minucci-ease-out) 0.2s forwards !important;
}

@keyframes minucci-check-pop {
    0% {
        transform: translateY(-50%) scale(0);
    }

    60% {
        transform: translateY(-50%) scale(1.15);
    }

    100% {
        transform: translateY(-50%) scale(1);
    }
}

@keyframes minucci-check-mark {
    to {
        transform: translateY(-50%) rotate(45deg) scale(1);
    }
}

/* ==========================================================================
   Radio & Checkbox - iOS Toggle Style
   ========================================================================== */

.minucci-form.minucci-form .minucci-radio-group,
.minucci-form.minucci-form .minucci-checkbox-group {
    display: flex !important;
    flex-direction: column !important;
    gap: 8px !important;
}

.minucci-form.minucci-form .minucci-checkbox-group-label {
    display: block !important;
    font-size: 0.875rem !important;
    font-weight: 500 !important;
    color: var(--minucci-text) !important;
    margin-bottom: 8px !important;
}

.minucci-form.minucci-form .minucci-radio-label,
.minucci-form.minucci-form .minucci-checkbox-label {
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
    cursor: pointer !important;
    font-size: 0.9375rem !important;
    color: var(--minucci-text) !important;
    padding: 12px 14px !important;
    margin: 0 !important;
    border-radius: var(--minucci-radius-sm) !important;
    background: var(--minucci-bg) !important;
    border: 1px solid var(--minucci-border-light) !important;
    transition: all var(--minucci-duration-fast) var(--minucci-ease-smooth) !important;
}

.minucci-form.minucci-form .minucci-radio-label:hover,
.minucci-form.minucci-form .minucci-checkbox-label:hover {
    background: var(--minucci-bg-elevated) !important;
    border-color: var(--minucci-primary) !important;
    box-shadow: var(--minucci-shadow-sm) !important;
}

.minucci-form.minucci-form .minucci-radio-label input,
.minucci-form.minucci-form .minucci-checkbox-label input {
    position: absolute !important;
    opacity: 0 !important;
    width: 0 !important;
    height: 0 !important;
    padding: 0 !important;
    margin: 0 !important;
}

.minucci-form.minucci-form .minucci-radio-mark,
.minucci-form.minucci-form .minucci-checkbox-mark {
    width: 24px !important;
    height: 24px !important;
    min-width: 24px !important;
    border: 2px solid var(--minucci-border) !important;
    background: var(--minucci-bg-elevated) !important;
    transition: all var(--minucci-duration-fast) var(--minucci-ease-spring) !important;
    flex-shrink: 0 !important;
    position: relative !important;
}

.minucci-form.minucci-form .minucci-radio-mark {
    border-radius: 50% !important;
}

.minucci-form.minucci-form .minucci-checkbox-mark {
    border-radius: 7px !important;
}

/* Radio Checked - iOS Blue Dot */
.minucci-form.minucci-form .minucci-radio-label input:checked+.minucci-radio-mark {
    border-color: var(--minucci-primary) !important;
    border-width: 7px !important;
    background: var(--minucci-bg-elevated) !important;
    animation: minucci-radio-pop 0.25s var(--minucci-ease-spring) !important;
    box-shadow: 0 2px 8px rgba(0, 122, 255, 0.25) !important;
}

@keyframes minucci-radio-pop {
    50% {
        transform: scale(1.12);
    }
}

/* Checkbox Checked - iOS Checkmark */
.minucci-form.minucci-form .minucci-checkbox-label input:checked+.minucci-checkbox-mark {
    border-color: var(--minucci-primary) !important;
    background: var(--minucci-primary) !important;
    animation: minucci-checkbox-pop 0.3s var(--minucci-ease-spring) !important;
    box-shadow: 0 2px 8px rgba(0, 122, 255, 0.25) !important;
}

@keyframes minucci-checkbox-pop {
    50% {
        transform: scale(1.18);
    }
}

.minucci-form.minucci-form .minucci-checkbox-label input:checked+.minucci-checkbox-mark::after {
    content: '' !important;
    position: absolute !important;
    left: 7px !important;
    top: 3px !important;
    width: 6px !important;
    height: 11px !important;
    border: 2.5px solid var(--minucci-white) !important;
    border-top: none !important;
    border-left: none !important;
    transform: rotate(45deg) !important;
    animation: minucci-checkmark-draw 0.2s var(--minucci-ease-out) !important;
}

@keyframes minucci-checkmark-draw {
    from {
        clip-path: inset(100% 0 0 0);
    }

    to {
        clip-path: inset(0 0 0 0);
    }
}

/* ==========================================================================
   Consent Checkbox - iOS Style
   ========================================================================== */

.minucci-form.minucci-form .minucci-consent-wrapper {
    margin-top: 20px !important;
    padding-top: 20px !important;
    border-top: 1px solid var(--minucci-separator) !important;
}

.minucci-form.minucci-form .minucci-consent-label {
    display: flex !important;
    align-items: flex-start !important;
    gap: 12px !important;
    cursor: pointer !important;
    font-size: 0.8125rem !important;
    color: var(--minucci-text-secondary) !important;
    line-height: 1.5 !important;
    padding: 2px 0 !important;
    margin: 0 !important;
}

.minucci-form.minucci-form .minucci-consent-checkbox {
    position: absolute !important;
    opacity: 0 !important;
    width: 0 !important;
    height: 0 !important;
}

.minucci-form.minucci-form .minucci-consent-checkmark {
    width: 20px !important;
    height: 20px !important;
    min-width: 20px !important;
    border: 1.5px solid var(--minucci-border) !important;
    border-radius: 5px !important;
    background: var(--minucci-bg-elevated) !important;
    transition: all var(--minucci-duration-fast) var(--minucci-ease-spring) !important;
    position: relative !important;
    margin-top: -1px !important;
}

.minucci-form.minucci-form .minucci-consent-label:hover .minucci-consent-checkmark {
    border-color: var(--minucci-primary) !important;
    transform: scale(1.06) !important;
    box-shadow: var(--minucci-shadow-sm) !important;
}

.minucci-form.minucci-form .minucci-consent-checkbox:checked+.minucci-consent-checkmark {
    border-color: var(--minucci-primary) !important;
    background: var(--minucci-primary) !important;
    animation: minucci-checkbox-pop 0.3s var(--minucci-ease-spring) !important;
    box-shadow: 0 3px 10px rgba(0, 122, 255, 0.3) !important;
}

.minucci-form.minucci-form .minucci-consent-checkbox:checked+.minucci-consent-checkmark::after {
    content: '' !important;
    position: absolute !important;
    left: 6px !important;
    top: 2px !important;
    width: 5px !important;
    height: 10px !important;
    border: 2px solid var(--minucci-white) !important;
    border-top: none !important;
    border-left: none !important;
    transform: rotate(45deg) !important;
    animation: minucci-checkmark-draw 0.2s var(--minucci-ease-out) !important;
}

.minucci-form.minucci-form .minucci-consent-text a,
.minucci-form.minucci-form .minucci-legal-link {
    color: var(--minucci-primary) !important;
    text-decoration: none !important;
    font-weight: 500 !important;
    transition: all var(--minucci-duration-fast) var(--minucci-ease-smooth) !important;
    position: relative !important;
}

.minucci-form.minucci-form .minucci-consent-text a::after,
.minucci-form.minucci-form .minucci-legal-link::after {
    content: '' !important;
    position: absolute !important;
    bottom: -2px !important;
    left: 0 !important;
    width: 0 !important;
    height: 1.5px !important;
    background: var(--minucci-primary) !important;
    transition: width var(--minucci-duration-normal) var(--minucci-ease-smooth) !important;
}

.minucci-form.minucci-form .minucci-consent-text a:hover::after,
.minucci-form.minucci-form .minucci-legal-link:hover::after {
    width: 100% !important;
}

/* ==========================================================================
   Legal Modal - iOS Sheet Style
   ========================================================================== */

.minucci-form.minucci-form .minucci-legal-modal {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100% !important;
    z-index: 999999 !important;
    display: none !important;
    /* Caché par défaut */
    align-items: flex-end !important;
    justify-content: center !important;
    padding: 0 !important;
}

/* Modale visible quand ouverte */
.minucci-form.minucci-form .minucci-legal-modal.is-open {
    display: flex !important;
}

@media (min-width: 600px) {
    .minucci-form.minucci-form .minucci-legal-modal {
        align-items: center !important;
        padding: 24px !important;
    }
}

.minucci-form.minucci-form .minucci-legal-backdrop {
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100% !important;
    background: rgba(0, 0, 0, 0.35) !important;
    backdrop-filter: blur(4px) !important;
    -webkit-backdrop-filter: blur(4px) !important;
    animation: minucci-fade-in var(--minucci-duration-normal) var(--minucci-ease-out) !important;
}

.minucci-form.minucci-form .minucci-legal-content {
    position: relative !important;
    background: var(--minucci-bg-elevated) !important;
    border-radius: var(--minucci-radius-2xl) var(--minucci-radius-2xl) 0 0 !important;
    max-width: 560px !important;
    width: 100% !important;
    max-height: 85vh !important;
    overflow: hidden !important;
    box-shadow: var(--minucci-shadow-xl) !important;
    animation: minucci-sheet-in var(--minucci-duration-slow) var(--minucci-ease-spring) !important;
}

@media (min-width: 600px) {
    .minucci-form.minucci-form .minucci-legal-content {
        border-radius: var(--minucci-radius-2xl) !important;
        animation: minucci-modal-in var(--minucci-duration-slow) var(--minucci-ease-spring) !important;
    }
}

@keyframes minucci-sheet-in {
    from {
        opacity: 0;
        transform: translateY(100%);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes minucci-modal-in {
    from {
        opacity: 0;
        transform: scale(0.9) translateY(40px);
    }

    to {
        opacity: 1;
        transform: scale(1) translateY(0);
    }
}

/* Modal Handle (iOS style) */
.minucci-form.minucci-form .minucci-legal-content::before {
    content: '' !important;
    position: absolute !important;
    top: 8px !important;
    left: 50% !important;
    transform: translateX(-50%) !important;
    width: 36px !important;
    height: 5px !important;
    background: var(--minucci-border) !important;
    border-radius: 3px !important;
}

@media (min-width: 600px) {
    .minucci-form.minucci-form .minucci-legal-content::before {
        display: none !important;
    }
}

.minucci-form.minucci-form .minucci-legal-close {
    position: absolute !important;
    top: 16px !important;
    right: 16px !important;
    width: 32px !important;
    height: 32px !important;
    border: none !important;
    background: var(--minucci-bg) !important;
    border-radius: 50% !important;
    font-size: 18px !important;
    line-height: 1 !important;
    color: var(--minucci-text-secondary) !important;
    cursor: pointer !important;
    transition: all var(--minucci-duration-fast) var(--minucci-ease-spring) !important;
    z-index: 1 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 0 !important;
}

.minucci-form.minucci-form .minucci-legal-close:hover {
    background: var(--minucci-border-light) !important;
    color: var(--minucci-text) !important;
    transform: scale(1.1) rotate(90deg) !important;
}

.minucci-form.minucci-form .minucci-legal-close:active {
    transform: scale(0.92) !important;
}

.minucci-form.minucci-form .minucci-legal-body {
    padding: 48px 32px 32px !important;
    max-height: 85vh !important;
    overflow-y: auto !important;
    overscroll-behavior: contain !important;
    -webkit-overflow-scrolling: touch !important;
}

.minucci-form.minucci-form .minucci-legal-body::-webkit-scrollbar {
    width: 6px !important;
}

.minucci-form.minucci-form .minucci-legal-body::-webkit-scrollbar-track {
    background: transparent !important;
}

.minucci-form.minucci-form .minucci-legal-body::-webkit-scrollbar-thumb {
    background: var(--minucci-border) !important;
    border-radius: 3px !important;
}

.minucci-form.minucci-form .minucci-legal-body h3 {
    margin: 0 0 20px 0 !important;
    font-size: 1.5rem !important;
    font-weight: 600 !important;
    color: var(--minucci-text) !important;
    letter-spacing: -0.02em !important;
}

.minucci-form.minucci-form .minucci-legal-body p {
    margin: 0 0 16px 0 !important;
    line-height: 1.65 !important;
    color: var(--minucci-text-secondary) !important;
}

/* ==========================================================================
   Submit Button - iOS Primary Action Button
   ========================================================================== */

.minucci-form.minucci-form .minucci-submit-wrapper {
    display: flex !important;
    margin-top: var(--minucci-spacing-button) !important;
}

.minucci-form.minucci-form .minucci-submit {
    position: relative !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 8px !important;
    padding: 14px 32px !important;
    font-family: inherit !important;
    font-size: 1rem !important;
    font-weight: 600 !important;
    letter-spacing: -0.01em !important;
    color: var(--minucci-white);
    background: var(--minucci-primary);
    border: none !important;
    border-radius: var(--minucci-radius-md) !important;
    cursor: pointer !important;
    transition: all var(--minucci-duration-fast) var(--minucci-ease-smooth) !important;
    overflow: hidden !important;
    isolation: isolate !important;
    box-shadow: 0 2px 8px rgba(0, 122, 255, 0.2) !important;
    line-height: 1.4 !important;
    text-transform: none !important;
}

/* Shine Effect */
.minucci-form.minucci-form .minucci-submit::after {
    content: '' !important;
    position: absolute !important;
    top: 0 !important;
    left: -100% !important;
    width: 60% !important;
    height: 100% !important;
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.2), transparent) !important;
    transform: skewX(-20deg) !important;
    z-index: 2 !important;
}

.minucci-form.minucci-form .minucci-submit:hover::after {
    animation: minucci-shine 0.6s ease !important;
}

@keyframes minucci-shine {
    to {
        left: 150%;
    }
}

/* Hover Animations */
.minucci-form.minucci-form .minucci-btn-lift:hover {
    transform: translateY(-2px) !important;
    box-shadow: 0 4px 12px rgba(0, 122, 255, 0.3) !important;
}

.minucci-form.minucci-form .minucci-btn-lift:active {
    transform: translateY(0px) !important;
    box-shadow: 0 2px 8px rgba(0, 122, 255, 0.2) !important;
}

.minucci-form.minucci-form .minucci-btn-scale:hover {
    transform: scale(1.02) !important;
    box-shadow: 0 4px 12px rgba(0, 122, 255, 0.3) !important;
}

.minucci-form.minucci-form .minucci-btn-scale:active {
    transform: scale(0.97) !important;
}

.minucci-form.minucci-form .minucci-btn-color-swap {
    background: var(--minucci-primary) !important;
    position: relative !important;
}

.minucci-form.minucci-form .minucci-btn-color-swap::before {
    content: '' !important;
    position: absolute !important;
    inset: 0 !important;
    background: var(--minucci-bg-elevated) !important;
    border-radius: inherit !important;
    transform: scaleX(0) !important;
    transform-origin: right !important;
    transition: transform var(--minucci-duration-normal) var(--minucci-ease-smooth) !important;
    z-index: -1 !important;
}

.minucci-form.minucci-form .minucci-btn-color-swap:hover {
    color: var(--minucci-primary) !important;
    box-shadow: inset 0 0 0 2px var(--minucci-primary) !important;
}

.minucci-form.minucci-form .minucci-btn-color-swap:hover::before {
    transform: scaleX(1) !important;
    transform-origin: left !important;
}

/* Loading State */
.minucci-form.minucci-form .minucci-submit.is-loading {
    pointer-events: none !important;
    background: var(--minucci-border) !important;
    box-shadow: none !important;
}

.minucci-form.minucci-form .minucci-submit.is-loading .minucci-submit-text {
    opacity: 0 !important;
    transform: translateY(12px) !important;
}

.minucci-form.minucci-form .minucci-submit-loading,
.minucci-form.minucci-form .minucci-submit-success {
    position: absolute !important;
    display: none !important;
    align-items: center !important;
    justify-content: center !important;
}

.minucci-form.minucci-form .minucci-submit.is-loading .minucci-submit-loading {
    display: flex !important;
}

.minucci-form.minucci-form .minucci-spinner {
    animation: minucci-spin 0.75s linear infinite !important;
}

/* Success State */
.minucci-form.minucci-form .minucci-submit.is-success {
    background: var(--minucci-success) !important;
    pointer-events: none !important;
    animation: minucci-success-pulse 0.5s var(--minucci-ease-spring) !important;
    box-shadow: 0 4px 16px rgba(48, 209, 88, 0.3) !important;
}

@keyframes minucci-success-pulse {

    0%,
    100% {
        transform: scale(1);
    }

    50% {
        transform: scale(1.06);
    }
}

.minucci-form.minucci-form .minucci-submit.is-success .minucci-submit-text {
    opacity: 0 !important;
    transform: translateY(12px) !important;
}

.minucci-form.minucci-form .minucci-submit.is-success .minucci-submit-success {
    display: flex !important;
    animation: minucci-success-check 0.4s var(--minucci-ease-spring) !important;
}

@keyframes minucci-success-check {
    from {
        opacity: 0;
        transform: scale(0.4) rotate(-45deg);
    }

    to {
        opacity: 1;
        transform: scale(1) rotate(0deg);
    }
}

/* ==========================================================================
   Form Messages - iOS Notification Style
   ========================================================================== */

.minucci-form.minucci-form .minucci-form-message {
    margin-top: 24px !important;
    padding: 16px 20px !important;
    border-radius: var(--minucci-radius-md) !important;
    font-size: 0.9375rem !important;
    font-weight: 500 !important;
    line-height: 1.5 !important;
    animation: minucci-message-in var(--minucci-duration-normal) var(--minucci-ease-spring) !important;
    display: flex !important;
    align-items: center !important;
    gap: 14px !important;
}

@keyframes minucci-message-in {
    from {
        opacity: 0;
        transform: translateY(12px) scale(0.96);
    }

    to {
        opacity: 1;
        transform: translateY(0) scale(1);
    }
}

.minucci-form.minucci-form .minucci-form-message.is-success {
    background: var(--minucci-success-light) !important;
    color: #1E8449 !important;
    border: 1px solid rgba(48, 209, 88, 0.25) !important;
}

.minucci-form.minucci-form .minucci-form-message.is-success::before {
    content: '' !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 26px !important;
    height: 26px !important;
    min-width: 26px !important;
    background: var(--minucci-success) !important;
    border-radius: 50% !important;
    flex-shrink: 0 !important;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E") !important;
    background-repeat: no-repeat !important;
    background-position: center !important;
}

.minucci-form.minucci-form .minucci-form-message.is-error {
    background: var(--minucci-error-light) !important;
    color: #B71C1C !important;
    border: 1px solid rgba(255, 69, 58, 0.25) !important;
}

.minucci-form.minucci-form .minucci-form-message.is-error::before {
    content: '!' !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 26px !important;
    height: 26px !important;
    min-width: 26px !important;
    background: var(--minucci-error) !important;
    color: white !important;
    border-radius: 50% !important;
    font-size: 14px !important;
    font-weight: 700 !important;
    flex-shrink: 0 !important;
}

/* ==========================================================================
   Animations
   ========================================================================== */

@keyframes minucci-fade-in {
    from {
        opacity: 0;
    }

    to {
        opacity: 1;
    }
}

@keyframes minucci-shake {

    0%,
    100% {
        transform: translateX(0);
    }

    15% {
        transform: translateX(-8px);
    }

    30% {
        transform: translateX(8px);
    }

    45% {
        transform: translateX(-6px);
    }

    60% {
        transform: translateX(6px);
    }

    75% {
        transform: translateX(-3px);
    }

    90% {
        transform: translateX(3px);
    }
}

@keyframes minucci-spin {
    from {
        transform: rotate(0deg);
    }

    to {
        transform: rotate(360deg);
    }
}

/* Staggered Field Animation on Form Load */
.minucci-form.minucci-form .minucci-form-inner .minucci-field {
    animation: minucci-field-in 0.5s var(--minucci-ease-out) both !important;
}

.minucci-form.minucci-form .minucci-form-inner .minucci-field:nth-child(1) {
    animation-delay: 0.05s !important;
}

.minucci-form.minucci-form .minucci-form-inner .minucci-field:nth-child(2) {
    animation-delay: 0.1s !important;
}

.minucci-form.minucci-form .minucci-form-inner .minucci-field:nth-child(3) {
    animation-delay: 0.15s !important;
}

.minucci-form.minucci-form .minucci-form-inner .minucci-field:nth-child(4) {
    animation-delay: 0.2s !important;
}

.minucci-form.minucci-form .minucci-form-inner .minucci-field:nth-child(5) {
    animation-delay: 0.25s !important;
}

.minucci-form.minucci-form .minucci-form-inner .minucci-field:nth-child(6) {
    animation-delay: 0.3s !important;
}

.minucci-form.minucci-form .minucci-form-inner .minucci-field:nth-child(7) {
    animation-delay: 0.35s !important;
}

.minucci-form.minucci-form .minucci-form-inner .minucci-field:nth-child(8) {
    animation-delay: 0.4s !important;
}

@keyframes minucci-field-in {
    from {
        opacity: 0;
        transform: translateY(20px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* ==========================================================================
   Accessibility
   ========================================================================== */

.minucci-form.minucci-form .minucci-field input:focus-visible,
.minucci-form.minucci-form .minucci-field textarea:focus-visible,
.minucci-form.minucci-form .minucci-field select:focus-visible,
.minucci-form.minucci-form .minucci-submit:focus-visible,
.minucci-form.minucci-form .minucci-cookie-accept:focus-visible,
.minucci-form.minucci-form .minucci-legal-close:focus-visible {
    outline: 3px solid var(--minucci-primary) !important;
    outline-offset: 2px !important;
}

/* Reduced Motion */
@media (prefers-reduced-motion: reduce) {

    .minucci-form.minucci-form *,
    .minucci-form.minucci-form *::before,
    .minucci-form.minucci-form *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }

    .minucci-form.minucci-form .minucci-cookie-overlay {
        backdrop-filter: none !important;
        -webkit-backdrop-filter: none !important;
        background: rgba(255, 255, 255, 0.95) !important;
    }
}

/* ==========================================================================
   Responsive Adjustments
   ========================================================================== */

@media (max-width: 480px) {
    .minucci-form.minucci-form .minucci-cookie-content {
        padding: 40px 28px 32px !important;
        border-radius: 20px !important;
        max-width: calc(100% - 32px) !important;
        width: auto !important;
        height: auto !important;
    }

    .minucci-form.minucci-form .minucci-cookie-title {
        font-size: 1.25rem !important;
    }

    .minucci-form.minucci-form .minucci-cookie-text {
        font-size: 0.875rem !important;
    }

    .minucci-form.minucci-form .minucci-cookie-overlay {
        padding: 0 !important;
    }

    .minucci-form.minucci-form .minucci-field input,
    .minucci-form.minucci-form .minucci-field textarea,
    .minucci-form.minucci-form .minucci-field select {
        padding: 16px 14px !important;
        font-size: 16px !important;
        /* Prevents zoom on iOS */
    }

    .minucci-form.minucci-form .minucci-submit {
        padding: 16px 28px !important;
        font-size: 1rem !important;
    }

    .minucci-form.minucci-form .minucci-legal-body {
        padding: 40px 20px 24px !important;
    }
}

/* ==========================================================================
   Style Prestige - Design Premium & Editorial (DA Constantin-Vallet)
   ========================================================================== */

.minucci-form.minucci-style-prestige {
    /* DA Colors - Exact specifications */
    --prestige-bg: #2A3B4C;                          /* Bleu Petrole - DA */
    --prestige-bg-greige: #EBEBE6;                   /* Greige - DA */
    --prestige-text: #F5F5F5;                        /* Blanc casse sur fond bleu - DA */
    --prestige-text-dark: #1A1A1A;                   /* Noir Charbon - DA */
    --prestige-text-muted: rgba(245, 245, 245, 0.65);
    --prestige-text-secondary: #555555;             /* Gris soutenu - DA */
    --prestige-border: rgba(160, 160, 160, 0.4);    /* Filets - DA (#A0A0A0) */
    --prestige-border-focus: rgba(245, 245, 245, 0.85);
    --prestige-separator: #A0A0A0;                  /* Separateurs - DA */

    /* Validation colors - Muted, sophisticated */
    --prestige-valid: rgba(245, 245, 245, 0.9);     /* Subtle white confirmation */
    --prestige-error: #C9564D;                       /* Muted terracotta red */

    /* Typography */
    --prestige-font-serif: 'Playfair Display', 'Georgia', 'Baskerville', serif;
    --prestige-font-sans: 'Montserrat', 'Lato', -apple-system, BlinkMacSystemFont, sans-serif;

    background: var(--prestige-bg) !important;
    border-radius: 0 !important;
    font-family: var(--prestige-font-sans) !important;
    padding: 32px 24px !important; /* Marges generouses - DA */
}

/* Labels Prestige - Typography hierarchy DA */
.minucci-form.minucci-style-prestige .minucci-label,
.minucci-form.minucci-style-prestige.minucci-label-outside .minucci-label {
    color: var(--prestige-text) !important;
    font-family: var(--prestige-font-sans) !important;
    font-weight: 400 !important;
    font-size: 0.9375rem !important;
    letter-spacing: 0.01em !important;
    background: transparent !important;
    text-transform: none !important;
    transition: color 0.25s ease, transform 0.25s ease !important;
}

/* Label floated state - stays subtle white, no green */
.minucci-form.minucci-style-prestige .minucci-field.is-floating .minucci-label,
.minucci-form.minucci-style-prestige .minucci-field.is-focused .minucci-label,
.minucci-form.minucci-style-prestige .minucci-field input:focus ~ .minucci-label,
.minucci-form.minucci-style-prestige .minucci-field textarea:focus ~ .minucci-label,
.minucci-form.minucci-style-prestige .minucci-field input:not(:placeholder-shown) ~ .minucci-label,
.minucci-form.minucci-style-prestige .minucci-field textarea:not(:placeholder-shown) ~ .minucci-label {
    color: var(--prestige-text) !important;
    background: var(--prestige-bg) !important;
}

/* Valid state label - NO green, subtle confirmation */
.minucci-form.minucci-style-prestige .minucci-field.is-valid .minucci-label {
    color: var(--prestige-text) !important;
}

.minucci-form.minucci-style-prestige .minucci-required {
    color: var(--prestige-text-muted) !important;
    font-weight: 400 !important;
}

/* Fields wrapper - Generous spacing (DA: min 20-24px) */
.minucci-form.minucci-style-prestige .minucci-fields-wrapper {
    gap: 20px !important;
}

/* Champs 50% ajustes pour gap 20px (2 x 10px = 20px) */
.minucci-form.minucci-style-prestige .minucci-field-width-50 {
    width: calc(50% - 10px) !important;
}

/* Champs Prestige - Bordure inferieure, style editorial */
.minucci-form.minucci-style-prestige .minucci-field input,
.minucci-form.minucci-style-prestige .minucci-field textarea,
.minucci-form.minucci-style-prestige .minucci-field select {
    background: transparent !important;
    border: none !important;
    border-bottom: 1px solid var(--prestige-border) !important;
    border-radius: 0 !important;
    color: var(--prestige-text) !important;
    font-family: var(--prestige-font-sans) !important;
    font-size: 1rem !important;
    font-weight: 400 !important;
    padding: 10px 0 12px 0 !important;
    box-shadow: none !important;
    transition: border-color 0.25s ease !important;
}

.minucci-form.minucci-style-prestige .minucci-field textarea {
    min-height: 100px !important;
    resize: vertical !important;
    line-height: 1.6 !important;
}

.minucci-form.minucci-style-prestige .minucci-field input::placeholder,
.minucci-form.minucci-style-prestige .minucci-field textarea::placeholder {
    color: var(--prestige-text-muted) !important;
    font-weight: 400 !important;
}

/* Hover state - subtle brightening */
.minucci-form.minucci-form.minucci-style-prestige .minucci-field input:hover:not(:focus),
.minucci-form.minucci-form.minucci-style-prestige .minucci-field textarea:hover:not(:focus),
.minucci-form.minucci-form.minucci-style-prestige .minucci-field select:hover:not(:focus),
.minucci-form.minucci-style-prestige .minucci-field input:hover,
.minucci-form.minucci-style-prestige .minucci-field textarea:hover,
.minucci-form.minucci-style-prestige .minucci-field select:hover {
    background: transparent !important;
    border-bottom-color: var(--prestige-border-focus) !important;
}

/* Focus state - full white underline, no glow */
.minucci-form.minucci-style-prestige .minucci-field input:focus,
.minucci-form.minucci-style-prestige .minucci-field textarea:focus,
.minucci-form.minucci-style-prestige .minucci-field select:focus {
    background: transparent !important;
    border-bottom-color: var(--prestige-text) !important;
    border-bottom-width: 1.5px !important;
    box-shadow: none !important;
    outline: none !important;
}

/* Filled state - return to subtle border */
.minucci-form.minucci-style-prestige .minucci-field input:not(:placeholder-shown),
.minucci-form.minucci-style-prestige .minucci-field textarea:not(:placeholder-shown) {
    background: transparent !important;
    border-bottom-color: var(--prestige-border) !important;
}

/* Select Prestige */
.minucci-form.minucci-style-prestige .minucci-field 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='rgba(255,255,255,0.7)' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E") !important;
    background-position: right 0 center !important;
    padding-right: 24px !important;
}

/* Radio & Checkbox Prestige */
.minucci-form.minucci-style-prestige .minucci-radio-group,
.minucci-form.minucci-style-prestige .minucci-checkbox-group {
    flex-direction: row !important;
    gap: 24px !important;
}

.minucci-form.minucci-style-prestige .minucci-radio-label,
.minucci-form.minucci-style-prestige .minucci-checkbox-label {
    background: transparent !important;
    border: none !important;
    padding: 8px 0 !important;
    color: var(--prestige-text) !important;
    font-size: 1rem !important;
}

.minucci-form.minucci-style-prestige .minucci-radio-label:hover,
.minucci-form.minucci-style-prestige .minucci-checkbox-label:hover {
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
}

.minucci-form.minucci-style-prestige .minucci-radio-mark {
    border-color: var(--prestige-border) !important;
    background: transparent !important;
    width: 18px !important;
    height: 18px !important;
    min-width: 18px !important;
}

.minucci-form.minucci-style-prestige .minucci-radio-label input:checked+.minucci-radio-mark {
    border-color: var(--prestige-text) !important;
    border-width: 5px !important;
    background: transparent !important;
    box-shadow: none !important;
}

.minucci-form.minucci-style-prestige .minucci-checkbox-mark {
    border-color: var(--prestige-border) !important;
    background: transparent !important;
    border-radius: 3px !important;
    width: 18px !important;
    height: 18px !important;
    min-width: 18px !important;
}

.minucci-form.minucci-style-prestige .minucci-checkbox-label input:checked+.minucci-checkbox-mark {
    border-color: var(--prestige-text) !important;
    background: var(--prestige-text) !important;
    box-shadow: none !important;
}

.minucci-form.minucci-style-prestige .minucci-checkbox-label input:checked+.minucci-checkbox-mark::after {
    border-color: var(--prestige-bg) !important;
    left: 5px !important;
    top: 1px !important;
    width: 5px !important;
    height: 9px !important;
}

/* Consent Prestige - Clean separator, editorial style */
.minucci-form.minucci-style-prestige .minucci-consent-wrapper {
    border-top: 1px solid var(--prestige-separator) !important;
    margin-top: 24px !important;
    padding-top: 24px !important;
}

.minucci-form.minucci-style-prestige .minucci-consent-label {
    color: var(--prestige-text-muted) !important;
    font-family: var(--prestige-font-sans) !important;
    font-size: 0.8125rem !important;
    line-height: 1.55 !important;
}

.minucci-form.minucci-style-prestige .minucci-consent-checkmark {
    border: 1px solid var(--prestige-border) !important;
    border-radius: 3px !important;
    background: transparent !important;
    width: 18px !important;
    height: 18px !important;
    min-width: 18px !important;
    transition: all 0.2s ease !important;
}

.minucci-form.minucci-style-prestige .minucci-consent-label:hover .minucci-consent-checkmark {
    border-color: var(--prestige-border-focus) !important;
    transform: none !important;
    box-shadow: none !important;
}

.minucci-form.minucci-style-prestige .minucci-consent-checkbox:checked+.minucci-consent-checkmark {
    border-color: var(--prestige-text) !important;
    background: var(--prestige-text) !important;
    box-shadow: none !important;
}

.minucci-form.minucci-style-prestige .minucci-consent-checkbox:checked+.minucci-consent-checkmark::after {
    border-color: var(--prestige-bg) !important;
    left: 5px !important;
    top: 1px !important;
    width: 5px !important;
    height: 9px !important;
}

.minucci-form.minucci-style-prestige .minucci-consent-text a,
.minucci-form.minucci-style-prestige .minucci-legal-link {
    color: var(--prestige-text) !important;
    text-decoration: none !important;
    border-bottom: 1px solid transparent !important;
    transition: border-color 0.2s ease !important;
}

.minucci-form.minucci-style-prestige .minucci-consent-text a:hover,
.minucci-form.minucci-style-prestige .minucci-legal-link:hover {
    border-bottom-color: var(--prestige-text) !important;
}

/* Remove the animated underline, use simple border-bottom */
.minucci-form.minucci-style-prestige .minucci-consent-text a::after,
.minucci-form.minucci-style-prestige .minucci-legal-link::after {
    display: none !important;
}

/* Consent Error State - Prestige (DA: terracotta muted) */
.minucci-form.minucci-style-prestige .minucci-consent-wrapper.has-error {
    animation: minucci-shake 0.4s ease !important;
}

.minucci-form.minucci-style-prestige .minucci-consent-wrapper.has-error .minucci-consent-checkmark {
    border-color: var(--prestige-error) !important;
    box-shadow: 0 0 0 3px rgba(201, 86, 77, 0.15) !important;
}

.minucci-form.minucci-style-prestige .minucci-consent-wrapper.has-error .minucci-consent-text {
    color: #E8A39E !important;
}

.minucci-form.minucci-style-prestige .minucci-consent-error {
    display: none;
    font-size: 0.75rem !important;
    color: #E8A39E !important;
    margin-top: 8px !important;
    padding-left: 30px !important;
    font-family: var(--prestige-font-sans) !important;
}

.minucci-form.minucci-style-prestige .minucci-consent-wrapper.has-error .minucci-consent-error {
    display: block !important;
}

/* Bouton Prestige - Style Pillule Ghost/Outline (DA specification) */
.minucci-form.minucci-style-prestige .minucci-submit-wrapper {
    justify-content: flex-start !important;
    margin-top: 28px !important;
}

.minucci-form.minucci-style-prestige .minucci-submit {
    background: transparent !important;
    color: var(--prestige-text) !important;
    border: 1px solid var(--prestige-text) !important;
    border-radius: 50px !important; /* Pillule - DA */
    padding: 14px 36px !important;
    box-shadow: none !important;
    font-family: var(--prestige-font-sans) !important;
    font-weight: 500 !important;
    font-size: 0.9375rem !important;
    letter-spacing: 0.02em !important;
    text-transform: none !important;
    min-width: auto !important;
    position: relative !important;
    overflow: hidden !important;
    transition: all 0.3s cubic-bezier(0.25, 0.1, 0.25, 1) !important;
}

/* Remove the underline effect, not needed for pill button */
.minucci-form.minucci-style-prestige .minucci-submit::after {
    content: none !important;
    display: none !important;
}

/* Hover: fill with text color, invert text - DA Ghost button behavior */
.minucci-form.minucci-style-prestige .minucci-submit:hover {
    background: var(--prestige-text) !important;
    color: var(--prestige-bg) !important;
    transform: none !important;
    box-shadow: none !important;
}

/* Active/pressed state */
.minucci-form.minucci-style-prestige .minucci-submit:active {
    transform: scale(0.98) !important;
}

/* Loading state */
.minucci-form.minucci-style-prestige .minucci-submit.is-loading {
    background: transparent !important;
    border-color: var(--prestige-text-muted) !important;
    color: var(--prestige-text-muted) !important;
    pointer-events: none !important;
}

/* Success state - subtle, no bright green */
.minucci-form.minucci-style-prestige .minucci-submit.is-success {
    background: var(--prestige-text) !important;
    color: var(--prestige-bg) !important;
    border-color: var(--prestige-text) !important;
    box-shadow: none !important;
}

/* Messages Prestige - Sophisticated, muted feedback */
.minucci-form.minucci-style-prestige .minucci-form-message {
    font-family: var(--prestige-font-sans) !important;
    border-radius: 4px !important;
}

.minucci-form.minucci-style-prestige .minucci-form-message.is-success {
    background: rgba(245, 245, 245, 0.1) !important;
    color: var(--prestige-text) !important;
    border: 1px solid rgba(245, 245, 245, 0.25) !important;
}

/* Success message icon - elegant circle with checkmark (DA style) */
.minucci-form.minucci-style-prestige .minucci-form-message.is-success::before {
    background: transparent !important;
    border: 1.5px solid var(--prestige-text) !important;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23F5F5F5' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E") !important;
    background-repeat: no-repeat !important;
    background-position: center !important;
}

.minucci-form.minucci-style-prestige .minucci-form-message.is-error {
    background: rgba(201, 86, 77, 0.15) !important;
    color: #E8A39E !important;
    border: 1px solid rgba(201, 86, 77, 0.3) !important;
}

.minucci-form.minucci-style-prestige .minucci-form-message.is-error::before {
    background: var(--prestige-error) !important;
}

/* Erreurs Prestige - Muted terracotta, not aggressive red */
.minucci-form.minucci-style-prestige .minucci-field.has-error input,
.minucci-form.minucci-style-prestige .minucci-field.has-error textarea,
.minucci-form.minucci-style-prestige .minucci-field.has-error select {
    border-bottom-color: var(--prestige-error) !important;
    background: transparent !important;
    animation: minucci-shake 0.4s ease !important;
}

.minucci-form.minucci-style-prestige .minucci-field.has-error .minucci-label {
    color: #E8A39E !important;
}

.minucci-form.minucci-style-prestige .minucci-field-error {
    color: #E8A39E !important;
    font-family: var(--prestige-font-sans) !important;
    font-size: 0.75rem !important;
    margin-top: 8px !important;
}

/* Validation Prestige - Subtle, sophisticated feedback */
.minucci-form.minucci-style-prestige .minucci-field.is-valid input,
.minucci-form.minucci-style-prestige .minucci-field.is-valid textarea {
    border-bottom-color: var(--prestige-border-focus) !important;
    background: transparent !important;
    padding-right: 0 !important;
}

/* No checkmark circle - keep it minimal and editorial */
.minucci-form.minucci-style-prestige .minucci-field.is-valid::after,
.minucci-form.minucci-style-prestige .minucci-field.is-valid::before {
    display: none !important;
}

/* reCAPTCHA Prestige - Minimal, integrated */
.minucci-form.minucci-style-prestige .minucci-recaptcha-badge {
    background: transparent !important;
    border: none !important;
    border-radius: 0 !important;
    padding: 16px 0 !important;
    margin-top: 8px !important;
}

.minucci-form.minucci-style-prestige .minucci-recaptcha-text {
    color: var(--prestige-text-muted) !important;
    font-family: var(--prestige-font-sans) !important;
    font-size: 0.75rem !important;
}

.minucci-form.minucci-style-prestige .minucci-recaptcha-icon svg {
    opacity: 0.6 !important;
}

/* Cookie Wall Prestige - Refined blur, editorial feel */
.minucci-form.minucci-style-prestige .minucci-cookie-overlay {
    background: transparent !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    padding: 24px !important;
}

.minucci-form.minucci-style-prestige .minucci-cookie-content {
    background: rgba(42, 59, 76, 0.95) !important;
    backdrop-filter: blur(32px) !important;
    -webkit-backdrop-filter: blur(32px) !important;
    border: 1px solid rgba(160, 160, 160, 0.25) !important;
    border-radius: 8px !important; /* More editorial, less iOS */
    max-width: 420px !important;
    width: 100% !important;
    padding: 40px 36px !important;
    box-shadow: 0 24px 64px rgba(0, 0, 0, 0.45), 0 8px 24px rgba(0, 0, 0, 0.25) !important;
}

.minucci-form.minucci-style-prestige .minucci-cookie-title {
    color: var(--prestige-text) !important;
    font-family: var(--prestige-font-serif) !important;
    font-size: 1.5rem !important;
    font-weight: 500 !important;
    letter-spacing: -0.01em !important;
    margin-bottom: 12px !important;
}

.minucci-form.minucci-style-prestige .minucci-cookie-text {
    color: var(--prestige-text-muted) !important;
    font-family: var(--prestige-font-sans) !important;
    font-size: 0.9375rem !important;
    line-height: 1.6 !important;
    margin-bottom: 28px !important;
}

/* Cookie accept button - Pill ghost style per DA */
.minucci-form.minucci-style-prestige .minucci-cookie-accept {
    background: transparent !important;
    color: var(--prestige-text) !important;
    border: 1px solid var(--prestige-text) !important;
    border-radius: 50px !important;
    padding: 12px 32px !important;
    font-family: var(--prestige-font-sans) !important;
    font-weight: 500 !important;
    font-size: 0.9375rem !important;
    box-shadow: none !important;
    transition: all 0.25s ease !important;
    max-width: none !important;
    width: auto !important;
}

.minucci-form.minucci-style-prestige .minucci-cookie-accept:hover {
    background: var(--prestige-text) !important;
    color: var(--prestige-bg) !important;
    transform: none !important;
    box-shadow: none !important;
}

/* Etat verrouille Prestige - Override shimmer animations (les deux modes) */
.minucci-form.minucci-style-prestige.is-locked .minucci-field {
    animation: none !important;
    opacity: 1 !important;
    transform: none !important;
}

.minucci-form.minucci-style-prestige.is-locked .minucci-field input,
.minucci-form.minucci-style-prestige.is-locked .minucci-field textarea,
.minucci-form.minucci-style-prestige.is-locked .minucci-field select {
    background: transparent !important;
    background-size: auto !important;
    border: none !important;
    border-bottom: 1px solid var(--prestige-border) !important;
    border-radius: 0 !important;
    color: var(--prestige-text) !important;
    -webkit-text-fill-color: var(--prestige-text) !important;
    animation: none !important;
}

.minucci-form.minucci-style-prestige.is-locked .minucci-field input::placeholder,
.minucci-form.minucci-style-prestige.is-locked .minucci-field textarea::placeholder {
    color: var(--prestige-text-muted) !important;
    -webkit-text-fill-color: var(--prestige-text-muted) !important;
}

.minucci-form.minucci-style-prestige.is-locked .minucci-label {
    animation: none !important;
    color: var(--prestige-text) !important;
    -webkit-text-fill-color: var(--prestige-text) !important;
    font-weight: 400 !important;
    font-size: 0.9375rem !important;
    opacity: 1 !important;
}

.minucci-form.minucci-style-prestige.is-locked .minucci-submit {
    background: transparent !important;
    background-size: auto !important;
    border: 1px solid var(--prestige-text) !important;
    border-radius: 50px !important;
    color: var(--prestige-text) !important;
    -webkit-text-fill-color: var(--prestige-text) !important;
    animation: none !important;
    transform: none !important;
    opacity: 1 !important;
}

.minucci-form.minucci-style-prestige.is-locked .minucci-consent-wrapper {
    animation: none !important;
    opacity: 1 !important;
}

.minucci-form.minucci-style-prestige.is-locked .minucci-consent-checkmark {
    animation: none !important;
    background: transparent !important;
    background-size: auto !important;
    border: 1px solid var(--prestige-border) !important;
}

.minucci-form.minucci-style-prestige.is-locked .minucci-consent-label {
    color: var(--prestige-text-muted) !important;
    -webkit-text-fill-color: var(--prestige-text-muted) !important;
}

/* Prestige Sans Flou - override old Elementor blur value */
.elementor-widget-minucci-form .minucci-form.minucci-style-prestige.is-locked.minucci-blur-none .minucci-form-inner,
.minucci-form.minucci-form.minucci-style-prestige.is-locked.minucci-blur-none .minucci-form-inner {
    filter: none !important;
    opacity: 1 !important;
}

/* Floating labels Prestige */
.minucci-form.minucci-style-prestige:not(.minucci-label-outside) .minucci-field.is-floating .minucci-label,
.minucci-form.minucci-style-prestige:not(.minucci-label-outside) .minucci-field input:focus~.minucci-label,
.minucci-form.minucci-style-prestige:not(.minucci-label-outside) .minucci-field input:not(:placeholder-shown)~.minucci-label {
    color: var(--prestige-text-muted) !important;
    background: var(--prestige-bg) !important;
}

/* Responsive Prestige */
@media (max-width: 768px) {
    .minucci-form.minucci-style-prestige {
        padding: 24px 20px !important; /* Still generous but adapted */
    }

    .minucci-form.minucci-style-prestige .minucci-fields-wrapper {
        gap: 16px !important;
    }

    .minucci-form.minucci-style-prestige .minucci-submit {
        padding: 12px 28px !important;
        font-size: 0.875rem !important;
    }

    .minucci-form.minucci-style-prestige .minucci-cookie-content {
        padding: 32px 24px !important;
        margin: 16px !important;
    }

    .minucci-form.minucci-style-prestige .minucci-cookie-title {
        font-size: 1.25rem !important;
    }
}

@media (max-width: 600px) {
    .minucci-form.minucci-style-prestige .minucci-radio-group,
    .minucci-form.minucci-style-prestige .minucci-checkbox-group {
        flex-direction: row !important;
        flex-wrap: wrap !important;
    }

    .minucci-form.minucci-style-prestige .minucci-field-width-50 {
        width: 100% !important;
    }

    .minucci-form.minucci-style-prestige .minucci-consent-wrapper {
        margin-top: 20px !important;
        padding-top: 20px !important;
    }

    .minucci-form.minucci-style-prestige .minucci-submit-wrapper {
        margin-top: 24px !important;
    }
}

/* ==========================================================================
   Styles Modernes - Clair & Sombre (v2.1.0)
   UX/UI 2026 : carte arrondie, champs boxes avec focus ring accessible,
   contrastes AA, micro-interactions limitees a transform/opacity/couleurs.
   La structure est commune aux deux styles ; seules les palettes divergent.
   Les variables --minucci-* sont redefinies dans le scope : les etats de
   base (erreur, succes, modale, consentement) heritent automatiquement.
   ========================================================================== */

/* ---------- Palette Moderne Clair ---------- */
.minucci-form.minucci-style-modern-light {
    --minucci-primary: #2563EB;
    --minucci-primary-dark: #1D4ED8;                 /* hover bouton */
    --minucci-primary-light: rgba(37, 99, 235, 0.08);
    --minucci-success: #16A34A;
    --minucci-success-light: rgba(22, 163, 74, 0.08);
    --minucci-error: #DC2626;
    --minucci-error-light: rgba(220, 38, 38, 0.06);
    --minucci-text: #16181D;
    --minucci-text-secondary: #5A5E6B;
    --minucci-placeholder: #9CA0AA;
    --minucci-border: #D8DBE1;
    --minucci-border-light: #E7E9EE;
    --minucci-border-focus: #2563EB;
    --minucci-separator: #ECEDF1;
    --minucci-bg: #FFFFFF;
    --minucci-bg-elevated: #FFFFFF;                  /* fond carte + notch du label flottant */
    --minucci-white: #FFFFFF;                        /* texte pose sur l'accent */
    --minucci-radius-sm: 8px;
    --minucci-radius-md: 10px;
    --minucci-radius-lg: 12px;
    --minucci-radius-2xl: 20px;
    --minucci-spacing-field: 20px;
    --minucci-shadow-sm: 0 1px 2px rgba(22, 24, 29, 0.06);
    --minucci-shadow-xl: 0 24px 64px rgba(22, 24, 29, 0.18);
    --minucci-shadow-error: 0 0 0 4px rgba(220, 38, 38, 0.12);
    --minucci-duration-normal: 300ms;
    --minucci-duration-slow: 400ms;
    --minucci-ease-out: cubic-bezier(0.25, 0.46, 0.45, 0.94);
    --minucci-ease-spring: cubic-bezier(0.34, 1.56, 0.64, 1);
    --modern-surface-border: #E7E9EE;
    --modern-card-shadow: 0 1px 2px rgba(22, 24, 29, 0.04), 0 16px 40px -20px rgba(22, 24, 29, 0.12);
    --modern-field-bg: #FFFFFF;
    --modern-field-bg-focus: #FFFFFF;
    --modern-border-strong: #ABB0BB;                 /* hover champs + coches */
    --modern-ring: 0 0 0 4px rgba(37, 99, 235, 0.12);
    --modern-btn-shadow: 0 1px 2px rgba(37, 99, 235, 0.30), 0 8px 20px -8px rgba(37, 99, 235, 0.50);
    --modern-btn-shadow-hover: 0 2px 4px rgba(37, 99, 235, 0.30), 0 12px 28px -10px rgba(37, 99, 235, 0.55);
    --modern-msg-success-text: #166534;
    --modern-msg-success-border: rgba(22, 163, 74, 0.25);
    --modern-msg-error-text: #B42318;
    --modern-msg-error-border: rgba(220, 38, 38, 0.25);
}

/* ---------- Palette Moderne Sombre ---------- */
.minucci-form.minucci-style-modern-dark {
    --minucci-primary: #8AA7FF;
    --minucci-primary-dark: #A5BBFF;                 /* hover bouton : eclairci en sombre */
    --minucci-primary-light: rgba(138, 167, 255, 0.12);
    --minucci-success: #3FCF8E;
    --minucci-success-light: rgba(63, 207, 142, 0.10);
    --minucci-error: #FF7A70;
    --minucci-error-light: rgba(255, 122, 112, 0.08);
    --minucci-text: #F2F3F7;
    --minucci-text-secondary: #A8ABB6;
    --minucci-placeholder: #787C88;
    --minucci-border: #33353E;
    --minucci-border-light: #2A2C34;
    --minucci-border-focus: #8AA7FF;
    --minucci-separator: #2A2C34;
    --minucci-bg: #212229;
    --minucci-bg-elevated: #1B1C22;                  /* fond carte, jamais de noir pur */
    --minucci-white: #15161B;                        /* texte sombre sur accent clair (contraste AA) */
    --minucci-radius-sm: 8px;
    --minucci-radius-md: 10px;
    --minucci-radius-lg: 12px;
    --minucci-radius-2xl: 20px;
    --minucci-spacing-field: 20px;
    --minucci-shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.40);
    --minucci-shadow-xl: 0 24px 64px rgba(0, 0, 0, 0.60);
    --minucci-shadow-error: 0 0 0 4px rgba(255, 122, 112, 0.15);
    --minucci-duration-normal: 300ms;
    --minucci-duration-slow: 400ms;
    --minucci-ease-out: cubic-bezier(0.25, 0.46, 0.45, 0.94);
    --minucci-ease-spring: cubic-bezier(0.34, 1.56, 0.64, 1);
    --modern-surface-border: rgba(255, 255, 255, 0.08);
    --modern-card-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04), 0 20px 48px -20px rgba(0, 0, 0, 0.60);
    --modern-field-bg: #212229;
    --modern-field-bg-focus: #24252D;
    --modern-border-strong: #4A4D58;
    --modern-ring: 0 0 0 4px rgba(138, 167, 255, 0.18);
    --modern-btn-shadow: 0 8px 20px -8px rgba(138, 167, 255, 0.35);
    --modern-btn-shadow-hover: 0 12px 28px -10px rgba(138, 167, 255, 0.45);
    --modern-msg-success-text: #7BE0B1;
    --modern-msg-success-border: rgba(63, 207, 142, 0.30);
    --modern-msg-error-text: #FFB4AD;
    --modern-msg-error-border: rgba(255, 122, 112, 0.30);
}

/* ---------- Carte conteneur ---------- */
.minucci-form.minucci-style-modern-light,
.minucci-form.minucci-style-modern-dark {
    background: var(--minucci-bg-elevated) !important; /* contre .minucci-form { background: transparent } */
    border: 1px solid var(--modern-surface-border) !important;
    border-radius: 16px !important;
    padding: 32px 28px !important;
    box-shadow: var(--modern-card-shadow) !important;
    color: var(--minucci-text) !important;
}

/* Champs 50% ajustes au gap de 20px */
.minucci-form.minucci-style-modern-light .minucci-field-width-50,
.minucci-form.minucci-style-modern-dark .minucci-field-width-50 {
    width: calc(50% - 10px) !important;
}

/* ---------- Champs boxes (contre le style underline de base) ---------- */
.minucci-form.minucci-style-modern-light .minucci-field input,
.minucci-form.minucci-style-modern-light .minucci-field textarea,
.minucci-form.minucci-style-modern-light .minucci-field select,
.minucci-form.minucci-style-modern-dark .minucci-field input,
.minucci-form.minucci-style-modern-dark .minucci-field textarea,
.minucci-form.minucci-style-modern-dark .minucci-field select {
    background: var(--modern-field-bg) !important;
    border: 1px solid var(--minucci-border) !important;
    border-radius: var(--minucci-radius-md) !important;
    padding: 12px 16px !important;
    min-height: 48px !important; /* cible tactile 44px+ */
    transition: border-color 200ms var(--minucci-ease-smooth),
        box-shadow 200ms var(--minucci-ease-smooth),
        background 200ms var(--minucci-ease-smooth) !important;
}

.minucci-form.minucci-style-modern-light .minucci-field textarea,
.minucci-form.minucci-style-modern-dark .minucci-field textarea {
    min-height: 130px !important;
    padding-top: 14px !important;
    line-height: 1.6 !important;
    resize: vertical !important;
}

.minucci-form.minucci-style-modern-light .minucci-field select,
.minucci-form.minucci-style-modern-dark .minucci-field select {
    padding-right: 44px !important; /* reserve la place de la fleche */
}

/* Hover : bordure renforcee, fond stable */
.minucci-form.minucci-style-modern-light .minucci-field input:hover:not(:focus),
.minucci-form.minucci-style-modern-light .minucci-field textarea:hover:not(:focus),
.minucci-form.minucci-style-modern-light .minucci-field select:hover:not(:focus),
.minucci-form.minucci-style-modern-dark .minucci-field input:hover:not(:focus),
.minucci-form.minucci-style-modern-dark .minucci-field textarea:hover:not(:focus),
.minucci-form.minucci-style-modern-dark .minucci-field select:hover:not(:focus) {
    border-color: var(--modern-border-strong) !important;
    background: var(--modern-field-bg) !important;
}

/* Rempli (hors focus) : retour a la bordure neutre */
.minucci-form.minucci-style-modern-light .minucci-field input:not(:placeholder-shown):not(:focus),
.minucci-form.minucci-style-modern-light .minucci-field textarea:not(:placeholder-shown):not(:focus),
.minucci-form.minucci-style-modern-dark .minucci-field input:not(:placeholder-shown):not(:focus),
.minucci-form.minucci-style-modern-dark .minucci-field textarea:not(:placeholder-shown):not(:focus) {
    border-color: var(--minucci-border) !important;
    background: var(--modern-field-bg) !important;
}

/* Focus : bordure accent + ring 4px (indicateur clavier AA) */
.minucci-form.minucci-style-modern-light .minucci-field input:focus,
.minucci-form.minucci-style-modern-light .minucci-field textarea:focus,
.minucci-form.minucci-style-modern-light .minucci-field select:focus,
.minucci-form.minucci-style-modern-dark .minucci-field input:focus,
.minucci-form.minucci-style-modern-dark .minucci-field textarea:focus,
.minucci-form.minucci-style-modern-dark .minucci-field select:focus {
    border-color: var(--minucci-border-focus) !important;
    background: var(--modern-field-bg-focus) !important;
    box-shadow: var(--modern-ring) !important;
    outline: none !important; /* le ring remplace l'outline de base */
}

/* ---------- Radio, Checkbox & Consentement ---------- */
.minucci-form.minucci-style-modern-light .minucci-radio-mark,
.minucci-form.minucci-style-modern-light .minucci-checkbox-mark,
.minucci-form.minucci-style-modern-light .minucci-consent-checkmark,
.minucci-form.minucci-style-modern-dark .minucci-radio-mark,
.minucci-form.minucci-style-modern-dark .minucci-checkbox-mark,
.minucci-form.minucci-style-modern-dark .minucci-consent-checkmark {
    border-color: var(--modern-border-strong) !important;
    background: var(--modern-field-bg) !important;
}

/* Coches actives : halo accent au lieu du bleu iOS code en dur */
.minucci-form.minucci-style-modern-light .minucci-radio-label input:checked+.minucci-radio-mark,
.minucci-form.minucci-style-modern-light .minucci-checkbox-label input:checked+.minucci-checkbox-mark,
.minucci-form.minucci-style-modern-light .minucci-consent-checkbox:checked+.minucci-consent-checkmark,
.minucci-form.minucci-style-modern-dark .minucci-radio-label input:checked+.minucci-radio-mark,
.minucci-form.minucci-style-modern-dark .minucci-checkbox-label input:checked+.minucci-checkbox-mark,
.minucci-form.minucci-style-modern-dark .minucci-consent-checkbox:checked+.minucci-consent-checkmark {
    box-shadow: 0 0 0 4px var(--minucci-primary-light) !important;
}

/* ---------- Bouton d'envoi ---------- */
.minucci-form.minucci-style-modern-light .minucci-submit,
.minucci-form.minucci-style-modern-dark .minucci-submit {
    background: var(--minucci-primary) !important;
    color: var(--minucci-white) !important;
    border-radius: var(--minucci-radius-md) !important;
    box-shadow: var(--modern-btn-shadow) !important;
    min-height: 48px !important;
}

.minucci-form.minucci-style-modern-light .minucci-submit:hover,
.minucci-form.minucci-style-modern-dark .minucci-submit:hover {
    background: var(--minucci-primary-dark) !important;
    box-shadow: var(--modern-btn-shadow-hover) !important;
}

.minucci-form.minucci-style-modern-light .minucci-submit:active,
.minucci-form.minucci-style-modern-dark .minucci-submit:active {
    transform: translateY(0) scale(0.98) !important;
}

.minucci-form.minucci-style-modern-light .minucci-submit.is-loading,
.minucci-form.minucci-style-modern-dark .minucci-submit.is-loading {
    background: var(--minucci-border) !important;
    color: var(--minucci-text-secondary) !important; /* spinner en currentColor */
    box-shadow: none !important;
}

.minucci-form.minucci-style-modern-light .minucci-submit.is-success,
.minucci-form.minucci-style-modern-dark .minucci-submit.is-success {
    background: var(--minucci-success) !important;
    color: var(--minucci-white) !important;
    box-shadow: 0 8px 20px -8px var(--minucci-success) !important;
}

/* ---------- Messages de formulaire ---------- */
.minucci-form.minucci-style-modern-light .minucci-form-message.is-success,
.minucci-form.minucci-style-modern-dark .minucci-form-message.is-success {
    background: var(--minucci-success-light) !important;
    color: var(--modern-msg-success-text) !important;
    border-color: var(--modern-msg-success-border) !important;
}

.minucci-form.minucci-style-modern-light .minucci-form-message.is-error,
.minucci-form.minucci-style-modern-dark .minucci-form-message.is-error {
    background: var(--minucci-error-light) !important;
    color: var(--modern-msg-error-text) !important;
    border-color: var(--modern-msg-error-border) !important;
}

.minucci-form.minucci-style-modern-light .minucci-form-message.is-error::before,
.minucci-form.minucci-style-modern-dark .minucci-form-message.is-error::before {
    color: var(--minucci-white) !important;
}

/* ---------- Erreur de consentement (parite avec Prestige) ---------- */
.minucci-form.minucci-style-modern-light .minucci-consent-wrapper.has-error,
.minucci-form.minucci-style-modern-dark .minucci-consent-wrapper.has-error {
    animation: minucci-shake 0.4s ease !important;
}

.minucci-form.minucci-style-modern-light .minucci-consent-wrapper.has-error .minucci-consent-checkmark,
.minucci-form.minucci-style-modern-dark .minucci-consent-wrapper.has-error .minucci-consent-checkmark {
    border-color: var(--minucci-error) !important;
    box-shadow: var(--minucci-shadow-error) !important;
}

.minucci-form.minucci-style-modern-light .minucci-consent-wrapper.has-error .minucci-consent-text,
.minucci-form.minucci-style-modern-dark .minucci-consent-wrapper.has-error .minucci-consent-text {
    color: var(--minucci-error) !important;
}

.minucci-form.minucci-style-modern-light .minucci-consent-error,
.minucci-form.minucci-style-modern-dark .minucci-consent-error {
    display: none;
    font-size: 0.75rem !important;
    color: var(--minucci-error) !important;
    margin-top: 8px !important;
    padding-left: 32px !important;
}

.minucci-form.minucci-style-modern-light .minucci-consent-wrapper.has-error .minucci-consent-error,
.minucci-form.minucci-style-modern-dark .minucci-consent-wrapper.has-error .minucci-consent-error {
    display: block !important;
}

/* ---------- Bouton Cookie Wall aligne sur l'accent ---------- */
.minucci-form.minucci-style-modern-light .minucci-cookie-accept,
.minucci-form.minucci-style-modern-dark .minucci-cookie-accept {
    background: var(--minucci-primary) !important; /* contre le noir force de base */
    color: var(--minucci-white) !important;
    border-radius: var(--minucci-radius-md) !important;
    box-shadow: var(--modern-btn-shadow) !important;
}

.minucci-form.minucci-style-modern-light .minucci-cookie-accept:hover,
.minucci-form.minucci-style-modern-dark .minucci-cookie-accept:hover {
    filter: none !important; /* contre brightness(0.92) de base */
    background: var(--minucci-primary-dark) !important;
    box-shadow: var(--modern-btn-shadow-hover) !important;
}

.minucci-form.minucci-style-modern-light .minucci-cookie-accept:active,
.minucci-form.minucci-style-modern-dark .minucci-cookie-accept:active {
    box-shadow: var(--modern-btn-shadow) !important;
}

/* ---------- Specifique Sombre ---------- */

/* Fleche de select claire, lisible sur fond sombre */
.minucci-form.minucci-style-modern-dark .minucci-field 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='%23A8ABB6' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E") !important;
}

/* Backdrop de la modale legale plus dense */
.minucci-form.minucci-style-modern-dark .minucci-legal-backdrop {
    background: rgba(0, 0, 0, 0.55) !important;
}

/* Cookie Wall sombre */
.minucci-form.minucci-style-modern-dark .minucci-cookie-overlay {
    background: rgba(23, 24, 29, 0.20) !important;
}

.minucci-form.minucci-style-modern-dark .minucci-cookie-content {
    background: rgba(27, 28, 34, 0.92) !important;
    border: 1px solid rgba(255, 255, 255, 0.08) !important;
    box-shadow: 0 24px 64px rgba(0, 0, 0, 0.55) !important;
}

/* Skeleton shimmer adapte au sombre (etat verrouille avec flou) */
.minucci-form.minucci-style-modern-dark.is-locked.minucci-blur-active .minucci-field input,
.minucci-form.minucci-style-modern-dark.is-locked.minucci-blur-active .minucci-field textarea,
.minucci-form.minucci-style-modern-dark.is-locked.minucci-blur-active .minucci-field select {
    background: linear-gradient(110deg,
            rgba(255, 255, 255, 0.04) 0%,
            rgba(255, 255, 255, 0.10) 50%,
            rgba(255, 255, 255, 0.04) 100%) !important;
    background-size: 200% 100% !important;
    border-color: rgba(255, 255, 255, 0.08) !important;
}

.minucci-form.minucci-style-modern-dark.is-locked.minucci-blur-active .minucci-submit {
    background: linear-gradient(110deg,
            rgba(255, 255, 255, 0.08) 0%,
            rgba(255, 255, 255, 0.16) 50%,
            rgba(255, 255, 255, 0.08) 100%) !important;
    background-size: 200% 100% !important;
}

.minucci-form.minucci-style-modern-dark.is-locked.minucci-blur-active .minucci-consent-checkmark {
    background: linear-gradient(110deg,
            rgba(255, 255, 255, 0.06) 0%,
            rgba(255, 255, 255, 0.12) 50%,
            rgba(255, 255, 255, 0.06) 100%) !important;
    background-size: 200% 100% !important;
    border-color: rgba(255, 255, 255, 0.10) !important;
}

/* Reduced motion : pas de flash blanc sur l'overlay cookie en sombre */
@media (prefers-reduced-motion: reduce) {
    .minucci-form.minucci-form.minucci-style-modern-dark .minucci-cookie-overlay {
        background: rgba(23, 24, 29, 0.95) !important;
    }
}

/* ---------- Responsive Modernes ---------- */
@media (max-width: 768px) {
    .minucci-form.minucci-style-modern-light,
    .minucci-form.minucci-style-modern-dark {
        padding: 24px 20px !important;
    }
}

@media (max-width: 600px) {
    .minucci-form.minucci-style-modern-light,
    .minucci-form.minucci-style-modern-dark {
        padding: 20px 16px !important;
        border-radius: 14px !important;
    }

    .minucci-form.minucci-style-modern-light .minucci-fields-wrapper,
    .minucci-form.minucci-style-modern-dark .minucci-fields-wrapper {
        gap: 16px !important;
    }

    .minucci-form.minucci-style-modern-light .minucci-field-width-50,
    .minucci-form.minucci-style-modern-dark .minucci-field-width-50 {
        width: 100% !important;
    }
}

/* ============================================================
   v2.2.0 - Anti-spam & RGPD
   ============================================================ */

/* Honeypot : champ invisible pour les humains (hors ecran, pas de
   display:none - certains bots l'ignorent), mais present dans le DOM */
.minucci-form.minucci-form .minucci-hp-field {
    position: absolute !important;
    left: -9999px !important;
    top: auto !important;
    width: 1px !important;
    height: 1px !important;
    overflow: hidden !important;
    opacity: 0 !important;
    pointer-events: none !important;
}

/* Cookie Wall : texte alternatif RGPD (autre moyen de contact en cas de refus) */
.minucci-form.minucci-form .minucci-cookie-alt {
    margin: 14px 0 0 0 !important;
    font-size: 0.8125rem !important;
    line-height: 1.5 !important;
    color: #666666 !important;
    opacity: 0.9 !important;
}
