:root {
    --navy-blue: #0A192F;
    --navy-darker: #050C16;
    --cyan-neon: #00E5FF;
    --skynet-orange: #FF8C00;
    --white: #FFFFFF;
    --light-gray: #EDF2F7;
    --dark-text: #1A202C;
}

* { margin: 0; padding: 0; box-sizing: border-box; scroll-behavior: smooth; }

body {
    font-family: 'Inter', sans-serif;
    color: var(--dark-text);
    background-color: var(--light-gray);
    /* FONDO SKYNET RECUPERADO */
    background-image: 
        linear-gradient(rgba(0, 229, 255, 0.05) 1px, transparent 1px),
        linear-gradient(90deg, rgba(0, 229, 255, 0.05) 1px, transparent 1px);
    background-size: 40px 40px;
    line-height: 1.6;
}

h1, h2, h3, h4 { font-family: 'Rajdhani', sans-serif; }
.container { width: 90%; max-width: 1200px; margin: auto; }
.text-white { color: var(--white) !important; }

.whatsapp-float {
    position: fixed; width: 60px; height: 60px; bottom: 30px; right: 30px;
    background-color: #25d366; color: #FFF; border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-size: 30px; z-index: 2000; box-shadow: 2px 5px 15px rgba(0,0,0,0.3);
    text-decoration: none;
}

header { background-color: var(--navy-blue); padding: 1rem 0; position: fixed; width: 100%; top: 0; z-index: 1000; }
.nav-container { display: flex; justify-content: space-between; align-items: center; }
.header-logo { height: 40px; }
.nav-links { list-style: none; display: flex; gap: 2rem; }
.nav-links a { color: var(--white); text-decoration: none; font-weight: 600; font-size: 0.8rem; text-transform: uppercase; }

/* HERO CON BRILLO SKYNET */
#hero {
    background-color: var(--navy-blue); 
    min-height: 80vh; 
    display: flex; 
    align-items: center;
    padding-top: 100px; 
    color: var(--white); 
    text-align: center;
    background-image: radial-gradient(circle at 50% 50%, rgba(0, 229, 255, 0.15) 0%, transparent 60%);
}
#hero h1 { font-size: 4rem; line-height: 1.1; margin-bottom: 1rem; }
.highlight { color: var(--cyan-neon); }

