:root {
    --cayudi-primary-dark: #0E679B;
    --cayudi-primary: #1C86B9;
    --cayudi-primary-light: #1D9CD1;
    --cayudi-secondary: #1FB2E4;
    --cayudi-accent: #57BAA3;
}

/* Minimalist Floating Form Styles - Matching Mobile Aesthetics */

/* --- MOBILE: HIDE FLOATING FORM --- */
@media only screen and (max-width: 991px) {

    #floating-form,
    .curso-floating-form,
    .diplomado-floating-form {
        display: none !important;
        visibility: hidden !important;
    }
}

.curso-floating-form,
.diplomado-floating-form {
    position: fixed !important;
    top: 50% !important;
    right: 3rem !important;
    transform: translateY(-45%) !important;
    /* Start slightly higher/lower for animation */
    width: 360px !important;
    background: #ffffff !important;
    border-radius: 16px !important;
    box-shadow: 0 15px 40px rgba(13, 107, 155, 0.12) !important;
    padding: 1.25rem !important;
    z-index: 10000 !important;
    border: 1px solid rgba(13, 107, 155, 0.08) !important;
    transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1) !important;
    max-height: 90vh !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;

    /* Hidden state enabling animation */
    display: block !important;
    visibility: hidden !important;
    opacity: 0 !important;
    pointer-events: none !important;
}

.curso-floating-form.visible,
.diplomado-floating-form.visible {
    visibility: visible !important;
    opacity: 1 !important;
    pointer-events: auto !important;
    transform: translateY(-50%) !important;
    /* Slide into place */
}

/* Header */
.curso-floating-form-header,
.diplomado-floating-form-header {
    text-align: left !important;
    margin-bottom: 0.85rem !important;
}

.curso-floating-form-title,
.diplomado-floating-form-title {
    font-size: 1.5rem !important;
    font-weight: 700 !important;
    color: #0f172a !important;
    margin-bottom: 0.15rem !important;
    letter-spacing: -0.02em !important;
}

.curso-floating-form-subtitle {
    font-size: 0.8rem !important;
    color: #475569 !important;
}

/* Forms and Groups */
:is(.curso-floating-form, .diplomado-floating-form, .cayudi-inscripcion-form) .cayudi-inscripcion-form {
    gap: 0.65rem !important;
}

:is(.curso-floating-form, .diplomado-floating-form, .cayudi-inscripcion-form) .form-group label {
    font-size: 0.65rem !important;
    font-weight: 700 !important;
    color: #475569 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.05em !important;
    margin-bottom: 0.25rem !important;
}

:is(.curso-floating-form, .diplomado-floating-form, .cayudi-inscripcion-form) .form-group input:not([type="radio"]),
:is(.curso-floating-form, .diplomado-floating-form, .cayudi-inscripcion-form) .form-group select {
    background-color: #ffffff !important;
    border: 1.5px solid #d1d5db !important;
    padding: 0 0.65rem !important;
    font-size: 0.85rem !important;
    border-radius: 8px !important;
    color: #1e293b !important;
    font-weight: 500 !important;
    height: 36.4px !important;
    max-height: 36.4px !important;
    width: 100% !important;
    box-sizing: border-box !important;
}

:is(.curso-floating-form, .diplomado-floating-form, .cayudi-inscripcion-form) .form-group input:focus,
:is(.curso-floating-form, .diplomado-floating-form, .cayudi-inscripcion-form) .form-group select:focus {
    border-color: var(--cayudi-primary) !important;
    background: #fafbff !important;
}

/* Selector Modalidad - MATCHING MOBILE STYLE */
:is(.curso-floating-form, .diplomado-floating-form, .cayudi-inscripcion-form) .modalidad-container {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 0.4rem !important;
    margin-bottom: 0.4rem !important;
}

:is(.curso-floating-form, .diplomado-floating-form, .cayudi-inscripcion-form) .modalidad-option {
    position: relative !important;
    padding: 0.35rem 0.4rem !important;
    background: #f1f5f9 !important;
    border: 1.5px solid #cbd5e1 !important;
    border-radius: 8px !important;
    font-weight: 700 !important;
    font-size: 0.7rem !important;
    color: #475569 !important;
    text-align: center !important;
    transition: all 0.2s ease !important;
    cursor: pointer !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-height: 36.4px !important;
    max-height: 36.4px !important;
    flex: 1 1 calc(50% - 0.2rem) !important;
    text-transform: uppercase !important;
}

