/* VARIABLES CSS: FÁCIL PERSONALIZACIÓN */
:root {
    /* COLORES */
    --gradient-left-color: #2db1c1; /* Degradado izquierdo */
    --gradient-right-color: #144f9c; /* Degradado derecho */
    --text-color-dark: #333333; /* Color de texto general oscuro */
    --text-color-light: #ffffff; /* Color de texto general claro (para secciones de degradado) */
    --form-background: #f8f8f8; /* Fondo del formulario */
    --form-border: #cccccc; /* Borde de los campos del formulario */
    --button-send-color: #144f9c; /* Color del botón Enviar */
    --button-send-hover-color: #0c3a7a; /* Color al pasar el mouse sobre el botón Enviar */
    --button-whatsapp-color: #25D366; /* Color de WhatsApp */
    --button-whatsapp-hover-color: #1DA851; /* Color de WhatsApp al pasar el mouse */
    --bullet-check-color: #28a745; /* Verde para las viñetas de check */
    --footer-background: #343a40; /* Fondo del pie de página */
    --section-bg-light: #f7f7f7; /* Fondo para secciones de contenido ligero */
    --section-bg-white: #ffffff; /* Fondo para secciones de contenido blanco */

    /* TIPOGRAFÍA */
    --font-heading: 'Montserrat', sans-serif; /* Fuentes para títulos (Bold) */
    --font-body: 'Montserrat', sans-serif; /* Fuentes para texto general (Regular) */
    --font-size-base: 1em; /* 16px */
    --font-size-large: 1.125em; /* 18px */
    --font-size-xl: 1.25em; /* 20px */
    --font-size-h2: 2.5em; /* Título de división */
    --font-size-h3: 2em; /* Título de formulario */

    /* ALTURAS Y ANCHOS */
    --hero-logo-container-height: 146px; /* Altura máxima del espacio del logo */
    --logo-width: 340px; /* Ancho del logo */
    --logo-height: 156px; /* Alto del logo */
    --section-divider-height: 145px; /* Altura de la división con degradado */
    --section-padding-y: 60px; /* Relleno vertical para secciones de contenido */
    --container-max-width: 1200px; /* Ancho máximo del contenido central */
}

/* --- ESTILOS GENERALES Y RESET --- */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

body {
    font-family: var(--font-body);
    font-size: var(--font-size-base);
    line-height: 1.6;
    color: var(--text-color-dark);
    background-color: #ffffff;
    scroll-behavior: smooth;
}

.container {
    max-width: var(--container-max-width);
    margin: 0 auto;
    padding: 0 20px;
}

h1, h2, h3 {
    font-family: var(--font-heading);
    font-weight: 700; /* Bold */
    margin-bottom: 20px;
    line-height: 1.2;
}

p {
    margin-bottom: 15px;
}

/* --- CABECERA (HERO SECTION) --- */
.hero-section {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 200px; /* Altura mínima del hero para espacio superior */
    padding: 20px;
    background-color: #ffffff; /* Fondo blanco para todo el hero si no hay imagen */
}

.logo-container {
    background-color: #ffffff; /* Fondo blanco para el contenedor del logo */
    height: var(--hero-logo-container-height); /* Altura máxima del espacio del logo */
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 10px; /* Pequeño padding alrededor del logo */
    width: var(--logo-width);
    max-width: 100%;
    margin: 0 auto; /* Centrar el contenedor del logo */
}

.hero-logo {
    width: var(--logo-width);
    height: var(--logo-height);
    max-width: 100%; /* Asegura que el logo no se desborde */
    display: block; /* Para centrar la imagen dentro del contenedor */
    object-fit: contain; /* Para que la imagen se ajuste sin cortarse */
}


/* --- DIVISIÓN CON TÍTULO Y SUBTÍTULO --- */
.section-divider {
    background: linear-gradient(to right, var(--gradient-left-color), var(--gradient-right-color));
    width: 100%;
    height: var(--section-divider-height);
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    text-align: center;
    padding: 0 20px;
    color: var(--text-color-light); /* Texto blanco para el degradado */
}

.section-divider-title {
    font-size: var(--font-size-h2);
    margin-bottom: 10px;
    color: var(--text-color-light);
}

.section-divider-subtitle {
    font-size: var(--font-size-xl);
    font-weight: 400; /* Regular */
    color: var(--text-color-light);
    max-width: 900px; /* Limita el ancho del subtítulo para mejor lectura */
}

