/* ===============================================
    VARIABLES CSS (Paleta de Colores de "Last War Lullaby")
    =============================================== */
:root {
    --color-fondo-base: #DAC7B3; /* Crema Tostado / Papel Viejo */
    --color-marron-topo: #987A6C; /* Marrón/Tierra - Detalle */
    --color-carbon-oscuro: #2D2D2D; /* Gris Carbón - Texto Principal */
    --color-acento: #647477; /* Azul-Gris Embotellado - Botones/Links */
    --color-blanco: #FFFFFF;
    
    /* Nueva variable necesaria para la página "El Grupo" (bordes y separadores) */
    --color-marron-topo-claro: #BCAAA4; 
}

/* ===============================================
    TIPOGRAFÍA Y RESET BÁSICO
    =============================================== */
* {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

body {
    background-color: var(--color-fondo-base);
    color: var(--color-carbon-oscuro);
    font-family: 'Montserrat', sans-serif; /* Fuente Cuerpo */
    line-height: 1.6;
    font-size: 16px;
    /* FIX EXTREMO: Evitar el desbordamiento horizontal en todo el cuerpo */
    overflow-x: hidden; 
    /* FIX EXTREMO 2: Asegurar que el cuerpo nunca exceda el ancho del viewport */
    max-width: 100vw; 
}

h1, h2, h3 {
    font-family: 'Playfair Display', serif; /* Fuente Principal */
    font-weight: 700;
}

h1 { /* Título HERO */
    font-size: 3rem;
    font-style: italic;
    font-weight: 400;
}

h2 { /* Títulos de Sección */
    font-size: 2rem;
    color: var(--color-marron-topo);
    text-align: center;
    margin-bottom: 2rem;
}

a {
    text-decoration: none;
    color: var(--color-carbon-oscuro);
    transition: color 0.3s;
}

/* ===============================================
    CABECERA (HEADER y NAVEGACIÓN)
    =============================================== */
.main-header {
    background-color: rgba(218, 199, 179, 0.95); /* Semi-transparente para 'paper look' */
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1rem 5%;
    border-bottom: 1px solid var(--color-marron-topo);
    position: sticky;
    top: 0;
    z-index: 1000;
    /* FIX: Garantizar que el ancho del encabezado sticky no exceda el viewport */
    width: 100%; 
}

.logo a {
    font-family: 'Montserrat', sans-serif; /* Fuente Detalle */
    font-weight: 600;
    text-transform: uppercase;
}

.main-nav a {
    margin-left: 1.5rem;
    font-size: 0.9rem;
    font-weight: 400;
    padding: 5px 0;
}

.main-nav a:hover,
.main-nav a.active {
    color: var(--color-acento);
    border-bottom: 2px solid var(--color-acento);
}

.lang-switch {
    background-color: var(--color-acento);
    color: var(--color-blanco);
    padding: 0.3rem 0.5rem;
    border-radius: 4px;
    font-weight: 600;
    font-size: 0.8rem;
}

/* AÑADIDO: Botón de hamburguesa. Oculto por defecto en escritorio. */
.nav-toggle {
    display: none; 
    background: none;
    border: none;
    color: var(--color-carbon-oscuro);
    font-size: 1.5rem;
    cursor: pointer;
    padding: 0.5rem;
    /* Aseguramos que el botón no interfiera con el layout de escritorio */
    flex-shrink: 0; 
}

/* Estilo para la portada GRANDE en el HERO (350px) */
.hero-album-large {
    /* Tamaño para que sea prominente (aprox. 6x el tamaño anterior) */
    max-width: 450px; 
    height: auto;
    
    /* Centrar en el flexbox de la sección hero-overlay */
    display: block; 
    margin: 1.5rem auto 2.5rem auto; /* Espacio para separarla del título y del párrafo siguiente */
    
    border: 3px solid var(--color-blanco); /* Borde blanco para resaltar */
    border-radius: 4px;
    /* Sombra para darle profundidad sobre el fondo */
    box-shadow: 0 5px 15px rgba(0, 0, 0, 0.5); 
    z-index: 2; 
}

/* Estilo para el sello discográfico en el HERO (Punto 4) */
.album-label {
    color: var(--color-blanco);
    font-weight: 400;
    font-size: 1rem;
    margin-bottom: 2rem;
    z-index: 2;
}

/* Estilo para el sello discográfico en Album Details (Punto 4) */
.album-details .label-details {
    color: var(--color-fondo-base);
    font-style: italic;
    margin-bottom: 1rem;
    font-size: 1.1rem;
}


/* ===============================================
    SECCIÓN HERO (Ajuste de Legibilidad)
    =============================================== */

.hero-section {
    min-height: 85vh;
    background-size: cover;
    background-position: center center;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    position: relative;
}

/* Pseudo-elemento para el overlay oscuro en la imagen de fondo */
.hero-section::before {
    content: '';
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    background: rgba(0, 0, 0, 0.4); 
    z-index: 1; 
}

.hero-overlay {
    padding: 3rem 2rem;
    background: rgba(255, 255, 255, 0.1); 
    border-radius: 8px;
    z-index: 2;
}

/* El texto y botones deben estar en blanco puro para un alto contraste */
.hero-section h1, .hero-section p {
    color: var(--color-blanco);
    text-shadow: 2px 2px 5px rgba(0, 0, 0, 0.6); 
}

/* Ajuste del botón secundario para que funcione mejor sobre el fondo oscuro */
.cta-button.secondary {
    background: transparent;
    color: var(--color-blanco); 
    border: 2px solid var(--color-blanco); 
}

.cta-button.secondary:hover {
    background: rgba(255, 255, 255, 0.2);
}

/* ===============================================
    BOTONES DE LLAMADA A LA ACCIÓN (CTAs)
    =============================================== */
.cta-button {
    padding: 0.8rem 1.5rem;
    margin: 0 0.5rem;
    border-radius: 5px;
    text-transform: uppercase;
    font-weight: 600;
    display: inline-block;
}

.cta-button.primary {
    background-color: var(--color-acento);
    color: var(--color-blanco);
    border: 2px solid var(--color-acento);
}

.cta-button.secondary {
    background: transparent;
    color: var(--color-carbon-oscuro);
    border: 2px solid var(--color-carbon-oscuro);
}

.cta-button.primary:hover {
    background-color: #5A696C;
    border-color: #5A696C;
}

/* AÑADIDO: Estilo para el botón desactivado */
.cta-disabled {
    opacity: 0.6; /* Hacemos que se vea "gris" o menos prominente */
    pointer-events: none; /* CLAVE: Desactiva el clic */
    cursor: default;
}

/* Opcional: Desactivar hover en el botón desactivado */
.cta-disabled:hover {
    background: transparent !important; 
    color: var(--color-carbon-oscuro) !important;
}

/* ===============================================
    SECCIÓN DE NOVEDADES (NEWS HIGHLIGHT)
    =============================================== */
.news-highlight-section {
    padding: 4rem 5%;
    text-align: center;
}

.news-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 2rem;
    margin-bottom: 2rem;
    text-align: left;
}

