/* =========================================
   1. RESET BÁSICO Y FUENTES
   ========================================= */
@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@600;700&family=Roboto:wght@400;500&display=swap');

* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
    scroll-behavior: smooth;
}

/* =========================================
   2. VARIABLES DE COLORES (Tu Design System)
   ========================================= */
:root {
    /* Modo Claro (Default - Colores sugeridos de la Profe) */
    --bg-principal: #F4F6F8;
    --bg-tarjetas: #FFFFFF;
    --bg-header-footer: #0B1F3A;
    --text-principal: #333333;
    --text-logo: #FFFFFF;
    --text-hero: #FFFFFF;
    --color-primario: #0B1F3A;
    /* Azul oscuro */
    --color-secundario: #0EA5E9;
    /* Azul medio */
    --sombra: 0 4px 12px rgba(0, 0, 0, 0.08);
}

/* Modo Oscuro */
.dark-mode {
    --bg-principal: #121212;
    --bg-tarjetas: #242424;
    --text-principal: #F4F6F8;
    /* Invertimos el texto a claro */
    --color-primario: #F4F6F8;
    /* Los títulos pasan a ser claros */
    --sombra: 0 4px 12px rgba(0, 0, 0, 0.4);
}

/* =========================================
   3. ESTILOS BASE (Desktop First)
   ========================================= */
body {
    font-family: 'Roboto', sans-serif;
    font-size: 16px;
    background-color: var(--bg-principal);
    color: var(--text-principal);
    /* Transición suave para cuando cambie de Light a Dark Mode */
    transition: background-color 0.3s ease, color 0.3s ease;
}

h1, h2, h3, .logo {
    font-family: 'Montserrat', sans-serif;
    color: var(--color-primario);
}

/* Ajustes de tamaños sugeridos de la profe */
h1 {
    font-size: 40px;
}

h2 {
    font-size: 28px;
    text-align: center;
    margin-bottom: 40px;
}

/* =========================================
   4. HEADER Y NAVEGACIÓN
   ========================================= */
.header {
    display: flex;
    flex-direction: column;
    /* Apila el logo arriba y el menú abajo */
    align-items: center;
    gap: 20px;
    /* Espacio entre el logo "Con Ingenio" y los links */
    padding: 30px 50px;
    background-color: var(--bg-header-footer);
    color: #FFFFFF;
    position: relative;
    /* Necesario para posicionar la luna/sol */
}

.logo {
    font-size: 28px;
    /* Un poco más grande para que destaque como título principal */
    font-weight: 700;
    color: var(--text-logo);
}

/* El botón de la luna lo fijamos en la esquina superior izquierda */
.btn-theme {
    position: absolute;
    top: 30px;
    left: 50px;
    background: none;
    border: none;
    font-size: 24px;
    cursor: pointer;
}

.nav-links ul {
    list-style: none;
    display: flex;
    gap: 30px;
    /* Separación entre los links */
}

.nav-links a {
    text-decoration: none;
    color: #FFFFFF;
    font-size: 16px;
    transition: opacity 0.3s ease;
}

.nav-links a:hover {
    opacity: 0.7;
    /* Pequeño efecto al pasar el mouse */
}

/* Estilo base del botón hamburguesa */
.btn-hamburger {
    display: none;
    /* Oculto en Desktop */
    position: absolute;
    top: 25px;
    left: 30px;
    /* Lo pondremos a la derecha, la luna/sol está a la izquierda */
    background: none;
    border: none;
    color: #FFFFFF;
    font-size: 30px;
    cursor: pointer;
}

/* =========================================
   5. SECCIÓN HERO (Inicio)
   ========================================= */
.hero {
    /* Aplicamos efectos como en figma*/
    background-image: linear-gradient(rgba(11, 31, 58, 0.7), rgba(11, 31, 58, 0.7)), url('../assets/img/fondodesktop.png');
    background-size: cover;
    background-position: center;
    padding: 100px 50px;
    text-align: center;
    color: #FFFFFF;
    /* El texto sobre la foto siempre es blanco para que se note */

    /* Modo Card de la sección hero */
    max-width: 1200px;
    margin: 40px auto;
    border-radius: 12px;
}

