/* 1. Animación automática al entrar a la página */
body {
    /* ... tus estilos anteriores ... */
    animation: aparecer 1s ease-in-out forwards;
}

/* Definimos cómo es esa animación de entrada */
@keyframes aparecer {
    from { 
        opacity: 0; 
        transform: translateY(10px); /* Entra ligeramente desde abajo */
    }
    to { 
        opacity: 1; 
        transform: translateY(0); 
    }
}

/* 2. Clase especial que añadiremos con JS justo antes de salir de la página */
.desaparecer {
    opacity: 0 !important;
    transform: translateY(-10px) !important; /* Se va ligeramente hacia arriba */
    transition: opacity 0.4s ease-in-out, transform 0.4s ease-in-out;
}

/* =========================================
   1. VARIABLES Y RESET
   ========================================= */
@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@300;400;500&family=Playfair+Display:ital,wght@0,400;0,600;1,400&display=swap');

:root {
    --color-fondo: #fcfcfc;
    --color-texto: #2c2c2c;
    --color-acento: #c5a880; /* Tono arena/dorado elegante */
    --color-oscuro: #1a1a1a;
    --fuente-titulos: 'Playfair Display', serif;
    --fuente-textos: 'Montserrat', sans-serif;
    --max-width: 1200px;
}

html{
    scroll-behavior: smooth;
}

* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

body {
    font-family: var(--fuente-textos);
    color: var(--color-texto);
    background-color: var(--color-fondo);
    line-height: 1.6;
    -webkit-font-smoothing: antialiased;
}

a {
    text-decoration: none;
    color: inherit;
}

/* Para corregir visualmente las etiquetas <a> usadas como párrafos en tu HTML */
section a {
    display: block;
}

/* =========================================
   2. CABECERA (HEADER)
   ========================================= */
header {
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 1.5rem 5%;
    background-color: #ffffff;
    box-shadow: 0 2px 10px rgba(0,0,0,0.03);
    position: sticky;
    top: 0;
    z-index: 100;
    transition: transform 0.3s ease-in-out;
}

.header-oculto {
    /* Mueve el header hacia arriba el 100% de su propio tamaño */
    transform: translateY(-100%); 
}

nav {
    display: flex;
    gap: 5rem;
}

.nav-link {
    font-size: 0.9rem;
    text-transform: uppercase;
    letter-spacing: 1px;
    font-weight: 500;
    transition: color 0.3s ease;
}

.nav-link:hover {
    color: var(--color-acento);
}

.senzo-logo {
    margin: 0 4rem;
}

.senzo-logo img {
    height: 150px; /* Ajusta según el tamaño de tu logo */
    object-fit: contain;
}

/* =========================================
   3. SECCIÓN INICIO (HERO)
   ========================================= */
.inicio {
    height: 85vh;
    min-height: 600px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    text-align: center;
    /* 1. Añadimos la imagen con un filtro oscuro encima para que el texto resalte */
    background-image: linear-gradient(rgba(26, 26, 26, 0.6), rgba(26, 26, 26, 0.6)), url('images/local.jpg');
    /* 2. Configuramos el comportamiento del fondo */
    background-size: cover;      /* Hace que la imagen ocupe todo el espacio sin deformarse */
    background-position: center; /* Centra la imagen para que se vea la parte importante */
    background-repeat: no-repeat;/* Evita que la imagen se repita como un mosaico */
    color: #ffffff;
    padding: 2rem;
}

.inicio h1 {
    font-family: var(--fuente-titulos);
    font-size: 4rem;
    font-weight: 400;
    margin-bottom: 1rem;
    letter-spacing: 2px;
}

.inicio a {
    font-size: 1.2rem;
    font-weight: 300;
    color: #e0e0e0;
}

/* =========================================
   4. SECCIÓN SERVICIOS
   ========================================= */
.seccion_servicios {
    max-width: var(--max-width);
    margin: 5rem auto;
    padding: 0 2rem;
    text-align: center;
}

.titulo_servicios, 
.titulo_ubicacion {
    font-family: var(--fuente-titulos);
    font-size: 2.5rem;
    font-weight: 400;
    margin-bottom: 3rem;
    color: var(--color-oscuro);
}

.servicios {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: 3rem;
}

.servicio {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1.5rem;
}

.servicio img {
    width: 100%;
    height: 400px;
    object-fit: cover;
    border-radius: 4px;
    box-shadow: 0 10px 30px rgba(0,0,0,0.05);
    transition: transform 0.4s ease;
}

.servicio:hover img {
    transform: translateY(-5px);
}