.news-card {
    background-color: var(--color-blanco);
    border: 1px solid var(--color-marron-topo);
    padding: 1.5rem;
    border-radius: 4px;
}

.news-card h3 {
    color: var(--color-acento);
    margin-bottom: 0.5rem;
}

.news-card time {
    display: block;
    font-size: 0.8rem;
    color: var(--color-marron-topo);
    margin-bottom: 1rem;
}

.read-more {
    font-weight: 600;
    color: var(--color-acento);
    display: inline-block;
    margin-top: 1rem;
}

.all-news-button {
    display: inline-block;
    background: var(--color-carbon-oscuro);
    color: var(--color-blanco);
    padding: 0.6rem 1.2rem;
    border-radius: 4px;
    text-transform: uppercase;
    font-size: 0.9rem;
}

/* ===============================================
    SECCIÓN MERCH CTA
    =============================================== */
.merch-cta-section {
    background-color: var(--color-marron-topo);
    padding: 3rem 5%;
    text-align: center;
    color: var(--color-blanco);
}

.merch-cta-section h3 {
    color: var(--color-blanco);
    font-size: 1.8rem;
}

.merch-cta-section p {
    margin-bottom: 1.5rem;
}

/* ===============================================
    SECCIÓN ÁLBUM DESTACADO (Artística y Dinámica - Puede ir en index)
    =============================================== */
.album-highlight-section {
    display: flex;
    flex-wrap: wrap; 
    align-items: center;
    justify-content: space-around;
    padding: 6rem 5%;
    background-color: var(--color-marron-topo); 
    color: var(--color-blanco);
    text-align: left;
}

.album-visual {
    flex-basis: 40%; 
    text-align: center;
    perspective: 1000px; 
}

.album-visual img {
    width: 100%;
    max-width: 350px; 
    height: auto;
    display: block;
    border: 5px solid var(--color-blanco);
    border-radius: 5px;
    box-shadow: 10px 10px 30px rgba(0, 0, 0, 0.4); 
    
    transition: transform 0.4s ease-out, box-shadow 0.4s ease-out;
    transform: rotateY(0deg); 
}

/* Dinamismo: Efecto al pasar el ratón (Hover) */
.album-visual img:hover {
    transform: rotateY(5deg) scale(1.03); 
    box-shadow: 15px 15px 40px rgba(0, 0, 0, 0.6);
}

.album-details {
    flex-basis: 45%; 
    padding: 2rem 0;
}

.album-details h2 {
    color: var(--color-fondo-base); 
    text-align: left;
    margin-bottom: 0;
}

