/* ==========================================================================
   MÁSCARA DE RESERVAS MÓVIL — WD-14363
   En ≤991px la máscara de escritorio (#neobookings-mask) se reutiliza como
   overlay a pantalla completa: tarjeta blanca con campos apilados, abierta
   por el botón sticky "Reservar ahora" y cerrada con "Cerrar" o Escape.
   En ≥992px este archivo no altera nada (la máscara desktop sigue igual).
   Amarillo de marca: rgb(var(--primary)) = #F5DE6F. Base rem = 10px.
   Capas: botón sticky 1500 < overlay 1900 < popup huéspedes 2000 < datepicker 2100.
   ========================================================================== */

/* ----------------------------------------------------------------------------
   Estado por defecto (desktop): ni botón sticky ni botón cerrar
   ---------------------------------------------------------------------------- */
.book-now-sticky,
.neobookings-mask .mask-close {
    display: none;
}

@media (max-width: 991px) {

    /* ------------------------------------------------------------------
       Botón sticky "Reservar ahora" — acompaña al scroll
       ------------------------------------------------------------------ */
    .book-now-sticky {
        position: fixed;
        bottom: 18px;
        left: 50%;
        transform: translateX(-50%);
        z-index: 1500;
        display: block;
        padding: 15px 44px;
        font-family: 'Bitter', sans-serif;
        font-size: 1.6rem;
        font-weight: 600;
        letter-spacing: 0.05em;
        text-transform: uppercase;
        color: #000;
        background-color: rgb(var(--primary));
        border: 0;
        border-radius: 50px;
        box-shadow: 0 4px 16px rgba(0, 0, 0, 0.35);
        cursor: pointer;
        white-space: nowrap;
    }

    /* Mientras el overlay está abierto, el botón se oculta */
    body.booking-mask-open .book-now-sticky {
        display: none;
    }

    /* Sin scroll de fondo con el overlay abierto */
    body.booking-mask-open {
        overflow: hidden;
    }

    /* ------------------------------------------------------------------
       Overlay de la máscara — cerrado por defecto en cualquier sub-rango
       móvil de responsive.css (incluido 770-991px, donde antes se veía
       la barra de escritorio)
       ------------------------------------------------------------------ */
    .neobookings-mask:not(.is-open) {
        display: none;
    }

    .neobookings-mask.is-open {
        display: block;
        position: fixed;
        top: 0;
        left: 0;
        right: 0;
        bottom: 0;
        z-index: 1900;
        height: auto;
        margin: 0;
        padding: 0 16px;
        background-color: rgba(0, 0, 0, 0.55);
        overflow-y: auto;
        -webkit-overflow-scrolling: touch;
    }

    /* Neutraliza el posicionamiento desktop del contenedor (responsive.css
       lo deja absolute + translateY en ≥768px) */
    .neobookings-mask.is-open .container {
        position: relative;
        top: auto;
        left: auto;
        right: auto;
        transform: none;
        width: 100%;
        max-width: 420px;
        margin: 6vh auto 32px;
        padding: 0;
    }

    .neobookings-mask.is-open .row {
        margin: 0;
    }

    /* Tarjeta blanca */
    .neobookings-mask.is-open .col-md-12 {
        background-color: #fff;
        border-radius: 20px;
        padding: 18px 24px 28px;
        box-shadow: 0 12px 40px rgba(0, 0, 0, 0.30);
    }

    .neobookings-mask.is-open .neobookings-mask__neobookings-form {
        margin: 0;
        width: 100%;
    }

    /* ------------------------------------------------------------------
       Botón cerrar (texto + aspa en círculo) centrado en la cabecera
       ------------------------------------------------------------------ */
    .neobookings-mask.is-open .mask-close {
        display: flex;
        flex-direction: column;
        align-items: center;
        gap: 6px;
        margin: 0 auto 12px;
        padding: 4px;
        background: transparent;
        border: 0;
        font-family: 'Bitter', sans-serif;
        font-size: 1.4rem;
        color: #000;
        cursor: pointer;
    }

    .neobookings-mask.is-open .mask-close .mask-close__icon {
        display: flex;
        align-items: center;
        justify-content: center;
        width: 38px;
        height: 38px;
        border-radius: 50%;
        background-color: rgba(var(--primary), 0.45);
        font-size: 2.2rem;
        line-height: 1;
    }

    /* ------------------------------------------------------------------
       Títulos de la máscara dentro de la tarjeta
       ------------------------------------------------------------------ */
    .neobookings-mask.is-open .mask-title {
        display: block;
        width: auto;
        margin: 0 0 18px;
        text-align: center;
    }

    .neobookings-mask.is-open .mask-garantizado {
        display: block;
        width: auto;
        margin: 14px 0 0;
        padding: 0;
        text-align: center;
    }

    /* ------------------------------------------------------------------
       Campos apilados a ancho completo, estilo subrayado
       ------------------------------------------------------------------ */
    .neobookings-mask.is-open .neobookings-form__input {
        display: block;
        width: 100%;
        margin: 0 0 16px;
    }

    /* responsive.css fija anchos en línea con ID en ≥768px
       (.neobookings-form__input#guests { width: 13% }): se replica el ID */
    .neobookings-mask.is-open .neobookings-form__input#guests,
    .neobookings-mask.is-open .neobookings-form__input.input--special-input {
        width: 100%;
        margin-right: 0;
    }

    /* Etiquetas visibles encima de cada campo (en desktop van ocultas) */
    .neobookings-mask.is-open .neobookings-form__input .label__label-text {
        display: block;
        margin-bottom: 2px;
        font-family: 'Bitter', sans-serif;
        font-size: 1.3rem;
        font-weight: 600;
        text-align: left;
        color: #000;
    }

    /* Inputs de fecha y disparador de huéspedes: subrayado sobre tarjeta blanca */
    .neobookings-mask.is-open .neobookings-form__input label .type--type-text,
    .neobookings-mask.is-open .neobookings-form__input label input[type="text"] {
        padding: 11px 44px 11px 2px;
        background-color: transparent;
        border: 0;
        border-bottom: 1px solid rgba(0, 0, 0, 0.35);
        border-radius: 0;
        text-align: left;
        font-size: 1.6rem; /* 16px reales: evita zoom automático en iOS */
        text-transform: none;
    }

    /* Placeholders legibles sobre fondo blanco (en desktop son blancos) */
    .neobookings-mask.is-open .neobookings-form__input label .type--type-text::placeholder,
    .neobookings-mask.is-open .neobookings-form__input label input[type="text"]::placeholder {
        color: #767676;
    }

    /* Iconos (calendario / huéspedes) a la derecha del campo, anclados al
       input (la etiqueta visible está encima y descentra el bloque) */
    .neobookings-mask.is-open .neobookings-form__input .input__label .icon--misa {
        position: absolute;
        left: auto;
        right: 4px;
        top: auto;
        bottom: 12px;
        width: auto;
        height: auto;
        margin-top: 0;
    }

    /* El icono de huéspedes tiene una regla con 2 IDs en guests.css
       (#neobookings-mask #guests .icon--pax, anclado a la izquierda):
       se replica la especificidad para llevarlo a la derecha del input */
    #neobookings-mask.is-open #guests .icon--pax {
        left: auto;
        right: 4px;
        top: auto;
        bottom: 12px;
        transform: none;
    }

    /* ------------------------------------------------------------------
       Botón de reserva centrado
       ------------------------------------------------------------------ */
    .neobookings-mask.is-open .neobookings-form__input.input--special-input {
        margin: 22px 0 0;
        text-align: center;
    }

    .neobookings-mask.is-open .input--special-input input[type="submit"] {
        display: inline-block;
        width: auto;
        min-width: 220px;
        padding: 13px 32px;
        border-radius: 50px;
        font-size: 1.5rem;
    }

    /* ------------------------------------------------------------------
       Datepicker jQuery UI como tarjeta centrada (lo recoloca el módulo
       booking-mask-mobile.js mientras el overlay está abierto)
       ------------------------------------------------------------------ */
    #ui-datepicker-div.mobile-datepicker {
        width: min(92vw, 340px);
        max-height: 80vh;
        overflow-y: auto;
        border-radius: 12px;
        box-shadow: 0 12px 40px rgba(0, 0, 0, 0.35);
    }
}
