
:root{
  /* Paleta derivada del logo Sabnez */
  --celeste:#56A9F3;       /* azul claro del circuito */
  --azul:#325EB4;          /* azul royal del logo */
  --azul-hover:#27498C;
  --marino:#0B2347;        /* navy profundo */
  --marino-2:#122F5C;
  --fondo:#F4F8FC;         /* base clara */
  --fondo-2:#E9F1F9;
  --tinta:#15233B;
  --tinta-suave:#46586F;
  --linea:#D0DCEA;
  --code-bg:#0B2347;
  --code-line:#1A3A6B;
  --sintaxis:#F2B544;      /* solo dentro del editor, como resaltado de sintaxis */
  --radius:10px;
  --display:'Wix Madefor Display',sans-serif;
  --body:'Wix Madefor Text',sans-serif;
  --mono:'IBM Plex Mono',monospace;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--body);background:var(--fondo);color:var(--tinta);line-height:1.65;font-size:16px}
a{color:inherit}
:focus-visible{outline:3px solid var(--celeste);outline-offset:2px;border-radius:4px}
.wrap{max-width:1140px;margin:0 auto;padding:0 24px}
.eyebrow{font-family:var(--mono);font-size:.76rem;letter-spacing:.14em;text-transform:uppercase;color:var(--azul);display:inline-flex;align-items:center;gap:.55em}
.eyebrow::before{content:"";width:10px;height:10px;border:2.5px solid var(--celeste);border-radius:50%;display:inline-block}
h1,h2,h3{font-family:var(--display);line-height:1.14;letter-spacing:-.015em}
section{padding:88px 0;position:relative}
h2.titulo{font-size:clamp(1.7rem,3vw,2.4rem);margin-top:14px;font-weight:700}

/* Motivo de circuito (eco del logo) */
.circuit{position:absolute;pointer-events:none;opacity:.55}