.hero-content {
    max-width: 800px;
    margin: 0 auto;
    /* Centra el contenido */
}

.hero-content h1 {
    color: var(--text-hero);
}

.hero p {
    margin: 20px 0;
    line-height: 1.6;
}

.hero-subtext {
    font-weight: 600;
    margin-bottom: 30px;
}

/* El botón azul que resalta */
.btn-primary {
    background-color: var(--color-secundario);
    color: #FFFFFF;
    border: none;
    padding: 15px 30px;
    font-size: 16px;
    font-weight: 600;
    border-radius: 8px;
    cursor: pointer;
    font-family: 'Montserrat', sans-serif;
    transition: background-color 0.3s ease;
}

.btn-primary:hover {
    background-color: #0284C7;
    /* Un celeste un poco más oscuro al hacer hover */
}

.call-to-action{
    display: inline-block; 
    text-decoration: none;
}

/* =========================================
   6. CLASES DE UTILIDAD GENERAL
   ========================================= */
/* Esta clase mantiene todas las secciones centradas y con buen respiro */
.section-padding {
    padding: 80px 50px;
    max-width: 1200px;
    margin: 0 auto;
}

/* =========================================
   7. SECCIÓN NUESTROS SERVICIOS
   ========================================= */
.grid-servicios {
    display: grid;
    /* Crea 4 columnas exactamente iguales (1fr) */
    grid-template-columns: repeat(4, 1fr);
    gap: 30px;
    margin-top: 40px;
}

.card {
    background-color: var(--bg-tarjetas);
    padding: 40px 20px;
    border-radius: 12px;
    box-shadow: var(--sombra);
    /* Usamos variable de sombra */
    text-align: center;
    /* Transición suave para el efecto hover y el modo oscuro */
    transition: transform 0.3s ease, background-color 0.3s ease;
}

/* Pequeño toque profesional: la tarjeta "flota" al pasar el mouse */
.card:hover {
    transform: translateY(-5px);
}

.card-icon {
    width: 70px;
    height: auto;
    margin-bottom: 20px;
}

.card h3 {
    font-size: 18px;
    margin-bottom: 15px;
    color: var(--color-primario);
}

.card p {
    font-size: 16px;
    line-height: 1.6;
    color: var(--text-principal);
}

/* =========================================
   8. SECCIÓN CONTACTO Y FORMULARIO
   ========================================= */
.grid-contacto {
    display: grid;
    /* La columna del formulario es un poco más ancha que la de la info (3 vs 2) */
    grid-template-columns: 3fr 2fr;
    gap: 60px;
    padding: 50px;
}

/* Estilos de los inputs */
.form-group {
    margin-bottom: 20px;
}

.form-group label {
    display: block;
    margin-bottom: 8px;
    font-size: 16px;
    font-weight: 500;
    text-align: left;
}

/* Aplicamos el mismo estilo a los 3 tipos de entrada */
.form-group input,
.form-group select,
.form-group textarea {
    width: 100%;
    padding: 15px;
    border: none;
    /* Usamos el color de fondo principal (el gris) para que destaquen sobre la tarjeta blanca */
    background-color: var(--bg-principal);
    border-radius: 8px;
    font-family: 'Roboto', sans-serif;
    color: var(--text-principal);
    transition: outline 0.3s ease, background-color 0.3s ease;
}

/* El borde celeste cuando haces clic en la caja para escribir */
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
    outline: 2px solid var(--color-secundario);
}

/* Textos de la info de empresa */
.info-empresa h3 {
    font-size: 20px;
    margin-bottom: 25px;
    color: var(--color-primario);
}

.info-empresa p {
    font-size: 16px;
    margin-bottom: 20px;
    line-height: 1.6;
}

