/* ============================================
   FF Cajon de Reservas — horizontal desktop / vertical movil
   Paleta WP: navy #0A2540, azul #263C89, coral #E0984C
   ============================================ */

:root {
    --ff-navy: #0A2540;
    --ff-azul: #263C89;
    --ff-coral: #E0984C;
    --ff-blanco: #ffffff;
    --ff-gris-claro: #f3f3f3;
    --ff-gris-medio: #d9dce5;
    --ff-gris-texto: #6a7285;
}

.ff-cajon {
    font-family: 'Montserrat', system-ui, -apple-system, sans-serif;
    background: var(--ff-azul);
    border-radius: 14px;
    padding: 18px;
    box-shadow: 0 18px 50px rgba(38, 60, 137, 0.25);
    max-width: 1100px;
    margin: 0 auto;
    color: var(--ff-blanco);
    position: relative;
}

/* Tabs Ida y vuelta / Solo ida */
.ff-cajon__tabs {
    display: flex;
    gap: 8px;
    margin-bottom: 14px;
}

.ff-cajon__tab {
    flex: 0 0 auto;
    background: transparent;
    border: 2px solid rgba(255, 255, 255, 0.25);
    color: var(--ff-blanco);
    padding: 9px 18px;
    border-radius: 999px;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    transition: all 0.2s ease;
    font-family: inherit;
}

.ff-cajon__tab svg { fill: currentColor; }

.ff-cajon__tab:hover {
    border-color: var(--ff-coral);
}

.ff-cajon__tab--active {
    background: var(--ff-coral);
    border-color: var(--ff-coral);
    color: var(--ff-blanco);
}

/* Formulario */
.ff-cajon__form {
    display: grid;
    gap: 10px;
    grid-template-columns: minmax(210px, 1.7fr) minmax(150px, 1fr) minmax(150px, 1fr) minmax(160px, 1.1fr) auto;
    align-items: end;
}

.ff-cajon__field {
    display: flex;
    flex-direction: column;
    gap: 4px;
    position: relative;
    min-width: 0;
    margin: 0;
}

.ff-cajon__field label {
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: rgba(255, 255, 255, 0.75);
    padding-left: 2px;
    margin: 0;
    line-height: 1.4;
    min-height: 16px;
}

.ff-cajon__select,
.ff-cajon__date,
.ff-cajon__pax-trigger {
    background: var(--ff-blanco);
    border: 1px solid transparent;
    border-radius: 10px;
    padding: 0 14px;
    font-size: 14px;
    font-weight: 600;
    color: var(--ff-navy);
    font-family: inherit;
    width: 100%;
    box-sizing: border-box;
    cursor: pointer;
    line-height: 48px;
    height: 48px;
    margin: 0;
    vertical-align: middle;
    outline: none;
}
.ff-cajon__select:focus,
.ff-cajon__date:focus,
.ff-cajon__pax-trigger:focus { border-color: var(--ff-coral); }

/* Trayecto con icono de barco (estilo booking) */
.ff-cajon__select {
    appearance: none;
    -webkit-appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%230A2540'%3E%3Cpath d='M20 21c-1.39 0-2.78-.47-4-1.32-2.44 1.71-5.56 1.71-8 0C6.78 20.53 5.39 21 4 21H2v2h2c1.38 0 2.74-.35 4-.99 2.52 1.29 5.48 1.29 8 0 1.26.65 2.62.99 4 .99h2v-2h-2zM3.95 19H4c1.6 0 3.02-.88 4-2 .98 1.12 2.4 2 4 2s3.02-.88 4-2c.98 1.12 2.4 2 4 2h.05l1.89-6.68c.08-.26.06-.54-.06-.78s-.34-.42-.6-.5L20 10.62V6c0-1.1-.9-2-2-2h-3V1H9v3H6c-1.1 0-2 .9-2 2v4.62l-1.29.42c-.26.08-.48.26-.6.5s-.15.52-.06.78L3.95 19zM6 6h12v3.97L12 8 6 9.97V6z'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 12px center;
    background-size: 20px;
    padding-right: 40px;
    text-overflow: ellipsis;
    white-space: nowrap;
    overflow: hidden;
}

.ff-cajon__date::-webkit-calendar-picker-indicator {
    opacity: 0.6;
    cursor: pointer;
}

.ff-cajon__pax-trigger {
    display: inline-flex;
    align-items: center;
    justify-content: space-between;
    text-align: left;
    gap: 8px;
    line-height: 1 !important;
}