:is(.curso-floating-form, .diplomado-floating-form, .cayudi-inscripcion-form) .modalidad-option:hover {
    border-color: var(--cayudi-primary) !important;
    background: #f0f9ff !important;
    transform: translateY(-1px) !important;
    box-shadow: 0 4px 12px rgba(28, 134, 185, 0.12) !important;
}

:is(.curso-floating-form, .diplomado-floating-form, .cayudi-inscripcion-form) .modalidad-option:has(input:checked) {
    background: #1C86B9 !important;
    border-color: #1C86B9 !important;
    color: #ffffff !important;
    box-shadow: 0 4px 12px rgba(28, 134, 185, 0.25) !important;
    transform: translateY(-1px) !important;
}

:is(.curso-floating-form, .diplomado-floating-form, .cayudi-inscripcion-form) .modalidad-option input {
    position: absolute !important;
    opacity: 0 !important;
    width: 100% !important;
    height: 100% !important;
    top: 0 !important;
    left: 0 !important;
    cursor: pointer !important;
    z-index: 2 !important;
}

/* Base Row: Dynamic layout */
:is(.curso-floating-form, .diplomado-floating-form, .cayudi-inscripcion-form) .form-row-dynamic {
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: wrap !important;
    align-items: flex-end !important;
    gap: 0.5rem !important;
    margin-bottom: 0.6rem !important;
}

/* Side-by-Side Row: Pais + Price */
:is(.curso-floating-form, .diplomado-floating-form, .cayudi-inscripcion-form) .form-row-dynamic.side-by-side {
    display: flex !important;
    flex-direction: row !important;
    align-items: flex-end !important;
    gap: 0.5rem !important;
    margin-bottom: 0.6rem !important;
}

:is(.curso-floating-form, .diplomado-floating-form, .cayudi-inscripcion-form) .form-row-dynamic.side-by-side>div {
    flex: 0 0 calc(50% - 0.25rem) !important;
    max-width: calc(50% - 0.25rem) !important;
    margin-bottom: 0 !important;
}

/* Full width when only price container is visible (no country) */
:is(.curso-floating-form, .diplomado-floating-form, .cayudi-inscripcion-form) .form-row-dynamic #floating-price-container:only-child,
:is(.curso-floating-form, .diplomado-floating-form, .cayudi-inscripcion-form) .form-row-dynamic.side-by-side #floating-price-container:only-child {
    flex: 1 1 100% !important;
    max-width: 100% !important;
}

:is(.curso-floating-form, .diplomado-floating-form, .cayudi-inscripcion-form) #floating-price-container {
    /* NEW CONTAINER STYLE: TRANSPARENT WRAPPER */
    height: auto !important;
    max-height: none !important;
    margin: 0 !important;
    background: transparent !important;
    border: none !important;
    border-radius: 0 !important;

    display: flex;
    /* Removed !important to allow JS toggling */
    flex-direction: column !important;
    justify-content: flex-end !important;
    align-items: stretch !important;
    padding: 0 !important;
    gap: 0.2rem !important;

    /* Failsafes for visibility but CLEAN layout */
    flex: 1 !important;
    min-width: 140px !important;
    z-index: 5 !important;
    position: relative !important;
    visibility: visible !important;
    opacity: 1 !important;
}

/* Estado inicial (Oculto) - Transición sutil */
.curso-floating-form,
.diplomado-floating-form {
    /* ... propiedades base anteriores ... */
    transform: translateY(-45%) !important;
    /* Ligero slide */
    opacity: 0 !important;
    visibility: hidden !important;
    pointer-events: none !important;
    display: block !important;
}

/* Estado Visible */
.curso-floating-form.visible,
.diplomado-floating-form.visible {
    visibility: visible !important;
    opacity: 1 !important;
    pointer-events: auto !important;
    transform: translateY(-50%) !important;
}

/* RESET INTERNAL STYLES TO FIX OVERLAP (Restored) */
:is(.curso-floating-form, .diplomado-floating-form, .cayudi-inscripcion-form) #floating-price-container * {
    background: transparent !important;
    box-shadow: none !important;
    border: none !important;
    margin: 0 !important;
    padding: 0 !important;
    height: auto !important;
    min-height: 0 !important;
    width: auto !important;
    position: static !important;
}