.album-details h3 {
    font-size: 3rem;
    font-style: italic;
    color: var(--color-blanco);
    margin-top: 0.5rem;
    margin-bottom: 2rem;
}

.album-details p {
    margin-bottom: 2rem;
    color: var(--color-fondo-base);
}

/* ===============================================
    PIE DE PÁGINA (FOOTER)
    =============================================== */
.main-footer {
    background-color: var(--color-carbon-oscuro);
    color: var(--color-fondo-base);
    text-align: center;
    padding: 2rem 5%;
    font-size: 0.9rem;
}

/* ESTILOS DE ICONOS EN EL FOOTER */
.footer-icon-links {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap; /* Permitir que los iconos se envuelvan en móvil */
    gap: 1.5rem; /* Espaciado entre iconos */
    margin-bottom: 1.5rem; /* Separación del texto de copyright */
}

.footer-icon-link {
    /* El enlace solo contiene el SVG, el texto no debe ser visible */
    padding: 0; 
    margin: 0;
    line-height: 1;
    color: var(--color-fondo-base); /* Color de los iconos */
    transition: color 0.3s;
}

.footer-icon-link:hover {
    color: var(--color-acento); /* Color de hover */
}

.footer-icon-link svg {
    /* Estilo del SVG */
    width: 24px; 
    height: 24px;
    display: block;
    fill: currentColor; /* El SVG hereda el color del <a> */
}

/* ELIMINAMOS el estilo antiguo de enlaces sociales que incluía texto */
.social-links {
    display: none; /* Asegurar que el antiguo contenedor social desaparezca si aún existe */
}
/* FIN ESTILOS DE ICONOS EN EL FOOTER */


/* ===============================================
    ESTILOS ESPECÍFICOS DE LA PÁGINA "EL GRUPO"
    =============================================== */

/* Contenedor central (para limitar el ancho del contenido de la página) */
.band-page-content > div {
    max-width: 1000px; 
    margin-left: auto;
    margin-right: auto;
    padding-left: 5%;
    padding-right: 5%;
}

/* --- Título y Subtítulo --- */
.project-container-title {
    text-align: center;
    padding-top: 3rem;
    padding-bottom: 1rem;
}

.project-container-title h1 {
    font-size: 3rem;
    color: var(--color-marron-topo);
    font-style: italic;
    margin-bottom: 0.5rem;
}

.project-subtitle {
    font-size: 1.1rem;
    color: var(--color-carbon-oscuro);
    font-weight: 300;
}

/* --- Imagen Principal --- */
.project-header-image {
    padding: 0; /* Removemos el padding horizontal para que la imagen toque los bordes */
}

.project-header-image img {
    width: 100%;
    height: auto;
    display: block;
    object-fit: cover;
    border-bottom: 5px solid var(--color-marron-topo);
}

/* --- Stream & Social Icons (Fichas laterales) --- */
.icons-section-wrapper {
    display: flex;
    justify-content: center;
    gap: 3rem;
    padding-top: 4rem;
    padding-bottom: 4rem;
    color: var(--color-carbon-oscuro);
}

.icons-column {
    flex-basis: 45%;
    max-width: 380px;
    padding: 2rem;
    background-color: var(--color-fondo-base); 
    border-radius: 8px;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1); 
    text-align: left;
}

.icons-column h3 {
    color: var(--color-marron-topo);
    text-align: left;
    margin-bottom: 1.5rem;
    border-bottom: 2px solid var(--color-marron-topo-claro);
    padding-bottom: 0.5rem;
}

.icon-link {
    display: flex;
    align-items: center;
    color: var(--color-carbon-oscuro);
    padding: 0.7rem 0;
    font-weight: 500;
    transition: color 0.2s, transform 0.2s;
}

.icon-link:hover {
    color: var(--color-marron-topo);
    transform: translateX(5px);
}

.icon-link svg {
    width: 20px;
    height: 20px;
    margin-right: 10px;
    fill: currentColor;
}


/* --- TEXTO PRINCIPAL --- */
.project-text {
    padding-top: 3rem;
    padding-bottom: 3rem;
    /* Restricción de ancho para mejor legibilidad y centrado */
    max-width: 750px; 
    margin: 0 auto; 
}

.project-text p {
    margin-bottom: 1.5rem;
    font-size: 1.1rem;
    text-align: justify;
    /* FIX: Forzar el salto de palabras largas para evitar desbordamiento */
    overflow-wrap: break-word; 
    word-wrap: break-word; /* Fallback para navegadores antiguos */
}

/* Imagen grande dentro del texto (thebrassbuttons3.jpg) */
.project-text .wide-inline-photo {
    display: block;
    width: 100%; /* Ocupa todo el ancho del contenedor de texto (max 750px) */
    height: auto;
    margin: 2.5rem 0; /* Agrega margen superior e inferior para separarla del texto */
    box-shadow: 0 5px 20px rgba(0, 0, 0, 0.2);
}