.servicio a {
    font-family: var(--fuente-titulos);
    font-size: 1.5rem;
    color: var(--color-oscuro);
}

.cta_servicios {
    background-color: var(--color-oscuro);
    color: #ffffff;
    padding: 3rem 2rem;
    border-radius: 18px;
    margin-top: 2rem;
}

.cta_servicios h2 {
    font-family: var(--fuente-titulos);
    font-size: 2rem;
    font-weight: 400;
    margin-bottom: 1rem;
    color: var(--color-acento);
}

.cta_servicios p {
    margin-bottom: 2rem;
    color: #cccccc;
}

.btn_servicios {
    display: inline-block;
    background-color: var(--color-acento);
    color: var(--color-oscuro);
    padding: 1rem 2.5rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 1px;
    border-radius: 4px;
    transition: background-color 0.3s ease, transform 0.2s ease;
}

.btn_servicios:hover {
    background-color: #d8be96; /* Un tono un poco más claro para el hover */
    transform: translateY(-3px); /* Se eleva un poquito al pasar el ratón */
    color: var(--color-oscuro);
}

/* =========================================
   5. SECCIÓN UBICACIÓN
   ========================================= */
.seccion_ubicacion {
    max-width: var(--max-width);
    margin: 5rem auto;
    padding: 0 2rem;
}

.titulo_ubicacion {
    text-align: center;
}

.contenido_ubicacion {
    display: flex;
    flex-wrap: wrap;
    gap: 4rem;
    align-items: center;
}

.contenido_ubicacion iframe {
    flex: 1 1 500px;
    width: 100%;
    border-radius: 4px;
    box-shadow: 0 10px 30px rgba(0,0,0,0.05);
}