:is(.curso-floating-form, .diplomado-floating-form, .cayudi-inscripcion-form) #floating-price-container .price-showcase {
    /* Input Box Styles */
    background: #ffffff !important;
    border: 1.5px solid #d1d5db !important;
    border-radius: 8px !important;
    height: 36.4px !important;
    box-shadow: none !important;

    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 0.4rem !important;
    width: 100% !important;
    visibility: visible !important;
    opacity: 1 !important;
    padding: 0 0.5rem !important;
}

/* Add Label "Inversión:" via CSS */
/* Label externo "INVERSIÓN:" on WRAPPER via ::before */
:is(.curso-floating-form, .diplomado-floating-form, .cayudi-inscripcion-form) #floating-price-container::before {
    content: "INVERSIÓN:";
    font-size: 0.65rem !important;
    font-weight: 700 !important;
    color: #475569 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.05em !important;
    margin-bottom: 0.05rem !important;
    /* Tiny adjustment */
    text-align: left !important;
    display: block !important;
    line-height: 1 !important;
}

/* Remove old pseudo on child */
:is(.curso-floating-form, .diplomado-floating-form, .cayudi-inscripcion-form) #floating-price-container .price-showcase::before {
    content: none !important;
}

:is(.curso-floating-form, .diplomado-floating-form, .cayudi-inscripcion-form) #floating-price-container .price-amount-wrapper {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 0.25rem !important;
    visibility: visible !important;
    opacity: 1 !important;
}

:is(.curso-floating-form, .diplomado-floating-form, .cayudi-inscripcion-form) #floating-price-container:hover {
    border-color: var(--cayudi-primary) !important;
    background: #f1f8fc !important;
}

/* Ensure original label is hidden to avoid duplicate */
:is(.curso-floating-form, .diplomado-floating-form, .cayudi-inscripcion-form) #floating-price-container .price-label {
    display: none !important;
}

:is(.curso-floating-form, .diplomado-floating-form, .cayudi-inscripcion-form) #floating-precio-dinamico {
    font-size: 1.1rem !important;
    font-weight: 800 !important;
    color: var(--cayudi-primary) !important;
    line-height: 1 !important;
}

:is(.curso-floating-form, .diplomado-floating-form, .cayudi-inscripcion-form) .price-currency {
    font-size: 0.7rem !important;
    font-weight: 700 !important;
    color: #94a3b8 !important;
    text-transform: uppercase !important;
}

:is(.curso-floating-form, .diplomado-floating-form, .cayudi-inscripcion-form) #floating-pais-container,
:is(.curso-floating-form, .diplomado-floating-form, .cayudi-inscripcion-form) #floating-virtual-type-container {
    display: none;
    visibility: visible !important;
    opacity: 1 !important;
    height: auto !important;
    min-height: 36.4px !important;
    position: relative !important;
    z-index: 10 !important;
    overflow: visible !important;
}

/* Virtual Type Selection - With BADGE and DESC */
:is(.curso-floating-form, .diplomado-floating-form, .cayudi-inscripcion-form) .virtual-type-options {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 0.75rem !important;
    margin-top: 1.25rem !important;
}

:is(.curso-floating-form, .diplomado-floating-form, .cayudi-inscripcion-form) .virtual-type-option {
    position: relative !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    padding: 1rem 0.75rem !important;
    border: 2px solid #e2e8f0 !important;
    background: #ffffff !important;
    border-radius: 14px !important;
    cursor: pointer !important;
    transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1) !important;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04) !important;
}

:is(.curso-floating-form, .diplomado-floating-form, .cayudi-inscripcion-form) .virtual-type-option input {
    position: absolute !important;
    opacity: 0 !important;
    width: 100% !important;
    height: 100% !important;
    top: 0 !important;
    left: 0 !important;
    cursor: pointer !important;
    margin: 0 !important;
    z-index: 5 !important;
}