/* Imagen flotante dentro del texto (thebrassbuttons4.jpg) */
.project-text .float-image-left {
    float: left; 
    display: block;
    /* Ancho fijo de 180px para que sea pequeña y flotante */
    width: 180px; 
    height: auto; 
    /* Margen ajustado para escritorio */
    margin: 0 1.5rem 1.5rem 0; 
    box-shadow: 5px 5px 15px rgba(0, 0, 0, 0.15);
}

/* Limpieza de flotación después del bloque de texto */
.project-text::after {
    content: "";
    display: table;
    clear: both;
}

/* Diseño de la foto final al final del texto */
.project-photo-row {
    margin-top: 4rem;
    margin-bottom: 4rem;
    display: flex;
    justify-content: center;
}

.project-photo-row .single-final-photo {
    width: 70%; /* La foto final ocupa un 70% del ancho del contenedor */
    max-width: 100%;
}


/* --- SECCIÓN DE DISCOGRAFÍA (En página "El Grupo") --- */
.discography-section {
    padding-top: 4rem;
    padding-bottom: 4rem;
    text-align: center;
    background-color: var(--color-fondo-base);
}

.discography-section h2 {
    color: var(--color-carbon-oscuro);
    font-size: 2.5rem;
    margin-bottom: 3rem;
    font-style: italic;
}

.discography-grid {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 2rem;
}

.album-item {
    width: 180px; 
    text-align: center;
}

.album-item img {
    width: 100%;
    height: auto;
    display: block;
    border: 3px solid var(--color-marron-topo);
    margin-bottom: 0.8rem;
    box-shadow: 2px 2px 10px rgba(0, 0, 0, 0.2);
}

.album-item h4 {
    font-size: 1rem;
    font-weight: 600;
    margin-bottom: 0.2rem;
}

.album-item p {
    font-size: 0.9rem;
    color: var(--color-marron-topo);
}


/* ===============================================
    RESPONSIVE DESIGN (Para móviles)
    =============================================== */
@media (max-width: 900px) {
    /* Novedades: Pasa a 2 columnas */
    .news-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    /* Album Highlight */
    .album-highlight-section {
        flex-direction: column;
        text-align: center;
    }
    .album-visual, .album-details {
        flex-basis: 100%;
        max-width: 400px; /* Limita el tamaño en móvil */
    }
    .album-visual {
        margin-bottom: 2rem;
    }
    .album-details h2, .album-details h3 {
        text-align: center;
    }
    .album-visual img:hover {
        transform: none; /* Desactivar 3D en táctil para evitar errores */
        box-shadow: 10px 10px 30px rgba(0, 0, 0, 0.4);
    }

    /* El Grupo - Icons */
    .icons-section-wrapper {
        flex-direction: column;
        padding: 2rem 5%;
    }
    .icons-column {
        flex-basis: 100%;
        max-width: none;
        margin-bottom: 1.5rem;
    }
    
    /* El Grupo - Text */
    .project-text .wide-inline-photo {
        /* Permanece 100% de 750px, que ya es responsivo */
        margin: 1.5rem auto; 
    }

    .project-text .float-image-left {
        float: none; 
        /* Usar el mismo ancho fijo pequeño y centrarlo. */
        width: 180px; 
        margin: 2rem auto; 
    }
    
    .project-photo-row .single-final-photo {
        width: 90%; /* Ajuste menor en tablets */
    }

    /* Footer en móvil */
    .footer-icon-links {
        gap: 1rem;
    }
}

@media (max-width: 600px) {
    /* =============================================== */
    /* INICIO: AJUSTES PARA EL MENÚ HAMBURGUESA (Punto 2) */
    /* =============================================== */
    
    /* CABECERA: Mantenemos el logo, idioma y botón en la misma línea superior */
    .main-header {
        flex-direction: row; 
        justify-content: space-between; 
        align-items: center;
        /* Quitamos flex-direction: column, etc. */
    }
    
    /* 1. MOSTRAR el botón de hamburguesa en móvil */
    .nav-toggle {
        display: block; 
    }
    
    /* 2. OCULTAR la navegación principal por defecto */
    .main-nav {
        display: none; /* CLAVE: Oculto hasta que se active */
        position: absolute; 
        top: 4.5rem; /* Ajusta este valor al alto real de tu header */
        left: 0;
        width: 100%;
        background-color: var(--color-fondo-base); /* Fondo para cubrir el contenido */
        z-index: 990; /* Alto, pero menor que el del header (1000) */
        box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
        padding: 0;
    }
    
    /* Clase para mostrar el menú (alternada por JS) */
    .main-nav.show-menu {
        display: flex;
        flex-direction: column;
    }
    
    /* Estilo de los enlaces dentro del menú desplegado */
    .main-nav a {
        display: block; 
        width: 100%;
        text-align: center;
        margin: 0; 
        padding: 15px 0;
        border-bottom: 1px solid var(--color-marron-topo-claro);
    }
    
    /* Ajuste del lang-switch (Ya no es absolute, se queda arriba junto al logo/botón) */
    .lang-switch {
        position: static;
        margin-left: 1rem;
        top: auto;
        right: auto;
    }
    
    /* FIN: AJUSTES PARA EL MENÚ HAMBURGUESA */
    /* =============================================== */
    
    /* HERO: Reduce el tamaño de fuente */
    .hero-section h1 {
        font-size: 2.5rem;
    }
    
    /* AJUSTE: Imagen de la portada dentro del título en móvil */
    .hero-title-cover {
        width: 45px; 
        height: 45px;
    }

    /* Novedades: Pasa a 1 columna */
    .news-grid {
        grid-template-columns: 1fr;
    }
    
    /* El Grupo - Discografía */
    .discography-grid {
        gap: 1rem;
    }
    .album-item {
        width: 150px;
    }
    
    .project-photo-row .single-final-photo {
        width: 100%; 
    }
}


