/* =====================================================
   ESTILOS GENERALES v3
   ===================================================== */
body { font-family: 'Segoe UI', Roboto, sans-serif; }
.navbar { box-shadow: 0 2px 8px rgba(0,0,0,0.1); }

/* Botón Acceso Agente en navbar */
.btn-acceso-agente {
    background: rgba(255, 193, 7, 0.15);
    border: 1px solid rgba(255, 193, 7, 0.5);
    border-radius: 6px;
    color: #ffc107 !important;
    padding: 6px 14px !important;
    transition: all 0.2s;
    font-weight: 600;
}
.btn-acceso-agente:hover {
    background: #ffc107;
    color: #1a1a2e !important;
    border-color: #ffc107;
}

/* Tarjeta antigua de viaje (hoteles) */
.card-viaje { transition: transform 0.2s, box-shadow 0.2s; }
.card-viaje:hover { transform: translateY(-4px); box-shadow: 0 8px 20px rgba(0,0,0,0.1); }

/* =====================================================
   GRID DE PAQUETES - FORZADO
   ===================================================== */
.paquetes-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 20px;
    margin-top: 20px;
}
@media (max-width: 991px) {
    .paquetes-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 575px) {
    .paquetes-grid { grid-template-columns: 1fr; }
}

/* =====================================================
   TARJETA DE PAQUETE ESTILO DESPEGAR
   ===================================================== */
.paquete-card {
    background: #fff;
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 2px 8px rgba(0,0,0,0.08);
    transition: transform 0.2s, box-shadow 0.2s;
    display: flex;
    flex-direction: column;
    width: 100%;
    height: 100%;
}
.paquete-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 6px 20px rgba(0,0,0,0.15);
}