:is(.curso-floating-form, .diplomado-floating-form, .cayudi-inscripcion-form) .virtual-type-option:has(input:checked) {
    background: linear-gradient(135deg, #1C86B9 0%, #1D9CD1 100%) !important;
    border-color: #1C86B9 !important;
    box-shadow: 0 4px 12px rgba(28, 134, 185, 0.3) !important;
}

:is(.curso-floating-form, .diplomado-floating-form, .cayudi-inscripcion-form) .virtual-type-price {
    position: absolute !important;
    top: -15px !important;
    right: -8px !important;
    background: linear-gradient(135deg, #57BAA3 0%, #3ba68c 100%) !important;
    color: #ffffff !important;
    padding: 5px 15px !important;
    border-radius: 50px !important;
    font-size: 0.85rem !important;
    font-weight: 900 !important;
    z-index: 25 !important;
    box-shadow: 0 4px 12px rgba(87, 186, 163, 0.4) !important;
    border: 2px solid #ffffff !important;
    transform: rotate(2deg) !important;
}

:is(.curso-floating-form, .diplomado-floating-form, .cayudi-inscripcion-form) .virtual-type-label {
    display: flex !important;
    flex-direction: column !important;
    text-align: left !important;
}

:is(.curso-floating-form, .diplomado-floating-form, .cayudi-inscripcion-form) .virtual-type-label strong {
    font-size: 0.8rem !important;
    font-weight: 800 !important;
    color: #0f172a !important;
    letter-spacing: -0.01em !important;
}

:is(.curso-floating-form, .diplomado-floating-form, .cayudi-inscripcion-form) .virtual-type-label small {
    font-size: 0.6rem !important;
    font-weight: 500 !important;
    color: #64748b !important;
    line-height: 1.1 !important;
}

:is(.curso-floating-form, .diplomado-floating-form, .cayudi-inscripcion-form) #floating-pais-container,
:is(.curso-floating-form, .diplomado-floating-form, .cayudi-inscripcion-form) #floating-virtual-type-container,
:is(.curso-floating-form, .diplomado-floating-form, .cayudi-inscripcion-form) #floating-price-container {
    animation: none !important;
    transition: none !important;
    overflow: visible !important;
}

:is(.curso-floating-form, .diplomado-floating-form, .cayudi-inscripcion-form) .form-row-compact {
    display: flex !important;
    gap: 0.5rem !important;
    width: 100% !important;
    flex-direction: column !important;
    /* Stack vertically by default */
}

@media (min-width: 992px) {
    :is(.curso-floating-form, .diplomado-floating-form, .cayudi-inscripcion-form) .form-row-compact {
        flex-direction: column !important;
        /* Keep stacked on desktop too per request */
    }
}

/* Ensure mobile form fields stack */
.inscripcion-section .form-row-compact {
    flex-direction: column !important;
}

.inscripcion-section .form-row-compact>div {
    width: 100% !important;
    margin-bottom: 0.5rem !important;
}

:is(.curso-floating-form, .diplomado-floating-form, .cayudi-inscripcion-form) .virtual-type-option:has(input:checked) .virtual-type-label strong {
    color: #ffffff !important;
}

:is(.curso-floating-form, .diplomado-floating-form, .cayudi-inscripcion-form) .virtual-type-option:has(input:checked) .virtual-type-label small {
    color: rgba(255, 255, 255, 0.9) !important;
}

/* Action Buttons */
:is(.curso-floating-form, .diplomado-floating-form, .cayudi-inscripcion-form) .btn-pago {
    background: linear-gradient(135deg, #6366f1 0%, #8b5cf6 100%) !important;
    color: white !important;
    font-weight: 600 !important;
    padding: 0.875rem !important;
    font-size: 1rem !important;
    border-radius: 0.75rem !important;
    border: none !important;
    box-shadow: 0 4px 12px rgba(99, 102, 241, 0.3) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 0.5rem !important;
    transition: all 0.3s ease !important;
    max-height: 42px !important;
}

:is(.curso-floating-form, .diplomado-floating-form, .cayudi-inscripcion-form) .btn-pago:hover {
    transform: translateY(-2px) !important;
    box-shadow: 0 6px 16px rgba(99, 102, 241, 0.45) !important;
    filter: brightness(1.1) !important;
}

:is(.curso-floating-form, .diplomado-floating-form, .cayudi-inscripcion-form) .btn-pago-paypal {
    background: linear-gradient(135deg, #003087 0%, #0070ba 100%) !important;
    border: none !important;
    color: #ffffff !important;
    box-shadow: 0 4px 12px rgba(0, 48, 135, 0.2) !important;
}

:is(.curso-floating-form, .diplomado-floating-form, .cayudi-inscripcion-form) .btn-pago-paypal:hover {
    background: linear-gradient(135deg, #001f5c 0%, #005ea6 100%) !important;
    transform: translateY(-1px) !important;
}

:is(.curso-floating-form, .diplomado-floating-form, .cayudi-inscripcion-form) .btn-pago-whatsapp {
    background: #25D366 !important;
    color: white !important;
}

/* Responsive */
@media (max-width: 1200px) {

    .curso-floating-form,
    .diplomado-floating-form {
        display: none !important;
    }
}

/* Ocultar formulario móvil en desktop - Corrección Crítica */
@media (min-width: 1201px) {

    #curso-inscripcion,
    #diplomado-inscripcion,
    .inscripcion-section {
        display: none !important;
    }
}

/* --- UTILIDAD PARA MODO VIRTUAL (OCULTAR PRECIO) --- */
/* Cuando el formulario tiene la clase .mode-virtual, ocultamos el contenedor de inversión */
form.mode-virtual #floating-price-container,
form.mode-virtual #price-container-mobile,
form.mode-virtual [id*="price-container"],
form.mode-virtual [id*="precio-container"],
form.mode-virtual .js-price-container {
    display: none !important;
}

/* --- MOBILE SPECIFIC FIXES (Scoped to inscripcion-section) --- */
.inscripcion-section .modalidad-container,
#diplomado-inscripcion .modalidad-container,
#curso-inscripcion .modalidad-container {
    padding: 0 !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    width: 100% !important;
}

.inscripcion-section .modalidad-option,
#diplomado-inscripcion .modalidad-option,
#curso-inscripcion .modalidad-option {
    /* Permitir flujo natural en móvil */
    flex: 1 1 auto !important;
    width: auto !important;
    max-width: none !important;
    min-width: 80px !important;
}

/* FORM MOBILE: País e Inversión Full Width */
.inscripcion-section .form-row-dynamic.side-by-side>div,
#diplomado-inscripcion .form-row-dynamic.side-by-side>div,
#curso-inscripcion .form-row-dynamic.side-by-side>div {
    flex: 1 1 100% !important;
    max-width: 100% !important;
    width: 100% !important;
}

/* --- MOBILE SPECIFIC: GLOBAL HEIGHT (Inputs, Selects, Buttons) - High Specificity --- */
#diplomado-inscripcion .cayudi-inscripcion-form input:not([type="radio"]):not([type="checkbox"]),
#diplomado-inscripcion .cayudi-inscripcion-form select,
#diplomado-inscripcion .cayudi-inscripcion-form button,
#diplomado-inscripcion .cayudi-inscripcion-form .btn-pago,
#curso-inscripcion .cayudi-inscripcion-form input:not([type="radio"]):not([type="checkbox"]),
#curso-inscripcion .cayudi-inscripcion-form select,
#curso-inscripcion .cayudi-inscripcion-form button,
#curso-inscripcion .cayudi-inscripcion-form .btn-pago,
.inscripcion-section form input:not([type="radio"]):not([type="checkbox"]),
.inscripcion-section form select,
.inscripcion-section form button,
.inscripcion-section form .btn-pago {
    height: 46px !important;
    min-height: 46px !important;
}

/* --- MOBILE SPECIFIC: PAIS SELECTOR FIX --- */
.inscripcion-section .js-pais-container select,
#diplomado-inscripcion select,
#curso-inscripcion select {
    height: 46px !important;
    padding: 0 10px !important;
    line-height: normal !important;
    background-color: white !important;
}