/* ===============================================
    ESTILOS PÁGINA PRENSA (prensa.php) - ACTUALIZADO
    =============================================== */

.press-album-section {
    max-width: 1000px;
    margin: 0 auto 4rem auto;
    padding: 0 5% 4rem 5%; /* Padding inferior para dar aire antes de la línea */
    border-bottom: 1px solid var(--color-marron-topo-claro); /* La línea ahora está aquí */
}

/* Eliminar el borde del último bloque para que no choque con el footer */
.press-album-section:last-child {
    border-bottom: none;
    padding-bottom: 0;
    margin-bottom: 2rem;
}

/* Cabecera de sección de álbum con portada */
.press-album-header {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    margin-bottom: 2.5rem;
    /* Borde ELIMINADO de aquí */
    padding-bottom: 0; 
    text-align: center;
}

/* Imagen de portada minimalista y elegante */
.album-cover-mini {
    width: 120px; /* Tamaño discreto */
    height: 120px;
    object-fit: cover;
    border-radius: 4px;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.15); /* Sombra suave para dar profundidad */
    margin-bottom: 1rem;
    border: 2px solid #fff; /* Borde blanco fino */
    transition: transform 0.3s ease;
}

.album-cover-mini:hover {
    transform: scale(1.05); /* Efecto sutil al pasar el ratón */
}

.header-text h2 {
    color: var(--color-acento);
    margin-bottom: 0.2rem;
    font-size: 1.8rem;
    letter-spacing: 0.05em;
}

.header-text .album-meta {
    font-size: 1rem;
    color: var(--color-marron-topo);
    font-style: italic;
    font-weight: 400;
}

/* --- GRID DE RESEÑAS --- */
.press-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); /* Grid responsivo */
    gap: 2rem;
}

.review-card {
    background-color: var(--color-blanco);
    padding: 2rem;
    border-radius: 4px;
    box-shadow: 0 2px 10px rgba(0,0,0,0.05); /* Sombra muy sutil */
    border-left: 4px solid var(--color-marron-topo); /* Borde lateral de acento */
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

.review-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 10px 20px rgba(0,0,0,0.1);
}

.review-card.highlight {
    background-color: #FDFBF7; /* Fondo ligeramente crema */
    border-left-color: var(--color-acento);
}

.review-content .quote {
    font-family: var(--font-serif); /* Fuente elegante para la cita */
    font-style: italic;
    font-size: 1.1rem;
    line-height: 1.6;
    color: var(--color-carbon-oscuro);
    margin-bottom: 1.5rem;
    position: relative;
    padding-left: 1rem;
}

/* Comillas decorativas */
.review-content .quote::before {
    content: "“";
    font-family: var(--font-serif);
    font-size: 4rem;
    line-height: 0;
    position: absolute;
    top: 20px;
    left: -20px;
    color: var(--color-marron-topo-claro);
    opacity: 0.4;
}

.review-source {
    text-align: right;
    font-size: 0.9rem;
    border-top: 1px solid #eee;
    padding-top: 1rem;
}