/* Header */
header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.94);backdrop-filter:blur(8px);border-bottom:1px solid var(--linea)}
.nav{display:flex;align-items:center;justify-content:space-between;height:74px}
.logo-img{height:40px;display:block}
.nav-links{display:flex;gap:28px;list-style:none;align-items:center}
.nav-links a{text-decoration:none;font-size:.92rem;font-weight:500;color:var(--tinta-suave)}
.nav-links a:hover{color:var(--azul)}
.nav-links a.btn{color:#fff}
.nav-links a.btn:hover{color:#fff;background:var(--azul-hover)}
.btn{display:inline-block;background:var(--azul);color:#fff;text-decoration:none;font-weight:600;font-size:.95rem;padding:12px 24px;border-radius:var(--radius);border:none;cursor:pointer;transition:background .2s}
.btn:hover{background:var(--azul-hover)}
.btn-ghost{background:transparent;color:var(--azul);border:1.5px solid var(--azul)}
.btn-ghost:hover{background:var(--fondo-2)}
.menu-toggle{display:none;background:none;border:none;font-size:1.6rem;cursor:pointer;color:var(--tinta)}

/* Hero */
.hero{padding:80px 0 72px;overflow:hidden;background:linear-gradient(180deg,#FFFFFF 0%,var(--fondo) 100%)}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center;position:relative;z-index:1}
.hero h1{font-size:clamp(2.1rem,4.5vw,3.4rem);font-weight:800;margin:18px 0 20px}
.hero h1 .hl{background:linear-gradient(90deg,var(--celeste),var(--azul));-webkit-background-clip:text;background-clip:text;color:transparent}
.hero p.lead{font-size:1.1rem;color:var(--tinta-suave);max-width:48ch;margin-bottom:30px}
.hero-ctas{display:flex;gap:14px;flex-wrap:wrap}
.hero-meta{margin-top:34px;font-family:var(--mono);font-size:.8rem;color:var(--tinta-suave);display:flex;gap:22px;flex-wrap:wrap}
.hero-meta b{color:var(--azul);font-weight:500}

/* Panel de código — elemento firma */
.code-panel{background:var(--code-bg);border-radius:14px;box-shadow:0 24px 60px rgba(11,35,71,.30);overflow:hidden;font-family:var(--mono);font-size:.82rem;line-height:1.75;transform:rotate(.6deg)}
.code-bar{display:flex;align-items:center;gap:8px;padding:12px 16px;background:var(--code-line)}
.dot{width:11px;height:11px;border-radius:50%}
.code-bar .name{margin-left:10px;color:#9DBCE8;font-size:.75rem}
.code-body{padding:20px 22px;color:#D7E6F8;white-space:pre;overflow-x:auto}
.k{color:var(--celeste)}.t{color:var(--sintaxis)}.c{color:#5F7FAE;font-style:italic}
.cursor{display:inline-block;width:8px;height:1.1em;background:var(--celeste);vertical-align:text-bottom;animation:blink 1.1s steps(1) infinite}
@keyframes blink{50%{opacity:0}}

/* Franja de confianza */
.trust{background:var(--marino);color:#E7F0FA;padding:36px 0;position:relative;overflow:hidden}
.trust .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;position:relative;z-index:1}
.trust .item b{display:block;font-family:var(--display);font-size:1.7rem;font-weight:700;color:#fff}
.trust .item span{font-size:.85rem;color:#9DBCE8}

/* Servicios */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:44px}
.svc{background:#fff;border:1px solid var(--linea);border-radius:var(--radius);padding:28px 26px;transition:transform .2s,box-shadow .2s,border-color .2s;position:relative}
.svc:hover{transform:translateY(-4px);box-shadow:0 14px 34px rgba(11,35,71,.10);border-color:var(--celeste)}
.svc .tcode{font-family:var(--mono);font-size:.72rem;color:var(--azul);letter-spacing:.08em;text-transform:uppercase}
.svc h3{font-size:1.16rem;margin:8px 0 10px;font-weight:700}
.svc p{font-size:.93rem;color:var(--tinta-suave)}
.svc-extra{grid-column:1/-1;background:var(--fondo-2);border-style:dashed}

/* Nosotros */
.about{background:#fff}
.about-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:56px;margin-top:36px;align-items:start}
.about p{color:var(--tinta-suave);margin-bottom:16px;max-width:62ch}
.about .hito{border-left:3px solid var(--celeste);padding:4px 0 4px 18px;margin-bottom:18px}
.about .hito b{font-family:var(--mono);font-size:.78rem;color:var(--azul);display:block;letter-spacing:.08em}
.about .hito span{font-size:.95rem;color:var(--tinta)}

/* Modalidades */
.mode-list{margin-top:44px;border-top:1px solid var(--linea)}
.mode{display:grid;grid-template-columns:230px 1fr;gap:30px;padding:30px 0;border-bottom:1px solid var(--linea)}
.mode h3{font-size:1.14rem;font-weight:700}
.mode p{color:var(--tinta-suave);font-size:.96rem;max-width:64ch}

/* Experiencia */
.exp{background:var(--fondo-2)}
.exp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:44px}
.case{background:#fff;border-radius:var(--radius);padding:28px 26px;border-top:4px solid var(--azul)}
.case .sector{font-family:var(--mono);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--azul)}
.case h3{font-size:1.06rem;margin:10px 0 8px;font-weight:700}
.case p{font-size:.92rem;color:var(--tinta-suave)}
.case .stack{margin-top:14px;display:flex;gap:6px;flex-wrap:wrap}
.case .tag{font-family:var(--mono);font-size:.7rem;background:var(--fondo);border:1px solid var(--linea);border-radius:5px;padding:3px 8px;color:var(--tinta-suave)}
.exp-note{margin-top:26px;font-size:.85rem;color:var(--tinta-suave);font-style:italic}

/* Contacto */
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:56px;margin-top:44px;align-items:start}
.contact-info p{color:var(--tinta-suave);margin-bottom:18px;max-width:44ch}
.contact-info .line{font-family:var(--mono);font-size:.88rem;margin-bottom:10px}
.contact-info .line a{color:var(--azul);text-decoration:none}
form{background:#fff;border:1px solid var(--linea);border-radius:14px;padding:32px;box-shadow:0 10px 30px rgba(11,35,71,.06)}
.field{margin-bottom:18px}
label{display:block;font-weight:600;font-size:.88rem;margin-bottom:6px}
input,textarea,select{width:100%;font-family:var(--body);font-size:.95rem;padding:11px 13px;border:1px solid var(--linea);border-radius:8px;background:var(--fondo)}
input:focus,textarea:focus,select:focus{outline:2px solid var(--azul);border-color:var(--azul)}
.consent{display:flex;gap:10px;align-items:flex-start;font-size:.8rem;color:var(--tinta-suave);margin:18px 0}
.consent input{width:auto;margin-top:3px}
.consent a{color:var(--azul)}

/* Footer */
footer{background:var(--marino);color:#9DBCE8;padding:56px 0 32px;font-size:.88rem;position:relative;overflow:hidden}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;margin-bottom:40px;position:relative;z-index:1}
.foot-logo{height:38px;filter:brightness(0) invert(1);opacity:.95}
footer h4{color:#fff;font-family:var(--body);font-size:.82rem;text-transform:uppercase;letter-spacing:.1em;margin-bottom:14px}
footer ul{list-style:none}
footer li{margin-bottom:9px}
footer a{color:#9DBCE8;text-decoration:none}
footer a:hover{color:var(--celeste)}
.legalbar{border-top:1px solid var(--code-line);padding-top:24px;font-size:.76rem;line-height:1.7;color:#6E8BB8;position:relative;z-index:1}

/* Banner de cookies */
.cookies{position:fixed;bottom:18px;left:18px;right:18px;max-width:520px;background:#fff;border:1px solid var(--linea);border-radius:14px;box-shadow:0 18px 50px rgba(11,35,71,.25);padding:22px;z-index:100;display:none}
.cookies.show{display:block}
.cookies p{font-size:.84rem;color:var(--tinta-suave);margin-bottom:14px}
.cookies .row{display:flex;gap:10px;flex-wrap:wrap}
.cookies .btn{padding:9px 18px;font-size:.85rem}

@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  html{scroll-behavior:auto}
}
@media (max-width:920px){
  .hero-grid,.contact-grid,.about-grid{grid-template-columns:1fr}
  .code-panel{transform:none}
  .svc-grid,.exp-grid{grid-template-columns:1fr 1fr}
  .trust .wrap{grid-template-columns:1fr 1fr;row-gap:26px}
  .mode{grid-template-columns:1fr;gap:8px}
  .foot-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:640px){
  .nav-links{display:none;position:absolute;top:74px;left:0;right:0;background:#fff;flex-direction:column;padding:20px;border-bottom:1px solid var(--linea);gap:18px}
  .nav-links.open{display:flex}
  .menu-toggle{display:block}
  .svc-grid,.exp-grid,.foot-grid{grid-template-columns:1fr}
  section{padding:64px 0}
  .logo-img{height:34px}
}

/* ── Páginas legales ── */
.legal-main{max-width:820px;margin:0 auto;padding:64px 24px 88px}
.legal-main h1{font-size:clamp(1.8rem,3.4vw,2.5rem);font-weight:800;margin:10px 0 6px}
.legal-main .fecha{font-family:var(--mono);font-size:.8rem;color:var(--tinta-suave);margin-bottom:34px}
.legal-main h2{font-size:1.3rem;font-weight:700;margin:36px 0 12px;color:var(--marino)}
.legal-main h3{font-size:1.05rem;font-weight:700;margin:24px 0 10px}
.legal-main p,.legal-main li{color:var(--tinta-suave);font-size:.97rem;margin-bottom:12px}
.legal-main ul,.legal-main ol{padding-left:24px;margin-bottom:16px}
.legal-main a{color:var(--azul)}
.legal-main table{width:100%;border-collapse:collapse;margin:18px 0;font-size:.9rem}
.legal-main th,.legal-main td{border:1px solid var(--linea);padding:9px 12px;text-align:left;color:var(--tinta-suave)}
.legal-main th{background:var(--fondo-2);color:var(--tinta);font-weight:600}
.legal-main hr{border:none;border-top:1px solid var(--linea);margin:30px 0}
.legal-main em{color:var(--tinta-suave)}
/* ── Estados del formulario ── */
.form-status{display:none;margin-top:14px;padding:12px 14px;border-radius:8px;font-size:.9rem}
.form-status.ok{display:block;background:#E8F6EE;color:#1F6B43;border:1px solid #BCE3CC}
.form-status.error{display:block;background:#FBEAEA;color:#9B2C2C;border:1px solid #F0C5C5}
.btn[disabled]{opacity:.6;cursor:wait}
/* ── 404 ── */
.notfound{min-height:55vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:60px 24px}
.notfound h1{font-size:clamp(2.2rem,5vw,3.4rem);font-weight:800;margin-bottom:12px}
.notfound p{color:var(--tinta-suave);margin-bottom:26px}