/* --- MOBILE SPECIFIC: Layout Row (Pais + Precio Side-by-Side) --- */
.inscripcion-section .form-row-dynamic.side-by-side,
#diplomado-inscripcion .form-row-dynamic.side-by-side,
#curso-inscripcion .form-row-dynamic.side-by-side {
    flex-direction: row !important;
    flex-wrap: nowrap !important;
    align-items: flex-end !important;
}

.inscripcion-section .form-row-dynamic.side-by-side>div,
#diplomado-inscripcion .form-row-dynamic.side-by-side>div,
#curso-inscripcion .form-row-dynamic.side-by-side>div {
    flex: 1 1 50% !important;
    max-width: 50% !important;
    min-width: 0 !important;
}

/* --- MOBILE SPECIFIC: INVERSION SIMPLIFIED --- */
.inscripcion-section .js-price-container,
#diplomado-inscripcion .js-price-container,
#curso-inscripcion .js-price-container {
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
    padding: 0 !important;
    margin: 0 !important;
    height: auto !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-start !important;
    justify-content: flex-end !important;
}

/* Label externo simulado */
.inscripcion-section .js-price-container::before,
#diplomado-inscripcion .js-price-container::before,
#curso-inscripcion .js-price-container::before {
    content: "INVERSIÓN:" !important;
    font-size: 0.85rem !important;
    font-weight: 600 !important;
    color: #374151 !important;
    margin-bottom: 5px !important;
    display: block !important;
    text-transform: uppercase !important;
    line-height: normal !important;
}