.review-source .media-name {
    display: block;
    font-weight: 700;
    color: var(--color-acento);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.review-source .date, 
.review-source .author {
    display: block;
    color: var(--color-marron-topo);
    font-size: 0.85rem;
}

/* Responsive para prensa */
@media (max-width: 600px) {
    .press-grid {
        grid-template-columns: 1fr; /* Una sola columna en móvil */
    }
    .review-content .quote::before {
        left: -10px; 
    }
}


/* ---------------------------------- */
/* ESTILOS DE MÚSICOS (ACTUALIZADO) */
/* ---------------------------------- */
.musicians-container {
    margin-top: 30px;
    padding-top: 20px;
    border-top: 1px solid var(--color-light-gray);
}

.musicians-title {
    margin-bottom: 15px;
}

.additional-musicians-title {
    font-size: 1.1rem;
    font-weight: 600;
    color: #555;
    margin-top: 25px;
    margin-bottom: 10px;
}

.musicians-list { 
    display: flex;
    flex-wrap: wrap;
    margin-bottom: 20px;
}

.musician-item {
    display: flex;
    flex-direction: row; 
    margin-right: 25px; 
    margin-bottom: 10px; 
    white-space: nowrap; 
}
/* Busca estas reglas en tu styles.css y reemplázalas */

.musician-name {
    /* Nueva fuente elegante y más grande */
    font-family: 'Playfair Display', serif; 
    font-size: 1.1rem; 
    font-weight: 700;
    color: var(--color-primary); /* Destaca con el color principal */
    line-height: 1.2;
    text-transform: capitalize; /* Capitaliza el nombre para uniformidad */
}

.musician-role {
    font-size: 0.9rem; /* Ligeramente más pequeño que el nombre */
    font-style: italic; /* Añade elegancia */
    font-weight: 400;
    color: var(--color-medium-gray); /* Color más tenue */
    margin-left: 5px; 
}
/* ... el resto de tu CSS ... */
.musicians-list:not(:last-child) {
    border-bottom: 1px solid transparent; 
    padding-bottom: 0px; 
}

/* ESTILOS DE CRÉDITOS */
.credits-container {
    margin-top: 30px;
    padding-top: 20px;
    border-top: 1px solid var(--color-light-gray);
}
.credits-dl {
    display: grid;
    grid-template-columns: 35% 65%;
    gap: 10px 20px;
    margin: 0;
    padding: 0;
}
.credits-dl dt {
    font-weight: 700;
    color: #1a1a1a;
    grid-column: 1 / 2;
    padding-right: 10px;
}
.credits-dl dd {
    margin-left: 0;
    color: #555;
    grid-column: 2 / 3;
}

/* ESTILOS DE PRE-ORDER BUTTON */
.preorder-container {
    margin-top: 30px;
    text-align: left; 
    padding: 20px 0;
    border-top: 1px solid var(--color-light-gray);
}
.preorder-button-index {
    display: inline-block;
    padding: 12px 30px;
    background-color: var(--color-primary); 
    color: #fff;
    text-decoration: none;
    font-weight: 700;
    font-size: 1.0rem;
    border-radius: 50px;
    letter-spacing: 1px;
    transition: background-color 0.3s, transform 0.2s, box-shadow 0.3s;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.2);
    text-transform: uppercase;
    border: 2px solid var(--color-primary); 
}
.preorder-button-index:hover {
    background-color: #fff; 
    color: var(--color-primary); 
    transform: translateY(-1px);
    box-shadow: 0 6px 15px rgba(0, 0, 0, 0.15);
}

/* ESTILOS DE STREAMING */
.streaming-links {
    margin-top: 30px;
    padding: 15px 0;
    border-top: 1px solid var(--color-light-gray);
}
.streaming-links h4 {
    font-size: 1rem;
    font-weight: 600;
    color: #555;
    margin-bottom: 10px;
}
.streaming-placeholder {
    font-style: italic;
    color: #999;
    font-size: 0.95rem;
    margin: 0;
}

/* MEDIA QUERIES (RESPONSIVE) */
@media (max-width: 900px) {
    .music-layout-container {
        padding-top: 10px;
    }
}
@media (max-width: 600px) {
    .album-header {
        flex-direction: column;
        align-items: center;
        text-align: center;
        gap: 15px;
    }
    .album-meta h2 {
        font-size: 1.8rem;
    }
    .credits-dl {
        grid-template-columns: 100%;
        gap: 5px 0;
    }
    .credits-dl dt, .credits-dl dd {
        grid-column: 1 / -1;
        padding: 0;
    }
    .credits-dl dt {
        margin-top: 10px;
        border-bottom: 1px dotted #ccc;
        padding-bottom: 2px;
    }
    
}





/* ----------------------------------------------------- */
/* ESTILOS ESPECÍFICOS DE LA PÁGINA DE PRE-ORDEN (LWL) */
/* ----------------------------------------------------- */

:root {
    /* COLOR PRIMARIO CAMBIADO: Naranja Quemado/Óxido */
    --color-primary: #c84e13; 
    --color-dark: #1a1a1a;
    --color-light-gray: #f0f0f0;
    --color-medium-gray: #666;
}

.music-page-content {
    max-width: 1000px;
    margin: 0 auto;
    padding: 0 15px;
}


/* ESTILOS DE DETALLES DEL ÁLBUM */
.album-header {
    display: flex;
    align-items: flex-start;
    gap: 30px;
    margin-bottom: 20px;
}
.album-cover {
    width: 150px;
    height: 150px;
    object-fit: cover;
    border-radius: 8px;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1);
    flex-shrink: 0;