/* --- SECCIÓN DE CONTENIDO PRINCIPAL (FORMULARIO) --- */
.content-section {
    padding: var(--section-padding-y) 0;
    background-color: var(--section-bg-white);
}

.two-columns {
    display: flex;
    flex-wrap: wrap; /* Permite que las columnas se apilen en móviles */
    gap: 40px; /* Espacio entre columnas */
    align-items: flex-start; /* Alinea las columnas al inicio */
}

.column {
    flex: 1; /* Permite que las columnas se expandan */
    min-width: 300px; /* Ancho mínimo antes de apilar */
}

.left-column .section-description {
    font-size: var(--font-size-large);
    margin-bottom: 30px;
    line-height: 1.8;
}

.left-column .section-image {
    max-width: 100%;
    height: auto;
    border-radius: 8px; /* Pequeños bordes redondeados para la imagen */
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
}

/* --- FORMULARIO DE CONTACTO --- */
.form-title {
    font-size: var(--font-size-h3);
    text-align: center;
    margin-bottom: 30px;
    color: var(--button-send-color); /* Color del título del formulario */
}

.contact-form {
    background-color: var(--form-background);
    padding: 30px;
    border-radius: 10px;
    box-shadow: 0 5px 20px rgba(0, 0, 0, 0.1);
    display: flex;
    flex-direction: column;
}

.form-group {
    margin-bottom: 20px;
}

.form-group label {
    display: block;
    margin-bottom: 8px;
    font-weight: 700; /* Bold */
    color: var(--text-color-dark);
}

.form-group input[type="text"],
.form-group input[type="tel"],
.form-group input[type="email"] {
    width: 100%;
    padding: 12px;
    border: 1px solid var(--form-border);
    border-radius: 5px;
    font-size: var(--font-size-base);
    color: var(--text-color-dark);
}

.form-group input:focus {
    border-color: var(--button-send-color);
    outline: none;
    box-shadow: 0 0 0 3px rgba(var(--button-send-color) 0.2);
}

.btn-submit {
    display: block;
    width: 100%;
    padding: 15px 30px;
    background-color: var(--button-send-color);
    color: var(--text-color-light);
    border: none;
    border-radius: 8px; /* Botón rectangular */
    font-size: var(--font-size-large);
    font-weight: 700;
    cursor: pointer;
    transition: background-color 0.3s ease, transform 0.2s ease;
    margin-top: 20px;
}

.btn-submit:hover {
    background-color: var(--button-send-hover-color);
    transform: translateY(-2px);
}

.privacy-note {
    font-size: 0.85em;
    color: #666666;
    margin-top: 15px;
    text-align: center;
}

.form-message {
    margin-top: 20px;
    padding: 15px;
    border-radius: 5px;
    font-weight: bold;
    text-align: center;
    display: none; /* Oculto por defecto, se muestra con JS */
}

.form-message.success {
    background-color: var(--bullet-check-color);
    color: var(--text-color-light);
}

.form-message.error {
    background-color: #dc3545; /* Rojo */
    color: var(--text-color-light);
}

/* --- SECCIONES DE CONTENIDO A DOS COLUMNAS (Beneficios, Tratamientos, Proceso) --- */
.two-columns-section {
    padding: var(--section-padding-y) 0;
}

.two-columns-section .container {
    display: flex;
    flex-wrap: wrap; /* Permite que las columnas se apilen en móviles */
    gap: 40px; /* Espacio entre columnas */
    align-items: flex-start; /* Alinea las columnas al inicio */
}

.two-columns-section .column {
    flex: 1; /* Permite que las columnas se expandan */
    min-width: 300px; /* Ancho mínimo antes de apilar */
}

.two-columns-section .image-column img {
    max-width: 100%;
    height: auto;
    border-radius: 8px; /* Pequeños bordes redondeados para la imagen */
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
}

.two-columns-section .text-column h2 {
    color: var(--button-send-color); /* Color del título de la sección */
    margin-top: 0; /* Resetear el margen superior del h2 en columnas */
}

/* Alternar orden de columnas en escritorio */
.image-left .image-column { order: 1; }
.image-left .text-column { order: 2; }

.image-right .image-column { order: 2; }
.image-right .text-column { order: 1; }