/* Caja tipo Input Mejorada */
.inscripcion-section .js-price-container .price-showcase,
#diplomado-inscripcion .js-price-container .price-showcase,
#curso-inscripcion .js-price-container .price-showcase {
    background: #f8fafc !important;
    border: 1px solid #cbd5e1 !important;
    border-radius: 6px !important;
    height: 46px !important;
    width: 100% !important;
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    justify-content: flex-start !important;
    padding: 0 12px !important;
    box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.05) !important;
    margin-top: 0 !important;
}

/* Texto del Precio Simple Ajustado */
/* Texto del Precio Simple Ajustado (Selector NUCLEAR) */
html body #diplomado-inscripcion #form-inscripcion-mobile #precio-dinamico,
html body #curso-inscripcion #form-inscripcion-mobile #precio-dinamico,
html body .inscripcion-section #precio-dinamico,
html body .inscripcion-section .price-currency {
    color: #1e293b !important;
    font-size: 0.95rem !important;
    font-weight: 600 !important;
    margin-right: 4px !important;
    display: inline-block !important;
    line-height: normal !important;
    -webkit-text-fill-color: #1e293b !important;
}

.inscripcion-section .price-amount-wrapper {
    display: flex !important;
    align-items: center !important;
    width: 100% !important;
}

/* Ocultar label interno duplicado (usamos ::before en contenedor) */
.inscripcion-section .js-price-container .price-label,
#diplomado-inscripcion .price-showcase .price-label {
    display: none !important;
}

/* --- MOBILE SPECIFIC: FAST ANIMATIONS & RESET --- */
.inscripcion-section .form-group,
.inscripcion-section input,
.inscripcion-section select,
.inscripcion-section button,
.inscripcion-section .btn-pago,
.inscripcion-section .js-price-container,
.inscripcion-section .js-pais-container,
.inscripcion-section .modalidad-option {
    transition: background-color 0.2s, border-color 0.2s, color 0.2s, transform 0.2s, box-shadow 0.2s !important;
    /* Excluir opacity para jQuery */
    /* Microanimaciones CSS */
    animation: none !important;
    /* Eliminar animaciones lentas heredadas */
    transform: none !important;

    /* Base visible pero permitiendo override por JS (fadeIn) */
    opacity: 1;
    visibility: visible;
}

/* --- ROBUST ANIMATION SYSTEM (JS CONTROLLER) --- */
@keyframes cayudiSlideIn {
    0% {
        opacity: 0;
        transform: translateY(8px);
    }

    100% {
        opacity: 1;
        transform: translateY(0);
    }
}

.js-pais-container,
.js-virtual-container,
.js-price-container,
#pais-container-mobile,
#price-container-mobile,
#virtual-type-container-mobile,
[id*="pais-container"],
[id*="virtual-type-container"] {
    transition: opacity 0.3s ease-in-out, max-height 0.3s ease-in-out, margin 0.3s ease, padding 0.3s ease !important;
    will-change: opacity, max-height;
}

.cayudi-visible {
    opacity: 1 !important;
    max-height: 800px !important;
    /* Altura generosa */
    visibility: visible !important;
    display: block !important;
    overflow: visible !important;
    animation: cayudiSlideIn 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94) forwards !important;
}

.cayudi-hidden {
    opacity: 0 !important;
    max-height: 0 !important;
    visibility: hidden !important;
    overflow: hidden !important;

    /* Colapsar espacio totalmente */
    margin-top: 0 !important;
    margin-bottom: 0 !important;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
    border: none !important;
    pointer-events: none !important;
}

/* --- MOBILE SPECIFIC: INTL TEL INPUT FIX --- */
@media (max-width: 991px) {
    .iti__country-list {
        max-width: 90vw !important;
        width: 300px !important;
        left: 50% !important;
        top: 50% !important;
        transform: translate(-50%, -50%) !important;
        position: fixed !important;
        border-radius: 12px !important;
        box-shadow: 0 10px 40px rgba(0, 0, 0, 0.5) !important;
        max-height: 50vh !important;
        z-index: 2147483647 !important;
    }

    /* Overlay dimming effect (simulated via box-shadow spread) */
    .iti__country-list:before {
        content: "";
        position: fixed;
        top: -100vh;
        left: -100vw;
        width: 300vw;
        height: 300vh;
        background: rgba(0, 0, 0, 0.5);
        z-index: -1;
        pointer-events: none;
    }
}