.music-layout-container {
    display: flex;
    gap: 40px;
    padding-top: 30px;
    flex-direction: column; 
}
.preorder-layout {
    width: 100%; 
}
.music-details-container {
    flex-grow: 1;
    min-width: 0;
}
.album-detail-section {
    padding-top: 20px;
}


}
.album-meta h2 {
    font-family: 'Playfair Display', serif;
    font-size: 2.2rem;
    font-weight: 700;
    margin-top: 0;
    margin-bottom: 5px;
    color: #000;
}
.album-label {
    font-size: 0.9rem;
    color: var(--color-medium-gray);
}
.album-description h3, .tracklist-container h3, .credits-container h3, .musicians-container h3 {
    font-family: 'Montserrat', sans-serif;
    font-size: 1.2rem;
    font-weight: 700;
    color: #444;
    border-bottom: 2px solid var(--color-light-gray); 
    padding-bottom: 5px;
    margin-bottom: 15px;
}
.album-description p {
    line-height: 1.6;
    font-size: 1rem;
    color: #333;
}

/* ESTILOS DE TRACKLIST */
.tracklist-container {
    margin-top: 30px;
    padding-top: 20px;
    border-top: 1px solid var(--color-light-gray);
}
.tracklist-ol {
    list-style-type: decimal;
    padding-left: 20px;
    margin: 0;
}
.tracklist-ol li {
    display: flex;
    justify-content: space-between;
    padding: 8px 0;
    border-bottom: 1px dashed var(--color-light-gray);
    font-size: 1rem;
    color: #333;
    line-height: 1.4;
}
.tracklist-ol li:last-child {
    border-bottom: none;
}
.track-title {
    flex-grow: 1;
    font-weight: 600;
    color: #1a1a1a;
}
.track-duration {
    font-family: 'Playfair Display', serif;
    font-size: 0.9rem;
    color: var(--color-primary); 
    font-weight: 400;
    flex-shrink: 0;
    margin-left: 15px;
}


/* === ESTILOS DE NOTICIAS / CONCIERTOS === */

/* ---------------------------------- */
/* BASE DE LA PÁGINA DE NOTICIAS */
/* ---------------------------------- */
.news-page-content {
    max-width: 1000px;
    margin: 0 auto;
    padding: 0 15px 50px;
}
.project-container-title {
    text-align: center;
    padding: 30px 0 20px;
}
.project-container-title h1 {
    font-size: 3rem; /* O la fuente que uses en tu header/títulos principales */
    margin-bottom: 5px;
    color: var(--color-dark);
}
.project-subtitle {
    font-size: 1.2rem;
    color: var(--color-medium-gray);
    margin-bottom: 30px;
}

/* ---------------------------------- */
/* ESTILO DE TARJETA DE EVENTO (NEWS CARD) */
/* ---------------------------------- */
.event-card {
    display: flex;
    margin-bottom: 40px;
    background-color: #fff;
    border: 1px solid #eee;
    border-radius: 8px;
    overflow: hidden;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.05);
}
.event-image-container {
    flex-shrink: 0;
    width: 35%; /* La imagen ocupa 35% del ancho */
    position: relative;
    overflow: hidden;
}
.event-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 0.3s ease-in-out;
}
.event-card:hover .event-image {
    transform: scale(1.05);
}
.event-content {
    flex-grow: 1;
    padding: 25px 30px;
}
.event-date {
    font-size: 0.9rem;
    color: var(--color-medium-gray);
    font-weight: 600;
    margin-top: 0;
    margin-bottom: 10px;
}
.event-date i {
    margin-right: 5px;
    color: var(--color-primary); /* Icono de calendario rojo */
}
.event-title {
    font-family: 'Playfair Display', serif;
    font-size: 1.8rem;
    font-weight: 700;
    color: var(--color-dark);
    margin-top: 0;
    margin-bottom: 15px;
    line-height: 1.2;
}
.event-body p {
    font-size: 1rem;
    line-height: 1.6;
    color: #333;
    margin-bottom: 15px;
}
.event-body b {
    color: var(--color-dark);
}

/* CTA Link */
.event-cta-link {
    display: inline-block;
    color: var(--color-primary);
    text-decoration: none;
    font-weight: 700;
    margin-top: 15px;
    transition: color 0.2s;
    font-size: 0.95rem;
}
.event-cta-link:hover {
    color: #000;
}
.event-cta-link i {
    margin-left: 5px;
    transition: transform 0.2s;
}
.event-cta-link:hover i {
    transform: translateX(3px);
}