.paquete-img-wrap {
    position: relative;
    width: 100%;
    height: 200px;
    overflow: hidden;
    flex-shrink: 0;
}
.paquete-img-wrap img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.paquete-img-placeholder {
    width: 100%;
    height: 100%;
    background: linear-gradient(135deg, #6a39d4, #3b1f8b);
    color: white;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 60px;
}

.paquete-duracion {
    position: absolute;
    bottom: 0;
    left: 0;
    background: rgba(20, 20, 35, 0.85);
    color: #fff;
    padding: 6px 12px;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.5px;
}

.paquete-body {
    padding: 16px;
    flex: 1;
    display: flex;
    flex-direction: column;
}

.paquete-tipo {
    color: #888;
    font-weight: 600;
    font-size: 11px;
    letter-spacing: 1px;
    text-transform: uppercase;
}

.paquete-titulo {
    color: #1a1a2e;
    font-weight: 700;
    margin: 4px 0 8px;
    font-size: 1.05rem;
    line-height: 1.3;
    min-height: 2.6em;
}

.paquete-rating {
    display: flex;
    align-items: center;
    gap: 6px;
    margin-bottom: 6px;
    min-height: 24px;
}
.puntaje-badge {
    background: #0d9488;
    color: #fff;
    padding: 2px 8px;
    border-radius: 4px;
    font-size: 12px;
    font-weight: 700;
}
.estrellas-mini { font-size: 12px; }
.star-on { color: #f5b301; }
.star-off { color: #ddd; }

.paquete-origen { font-size: 13px; color: #444; margin-bottom: 4px; }
.paquete-modalidad { font-size: 13px; color: #444; margin-bottom: 4px; }

.paquete-oferta-badge {
    display: inline-block;
    background: linear-gradient(90deg, #d946ef, #9333ea);
    color: #fbbf24;
    font-weight: 700;
    font-size: 12px;
    padding: 5px 12px;
    border-radius: 4px;
    margin: 6px 0;
}

.paquete-ahorro {
    background: #ecfdf5;
    color: #047857;
    border-left: 3px solid #10b981;
    padding: 6px 10px;
    border-radius: 4px;
    font-size: 13px;
    font-weight: 600;
    margin: 8px 0;
}

.paquete-precio-bloque {
    border-top: 1px solid #eee;
    padding-top: 10px;
    margin-top: auto;
}
.precio-anterior {
    color: #888;
    text-decoration: line-through;
    font-size: 13px;
}
.precio-actual {
    color: #1a1a2e;
    font-size: 1.5rem;
    font-weight: 800;
    line-height: 1.1;
}

/* =====================================================
   GRID DE HOTELES
   ===================================================== */
.hoteles-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
    margin-top: 20px;
}
@media (max-width: 991px) {
    .hoteles-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 575px) {
    .hoteles-grid { grid-template-columns: 1fr; }
}

/* =====================================================
   HERO Y SLIDER
   ===================================================== */
.hero {
    background: linear-gradient(135deg, #3b1f8b 0%, #6a39d4 100%);
    color: white;
    padding: 60px 0;
}
.estrellas { color: #f5b301; }
.footer { background: #1a1a2e; color: #ccc; padding: 30px 0; }

/* =====================================================
   GRID DE ACTIVIDADES
   ===================================================== */
.actividades-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 20px;
    margin-top: 20px;
}
@media (max-width: 991px) {
    .actividades-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 575px) {
    .actividades-grid { grid-template-columns: 1fr; }
}

/* TARJETA DE ACTIVIDAD */
.actividad-card {
    background: #fff;
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 2px 8px rgba(0,0,0,0.08);
    transition: transform 0.2s, box-shadow 0.2s;
    display: flex;
    flex-direction: column;
    width: 100%;
    height: 100%;
}
.actividad-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 6px 20px rgba(0,0,0,0.15);
}

.actividad-img-wrap {
    position: relative;
    width: 100%;
    height: 200px;
    overflow: hidden;
    flex-shrink: 0;
}
.actividad-img-wrap img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.actividad-img-placeholder {
    width: 100%;
    height: 100%;
    background: linear-gradient(135deg, #06b6d4, #0d9488);
    color: white;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 60px;
}

.actividad-descuento {
    position: absolute;
    bottom: -12px;
    right: 15px;
    background: #0d9488;
    color: #fff;
    padding: 6px 14px;
    border-radius: 20px;
    font-size: 13px;
    font-weight: 800;
    box-shadow: 0 2px 6px rgba(0,0,0,0.2);
}

.actividad-body {
    padding: 16px;
    flex: 1;
    display: flex;
    flex-direction: column;
}

.actividad-tipo {
    color: #888;
    font-weight: 600;
    font-size: 11px;
    letter-spacing: 1px;
    text-transform: uppercase;
}

.actividad-titulo {
    color: #1a1a2e;
    font-weight: 700;
    margin: 4px 0 8px;
    font-size: 1.05rem;
    line-height: 1.3;
    min-height: 2.6em;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.actividad-rating {
    display: flex;
    align-items: center;
    gap: 4px;
    margin-bottom: 6px;
    flex-wrap: wrap;
    font-size: 13px;
}

.actividad-ubicacion { font-size: 13px; color: #444; }

.badge-cancelacion {
    display: inline-block;
    background: #e5e7eb;
    color: #374151;
    padding: 3px 10px;
    border-radius: 4px;
    font-size: 12px;
    font-weight: 600;
    margin: 4px 0;
}

.actividad-oferta-badge {
    display: inline-block;
    background: linear-gradient(90deg, #d946ef, #9333ea);
    color: #fbbf24;
    font-weight: 700;
    font-size: 12px;
    padding: 5px 12px;
    border-radius: 4px;
    margin: 6px 0;
}

.actividad-precio-bloque {
    border-top: 1px solid #eee;
    padding-top: 10px;
    margin-top: auto;
}

@media (max-width: 576px) {
    .actividad-titulo { font-size: 1rem; min-height: auto; }
    .actividad-img-wrap { height: 180px; }
}

@media (max-width: 576px) {
    .paquete-titulo { font-size: 1rem; min-height: auto; }
    .precio-actual { font-size: 1.3rem; }
    .paquete-img-wrap { height: 180px; }
}

/* =====================================================
   SEGUROS DE VIAJE
   ===================================================== */
.seguros-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 20px;
    margin-top: 20px;
}
@media (max-width: 1199px) {
    .seguros-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 575px) {
    .seguros-grid { grid-template-columns: 1fr; }
}

.seguro-card {
    position: relative;
    background: #fff;
    border: 2px solid transparent;
    border-radius: 12px;
    padding: 20px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.06);
    transition: all 0.2s;
    display: flex;
    flex-direction: column;
}
.seguro-card:hover {
    box-shadow: 0 6px 20px rgba(0,0,0,0.12);
}
.seguro-card.mas-vendida {
    border-color: #0d9488;
    box-shadow: 0 4px 16px rgba(13, 148, 136, 0.15);
}

.badge-mas-vendida {
    position: absolute;
    top: -12px;
    left: 50%;
    transform: translateX(-50%);
    background: #0d9488;
    color: #fff;
    padding: 4px 14px;
    border-radius: 20px;
    font-size: 12px;
    font-weight: 700;
    white-space: nowrap;
}

.seguro-header {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 16px;
}
.seguro-logo {
    width: 60px;
    height: 60px;
    object-fit: contain;
    border-radius: 8px;
    background: #f8f9fa;
    padding: 4px;
}
.seguro-nombre {
    font-weight: 700;
    color: #1a1a2e;
    font-size: 0.95rem;
    line-height: 1.3;
}

.seguro-coberturas {
    list-style: none;
    padding: 0;
    margin: 0 0 16px 0;
    flex: 1;
}
.seguro-coberturas li {
    color: #047857;
    font-size: 13px;
    line-height: 1.6;
    margin-bottom: 4px;
}
.seguro-coberturas li i {
    color: #10b981;
    font-weight: 700;
}

.seguro-links {
    margin-bottom: 12px;
    padding-bottom: 12px;
    border-bottom: 1px solid #eee;
}
.link-condiciones {
    color: #6a39d4;
    text-decoration: none;
    font-size: 13px;
    font-weight: 600;
}
.link-condiciones:hover { text-decoration: underline; }

.seguro-precio-bloque {
    margin-bottom: 12px;
}
.seguro-precio {
    color: #1a1a2e;
    font-size: 1.5rem;
    font-weight: 800;
    line-height: 1.1;
}

.seguro-acciones .btn-comprar {
    background: #6a39d4;
    border-color: #6a39d4;
    font-weight: 600;
}
.seguro-acciones .btn-comprar:hover {
    background: #5829c1;
    border-color: #5829c1;
}

.seguro-comparar {
    display: flex;
    align-items: center;
    gap: 6px;
    justify-content: center;
    font-size: 13px;
    color: #6a39d4;
    cursor: pointer;
}
.seguro-comparar input { cursor: pointer; }

/* Barra flotante de comparación */
.barra-comparar {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    background: #1a1a2e;
    color: #fff;
    padding: 14px 0;
    box-shadow: 0 -4px 12px rgba(0,0,0,0.2);
    z-index: 1000;
}