.info-empresa a {
    color: var(--color-secundario);
    text-decoration: none;
    font-weight: 600;
}

/* Alineación y Divisor para la Info de la Empresa */
.info-empresa {
    text-align: left;
    /* Fuerza a que el texto se alinee a la izquierda rompiendo el centrado de la tarjeta */
    border-left: 2px solid rgba(128, 128, 128, 0.3);
    /* Dibuja la línea vertical. Usamos gris con transparencia para que se vea elegante en modo light y dark */
    padding-left: 40px; /* Añade una separacion entre la línea y la información dura de la empresa*/
}

/* =========================================
   9. SECCIÓN NOSOTROS Y FOOTER
   ========================================= */
.grid-nosotros {
    display: grid;
    /* 3 columnas iguales para Misión, Visión y Valores */
    grid-template-columns: repeat(3, 1fr);
    gap: 30px;
}

.footer {
    background-color: var(--bg-header-footer);
    color: #FFFFFF;
    text-align: center;
    padding: 20px;
    font-size: 14px;
    margin-top: 40px;
}

/* =========================================
   10. MEDIA QUERIES (Responsividad)
   ========================================= */

/* IPAD PRO Y PANTALLAS MEDIANAS (1200px) */
@media (max-width: 1200px) {
    .grid-servicios {
        grid-template-columns: repeat(2, 1fr);
    }

    .grid-nosotros {
        grid-template-columns: 1fr 1fr;
    }

    .grid-nosotros article:last-child {
        grid-column: 1 / -1;
        max-width: 400px;
        width: 100%;
        margin: 0 auto;
    }

    .hero {
        margin: 20px 15px;
    }
}

/* IPAD AIR Y TABLETS GRANDES (820px) */
@media (max-width: 820px) {

    /* Activamos la hamburguesa a la derecha y luna a la izquierda */
    .btn-hamburger {
        display: block;
        top: 30px;
        right: 30px;
        left: auto;
    }

    .btn-theme {
        top: 30px;
        left: 30px;
        right: auto;
    }

    /* Ocultamos menú normal y lo preparamos para el clic de JS */
    .nav-links {
        display: none;
        width: 100%;
        margin-top: 20px;
        text-align: right;
    }

    .nav-links.activo {
        display: block;
    }

    .nav-links ul {
        flex-direction: column;
        gap: 20px;
    }
}

/* TABLETS Y CELULARES (768px) */
@media (max-width: 768px) {
    .section-padding {
        padding: 60px 30px;
    }

    h1 {
        font-size: 32px;
    }

    /* Forzamos TODO a 1 sola columna vertical */
    .grid-servicios {
        grid-template-columns: 1fr;
    }

    .grid-contacto {
        grid-template-columns: 1fr;
        gap: 40px;
        padding: 30px;
    }

    .grid-nosotros {
        grid-template-columns: 1fr;
    }

    .grid-nosotros article:last-child {
        grid-column: auto;
        max-width: 100%;
    }

    /* Ajuste del divisor de contacto para móviles */
    .info-empresa {
        border-left: none;
        /* Borra la línea vertical */
        padding-left: 0;
        /* Quita el espacio lateral */

        border-top: 2px solid rgba(128, 128, 128, 0.3);
        /* Dibuja la nueva línea horizontal */
        padding-top: 40px;
        /* Da un respiro entre el formulario, la línea y el texto */
        margin-top: 10px;
        margin-left: 20px;
    }
}

/* CELULARES PEQUEÑOS (576px) */
@media (max-width: 576px) {
    h1 {
        font-size: 28px;
    }

    h2 {
        font-size: 24px;
    }

    .section-padding {
        padding: 40px 20px;
    }

    .header {
        padding: 15px 20px;
        gap: 15px;
    }

    /* Ajuste responsivo para que los botones interactivos no se salgan en pantallas enanas */
    .btn-hamburger {
        top: 20px;
        right: 20px;
    }

    .btn-theme {
        top: 20px;
        left: 20px;
    }
}