/* Estilos específicos para cada sección */
.benefits-section { background-color: var(--section-bg-light); }
.treatments-section { background-color: var(--section-bg-white); }
.process-section { background-color: var(--section-bg-light); }

/* Estilos para las listas dentro de las columnas */
.two-columns-section .bullet-list,
.two-columns-section .numbered-list {
    max-width: 100%; /* Las listas ocupan el ancho de su columna */
    margin-left: 0;
    margin-right: 0;
}

/* Centrar el botón de WhatsApp en la sección de proceso */
.process-section .whatsapp-cta-container {
    align-items: center;
    margin-top: 20px;
}

/* --- LISTAS (VIÑETAS Y NUMERADAS) --- */
.bullet-list, .numbered-list {
    list-style: none; /* Quita el estilo de lista por defecto */
    padding: 0;
    margin-bottom: 20px;
    text-align: left;
}

.bullet-list li, .numbered-list li {
    font-size: var(--font-size-large);
    margin-bottom: 10px;
    line-height: 1.6;
}

/* Estilo específico para la lista con checks */
.check-list li {
    display: flex;
    align-items: flex-start;
    gap: 10px; /* Espacio entre el ícono y el texto */
}

.check-list li i {
    color: var(--bullet-check-color); /* Color verde para el ícono de check */
    font-size: 1.2em;
    flex-shrink: 0; /* Evita que el ícono se encoja */
    margin-top: 2px; /* Alineación fina con el texto */
}

/* Estilo para listas numeradas */
.numbered-list {
    counter-reset: my-counter; /* Reinicia el contador */
}

.numbered-list li {
    position: relative;
    padding-left: 30px; /* Espacio para el número */
}

.numbered-list li::before {
    counter-increment: my-counter; /* Incrementa el contador */
    content: counter(my-counter) ".";
    position: absolute;
    left: 0;
    top: 0;
    font-weight: 700; /* Bold para el número */
    color: var(--button-send-color); /* Color del número */
    font-size: var(--font-size-large);
}

.final-cta-text {
    font-size: var(--font-size-xl);
    font-weight: 700; /* Bold para el texto de CTA final */
    margin-bottom: 10px;
    color: var(--text-color-dark);
    text-align: center; /* Centrar el texto final en la sección de proceso */
}

/* --- BOTÓN CTA WHATSAPP --- */
.whatsapp-cta-container {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px; /* Espacio entre el botón y el subtexto (si lo hubiera) */
    margin-top: 20px;
}

.full-width-whatsapp {
    max-width: 400px; /* Limita el ancho máximo del botón al 100% */
    width: 100%;
    margin-left: auto;
    margin-right: auto;
}

.btn-whatsapp {
    display: inline-flex;
    align-items: center;
    justify-content: center; /* Centra el icono y el texto en el botón */
    gap: 10px;
    background-color: var(--button-whatsapp-color);
    color: var(--text-color-light);
    padding: 15px 30px; /* Reducir un poco el padding para que quepa mejor en columnas */
    border-radius: 8px; /* Rectangular */
    text-decoration: none;
    font-size: 1.2em; /* Reducir un poco el tamaño del texto */
    font-weight: 700;
    border: none;
    cursor: pointer;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.2);
    transition: background-color 0.3s ease, transform 0.3s ease; /* Transición para el movimiento */
    width: 100%; /* Ocupa el 100% del ancho de su contenedor */
}

.btn-whatsapp i {
    font-size: 1em; /* Tamaño del ícono de WhatsApp */
}

.btn-whatsapp:hover {
    background-color: var(--button-whatsapp-hover-color);
    animation: pulse 1s infinite alternate; /* Animación sutil de pulso */
}

/* Animación de pulso discreto para el botón de WhatsApp */
@keyframes pulse {
    0% { transform: scale(1); }
    100% { transform: scale(1.02); } /* Aumenta ligeramente el tamaño */
}


/* --- PIE DE PÁGINA --- */
footer {
    background-color: var(--footer-background);
    color: var(--text-color-light);
    padding: 40px 0;
    text-align: center;
    font-size: 0.9em;
}

footer p {
    margin-bottom: 10px;
}

/* --- ESTILOS ESPECÍFICOS PARA LA PÁGINA DE AGRADECIMIENTO (GRACIAS.HTML) --- */
body.thank-you-page-body { /* Una clase para el body de la página de agradecimiento */
    display: flex;
    justify-content: center;
    align-items: center;
    min-height: 100vh;
    background-color: var(--section-bg-light); /* Utiliza una variable existente */
    text-align: center;
    flex-direction: column;
    padding: 20px;
}