.ff-cajon__pax-trigger svg { fill: var(--ff-navy); flex-shrink: 0; }

.ff-cajon__pax-summary {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    flex: 1;
}

/* ==================== Modal de pasajeros ==================== */
.ff-cajon__pax-modal {
    position: fixed;
    inset: 0;
    z-index: 10000;
    display: flex;
    align-items: center;
    justify-content: center;
}
.ff-cajon__pax-modal[hidden] { display: none; }

.ff-cajon__pax-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(10, 37, 64, 0.55);
    backdrop-filter: blur(2px);
    cursor: pointer;
}

.ff-cajon__pax-dialog {
    position: relative;
    background: var(--ff-blanco);
    color: var(--ff-navy);
    width: min(420px, 92vw);
    max-height: 85vh;
    overflow: auto;
    border-radius: 16px;
    box-shadow: 0 24px 60px rgba(10, 37, 64, 0.35);
    font-family: inherit;
}

.ff-cajon__pax-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 18px 22px 10px;
}

.ff-cajon__pax-header h3 {
    margin: 0;
    font-size: 20px;
    font-weight: 700;
    color: var(--ff-azul);
}

.ff-cajon__pax-close {
    background: transparent;
    border: 0;
    padding: 4px;
    cursor: pointer;
    color: var(--ff-gris-texto);
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: background 0.15s;
}
.ff-cajon__pax-close:hover { background: #f0f2f8; }
.ff-cajon__pax-close svg { fill: currentColor; }

.ff-cajon__pax-body { padding: 8px 22px 16px; }

.ff-cajon__pax-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 14px 0;
    border-bottom: 1px solid var(--ff-gris-medio);
}
.ff-cajon__pax-row:last-child { border-bottom: 0; }

.ff-cajon__pax-row strong {
    display: block;
    font-size: 15px;
    color: var(--ff-navy);
    font-weight: 700;
}

.ff-cajon__pax-row small {
    font-size: 11px;
    color: var(--ff-gris-texto);
}

.ff-cajon__counter {
    display: inline-flex;
    align-items: center;
    gap: 10px;
}

.ff-cajon__counter-btn {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    border: 1.5px solid var(--ff-azul);
    background: var(--ff-blanco);
    color: var(--ff-azul);
    font-size: 18px;
    font-weight: 700;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
    padding: 0;
    transition: all 0.15s ease;
    font-family: inherit;
}

.ff-cajon__counter-btn:hover:not(:disabled) {
    background: var(--ff-azul);
    color: var(--ff-blanco);
}

.ff-cajon__counter-btn:disabled {
    opacity: 0.3;
    cursor: not-allowed;
}

.ff-cajon__counter-val {
    min-width: 24px;
    text-align: center;
    font-weight: 700;
    font-size: 16px;
    color: var(--ff-navy);
}

.ff-cajon__pax-footer {
    padding: 14px 22px 20px;
    display: flex;
    justify-content: center;
}

