/* ==========================================================================
   VISTA DE PAQUETES / TARIFAS - MAYAN BOATS 
   ========================================================================== */

.header-tarifas {
    padding: 200px 20px 140px;
    background: linear-gradient(180deg, var(--navy-dark) 0%, #112B4A 100%);
    position: relative;
    border-bottom: 2px solid var(--gold);
}

.header-tarifas h1 {
    text-shadow: 0 4px 15px rgba(0, 0, 0, 0.5);
    margin-bottom: 10px;
    letter-spacing: 2px;
}

.mt-negativo {
    margin-top: -80px;
    position: relative;
    z-index: 10;
}

.text-navy {
    color: var(--navy-dark) !important;
}

.bg-navy {
    background-color: var(--navy-dark) !important;
}


/* ==========================================================================
   SECCIÓN VIP (BENEFICIOS INCLUIDOS)
   ========================================================================== */
.vip-ganga-card {
    background-color: var(--navy-dark);
    border-radius: 10px;
    overflow: hidden;
}

.vip-header {
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}

.border-end-vip {
    border-right: 1px solid rgba(255, 255, 255, 0.1);
}

.border-start-vip {
    border-left: 1px solid rgba(255, 255, 255, 0.1);
}

.luxury-carousel {
    border-radius: 10px;
    overflow: hidden;
    position: relative;
    border: 2px solid var(--gold);
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.3);
}

.vip-img {
    height: 250px;
    object-fit: cover;
    filter: brightness(0.9);
    transition: transform 0.5s ease;
}

.luxury-carousel:hover .vip-img {
    transform: scale(1.05);
}

.ribbon-incluido {
    position: absolute;
    top: 15px;
    left: -35px;
    z-index: 5;
    background-color: #28a745;
    color: white;
    font-weight: bold;
    font-size: 0.75rem;
    letter-spacing: 2px;
    padding: 5px 40px;
    transform: rotate(-45deg);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.4);
}

.carousel-caption-overlay {
    position: absolute;
    bottom: 15px;
    left: 50%;
    transform: translateX(-50%);
    background: rgba(10, 25, 47, 0.85);
    color: var(--gold);
    padding: 5px 20px;
    font-weight: bold;
    border-radius: 20px;
    font-size: 0.9rem;
    border: 1px solid var(--gold);
    white-space: nowrap;
}


/* ==========================================================================
   TABLA LUXURY
   ========================================================================== */
.table-luxury {
    width: 100%;
    text-align: center;
    background: white;
    border-radius: 10px 10px 0 0;
    overflow: hidden;
}

.table-luxury thead {
    background-color: var(--navy-dark);
    color: white;
    text-transform: uppercase;
    font-size: 0.85rem;
    letter-spacing: 1px;
}

.table-luxury th {
    padding: 20px;
    font-weight: 600;
    border: none;
}

.table-luxury td {
    padding: 20px;
    border-bottom: 1px solid #f0f0f0;
    border-top: none;
}

.table-luxury tbody tr {
    transition: background-color 0.3s ease;
}

.table-luxury tbody tr:hover {
    background-color: #f8f9fa;
}

.luxury-number {
    width: 65px;
    border: 1px solid #ddd;
    padding: 6px;
    outline: none;
    font-weight: bold;
    color: var(--navy-dark);
    transition: all 0.3s ease;
    border-radius: 5px;
    background-color: #f8f9fa;
}

.luxury-number:focus {
    border-color: var(--gold);
    background-color: white;
    box-shadow: 0 0 5px rgba(212, 175, 55, 0.3);
}


/* ==========================================================================
   MODALES (RESERVAR Y PAYPAL)
   ========================================================================== */
.luxury-modal {
    border-radius: 10px;
    border: none;
    box-shadow: 0 25px 50px rgba(0, 0, 0, 0.3);
}

.resumen-card {
    background: #f8f9fa;
    border-left: 2px solid var(--gold);
    height: 100%;
    border-radius: 5px;
}

.luxury-input-group {
    position: relative;
    margin-bottom: 10px;
}

.luxury-input {
    width: 100%;
    padding: 10px 0;
    border: none;
    border-bottom: 1px solid #ddd;
    background: transparent;
    outline: none;
    transition: all 0.3s ease;
    color: var(--text-dark);
}

.luxury-input:focus {
    border-bottom: 2px solid var(--gold);
}

.luxury-input-group label {
    position: absolute;
    top: 10px;
    left: 0;
    color: #999;
    pointer-events: none;
    transition: all 0.3s ease;
}

.luxury-input:focus~label,
.luxury-input:not(:placeholder-shown)~label,
.select-luxury~label {
    top: -15px;
    font-size: 0.75rem;
    color: var(--gold);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 1px;
}

select.select-luxury {
    cursor: pointer;
    padding-top: 15px;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
}

.flatpickr-mobile {
    display: none !important;
}


/* ==========================================================================
   ANIMACIONES
   ========================================================================== */
.reveal {
    opacity: 0;
    transform: translateY(40px);
    transition: all 0.8s cubic-bezier(0.4, 0, 0.2, 1);
}

.reveal.active {
    opacity: 1;
    transform: translateY(0);
}


/* ==========================================================================
   RESPONSIVIDAD (MÓVILES Y TABLETS)
   ========================================================================== */
@media (max-width: 991px) {
    .mt-negativo {
        margin-top: -30px;
    }

    .border-end-vip {
        border-right: none;
        border-bottom: 1px solid rgba(255, 255, 255, 0.1);
    }

    .border-start-vip {
        border-left: none;
        border-top: 1px solid rgba(255, 255, 255, 0.1);
    }

    .table-luxury th,
    .table-luxury td {
        padding: 15px 10px;
        font-size: 0.9rem;
    }
}

@media (max-width: 768px) {
    .header-tarifas {
        padding-top: 150px;
        padding-bottom: 100px;
    }

    .table-luxury {
        font-size: 0.85rem;
    }

    .luxury-number {
        width: 50px;
    }
}