/* Visión general */

:root {
    /* Paleta de Colores */
    --color-primary-dark-blue: #1A2B3C;
    --color-neutral-light-gray: #F0F2F5;
    --color-neutral-medium-gray: #CCCCCC;
    --color-neutral-white: #FFFFFF;
    --color-accent-lime: #8EFF45;
    --color-accent-cyan: #00C6FF;
    --color-accent-orange: #FF8C42;

    /* Tipografía */
    --font-heading: 'Montserrat', sans-serif; /* Alternativas: Poppins, Inter, Outfit */
    --font-body: 'Roboto', sans-serif;       /* Alternativas: Open Sans, Lato, Nunito */
    --font-size-base: 16px;

    /* Espaciado */
    --spacing-xs: 8px;
    --spacing-sm: 16px;
    --spacing-md: 24px;
    --spacing-lg: 48px;
    --spacing-xl: 80px;

    /* Sombras y Bordes */
    --shadow-light: 0 4px 15px rgba(0, 0, 0, 0.08);
    --shadow-medium: 0 8px 30px rgba(0, 0, 0, 0.15);
    --border-radius-sm: 4px;
    --border-radius-md: 8px;

    /* Transiciones */
    --transition-speed-fast: 0.2s;
    --transition-speed-medium: 0.3s;
    --transition-speed-slow: 0.5s;
    --transition-easing: ease-in-out;
}

html {
    scroll-behavior: smooth;
    overflow-x: hidden; /* Asegura que nada desborde la pantalla horizontalmente */
}

body {
    font-family: var(--font-body);
    font-size: var(--font-size-base);
    line-height: 1.6;
    color: var(--color-primary-dark-blue);
    background-color: var(--color-neutral-light-gray);
    margin: 0;
    padding: 0;
    overflow-x: hidden; /* Previene scroll horizontal no deseado */
    transition: opacity 0.4s ease-in-out;
}

body.fade-out {
    opacity: 0;
}

h1, h2, h3, h4, h5, h6 {
    font-family: var(--font-heading);
    color: var(--color-primary-dark-blue);
    line-height: 1.2;
    margin-bottom: var(--spacing-sm);
}


/* Tipografía */

/* Contenedor general para centrar contenido */
.container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 var(--spacing-sm);
}

/* Base de layout flexible para rejillas */
.service-grid, .lab-interface, .contact-layout {
    display: grid;
    gap: var(--spacing-md); /* Espacio entre elementos de la rejilla */
    padding: var(--spacing-lg) 0;
}

/* Media Queries para diseño responsive */
@media (min-width: 600px) {
    .container {
        padding: 0 var(--spacing-md);
    }
    .service-grid {
        grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); /* 2 columnas en tablets */
    }
    .contact-layout {
        grid-template-columns: 1fr; /* Una columna por defecto */
    }
}

@media (min-width: 900px) {
    .service-grid {
        grid-template-columns: repeat(3, 1fr); /* 3 columnas en escritorio pequeño */
    }
    .contact-layout {
        grid-template-columns: 2fr 1fr; /* Formulario y detalles lado a lado */
        gap: var(--spacing-xl);
    }
}

@media (min-width: 1200px) {
    .service-grid {
        grid-template-columns: repeat(4, 1fr); /* 4 columnas en escritorio grande */
    }
}



/* Componentes clave */

.main-header {
    background-color: var(--color-neutral-white);
    padding: var(--spacing-sm) 0;
    box-shadow: var(--shadow-light);
    position: sticky;
    top: 0;
    z-index: 1000;
    transition: background-color var(--transition-speed-medium) var(--transition-easing);
}