/* TAGS de Evento */
.event-tag {
    position: absolute;
    top: 15px;
    left: 0;
    padding: 5px 15px 5px 10px;
    color: #fff;
    font-size: 0.8rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    border-radius: 0 4px 4px 0;
    z-index: 10;
}
.event-tag-news {
    background-color: #333; /* Etiqueta discreta para noticias */
}
.event-tag-concert {
    background-color: var(--color-primary); /* Etiqueta roja para conciertos */
}

.end-of-list-message {
    text-align: center;
    padding: 30px 0;
    font-style: italic;
    color: var(--color-medium-gray);
    border-top: 1px dashed #eee;
    margin-top: 50px;
}


/* ---------------------------------- */
/* RESPONSIVE: MÓVIL */
/* ---------------------------------- */
@media (max-width: 768px) {
    .event-card {
        flex-direction: column;
    }
    .event-image-container {
        width: 100%; /* La imagen ocupa el 100% en móvil */
        height: 200px; /* Altura fija para la imagen */
    }
    .event-content {
        padding: 20px;
    }
    .event-title {
        font-size: 1.5rem;
    }
}


/* CENTRAR TODO EL CONTENIDO DE LA PÁGINA (sin header/footer) */
.contact-page-content {
    text-align: center;     /* Centra texto e inline-blocks */
}

.contact-page-content img {
    display: block;
    margin-left: auto;
    margin-right: auto;     /* Centra todas las imágenes */
}

/* ===============================================
   HAMBURGUESA — REGLAS IMPRESCINDIBLES
   =============================================== */
@media (max-width: 900px) {

    /* Mostrar botón hamburguesa en móvil */
    .nav-toggle {
        display: block !important;
        position: relative;
        z-index: 2000;
        font-size: 2rem;
        color: var(--color-carbon-oscuro);
    }

    /* Ocultar menú en móvil */
    .main-nav {
        display: none;
        position: absolute;
        top: 100%;
        left: 0;
        width: 100%;
        background: var(--color-fondo-base);
        flex-direction: column;
        z-index: 1500;
        box-shadow: 0 4px 8px rgba(0,0,0,0.1);
    }

    /* Mostrar menú cuando JS añade la clase */
    .main-nav.show-menu {
        display: flex;
    }
}


/* ===============================================
 Nuevo CSS para adaptar el layout de la página de noticias
   =============================================== */
/* Nuevo CSS para adaptar el layout de la página de noticias a 2 columnas */
.news-three-column-layout.two-column-adjustment {
    /* Si estás usando Grid */
    display: grid;
    grid-template-columns: 1fr 1fr; /* Divide el espacio en dos partes iguales */
    gap: 40px; /* Ajusta el espacio entre las columnas */
    /* Asegura que el contenedor no tenga un ancho fijo */
}

/* Opcional: Asegurar que el feed de FB ocupe su espacio */
.facebook-feed-column {
    /* Esto asegura que la columna de FB se ajuste al 1fr asignado por el grid */
    width: 100%; 
}

/* --- ESTILOS PARA PC (DEFAULT) --- */

/* La clave es resetear el display a 'block' para que los elementos se apilen 
y usar margin: auto para centrarlos.
*/
.news-three-column-layout.vertical-layout {
    display: block; /* Asegura el apilamiento vertical */
    
    /* Centrado y control de ancho */
    max-width: 1000px; /* Ancho elegante en PC (ej. 750px), ajusta a tu gusto */
    margin: 20px auto; /* Centra el contenedor completo */
    padding: 0; /* Asegura que no haya padding que interfiera con el centrado */
}

/* Control del ancho de las cajas individuales y el margen artístico */
.news-card,
.facebook-feed-column {
    width: 100%; /* Ocupan todo el ancho del contenedor (750px) */
    margin: 0 auto; /* Centrado interno (aunque no es estrictamente necesario aquí) */
}

/* Margen artístico y elegante entre las dos secciones */
.first-stack-item {
    margin-bottom: 60px; /* Espacio generoso después de la primera caja (el álbum) */
}

/* La segunda caja no necesita margen inferior si el footer está bien */
.second-stack-item {
    margin-bottom: 40px; 
}

/* --- ESTILOS PARA MÓVIL/TABLET (< 768px) --- */

@media (max-width: 768px) {
    
    .news-three-column-layout.vertical-layout {
        /* Eliminamos el max-width en móvil para que sea ancho completo */
        max-width: 100%; 
        padding: 0 20px; /* CLAVE: Añade relleno a los lados para que las cajas no toquen el borde de la pantalla */
        margin-top: 20px;
        /* El 'display: block' se mantiene y apila automáticamente */
    }
    
    /* Ajustamos los márgenes verticales en móvil para que sean menos espaciados */
    .first-stack-item {
        margin-bottom: 30px; /* Menos espacio en móvil */
    }

    /* Ajuste para el feed de Facebook en móvil, para que se adapte al 100% */
    .facebook-feed-column .fb-page {
        width: 100% !important; 
    }
}