.ff-cajon__pax-aceptar {
    background: var(--ff-azul);
    color: var(--ff-blanco);
    border: 0;
    border-radius: 10px;
    padding: 12px 36px;
    font-size: 14px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.6px;
    cursor: pointer;
    font-family: inherit;
    transition: background 0.15s;
}
.ff-cajon__pax-aceptar:hover { background: #1d2f6d; }

/* ==================== Boton BUSCAR ==================== */
.ff-cajon .ff-cajon__submit,
button.ff-cajon__submit {
    background: var(--ff-coral) !important;
    background-color: var(--ff-coral) !important;
    color: var(--ff-blanco) !important;
    border: 1px solid var(--ff-coral) !important;
    border-radius: 10px !important;
    padding: 0 28px !important;
    font-size: 15px !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.8px !important;
    cursor: pointer;
    font-family: inherit;
    transition: background 0.2s ease, transform 0.1s ease;
    white-space: nowrap;
    box-shadow: none !important;
    text-shadow: none !important;
    height: 48px !important;
    min-height: 48px !important;
    line-height: 48px !important;
    box-sizing: border-box !important;
    margin: 0 !important;
    vertical-align: middle;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}
.ff-cajon .ff-cajon__submit:hover,
button.ff-cajon__submit:hover {
    background: #d58636 !important;
    background-color: #d58636 !important;
}
.ff-cajon .ff-cajon__submit:active { transform: translateY(1px); }

/* Error de validacion */
.ff-cajon__error {
    color: #ffb4b4;
    font-size: 12px;
    margin-top: 8px;
    font-weight: 600;
}

/* Estado solo ida: oculta fecha vuelta */
.ff-cajon[data-tipo="solo-ida"] .ff-cajon__field--fecha-vuelta {
    display: none;
}
.ff-cajon[data-tipo="solo-ida"] .ff-cajon__form {
    grid-template-columns: minmax(210px, 1.8fr) minmax(150px, 1fr) minmax(160px, 1.1fr) auto;
}

/* Variante resultados: cajetin compacto arriba de los resultados */
.ff-cajon--resultados {
    padding: 14px;
    margin-bottom: 18px;
}
.ff-cajon--resultados .ff-cajon__tabs { margin-bottom: 10px; }

/* ==================== Responsive: VERTICAL en movil ==================== */
@media (max-width: 900px) {
    .ff-cajon {
        padding: 14px;
        border-radius: 12px;
    }

    .ff-cajon__form,
    .ff-cajon[data-tipo="solo-ida"] .ff-cajon__form {
        grid-template-columns: 1fr;
        gap: 8px;
    }

    /* Inputs compactos: el theme WP suele forzar altura grande, anulamos */
    .ff-cajon .ff-cajon__select,
    .ff-cajon .ff-cajon__date,
    .ff-cajon .ff-cajon__pax-trigger {
        height: 44px !important;
        min-height: 44px !important;
        line-height: 44px !important;
        padding: 0 12px !important;
        font-size: 14px !important;
        border-radius: 8px !important;
        box-sizing: border-box !important;
    }
    .ff-cajon .ff-cajon__select { padding-right: 36px !important; }
    .ff-cajon .ff-cajon__pax-trigger { line-height: 1 !important; }

    /* Label más cerca del input */
    .ff-cajon__field { gap: 2px; }
    .ff-cajon__field label {
        font-size: 10px;
        line-height: 1.2;
        min-height: 14px;
        margin-bottom: 2px;
    }

    /* Botón Buscar también compacto */
    .ff-cajon .ff-cajon__submit,
    button.ff-cajon__submit {
        height: 46px !important;
        min-height: 46px !important;
        line-height: 46px !important;
        padding: 0 20px !important;
        font-size: 15px !important;
        width: 100%;
        border-radius: 8px !important;
    }

    .ff-cajon__tabs {
        margin-bottom: 8px;
        gap: 6px;
    }

    .ff-cajon__tab {
        flex: 1 1 0;
        justify-content: center;
        padding: 8px 10px;
        font-size: 13px;
        min-height: 38px;
    }
}


/* ============================================
   Banner 'Modificando reserva' — visible cuando JS detecta sessionStorage.ff_compra_modificada.
   El cajetin tiene fondo navy, asi que usamos texto blanco para contraste.
   Fondo translucido + borde coral para mantener identidad visual.
   ============================================ */
.ff-cajon__banner-modificando {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 14px 20px;
    background: rgba(255, 255, 255, 0.10);
    border: 1px solid rgba(224, 152, 76, 0.5);
    border-left: 3px solid #e0984c;
    border-radius: 8px;
    margin-bottom: 14px;
    flex-wrap: wrap;
}
.ff-cajon__banner-modificando[hidden] { display: none; }
.ff-cajon__banner-modificando-texto {
    display: flex;
    flex-direction: column;
    gap: 3px;
    flex: 1;
    min-width: 200px;
}
.ff-cajon__banner-modificando-texto strong {
    font-size: 14px;
    font-weight: 700;
    color: #fff;
    letter-spacing: 0.2px;
}
.ff-cajon__banner-modificando-texto span {
    font-size: 12.5px;
    color: rgba(255, 255, 255, 0.85);
    line-height: 1.4;
}
.ff-cajon__banner-cancelar {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 14px;
    background: #fff;
    color: var(--ff-text, #2d3142);
    border: 1.5px solid rgba(192, 38, 38, 0.35);
    border-radius: 6px;
    font-family: inherit;
    font-size: 12.5px;
    font-weight: 600;
    cursor: pointer;
    transition: background 0.15s, border-color 0.15s, color 0.15s;
}
.ff-cajon__banner-cancelar:hover {
    background: rgba(192, 38, 38, 0.08);
    border-color: #c02626;
    color: #c02626;
}
.ff-cajon__banner-cancelar svg { fill: currentColor; }

@media (max-width: 600px) {
    .ff-cajon__banner-modificando { padding: 10px 14px; }
    .ff-cajon__banner-cancelar { width: 100%; justify-content: center; }
}