.main-header .container {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.main-nav ul {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex; /* Escritorio: elementos en línea */
}

.main-nav ul li a {
    text-decoration: none;
    color: var(--color-primary-dark-blue);
    padding: var(--spacing-xs) var(--spacing-sm);
    font-weight: 500;
    transition: color var(--transition-speed-fast) var(--transition-easing),
                background-color var(--transition-speed-fast) var(--transition-easing);
}

.main-nav ul li a:hover,
.main-nav ul li a.active {
    color: var(--color-accent-lime);
    background-color: rgba(var(--color-accent-lime), 0.1);
    border-radius: var(--border-radius-sm);
}

/* Menú móvil (oculto por defecto en escritorio) */
.menu-toggle {
    display: none; /* Oculto en escritorio */
    /* Estilos para icono hamburguesa */
}

@media (max-width: 899px) {
    .main-nav ul {
        display: flex; /* Ocultar menú en móvil por defecto */
        flex-direction: column;
        position: absolute;
        top: 100%;
        right: 0;
        background-color: var(--color-primary-dark-blue);
        width: 70%; /* Panel lateral */
        height: calc(100vh - 60px); /* Altura completa menos header */
        padding: var(--spacing-md);
        box-shadow: var(--shadow-medium);
        transform: translateX(100%); /* Oculto a la derecha */
        transition: transform var(--transition-speed-medium) var(--transition-easing);
    }

    .main-nav ul.is-open { /* Clase añadida con JS */
        transform: translateX(0); /* Mostrar panel */
    }

    .main-nav ul li a {
        color: var(--color-neutral-white);
        padding: var(--spacing-sm) 0;
        width: 100%;
        display: block;
    }

    .menu-toggle {
        display: block; /* Mostrar hamburguesa en móvil */
    }
}



/* Sección servicios */

.service-card {
    background-color: var(--color-neutral-white);
    padding: var(--spacing-md);
    border-radius: var(--border-radius-md);
    box-shadow: var(--shadow-light);
    text-align: center;
    transition: transform var(--transition-speed-medium) var(--transition-easing),
                box-shadow var(--transition-speed-medium) var(--transition-easing);
}

.service-card:hover {
    transform: translateY(-8px); /* Elevación sutil */
    box-shadow: var(--shadow-medium); /* Sombra más pronunciada */
}

.service-card .service-icon {
    margin-bottom: var(--spacing-sm);
}

.service-card .service-icon img {
    width: 60px; /* Tamaño del icono */
    height: 60px;
    object-fit: contain;
    filter: drop-shadow(0 2px 5px rgba(0, 0, 0, 0.1)); /* Sombra ligera para el icono */
}

.service-card h3 {
    font-size: 1.4em;
    margin-bottom: var(--spacing-xs);
}

.service-card .service-description {
    font-size: 0.95em;
    color: #555;
    min-height: 4em; /* Asegurar altura consistente */
}



/* Sección osint */

.osint-lab-section {
    background-color: var(--color-primary-dark-blue);
    color: var(--color-neutral-white);
    padding: var(--spacing-xl) 0;
}

.osint-lab-section .section-title,
.osint-lab-section .section-description {
    color: var(--color-neutral-white);
}

.lab-interface {
    display: grid;
    gap: var(--spacing-lg);
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); /* Distribución flexible */
    padding-bottom: var(--spacing-xl);
}

.tool-module {
    background-color: #283C50; /* Fondo más oscuro para el módulo */
    padding: var(--spacing-md);
    border-radius: var(--border-radius-md);
    box-shadow: var(--shadow-medium);
    border: 1px solid rgba(255, 255, 255, 0.1);
}

.tool-module h3 {
    color: var(--color-accent-lime);
    margin-bottom: var(--spacing-sm);
}

.tool-input {
    width: 100%;
    padding: var(--spacing-xs);
    border: 1px solid var(--color-neutral-medium-gray);
    border-radius: var(--border-radius-sm);
    background-color: #354960;
    color: var(--color-neutral-white);
    font-family: monospace; /* Para un toque "techy" */
    transition: border-color var(--transition-speed-fast) var(--transition-easing);
}

.tool-input:focus {
    outline: none;
    border-color: var(--color-accent-cyan);
    box-shadow: 0 0 0 3px rgba(var(--color-accent-cyan), 0.3);
}

.btn-tool {
    background-color: var(--color-accent-lime);
    color: var(--color-primary-dark-blue);
    border: none;
    padding: var(--spacing-xs) var(--spacing-sm);
    border-radius: var(--border-radius-sm);
    cursor: pointer;
    font-weight: bold;
    margin-top: var(--spacing-sm);
    transition: background-color var(--transition-speed-fast) var(--transition-easing),
                transform var(--transition-speed-fast) var(--transition-easing);
}

