/* --- VARIABLES DE MARCA --- */
:root {
    --color-fondo: #f6f2ec;     /* Beige claro */
    --color-primario: #7b5e44;  /* Marrón madera violín */
    --color-secundario: #d8c5ae; /* Crema suave */
    --color-texto: #4a3a2c;     /* Marrón oscuro tipográfico */
    --color-blanco: #ffffff;
    --color-acento: #b89a7c;    /* Dorado apagado */
}

/* --- ESTILOS BASE --- */
body {
    margin: 0;
    font-family: 'Open Sans', sans-serif;
    background-color: var(--color-fondo);
    color: var(--color-texto);
    line-height: 1.6;
}

h1, h2, h3, .fuente-elegante {
    font-family: 'Playfair Display', serif;
}

/* --- NAVEGACIÓN --- */
nav {
    position: fixed;
    top: 0;
    width: 100%;
    background: var(--color-secundario);
    display: flex;
    justify-content: center;
    gap: 30px;
    padding: 15px 0;
    z-index: 1000;
    box-shadow: 0 2px 10px rgba(0,0,0,0.05);
}

nav a {
    text-decoration: none;
    color: var(--color-texto);
    font-weight: 600;
    font-size: 14px;
    text-transform: uppercase;
    letter-spacing: 1px;
    transition: 0.3s;
}

nav a:hover {
    color: var(--color-primario);
}

/* --- HEADER / HERO --- */
header {
    padding: 140px 20px 80px 20px;
    text-align: center;
    background: #e9dfd3;
}

header h1 {
    font-size: 55px;
    margin: 0;
    font-style: italic;
    font-weight: 400;
}

header p {
    font-size: 22px;
    margin-top: 10px;
    font-weight: 300;
}

/* --- COMPONENTES --- */
.container {
    max-width: 1100px;
    margin: auto;
    padding: 40px 20px;
}

.boton-principal {
    display: inline-block;
    margin-top: 20px;
    padding: 14px 32px;
    background: var(--color-primario);
    color: var(--color-blanco);
    text-decoration: none;
    border-radius: 4px;
    font-weight: 600;
    transition: 0.3s ease;
    border: none;
    cursor: pointer;
}

.boton-principal:hover {
    background: #5d4037;
    transform: translateY(-2px);
}

/* --- SECCIÓN PERFIL (CARRUSEL VERTICAL) --- */
.perfil {
    display: flex;
    flex-wrap: wrap;
    gap: 50px;
    align-items: flex-start; /* Alinea texto arriba con la foto */
    margin-bottom: 60px;
}

.carrusel-wrapper {
    position: relative;
    width: 320px;          /* Ancho en PC */
    height: 480px;         /* Alto en PC (Formato vertical) */
    border-radius: 14px;
    overflow: hidden;
    box-shadow: 0 10px 30px rgba(0,0,0,0.1);
    background-color: #eee;
    flex-shrink: 0;        /* IMPORTANTE: Evita que el texto aplaste la imagen */
}

.slide-img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    opacity: 0;
    transition: opacity 1s ease-in-out;
    background-size: cover;     /* Llena el marco sin deformar */
    background-position: center;
    background-repeat: no-repeat;
}

.slide-img.active {
    opacity: 1 !important;
}

.perfil-info {
    flex: 1;
    min-width: 300px; /* Si el texto no cabe al lado, salta abajo */
}

/* --- ACORDEÓN DE PLANES --- */
.bloque {
    margin-top: 80px;
}

.bloque h2 {
    border-bottom: 2px solid var(--color-acento);
    padding-bottom: 10px;
    margin-bottom: 30px;
}

.plan {
    margin-top: 15px;
    border-radius: 8px;
    overflow: hidden;
    border: 1px solid #ccb59c;
    background: var(--color-blanco);
}

.plan button {
    width: 100%;
    padding: 20px;
    font-size: 19px;
    border: none;
    cursor: pointer;
    background: #e8ded2;
    text-align: left;
    color: var(--color-texto);
    font-family: 'Playfair Display', serif;
}

.plan-content {
    display: none; 
    padding: 25px;
    background: #faf7f3;
    border-top: 1px solid #eee;
}

/* --- FORMULARIOS --- */
input, select, textarea {
    font-family: 'Open Sans', sans-serif;
    border: 1px solid var(--color-secundario);
    border-radius: 4px;
}

/* --- RESTAURACIÓN DEL FOOTER (3 COLUMNAS) --- */
footer {
    background: #7b5e44; /* Marrón oscuro original */
    color: #f6f2ec;
    padding: 60px 20px 20px 20px;
    margin-top: 80px;
    text-align: left; /* Volvemos a alineación izquierda para las columnas */
}

footer h3, footer h4 {
    color: #d8c5ae;
    margin-bottom: 15px;
}

footer a {
    color: #d8c5ae;
    text-decoration: none;
    transition: 0.3s;
}

footer a:hover {
    color: #ffffff;
}

.footer-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 40px;
    max-width: 1100px;
    margin: auto;
}

.footer-bottom {
    text-align: center;
    margin-top: 40px;
    border-top: 1px solid rgba(255,255,255,0.1);
    padding-top: 20px;
    font-size: 12px;
}

/* --- BOTÓN FLOTANTE DE WHATSAPP --- */
.whatsapp-float {
    position: fixed;
    width: 60px;
    height: 60px;
    bottom: 30px;
    right: 30px;
    background-color: #25d366;
    color: #FFF;
    border-radius: 50px;
    text-align: center;
    font-size: 30px;
    box-shadow: 2px 2px 10px rgba(0,0,0,0.2);
    z-index: 2000;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: transform 0.3s ease;
    text-decoration: none;
}

.whatsapp-float:hover {
    transform: scale(1.1);
    color: #FFF;
}

/* Responsive para el footer */
@media (max-width: 768px) {
    .footer-grid {
        text-align: center;
    }
}
/* --- RESPONSIVE --- */

/* Celulares en vertical */
@media (max-width: 768px) {
    header h1 { font-size: 38px; }
    
    .perfil { 
        flex-direction: column; 
        text-align: center; 
        align-items: center;
    }
    
    .carrusel-wrapper { 
        width: 280px;   /* Ancho controlado para móviles */
        height: 380px;  /* Alto controlado para móviles */
        margin-bottom: 20px;
    }

    nav { gap: 15px; font-size: 12px; }
}

/* Celulares en horizontal (Landscape) */
@media (max-height: 480px) and (orientation: landscape) {
    header { padding: 60px 20px; }
    header h1 { font-size: 32px; }

    .perfil {
        flex-direction: row; /* Foto al lado del texto también en horizontal */
        text-align: left;
        align-items: flex-start;
    }

    .carrusel-wrapper {
        width: 180px;   /* Foto más pequeña para que no se corte por el alto de pantalla */
        height: 240px;
    }
}

/* Ajuste del botón para que no se estire */
.btn-aplicar {
    width: auto !important; /* El tamaño será el de su contenido */
    padding: 8px 20px !important; 
    flex-shrink: 0; /* Evita que el botón se comprima */
}

/* Contenedor del resultado oculto por defecto */
.descuento-applied {
    margin-top: 15px;
    padding: 10px;
    background: #fdf5e6;
    border: 1px solid #d8c5ae;
    border-radius: 6px;
    display: none; /* Oculto hasta que apliques cupón */
}