.btn-primary {
    display: inline-block; background-color: var(--skynet-orange); color: var(--navy-blue);
    padding: 15px 40px; text-decoration: none; font-weight: 800; text-transform: uppercase;
    border-radius: 4px; border: none; cursor: pointer; transition: 0.3s;
}
.btn-primary:hover { background-color: #e67e00; }

.btn-secondary {
    display: inline-block; background-color: transparent; color: var(--cyan-neon); 
    border: 2px solid var(--cyan-neon); padding: 13px 40px; text-decoration: none; 
    font-weight: 800; text-transform: uppercase; border-radius: 4px; cursor: pointer; transition: 0.3s;
}
.btn-secondary:hover { background-color: rgba(0, 229, 255, 0.1); }

.stack-tecnologico { background-color: var(--white); padding: 25px 0; border-bottom: 1px solid #ddd; overflow: hidden; }
.stack-linea { display: flex; justify-content: center; align-items: center; gap: 1.5rem; font-weight: 700; color: var(--navy-blue); font-size: 1.15rem; font-family: 'Rajdhani'; white-space: nowrap; }
.dot { color: var(--cyan-neon); font-size: 1.4rem; }

#mision-critica { background-color: var(--navy-darker); padding: 80px 0; border-bottom: 2px solid var(--cyan-neon); }
.grid-mision { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1rem; margin-top: 3rem; }
.mision-card { background: rgba(255,255,255,0.05); padding: 1.2rem; border: 1px solid rgba(0, 229, 255, 0.2); border-radius: 8px; color: white; text-align: center; }
.mision-card i { font-size: 2rem; color: var(--cyan-neon); margin-bottom: 0.8rem; }
.mision-card h4 { color: var(--skynet-orange); margin-bottom: 0.8rem; font-size: 1.1rem; min-height: 2.8rem; display: flex; align-items: center; justify-content: center; }
.mision-card p { font-size: 0.85rem; line-height: 1.4; }
.consultoria-card { border: 1px solid var(--skynet-orange); background: rgba(255, 140, 0, 0.1); }

section { padding: 80px 0; }
h2 { text-align: center; font-size: 3rem; margin-bottom: 3rem; color: var(--navy-blue); }
.grid-servicios { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 2rem; }
.card { background: white; padding: 2.5rem; border-top: 4px solid var(--cyan-neon); border-radius: 8px; box-shadow: 0 4px 6px rgba(0,0,0,0.05); transition: 0.3s; }
.card:hover { transform: translateY(-5px); border-top-color: var(--skynet-orange); }

/* NOSOTROS - LAYOUT EJECUTIVO vCIO */
#nosotros { background-color: var(--navy-blue); color: var(--white); }
#nosotros h2 { text-align: left; margin-bottom: 0; max-width: 500px; font-size: 2.8rem; }
.nosotros-header { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 2rem; border-bottom: 1px solid rgba(0, 229, 255, 0.2); padding-bottom: 2rem; margin-bottom: 2rem; }
.metricas-row { display: flex; gap: 4rem; flex-wrap: wrap; }
.metrica { border-left: 3px solid var(--skynet-orange); padding-left: 1.5rem; }
.metrica h4 { font-size: 3.5rem; color: var(--skynet-orange); line-height: 1; margin-bottom: 0.3rem; }
.nosotros-body p { font-size: 1.15rem; line-height: 1.8; margin-bottom: 1.2rem; color: #EDF2F7; max-width: 1000px; }

/* MARCA DE AGUA VECTORIAL CON BRILLO SKYNET (SECCIÓN NOSOTROS) */
.marca-de-agua-vcs {
    position: absolute; bottom: -30px; right: -20px; width: 600px; height: 300px;
    background-image: url("data:image/svg+xml,%3Csvg%20viewBox%3D%220%200%20605%20196%22%20xmlns%3D%22http%3A//www.w3.org/2000/svg%22%3E%0A%20%20%3Cpath%20d%3D%22M%20262%2C15%20L%20249%2C26%20L%20233%2C44%20L%20227%2C56%20L%20220%2C83%20L%20221%2C117%20L%20224%2C129%20L%20235%2C152%20L%20242%2C161%20L%20257%2C175%20L%20264%2C180%20L%20284%2C189%20L%20309%2C193%20L%20386%2C193%20L%20389%2C190%20L%20408%2C151%20L%20407%2C147%20L%20376%2C147%20L%20375%2C148%20L%20374%2C147%20L%20343%2C147%20L%20342%2C148%20L%20306%2C147%20L%20294%2C143%20L%20282%2C136%20L%20273%2C124%20L%20267%2C105%20L%20267%2C87%20L%20270%2C75%20L%20278%2C61%20L%20288%2C53%20L%20297%2C49%20L%20321%2C46%20L%20322%2C47%20L%20352%2C47%20L%20353%2C46%20L%20386%2C47%20L%20388%2C46%20L%20407%2C8%20L%20406%2C6%20L%20407%2C3%20L%20402%2C1%20L%20299%2C2%20L%20282%2C6%20Z%22%20fill%3D%22%23FFFFFF%22%20/%3E%0A%20%20%3Cpath%20d%3D%22M%20429%2C12%20L%20420%2C21%20L%20412%2C34%20L%20408%2C48%20L%20408%2C68%20L%20415%2C90%20L%20430%2C107%20L%20442%2C114%20L%20458%2C118%20L%20545%2C119%20L%20552%2C123%20L%20555%2C129%20L%20555%2C136%20L%20553%2C141%20L%20546%2C146%20L%20429%2C147%20L%20426%2C150%20L%20406%2C192%20L%20408%2C194%20L%20551%2C194%20L%20569%2C190%20L%20584%2C181%20L%20596%2C167%20L%20604%2C144%20L%20604%2C121%20L%20602%2C112%20L%20595%2C98%20L%20585%2C87%20L%20570%2C78%20L%20549%2C73%20L%20465%2C73%20L%20458%2C67%20L%20456%2C58%20L%20457%2C54%20L%20465%2C47%20L%20577%2C47%20L%20594%2C14%20L%20598%2C2%20L%20596%2C0%20L%20462%2C0%20L%20441%2C5%20Z%22%20fill%3D%22%23FFFFFF%22%20/%3E%0A%20%20%3Cpath%20d%3D%22M%200%2C2%20L%2082%2C167%20L%2093%2C184%20L%20102%2C192%20L%20110%2C195%20L%20128%2C194%20L%20137%2C189%20L%20148%2C176%20L%20194%2C84%20L%20208%2C59%20L%20218%2C37%20L%20236%2C4%20L%20232%2C0%20L%20229%2C1%20L%20226%2C0%20L%20225%2C1%20L%20186%2C0%20L%20183%2C2%20L%20125%2C118%20L%20120%2C131%20L%20117%2C133%20L%2070%2C40%20L%2053%2C3%20L%2049%2C0%20L%203%2C0%20Z%22%20fill%3D%22%23FFFFFF%22%20/%3E%0A%3C/svg%3E");
    background-size: contain; background-repeat: no-repeat; background-position: right bottom;
    opacity: 0.05; z-index: 0; pointer-events: none;
    filter: drop-shadow(0 0 10px rgba(0, 229, 255, 1)) drop-shadow(0 0 20px rgba(0, 229, 255, 0.8));
}
.nosotros-grid, .nosotros-header, .nosotros-body { position: relative; z-index: 1; }

.faq-grid-container { display: grid; grid-template-columns: 1fr 1fr; gap: 2.5rem; margin-top: 2rem; }
.faq-column { display: flex; flex-direction: column; gap: 1.5rem; }
.faq-item { background: white; padding: 1.5rem; border-radius: 8px; border-left: 4px solid var(--cyan-neon); box-shadow: 0 4px 10px rgba(0,0,0,0.05); }
.faq-item summary { font-weight: 700; cursor: pointer; }

#contacto { background-color: var(--navy-blue); border-top: 2px solid var(--skynet-orange); }
.contacto-wrapper { display: flex; flex-wrap: wrap; max-width: 1100px; margin: 0 auto; background: var(--white); border-radius: 8px; overflow: hidden; align-items: stretch; }
.contacto-info-box { flex: 1; min-width: 320px; padding: 3rem; background: #F8FAFC; color: var(--navy-blue); }
.contacto-lista { list-style: none; margin: 1.5rem 0; }
.contacto-lista li { margin-bottom: 1rem; font-weight: 600; display: flex; align-items: center; }
.contacto-lista i { color: var(--skynet-orange); margin-right: 15px; }
.contacto-bullets { margin-top: 2rem; border-top: 1px solid #ddd; padding-top: 1.5rem; }
.bullet-item { display: flex; align-items: center; margin-bottom: 0.8rem; }
.bullet-item i { color: #25d366; margin-right: 10px; }
.bullet-item span { font-size: 0.9rem; font-weight: 700; color: #4A5568; }

.contacto-form-box { flex: 1.5; min-width: 320px; padding: 3rem; background: white; }
.form-group { margin-bottom: 1.5rem; }
.form-group input, .form-group textarea { width: 100%; padding: 15px; border: 1px solid #ddd; border-radius: 4px; }

/* MARCA DE AGUA EN CONTACTO (IMAGEN PNG) */
.contacto-watermark {
    position: absolute; bottom: -30px; right: -40px; width: 300px;
    opacity: 0.05; pointer-events: none; mix-blend-mode: multiply; /* Oculta el fondo negro de la imagen */
}

footer { background-color: var(--navy-darker); color: var(--white); text-align: center; padding: 3rem 0; }

@media (max-width: 1100px) {
    .grid-mision { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 992px) {
    .faq-grid-container, .grid-mision { grid-template-columns: 1fr; }
    .nosotros-header { flex-direction: column; align-items: flex-start; }
    .metricas-row { gap: 2rem; }
    .stack-linea { animation: scrollStack 25s linear infinite; width: max-content; padding-left: 100%; }
}
@keyframes scrollStack { 0% { transform: translateX(0); } 100% { transform: translateX(-100%); } }