.thank-you-container {
    background-color: var(--section-bg-white); /* Utiliza una variable existente */
    padding: 40px 30px;
    border-radius: 10px;
    box-shadow: 0 5px 20px rgba(0, 0, 0, 0.1);
    max-width: 600px;
    width: 100%;
    margin: auto; /* Centrar en la pantalla */
}

.thank-you-container h1 {
    color: var(--button-send-color); /* Utiliza una variable existente */
    font-size: 2.5em;
    margin-bottom: 20px;
}

.thank-you-container p {
    font-size: 1.1em;
    line-height: 1.8;
    margin-bottom: 25px;
    color: var(--text-color-dark); /* Utiliza una variable existente */
}

.thank-you-logo {
    max-width: 200px; /* Ajusta el tamaño de tu logo */
    height: auto;
    margin-bottom: 30px;
}

/* --- MEDIA QUERIES (RESPONSIVE DESIGN) --- */
@media (max-width: 992px) {
    .two-columns,
    .two-columns-section .container {
        flex-direction: column; /* Apila las columnas en tablets y móviles */
        align-items: center; /* Centra el contenido apilado */
    }

    .column,
    .two-columns-section .column {
        min-width: unset; /* Reinicia el ancho mínimo */
        width: 100%; /* Cada columna ocupa el ancho completo */
        margin-bottom: 20px; /* Espacio entre columnas apiladas */
    }

    .left-column, .right-column {
        text-align: center; /* Centra el texto y la imagen en la columna izquierda */
    }
    .left-column p {
        text-align: left; /* Mantener el texto justificado si es largo */
    }

    .section-image,
    .two-columns-section .image-column img {
        max-width: 80%; /* Reduce el tamaño de la imagen en móviles si es muy grande */
    }

    .form-title {
        margin-top: 40px; /* Espacio extra sobre el formulario cuando las columnas se apilan */
    }
    .bullet-list, .numbered-list,
    .two-columns-section .bullet-list,
    .two-columns-section .numbered-list {
        margin-left: 0;
        margin-right: 0;
        padding: 0 15px; /* Ajusta el padding para que no se pegue a los bordes */
    }
    .bullet-list li, .numbered-list li {
        font-size: var(--font-size-base);
    }

    /* REGLA CLAVE: Las imágenes siempre arriba en móvil para secciones de 2 columnas */
    .two-columns-section .image-column {
        order: 1; /* La columna de la imagen va primero */
    }
    .two-columns-section .text-column {
        order: 2; /* La columna de texto va segunda */
    }
}

@media (max-width: 768px) {
    .hero-logo {
        width: 250px; /* Ajusta el tamaño del logo en móviles */
        height: auto; /* Mantiene la proporción */
    }

    .section-divider-title {
        font-size: 2em;
    }

    .section-divider-subtitle {
        font-size: var(--font-size-base);
    }

    .btn-whatsapp {
        padding: 12px 25px;
        font-size: 1em;
    }

    .final-cta-text {
        font-size: var(--font-size-large);
    }

    /* Media Query para la página de agradecimiento */
    .thank-you-container h1 {
        font-size: 2em; /* Ajuste para móviles en página de agradecimiento */
    }
}

@media (max-width: 480px) {
    .hero-section {
        min-height: 150px; /* Reduce la altura en móviles muy pequeños */
    }
    .hero-logo-container-height {
        height: 100px;
    }
    .hero-logo {
        width: 200px;
    }

    .section-divider {
        height: auto; /* Altura automática para el divisor en móviles muy pequeños */
        padding: 20px 15px; /* Más relleno en móviles pequeños */
    }

    .section-divider-title {
        font-size: 1.8em;
    }

    .section-divider-subtitle {
        font-size: 0.9em;
    }

    .content-section, .two-columns-section {
        padding: 40px 0; /* Menor padding general en móviles */
    }

    .contact-form {
        padding: 20px;
    }

    .btn-submit {
        padding: 10px 15px;
        font-size: var(--font-size-base);
    }

    /* Media Query para la página de agradecimiento */
    .thank-you-container h1 {
        font-size: 1.5em; /* Ajuste para móviles más pequeños en página de agradecimiento */
    }
    .thank-you-container p {
        font-size: 0.9em;
    }
}