/* --- ESTILOS PÁGINA HABITACIONES (CATÁLOGO) --- */

.rooms-page-bg {
    background-color: #0d1015; /* Fondo oscuro principal */
    color: #e2e8f0;
    padding-bottom: 100px;
}

/* 1. HERO HEADER */
.page-hero {
    position: relative;
    height: 60vh;
    min-height: 400px;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    margin-top: -90px; /* Para meterse detrás del header fixed */
    padding-top: 90px;
}
.page-hero-bg {
    position: absolute; inset: 0;
    background-size: cover; background-position: center;
    z-index: 0;
}
.page-hero-overlay {
    position: absolute; inset: 0;
    background: linear-gradient(to bottom, rgba(13,16,21,0.3), #0d1015);
    z-index: 1;
}
.page-hero-content { position: relative; z-index: 2; }

.page-title {
    font-family: 'Montserrat', sans-serif;
    font-size: clamp(2.5rem, 5vw, 4rem);
    color: #fff; margin-bottom: 1rem;
    text-shadow: 0 4px 10px rgba(0,0,0,0.5);
}
.page-subtitle {
    font-size: 1.2rem; color: var(--color-gold); text-transform: uppercase; letter-spacing: 2px;
}

/* 2. STICKY NAV */
.rooms-nav-sticky {
    position: sticky;
    top: 58px; /* Altura del header principal */
    z-index: 9000;
    background: rgba(13, 16, 21, 0.98);
    backdrop-filter: blur(10px);
    border-bottom: 1.5px solid var(--color-gold); 
    padding: 15px 0;
    margin-bottom: 50px;
}
.rooms-nav-sticky ul {
    display: flex; justify-content: center; gap: 30px;
    list-style: none; margin: 0; padding: 0;
    white-space: nowrap;
}
.rooms-nav-sticky a {
    color: #888; text-decoration: none; text-transform: uppercase;
    font-size: 1.2rem; font-weight: 600; letter-spacing: 1px;
    transition: color 0.3s;
}
/* 1. Al pasar el mouse (Solo color) */
.rooms-nav-sticky a:hover {
    color: var(--color-gold);
}

/* 2. Cuando está Activo (Color + Línea debajo) */
.rooms-nav-sticky a.active {
    color: var(--color-gold);
    border-bottom: 2px solid var(--color-gold); /* La línea dorada */
    padding-bottom: 5px; /* Espacio entre texto y línea */
}

/* Layout General */
.main-catalog-container { max-width: 1200px; }
.catalog-section { padding: 60px 0; scroll-margin-top: 140px; } /* Ajuste scroll */
.section-divider { border: 0; height: 1px; background: rgba(255,255,255,0.1); margin: 0; }

.cat-header { text-align: center; margin-bottom: 3rem; }
.cat-label { color: var(--color-gold); font-size: 0.8rem; letter-spacing: 2px; text-transform: uppercase; display: block; margin-bottom: 10px; }
.cat-title { font-family: 'Montserrat', sans-serif; font-size: 2.5rem; color: #fff; margin-bottom: 1rem; }
.cat-desc { color: #a0aec0; max-width: 600px; margin: 0 auto; line-height: 1.6; }

/* --- CARD: FULL WIDTH (Presidencial) --- */
.room-card-full {
    background: #151922; border-radius: 20px; overflow: hidden;
    display: grid; grid-template-columns: 1.2fr 1fr;
    margin-bottom: 2rem; border: 1px solid rgba(255,255,255,0.05);
}
.card-img { background-size: cover; background-position: center; min-height: 300px; position: relative; }
.badge-lujo {
    position: absolute; top: 20px; left: 20px;
    background: var(--color-gold); color: #000;
    padding: 5px 12px; border-radius: 4px; font-weight: 700; font-size: 0.7rem; text-transform: uppercase;
}
.card-info { padding: 40px; display: flex; flex-direction: column; justify-content: center; }
.card-info h3 { font-family: 'Montserrat', sans-serif; font-size: 1.5rem; color: #fff; margin-bottom: 15px; }
.card-info p { color: #999; margin-bottom: 20px; }
.specs { display: flex; gap: 20px; list-style: none; padding: 0; margin-bottom: 20px; color: #ccc; font-size: 0.9rem; }
.specs .icon { margin-right: 5px; font-style: normal; }

/* --- CARD: GRID (Suites) --- */
.grid-2-cols { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.grid-3-cols { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 15px; }

.room-card {
    background: #151922; border-radius: 12px; overflow: hidden;
    border: 1px solid rgba(255,255,255,0.05);
}
.card-img-top { height: 200px; background-size: cover; background-position: center; }
.card-body { padding: 20px; }
.card-body h4 { color: #fff; font-size: 1.1rem; margin-bottom: 10px; font-family: 'Montserrat', sans-serif; }
.mini-specs { color: var(--color-gold); font-size: 0.8rem; margin-bottom: 15px; font-weight: 600; }
.room-desc { color: #888; font-size: 0.9rem; margin-bottom: 20px; }
.card-header-flex { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 10px; }
.bed-badge { background: rgba(255,255,255,0.1); padding: 2px 8px; border-radius: 4px; font-size: 0.7rem; color: #ccc; }

/* --- BOTONES --- */
.btn-gold-solid {
    display: inline-block; background: var(--color-gold); color: #000;
    padding: 10px 25px; border-radius: 50px; font-weight: 700; text-decoration: none; text-transform: uppercase; font-size: 0.8rem;
    transition: all 0.3s;
}
.btn-gold-solid:hover { background: #fff; transform: translateY(-2px); }

.btn-gold-outline {
    display: block; text-align: center; border: 1px solid var(--color-gold); color: var(--color-gold);
    padding: 8px; border-radius: 6px; text-decoration: none; font-size: 0.8rem; font-weight: 600; text-transform: uppercase;
    transition: all 0.3s;
}
.btn-gold-outline:hover { background: var(--color-gold); color: #000; }

/* --- LISTA COMPACTA (Contemporánea/Tradicional) --- */
.sub-cat-title { color: #fff; margin-top: 30px; margin-bottom: 20px; font-family: 'Montserrat', sans-serif; border-left: 3px solid var(--color-gold); padding-left: 15px; }
.room-item {
    background: rgba(255,255,255,0.03); padding: 20px; border-radius: 8px;
    border: 1px solid rgba(255,255,255,0.05); display: flex; flex-direction: column; gap: 10px;
}
.room-item h5 { color: #e2e8f0; margin: 0; font-size: 1rem; }
.room-item .meta { color: #666; font-size: 0.85rem; }
.btn-book-sm { 
    margin-top: auto; color: var(--color-gold); font-size: 0.75rem; text-transform: uppercase; 
    font-weight: 700; text-decoration: none; border: 1px solid rgba(212,175,55,0.3); 
    padding: 5px 10px; text-align: center; border-radius: 4px; transition: all 0.3s;
}
.btn-book-sm:hover { background: var(--color-gold); color: #000; }

.room-item.highlight { border-color: rgba(212,175,55,0.3); background: rgba(212,175,55,0.05); }

/* --- TRADICIONAL LIST --- */
.traditional-list-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); gap: 2rem; }
.trad-col h4 { color: var(--color-gold); border-bottom: 1px solid rgba(255,255,255,0.1); padding-bottom: 10px; margin-bottom: 15px; }
.trad-col .specs { font-size: 0.7rem; color: #888; font-weight: normal; margin-left: 5px; }
.trad-col ul { list-style: none; padding: 0; }
.trad-col li { 
    display: flex; justify-content: space-between; align-items: center; 
    padding: 10px 0; border-bottom: 1px solid rgba(255,255,255,0.03); color: #ccc; font-size: 0.9rem;
}
.trad-col li a { color: #666; font-size: 0.7rem; text-transform: uppercase; text-decoration: none; border: 1px solid #444; padding: 2px 8px; border-radius: 4px; transition: all 0.3s; }
.trad-col li a:hover { border-color: var(--color-gold); color: var(--color-gold); }

/* RESPONSIVE */
@media (max-width: 768px) {
    .page-hero {
        margin-top: 0; /* Reset del margin negativo en móvil */
        padding-top: 80px; /* Espacio para header móvil */
        height: auto;
        min-height: 50vh;
    }
    .rooms-nav-sticky { top: 60px; overflow-x: auto; }
    .rooms-nav-sticky ul { padding: 0 15px; justify-content: flex-start; gap: 10px; }
    .room-card-full { grid-template-columns: 1fr; }
    .grid-2-cols { grid-template-columns: 1fr; }
    .card-img { min-height: 200px; }
}

/* --- CONTADOR DE HABITACIONES (1/4) --- */
.room-count-badge {
    position: absolute;
    bottom: 15px;
    right: 15px;
    z-index: 5;
    background: rgba(0, 0, 0, 0.7);
    backdrop-filter: blur(4px);
    color: #fff;
    font-family: 'Montserrat', sans-serif;
    font-size: 0.7rem;
    font-weight: 600;
    letter-spacing: 1px;
    padding: 4px 12px;
    border-radius: 20px;
    border: 1px solid rgba(212, 175, 55, 0.3);
    pointer-events: none; /* Para que no interfiera con el click de la tarjeta */
}

.room-count-badge span {
    color: var(--color-gold);
}

/* --- ESTILOS DEL MODAL (Copiado para Páginas Internas) --- */
.modal-overlay {
    position: fixed; top: 0; left: 0; width: 100%; height: 100%;
    background: rgba(0,0,0,0.9); /* Un poco más oscuro aquí */
    backdrop-filter: blur(5px);
    z-index: 10000;
    display: flex; justify-content: center; align-items: center;
    opacity: 0; visibility: hidden;
    transition: all 0.3s ease;
    padding: 20px;
}

.modal-overlay.active { opacity: 1; visibility: visible; }

.modal-container {
    background: #1a1f2c;
    width: 100%; max-width: 1000px; /* Un poco más ancho */
    border-radius: 12px;
    overflow: hidden;
    position: relative;
    border: 1px solid rgba(212, 175, 55, 0.3);
    display: flex; flex-direction: column;
    max-height: 90vh;
}

.modal-close {
    position: absolute; top: 15px; right: 15px;
    background: rgba(0,0,0,0.5); color: #fff;
    border: none; width: 35px; height: 35px; border-radius: 50%;
    font-size: 1.5rem; cursor: pointer; z-index: 20;
    display: flex; align-items: center; justify-content: center;
    transition: background 0.3s;
}
.modal-close:hover { background: var(--color-gold); color: #000; }

/* Estructura Interna */
.modal-content-grid {
    display: grid;
    /* CAMBIO CLAVE: 38% Imagen - 62% Información */
    grid-template-columns: 38% 1fr; 
    height: 100%;
    overflow: hidden;
}

/* --- COLUMNA IZQUIERDA (FOTO + SERVICIOS) --- */
.modal-gallery {
    position: relative;
    background: #0d1015; /* Fondo negro elegante */
    height: 100%;
    
    /* Flex vertical para apilar Foto y Servicios */
    display: flex;
    flex-direction: column;
}

.modal-main-img {
    width: 100%;
    /* La foto ocupa el 55% de la altura disponible */
    height: 55%; 
    background-size: cover; /* Volvemos a cover para que llene bien su mitad */
    background-position: center;
    background-repeat: no-repeat;
    transition: background-image 0.4s;
    
    /* Sombra interna para separar de los servicios */
    box-shadow: 0 10px 30px rgba(0,0,0,0.5);
    z-index: 1;
}

/* --- NUEVA ZONA DE SERVICIOS (Espacio Negro) --- */
.modal-bottom-services {
    /* Ocupa el resto del espacio (45%) */
    flex-grow: 1; 
    padding: 25px;
    overflow-y: auto; /* Scroll si hay muchos servicios */
    border-top: 1px solid rgba(212, 175, 55, 0.2); /* Línea dorada sutil */
}

.services-heading {
    color: var(--color-gold);
    font-family: 'Montserrat', sans-serif;
    font-size: 0.8rem;
    text-transform: uppercase;
    letter-spacing: 2px;
    margin-bottom: 15px;
    font-weight: 700;
}

/* Grid de Iconos */
.services-icon-grid {
    list-style: none;
    padding: 0;
    display: grid;
    /* 2 columnas */
    grid-template-columns: 1fr 1fr; 
    gap: 15px;
}

.services-icon-grid li {
    color: #e2e8f0;
    font-size: 0.85rem;
    display: flex;
    align-items: center;
    gap: 10px;
}

/* Círculo dorado para el icono */
.services-icon-grid li .s-icon {
    width: 24px;
    height: 24px;
    
    /* CAMBIO: Fondo Dorado Sólido para máxima visibilidad */
    background: var(--color-gold); 
    
    /* CAMBIO: Icono (Check) en Negro para contraste fuerte */
    color: #000; 
    
    border-radius: 50%;
    display: flex;
    justify-content: center;
    align-items: center;
    
    /* Un poco más grande y grueso */
    font-size: 0.85rem; 
    font-weight: 800;
    
    flex-shrink: 0;
    box-shadow: 0 2px 8px rgba(0,0,0,0.3); /* Sombra para que flote */
}

/* Responsive Móvil */
@media (max-width: 900px) {
    .modal-gallery {
        height: auto; /* Altura automática */
    }
    .modal-main-img {
        height: 250px; /* Altura fija en móvil */
    }
}

/* Ocultamos miniaturas por si quedó algo residual */
.modal-thumbnails { display: none; }

/* Responsive: En móvil la imagen va arriba pero pequeña */
@media (max-width: 900px) {
    .modal-content-grid {
        grid-template-columns: 1fr; /* Una sola columna */
        grid-template-rows: 250px 1fr; /* Imagen fija arriba */
        overflow-y: auto;
    }
}

/* --- ESTILOS DEL SLIDER EN TARJETA --- */

.card-slider-box {
    position: relative;
    width: 100%;
    height: 100%;
    min-height: 350px; /* Altura mínima para que se vea bien */
    overflow: hidden;
    background: #000; /* Fondo por si tarda en cargar */
}

/* Contenedor de imágenes */
.card-slides-container {
    width: 100%;
    height: 100%;
    position: relative;
}

/* Las imágenes individuales */
.card-slide {
    position: absolute;
    top: 0; left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover; /* Recorta la imagen para llenar el espacio sin deformar */
    opacity: 0;
    transition: opacity 0.5s ease-in-out;
    z-index: 1;
}

.card-slide.active {
    opacity: 1;
    z-index: 2;
}

/* Flechas de Navegación */
.slider-arrow {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    background: rgba(0, 0, 0, 0.6);
    color: #fff;
    border: 1px solid rgba(255, 255, 255, 0.3);
    width: 35px;
    height: 35px;
    border-radius: 50%;
    cursor: pointer;
    z-index: 10;
    font-size: 14px;
    display: flex;
    justify-content: center;
    align-items: center;
    transition: all 0.3s ease;
    opacity: 1; /* SIEMPRE VISIBLES */
}

.slider-arrow:hover {
    background: var(--color-gold);
    color: #000;
    border-color: var(--color-gold);
}

.slider-arrow.prev { left: 10px; }
.slider-arrow.next { right: 10px; }

/* Ajuste del contador para que esté encima de las fotos */
.room-count-badge {
    z-index: 5;
}
.badge-lujo {
    z-index: 5;
}

/* 1. Quitar cursor pointer de la tarjeta general */
.room-card-full, .room-card, .room-item {
    cursor: default; /* Ya no parece clicable todo el bloque */
}

/* 2. Contenedor de Botones (Lado a lado) */
.card-actions {
    display: flex;
    gap: 15px; /* Espacio entre botones */
    margin-top: auto;
    width: 100%;
    
    /* Opcional: Esto evita que los botones sean ETERNAMENTE largos en pantallas grandes */
    max-width: 500px; 
}

/* Aplicamos estilos base IGUALES a ambos botones */
.card-actions .btn-gold-solid,
.card-actions .btn-gold-outline {
    /* LA CLAVE: flex: 1 hace que ambos se repartan el espacio 50/50 */
    flex: 1; 
    
    /* Centrado del texto */
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;
    
    /* Dimensiones equilibradas */
    padding: 12px 10px; /* Padding cómodo pero no exagerado */
    height: 45px; /* Altura fija para uniformidad */
    
    /* Estilos de Borde y Fuente */
    border-radius: 50px;
    font-weight: 700;
    font-size: 0.75rem; /* Letra nítida y elegante */
    text-transform: uppercase;
    text-decoration: none;
    letter-spacing: 0.5px;
    cursor: pointer;
    transition: all 0.3s ease;
    
    /* Aseguramos que no se rompan */
    white-space: nowrap;
    box-sizing: border-box;
}

/* Estilos específicos: Sólido (Detalles) */
.card-actions .btn-gold-solid {
    background: var(--color-gold);
    color: #000;
    border: 1px solid var(--color-gold); /* Borde invisible para igualar tamaños */
}
.card-actions .btn-gold-solid:hover {
    background: #fff;
    border-color: #fff;
    transform: translateY(-2px);
    box-shadow: 0 5px 15px rgba(0,0,0,0.2);
}

/* Estilos específicos: Borde (Reservar) */
.card-actions .btn-gold-outline {
    background: transparent;
    border: 1px solid var(--color-gold);
    color: var(--color-gold);
}
.card-actions .btn-gold-outline:hover {
    background: var(--color-gold);
    color: #000;
    transform: translateY(-2px);
    box-shadow: 0 5px 15px rgba(212, 175, 55, 0.2);
}

/* Responsive Móvil */
@media (max-width: 550px) {
    .card-actions {
        flex-direction: column; /* Uno abajo del otro en celular */
        gap: 10px;
        max-width: 100%;
    }
    .card-actions .btn-gold-solid,
    .card-actions .btn-gold-outline {
        width: 100%; /* Ancho total en móvil */
    }
}



/* --- INFO DEL MODAL (Mejorada) --- */
.modal-info { 
    padding: 40px; 
    overflow-y: auto; 
    background: #1a1f2c; /* Aseguramos fondo oscuro */
    color: #fff; 
}

/* Título de la Habitación */
.modal-info h2 { 
    font-family: 'Montserrat', sans-serif; 
    font-size: 1.8rem; 
    margin-bottom: 10px; 
    color: #fff; /* Blanco brillante */
    line-height: 1.2;
}

/* Descripción */
.modal-description { 
    color: #a0aec0; /* Gris claro legible */
    line-height: 1.6; 
    margin-bottom: 30px; 
    font-size: 0.95rem; 
    border-bottom: 1px solid rgba(255,255,255,0.1);
    padding-bottom: 20px;
}

/* Título de Sección (Detalles) */
.specs-title { 
    color: var(--color-gold); 
    font-size: 0.85rem; 
    text-transform: uppercase; 
    letter-spacing: 2px; 
    margin-bottom: 15px; 
    font-weight: 700;
    display: block; /* Asegura que ocupe línea propia */
}

/* GRID DE 2 COLUMNAS PARA LOS DETALLES */
.modal-specs-list { 
    list-style: none; 
    padding: 0; 
    margin-bottom: 30px; 
    
    /* La magia: 2 columnas automáticas */
    display: grid; 
    grid-template-columns: 1fr 1fr; 
    gap: 15px 30px; /* Espacio vertical y horizontal */
}

.modal-specs-list li { 
    font-size: 0.9rem; 
    color: #e2e8f0; /* Blanco suave */
    display: flex; 
    align-items: center; 
    gap: 10px; 
}

/* Icono del detalle (la estrella o rombo) */
.modal-specs-list li i { 
    color: var(--color-gold); 
    font-style: normal;
    font-size: 1.2rem; /* Un poco más grande */
}

/* Botón Reservar (Centrado y Grande) */
.modal-footer-btn { 
    /* 1. TAMAÑO: Que se ajuste al texto, no al 100% */
    width: fit-content; /* O usa 'auto' si el navegador es muy viejo */
    min-width: 200px;   /* Un tamaño mínimo para que no se vea ridículo */
    
    /* 2. CENTRADO */
    display: block;
    margin: 30px auto 0 auto; /* 'auto' a los lados lo centra */
    
    /* 3. ESTÉTICA */
    padding: 12px 40px; /* Más aire a los lados */
    font-size: 0.9rem;
    
    box-shadow: 0 5px 20px rgba(212, 175, 55, 0.2);
    text-align: center;
}

/* Efecto Hover (Mantener igual) */
.modal-footer-btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 10px 30px rgba(212, 175, 55, 0.4);
}

/* Responsive Móvil */
@media (max-width: 600px) {
    .modal-specs-list { 
        grid-template-columns: 1fr; /* Una columna en celular */
    }
}

/* --- TARJETA VERTICAL (Para Grid de 2 Columnas) --- */
.room-card-vertical {
    background: #151922;
    border-radius: 20px;
    overflow: hidden;
    border: 1px solid rgba(255,255,255,0.05);
    display: flex;
    flex-direction: column; /* Esto hace que la foto vaya arriba y texto abajo */
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.room-card-vertical:hover {
    transform: translateY(-5px);
    box-shadow: 0 10px 30px rgba(0,0,0,0.3);
    border-color: rgba(212, 175, 55, 0.3);
}

/* Ajuste del Slider para tarjeta vertical */
.room-card-vertical .card-slider-box {
    width: 100%;
    height: 280px; /* Altura fija para la imagen */
    min-height: auto; /* Sobrescribe el min-height anterior */
}

/* Ajuste del contenido */
.room-card-vertical .card-info {
    padding: 25px;
    flex-grow: 1; /* Ocupa el resto del espacio */
    display: flex;
    flex-direction: column;
}

.room-card-vertical h3 {
    font-size: 1.3rem; /* Título un poco más pequeño para que quepa */
}

/* Botones en tarjeta vertical */
.room-card-vertical .card-actions .btn-gold-solid,
.room-card-vertical .card-actions .btn-gold-outline {
    padding: 10px 15px; /* Un poco menos de padding lateral */
    font-size: 0.7rem;
}

/* --- TARJETAS COMPACTAS (Para Grids de 3 o más) --- */

/* El Grid de 3 columnas */
.grid-3-cols {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); /* Se adapta a pantallas */
    gap: 25px;
    margin-bottom: 40px;
}

/* La Tarjeta Compacta */
.room-card-compact {
    background: #151922;
    border-radius: 16px;
    overflow: hidden;
    border: 1px solid rgba(255,255,255,0.05);
    display: flex;
    flex-direction: column;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.room-card-compact:hover {
    transform: translateY(-5px);
    box-shadow: 0 8px 25px rgba(0,0,0,0.3);
    border-color: rgba(212, 175, 55, 0.2);
}

/* Slider más bajito */
.room-card-compact .card-slider-box {
    width: 100%;
    height: 220px; /* Altura reducida para compactar */
}

/* Info compacta */
.room-card-compact .card-info {
    padding: 20px;
    flex-grow: 1;
    display: flex;
    flex-direction: column;
}

.room-card-compact h3 {
    font-size: 1.1rem; /* Título más pequeño */
    margin-bottom: 5px;
    min-height: 50px; /* Para alinear tarjetas si los títulos varían de largo */
}

.room-card-compact .specs {
    margin-bottom: 15px;
    font-size: 0.75rem; /* Texto técnico más fino */
}

/* Ajuste de botones para espacio reducido */
.room-card-compact .card-actions {
    gap: 10px;
}
.room-card-compact .btn-gold-solid,
.room-card-compact .btn-gold-outline {
    padding: 8px 15px;
    font-size: 0.65rem;
}

/* Subtítulos de Secciones (Individuales, Matrimoniales...) */
.sub-cat-title {
    color: #fff;
    font-family: 'Montserrat', sans-serif;
    font-size: 1.5rem;
    margin-top: 40px;
    margin-bottom: 20px;
    padding-left: 15px;
    border-left: 4px solid var(--color-gold);
    text-transform: uppercase;
    letter-spacing: 1px;
}

/* Responsive */
@media (max-width: 900px) {
    .grid-3-cols { grid-template-columns: 1fr 1fr; } /* 2 en tablet */
}
@media (max-width: 600px) {
    .grid-3-cols { grid-template-columns: 1fr; } /* 1 en móvil */
}



/* --- ESTILOS CATEGORÍA TRADICIONAL (Tipo Menú) --- */

.traditional-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: 30px;
    margin-top: 40px;
}

/* Tarjeta Contenedora */
.trad-card {
    background: #151922;
    border: 1px solid rgba(255, 255, 255, 0.05);
    border-radius: 16px;
    overflow: hidden;
    transition: transform 0.3s ease, border-color 0.3s ease;
}

.trad-card:hover {
    transform: translateY(-5px);
    border-color: rgba(212, 175, 55, 0.3);
    box-shadow: 0 10px 30px rgba(0,0,0,0.2);
}

/* Encabezado de la Tarjeta */
.trad-header {
    padding: 25px;
    background: rgba(255, 255, 255, 0.02);
    border-bottom: 1px solid rgba(255, 255, 255, 0.05);
    display: flex;
    align-items: center;
    gap: 15px;
}

.trad-header .icon-box {
    width: 45px; height: 45px;
    background: rgba(212, 175, 55, 0.1);
    border-radius: 50%;
    display: flex; justify-content: center; align-items: center;
    font-size: 1.2rem;
}

.trad-header h3 {
    margin: 0;
    font-family: 'Montserrat', sans-serif;
    font-size: 1.2rem;
    color: #fff;
}

.trad-meta {
    font-size: 0.8rem;
    color: var(--color-gold);
    text-transform: uppercase;
    letter-spacing: 1px;
    font-weight: 600;
}

/* Cuerpo de la Lista */
.trad-body {
    padding: 10px 25px 25px 25px;
}

.trad-options {
    list-style: none;
    padding: 0;
    margin: 0;
}

.trad-options li {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 15px 0;
    border-bottom: 1px solid rgba(255, 255, 255, 0.05);
}

.trad-options li:last-child {
    border-bottom: none;
}

.opt-name {
    color: #cbd5e0;
    font-size: 0.9rem;
}

/* Botón Pequeño de Reserva */
.btn-trad-book {
    display: inline-block;
    padding: 6px 15px;
    border: 1px solid rgba(212, 175, 55, 0.4);
    color: var(--color-gold);
    border-radius: 4px;
    font-size: 0.7rem;
    text-transform: uppercase;
    text-decoration: none;
    font-weight: 700;
    letter-spacing: 0.5px;
    transition: all 0.3s ease;
}

.btn-trad-book:hover {
    background: var(--color-gold);
    color: #000;
    box-shadow: 0 0 10px rgba(212, 175, 55, 0.3);
}

/* Responsive */
@media (max-width: 600px) {
    .traditional-grid { grid-template-columns: 1fr; }
}

/* --- ESTILOS CATEGORÍA TRADICIONAL (VISUAL) --- */

.traditional-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: 30px;
    margin-top: 40px;
}

/* Encabezado de Columna */
.trad-header-box {
    display: flex;
    align-items: center;
    gap: 15px;
    margin-bottom: 20px;
    padding-bottom: 10px;
    border-bottom: 2px solid var(--color-gold);
}
.trad-header-box .icon { font-size: 1.5rem; }
.trad-header-box h3 {
    margin: 0;
    font-size: 1.1rem;
    color: #fff;
    font-family: 'Montserrat', sans-serif;
    line-height: 1.2;
}
.trad-header-box h3 span {
    font-size: 0.8rem;
    color: #999;
    font-weight: 400;
}

/* Lista de Tarjetas */
.trad-items-list {
    display: flex;
    flex-direction: column;
    gap: 15px;
}

/* Mini Tarjeta */
.trad-mini-card {
    background: #1a1f2c;
    border-radius: 12px;
    overflow: hidden;
    border: 1px solid rgba(255,255,255,0.05);
    display: flex; /* Foto a la izquierda, texto a la derecha */
    align-items: center;
    transition: all 0.3s ease;
    cursor: pointer;
    padding: 10px;
    gap: 15px;
}

.trad-mini-card:hover {
    transform: translateX(5px);
    border-color: rgba(212, 175, 55, 0.3);
    background: #202533;
}

/* Imagen Pequeña */
.trad-img-box {
    width: 100px;
    height: 80px;
    border-radius: 8px;
    overflow: hidden;
    flex-shrink: 0;
}
.trad-img-box img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* Información */
.trad-info {
    flex-grow: 1;
}
.trad-info h4 {
    margin: 0 0 10px 0;
    font-size: 0.95rem;
    color: #e2e8f0;
    font-weight: 600;
}

/* Botones Pequeños */
.trad-actions {
    display: flex;
    gap: 8px;
}

.btn-trad-det {
    background: rgba(255,255,255,0.1);
    color: #fff;
    border: none;
    padding: 5px 10px;
    border-radius: 4px;
    font-size: 0.65rem;
    text-transform: uppercase;
    cursor: pointer;
    transition: background 0.3s;
}
.btn-trad-det:hover { background: rgba(255,255,255,0.2); }

.btn-trad-res {
    background: var(--color-gold);
    color: #000;
    text-decoration: none;
    padding: 5px 10px;
    border-radius: 4px;
    font-size: 0.65rem;
    text-transform: uppercase;
    font-weight: 700;
    transition: background 0.3s;
}
.btn-trad-res:hover { background: #fff; }


/* --- LISTA DE DETALLES EN TARJETA --- */
.specs-preview-box {
    margin: 15px 0 25px;
    padding-top: 15px;
    border-top: 1px solid rgba(255,255,255,0.05);
}

.specs-label {
    display: block;
    color: var(--color-gold);
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 1px;
    margin-bottom: 10px;
    font-weight: 700;
}

/* --- LISTA DE DETALLES EN TARJETA (CORREGIDA) --- */
.specs-list-visual {
    /* Quitar viñetas por defecto */
    list-style: none; 
    padding: 0;
    margin: 15px 0; /* Un poco de aire arriba y abajo */
    
    /* GRID DE 2 COLUMNAS */
    display: grid;
    grid-template-columns: repeat(2, 1fr); /* 50% - 50% */
    gap: 8px 10px; /* Espacio entre filas y columnas */
    
    width: 100%;
}

.specs-list-visual li {
    font-size: 0.8rem; /* Letra un poco más chica para que quepa bien */
    color: #cbd5e0;
    display: flex;
    align-items: flex-start; 
    gap: 6px;
    line-height: 1.3;
}

/* La Estrella Dorada */
.specs-list-visual li i {
    color: var(--color-gold);
    font-style: normal;
    font-size: 0.9rem;
    line-height: 1.3;
    flex-shrink: 0; /* Que no se aplaste */
}

/* En móviles, si el texto es muy largo, quizás 1 columna sea mejor */
@media (max-width: 400px) {
    .specs-list-visual {
        grid-template-columns: 1fr;
    }
}

/* --- BADGE DE CATEGORÍA (ESTILO LUJO PREMIUM) --- */
.modal-badge {
    position: absolute;
    top: 30px; /* Un poco más abajo del borde superior */
    right: 0;  /* Pegado al borde derecho */
    z-index: 10;
    
    /* Fondo: Degradado Dorado Metálico */
    background: linear-gradient(135deg, #f6e6b4 0%, #d4af37 50%, #997b2f 100%);
    
    /* Tipografía */
    color: #0b0e14; /* Texto oscuro para máximo contraste y elegancia */
    font-family: 'Montserrat', sans-serif;
    font-size: 0.75rem;
    font-weight: 800; /* Extra bold */
    text-transform: uppercase;
    letter-spacing: 2px; /* Espaciado amplio */
    
    /* Forma: Redondeada a la izquierda, recta a la derecha */
    padding: 10px 30px 10px 20px;
    border-radius: 50px 0 0 50px;
    
    /* Efectos de Profundidad */
    box-shadow: -8px 8px 20px rgba(0,0,0,0.5); /* Sombra difusa */
    
    /* Detalles finos de luz y sombra en los bordes */
    border-top: 1px solid rgba(255,255,255,0.5); /* Luz arriba */
    border-bottom: 1px solid rgba(0,0,0,0.2);   /* Sombra abajo */
}

/* Decoración: Pequeño punto estilo "etiqueta" */
.modal-badge::before {
    content: '';
    position: absolute;
    left: 12px;
    top: 50%;
    transform: translateY(-50%);
    width: 6px;
    height: 6px;
    background: #0b0e14;
    border-radius: 50%;
    box-shadow: 0 1px 0 rgba(255,255,255,0.5);
}