.info_ubicacion {
    flex: 1 1 300px;
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

.option_info_ubicacion {
    display: flex;
    /* CORRECCIÓN: Centrar iconos y texto verticalmente */
    align-items: center; 
    gap: 1rem;
}

.option_info_ubicacion img {
    /* Ajuste de tamaño base para iconos normales */
    width: 40px; 
    height: 25px;
    object-fit: contain;
    /* Eliminamos el margin-top para que no desvirtúe el centrado flex */
    margin: 0;
}

/* --- NUEVOS ESTILOS PARA LOS HORARIOS --- */
.horarios-wrapper {
    display: flex;
    flex-direction: column; /* Apila los horarios verticalmente */
    gap: 0.3rem; /* Espacio sutil entre líneas de horario */
}

.horarios-wrapper a {
    /* Opcional: ajustar ligeramente el tamaño del texto para que sea sutil */
    font-size: 0.95rem; 
}


/* --- ESTILOS ESPECÍFICOS PARA METRO Y CERCANÍAS --- */
/* Para que el logo de metro y cercanías se alineen bien con el texto a su derecha */
.option_info_ubicacion:has(.metro) > img {
    align-self: flex-start; /* Metro es complejo, alinea arriba */
    margin-top: 5px; /* Pequeño ajuste para que case con el texto */
}

/* Wrapper para cada línea de metro (icono + texto) */
.metro-linea {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.metro-linea img {
    width: 30px;
    height: 30px;
    margin: 0;
}

.metro-linea a{
    font-size: 0.95rem;
}

/* =========================================
   6. FOOTER
   ========================================= */
.pie-pagina {
    background-color: var(--color-oscuro);
    color: #ffffff;
    padding: 4rem 2rem 1rem;
    margin-top: 4rem;
}

.footer-contenido {
    max-width: var(--max-width);
    margin: 0 auto;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 3rem;
    margin-bottom: 3rem;
}

.footer-seccion h3, .footer-seccion h4 {
    font-family: var(--fuente-titulos);
    font-weight: 400;
    margin-bottom: 1.5rem;
    color: var(--color-acento);
}

.footer-seccion p {
    font-size: 0.9rem;
    color: #cccccc;
}

.footer-seccion ul {
    list-style: none;
}

.footer-seccion ul li {
    margin-bottom: 0.8rem;
}

.footer-seccion ul li a {
    color: #cccccc;
    transition: color 0.3s ease;
}

.footer-seccion ul li a:hover {
    color: var(--color-acento);
}

.redes-sociales {
    display: flex;
    gap: 1rem;
}

.redes-sociales img {
    width: 24px;
    height: 24px;
    transition: opacity 0.3s ease;
}

.redes-sociales a{
    font-size: 0.9rem;
    color: #cccccc;
    text-decoration: none;
}

.redes-sociales a:hover img {
    opacity: 0.7;
}

.footer-legal {
    text-align: center;
    border-top: 1px solid rgba(255,255,255,0.1);
    padding-top: 1.5rem;
    font-size: 0.8rem;
    color: #888888;
}

/* --- ESTILOS PARA LA IMAGEN DE TARIFAS --- */
.seccion_tarifas {
    max-width: var(--max-width);
    margin: 5rem auto;
    padding: 0 2rem;
    text-align: center;
}

.contenedor_imagen_tarifas {
    max-width: 800px; /* Evita que la imagen se vea gigantesca en pantallas grandes */
    margin: 0 auto 4rem auto;
}

.imagen_tarifas {
    width: 75%;
    height: auto;
    border-radius: 20px;
    box-shadow: 0 10px 30px rgba(0,0,0,0.1); /* Le da un efecto sombra muy elegante */
}

/* --- ESTILOS PARA LA LLAMADA A LA ACCIÓN (CTA) --- */
.cta_reservas {
    background-color: var(--color-oscuro);
    color: #ffffff;
    padding: 3rem 2rem;
    border-radius: 18px;
    margin-top: 2rem;
}

.cta_reservas h2 {
    font-family: var(--fuente-titulos);
    font-size: 2rem;
    font-weight: 400;
    margin-bottom: 1rem;
    color: var(--color-acento);
}

.cta_reservas p {
    margin-bottom: 2rem;
    color: #cccccc;
}

.btn_reserva {
    display: inline-block;
    background-color: var(--color-acento);
    color: var(--color-oscuro);
    padding: 1rem 2.5rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 1px;
    border-radius: 4px;
    transition: background-color 0.3s ease, transform 0.2s ease;
}

.btn_reserva:hover {
    background-color: #d8be96; /* Un tono un poco más claro para el hover */
    transform: translateY(-3px); /* Se eleva un poquito al pasar el ratón */
    color: var(--color-oscuro);
}

/* =========================================
   ESTILOS PARA "QUIÉNES SOMOS"
   ========================================= */

.cabecera-nosotros {
    background-image: linear-gradient(rgba(26, 26, 26, 0.6), rgba(26, 26, 26, 0.6)), url('images/senzo_logo_old.jpg');
}

.seccion_nosotros {
    max-width: var(--max-width);
    margin: 6rem auto;
    padding: 0 2rem;
    display: flex;
    flex-direction: column;
    gap: 6rem; /* Deja mucho espacio para que la página respire */
}

.bloque_nosotros {
    display: flex;
    align-items: center;
    gap: 4rem;
}

.texto_nosotros {
    flex: 1; /* Ocupa la mitad del espacio disponible */
}

.texto_nosotros h2 {
    font-family: var(--fuente-titulos);
    font-size: 2.5rem;
    color: var(--color-oscuro);
    margin-bottom: 1.5rem;
}

.texto_nosotros p {
    font-size: 1.1rem;
    color: #444444;
    line-height: 1.8;
    margin-bottom: 1.2rem;
    text-align: justify;
}

.imagen_nosotros {
    flex: 1; /* Ocupa la otra mitad del espacio */
}

.imagen_nosotros img {
    width: 100%;
    max-height: 500px;
    object-fit: cover; /* Recorta la imagen bonito si las proporciones no cuadran */
    border-radius: 18px;
    box-shadow: 0 15px 40px rgba(0,0,0,0.08); /* Sombra elegante */
}

/* =========================================
   GALERÍA DE IMÁGENES (DISEÑO EDGE-TO-EDGE)
   ========================================= */

/* 1. Contenedor principal (El ancla) */
.seccion_galeria {
    position: relative; /* ¡Clave! Mantiene a los botones atrapados dentro de esta sección */
    max-width: 100%;    /* Ocupa todo el ancho de la pantalla */
    margin: 5rem 0;
    padding: 0;
}

/* 2. El Título */
.seccion_galeria .titulo_servicios {
    margin-bottom: 2rem; /* Da aire entre el título y las fotos */
}

/* 3. El contenedor de las fotos (El que hace el scroll) */
.galeria-grid {
    display: flex;
    align-items: center;
    gap: 7rem;
    overflow-x: auto;
    
    /* Le damos 2rem de padding abajo para que quepa la sombra de las fotos al hacer hover */
    padding: 0 2rem 2rem 2rem; 
    
    /* Ocultamos la barra de scroll de forma universal */
    -ms-overflow-style: none;  /* Para IE y Edge antiguo */
    scrollbar-width: none;     /* Para Firefox */
}

/* Ocultamos la barra en Chrome, Safari y Edge moderno */
.galeria-grid::-webkit-scrollbar {
    display: none;
}

/* 4. Las fotos */
.img-galeria {
    flex: 0 0 auto; /* Prohíbe que el navegador aplaste las fotos */
    width: 500px;
    height: 400px;
    object-fit: cover;
    border-radius: 18px;
    cursor: pointer;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.img-galeria:hover {
    transform: translateY(-5px) scale(1.02);
    box-shadow: 0 15px 30px rgba(0,0,0,0.15);
}

/* 5. Los botones de navegación */
.btn-galeria {
    position: absolute; /* Se separan de las fotos para no hacer scroll con ellas */
    
    /* TRUCO MATEMÁTICO: Centrado vertical perfecto. 
       200px (la mitad de la foto) + 2rem (el padding inferior) */
    bottom: calc(200px + 2rem); 
    transform: translateY(50%); /* Termina de clavar el centro geométrico */
    
    background-color: rgba(26, 26, 26, 0.8);
    color: var(--color-acento); /* Tu dorado */
    border: none;
    width: 55px;
    height: 55px;
    border-radius: 50%;
    font-size: 1.5rem;
    cursor: pointer;
    z-index: 10;
    
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background-color 0.3s, transform 0.3s;
    box-shadow: 0 4px 15px rgba(0,0,0,0.3);
}

.btn-galeria:hover {
    background-color: var(--color-acento);
    color: var(--color-oscuro);
    transform: translateY(50%) scale(1.1);
}

/* Posición exacta a los lados */
.prev { left: 2rem; }
.next { right: 2rem; }

/* 6. Ajuste para teléfonos móviles */
@media (max-width: 768px) {
    .btn-galeria { 
        width: 45px; 
        height: 45px; 
        font-size: 1.2rem; 
    }
    .prev { left: 1rem; }
    .next { right: 1rem; }
    
    /* Hacemos las fotos un poco más pequeñas para que entren mejor en el móvil */
    .img-galeria {
        width: 300px;
        height: 250px;
    }
    
    /* Recalculamos el centro del botón para la nueva altura en móviles (mitad de 250 = 125) */
    .btn-galeria {
        bottom: calc(125px + 2rem);
    }
}

/* --- RESPONSIVE PARA MÓVILES --- */
@media (max-width: 900px) {
    .seccion_nosotros {
        gap: 4rem;
        margin: 4rem auto;
    }
    
    /* En móvil y tablet quitamos el "uno al lado del otro" y los apilamos */
    .bloque_nosotros, 
    .bloque_nosotros.invertido {
        flex-direction: column; 
        text-align: center;
        gap: 2rem;
    }

    .texto_nosotros h2 {
        font-size: 2rem;
    }
}

/* =========================================
   7. RESPONSIVE (MEDIA QUERIES)
   ========================================= */
@media (max-width: 900px) {
    header {
        flex-direction: column;
        gap: 1.5rem;
    }
    
    .senzo-logo {
        margin: 0;
        order: -1; /* Pone el logo arriba en pantallas pequeñas */
    }

    .inicio h1 {
        font-size: 3rem;
    }
}

@media (max-width: 600px) {
    nav {
        flex-wrap: wrap;
        justify-content: center;
        gap: 1rem;
    }
    
    .contenido_ubicacion {
        gap: 2rem;
    }
}

/* =========================================
   BANNER EN CONSTRUCCIÓN
   ========================================= */
.en-construccion {
    background-color: #8B0000; /* Tu rojo oscuro y elegante */
    color: #ffffff;
    text-align: center;
    
    /* LA CLAVE: Usamos padding en lugar de height para controlar el tamaño */
    padding: 4rem 2rem; 
    
    /* Lo centramos en la pantalla y le damos un ancho máximo para que no se estire demasiado en monitores grandes */
    max-width: 800px;
    margin: 4rem auto; 
    
    /* Un toque moderno: bordes ligeramente redondeados y una sombra suave */
    border-radius: 12px;
    box-shadow: 0 10px 30px rgba(139, 0, 0, 0.2);
}

.contenido-construccion h2 {
    font-family: var(--fuente-titulos); /* Usamos la fuente de tu peluquería */
    font-size: 2.2rem;
    margin-bottom: 1rem;
    text-transform: uppercase;
    letter-spacing: 2px;
}

.contenido-construccion p {
    font-size: 1.2rem;
    margin: 0;
    opacity: 0.9; /* Hace el texto un pelín más suave para que contraste bien con el blanco del título */
}

/* Ajuste para móviles */
@media (max-width: 768px) {
    .en-construccion {
        padding: 3rem 1.5rem;
        margin: 2rem 1rem; /* Deja un poco de margen a los lados en el móvil */
    }
    .contenido-construccion h2 {
        font-size: 1.8rem;
    }
}