.btn-tool:hover {
    background-color: #72E630; /* Tono más claro de lima */
    transform: translateY(-2px);
}

.tool-results {
    background-color: #1A2B3C;
    border: 1px solid rgba(255, 255, 255, 0.2);
    border-radius: var(--border-radius-sm);
    margin-top: var(--spacing-sm);
    padding: var(--spacing-sm);
    min-height: 80px; /* Para visualizar los resultados */
    font-family: 'Courier New', monospace;
    color: var(--color-neutral-light-gray);
    position: relative;
    overflow: hidden; /* Para animaciones de carga */
}

/* Indicador de carga (animación conceptual) */
.loading-indicator {
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 4px;
    background-color: var(--color-accent-cyan);
    animation: loading-bar 1.5s infinite linear;
    display: none; /* Oculto por defecto, visible con JS */
}

.tool-results.is-loading .loading-indicator {
    display: block;
}

@keyframes loading-bar {
    0% { left: -100%; }
    50% { left: 100%; }
    100% { left: -100%; }
}

.osint-sidebar {
    background-color: rgba(var(--color-primary-dark-blue), 0.8);
    border-left: 4px solid var(--color-accent-lime);
    padding: var(--spacing-md);
    border-radius: var(--border-radius-md);
    margin-top: var(--spacing-lg);
}

.osint-sidebar h3 {
    color: var(--color-accent-lime);
    margin-bottom: var(--spacing-xs);
}



/* Botones de acción */

.btn {
    display: inline-block;
    padding: var(--spacing-xs) var(--spacing-md);
    border-radius: var(--border-radius-sm);
    font-weight: 600;
    text-decoration: none;
    cursor: pointer;
    text-align: center;
    transition: all var(--transition-speed-fast) var(--transition-easing);
    font-family: var(--font-heading);
    white-space: nowrap; /* Evita que el texto del botón se rompa */
}

.btn-primary {
    background-color: var(--color-accent-lime);
    color: var(--color-primary-dark-blue);
    border: 2px solid var(--color-accent-lime);
}

.btn-primary:hover {
    background-color: #72E630; /* Tono más claro */
    transform: translateY(-2px); /* Pequeña elevación */
    box-shadow: 0 4px 10px rgba(var(--color-accent-lime), 0.3);
}

.btn-secondary {
    background-color: transparent;
    color: var(--color-primary-dark-blue);
    border: 2px solid var(--color-primary-dark-blue);
}

.btn-secondary:hover {
    background-color: var(--color-primary-dark-blue);
    color: var(--color-neutral-white);
    transform: translateY(-2px);
}

.btn-tertiary { /* Para enlaces complementarios, como "Aprende más" */
    background-color: transparent;
    color: var(--color-accent-cyan);
    border: 1px solid var(--color-accent-cyan);
}

.btn-tertiary:hover {
    background-color: var(--color-accent-cyan);
    color: var(--color-primary-dark-blue);
}



/* Animaciones más que sutiles */

.fade-in-on-scroll { /* Clase añadida por JS cuando el elemento es visible */
    opacity: 0;
    transform: translateY(20px);
    transition: opacity var(--transition-speed-slow) ease-out,
                transform var(--transition-speed-slow) ease-out;
}

.fade-in-on-scroll.is-visible { /* Clase que activa la animación */
    opacity: 1;
    transform: translateY(0);
}



/* Efecto de fondo sutiles */

/* Ejemplo conceptual de fondo con partículas/líneas animadas para .hero-background-effect */
.hero-background-effect {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    overflow: hidden;
    z-index: -1;
}

.hero-background-effect::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 200%;
    height: 200%;
    background: radial-gradient(circle at 10% 20%, rgba(0,198,255,0.1) 0%, transparent 50%),
                radial-gradient(circle at 80% 90%, rgba(142,255,69,0.1) 0%, transparent 50%);
    animation: subtle-pulse 15s infinite ease-in-out alternate;
}

@keyframes subtle-pulse {
    0% { transform: scale(1); opacity: 0.8; }
    100% { transform: scale(1.1); opacity: 1; }
}