  /* ============================================================
     DESIGN TOKENS
     ============================================================ */
  :root{
    --bg: #010004;
    --surface: #101013;
    --surface-2: #1a1a1d;
    --surface-3: #212124;
    --line: rgba(255,255,255,0.08);
    --line-strong: rgba(255,255,255,0.16);
    --ink: #ffffff;
    --ink-mid: #a8a8a8;
    --ink-dim: #6e6e72;
    --accent: #4d8eff;
    --accent-soft: rgba(77,142,255,0.14);
    --radius: 14px;
    --font: 'Geist', system-ui, sans-serif;
    --mono: 'Geist Mono', monospace;
  }

  *{margin:0;padding:0;box-sizing:border-box;}
  html{scroll-behavior:smooth;}
  body{
    background:var(--bg);
    color:var(--ink);
    font-family:var(--font);
    font-size:16px;
    line-height:1.6;
    -webkit-font-smoothing:antialiased;
    overflow-x:hidden;
  }
  ::selection{ background:var(--accent); color:#020a1a; }
  img{max-width:100%;height:auto;}
  a{color:inherit;}

  .wrap{ max-width:1240px; margin:0 auto; padding:0 28px; }
  section{ padding:110px 0; position:relative; }

  .eyebrow{
    font-family:var(--mono);
    font-size:12px;
    letter-spacing:.14em;
    text-transform:uppercase;
    color:var(--ink-mid);
    display:flex; align-items:center; gap:10px;
    margin-bottom:22px;
  }
  .eyebrow::before{ content:''; width:7px; height:7px; border-radius:50%; background:var(--accent); box-shadow:0 0 12px var(--accent); }

  h2.title{
    font-size:clamp(32px,4.6vw,52px);
    font-weight:500;
    letter-spacing:-0.04em;
    line-height:1.05;
    max-width:760px;
    margin-bottom:18px;
  }
  p.sub{ color:var(--ink-mid); max-width:620px; font-size:17px; }

  /* ============================================================
     NAV
     ============================================================ */
  nav{
    position:fixed; top:0; left:0; right:0; z-index:100;
    backdrop-filter:blur(18px);
    background:rgba(1,0,4,0.55);
    border-bottom:1px solid var(--line);
    transition:transform .38s ease;
  }
  nav.nav-hidden{ transform:translateY(-102%); }
  .nav-inner{
    max-width:1240px; margin:0 auto; padding:16px 28px;
    display:grid; grid-template-columns:1fr auto 1fr; align-items:center; gap:18px;
  }
  .brand{
    display:flex; align-items:center; gap:10px;
    font-weight:600; letter-spacing:.12em; font-size:15px;
    text-decoration:none; justify-self:start;
  }
  .brand .mark{ width:9px; height:9px; border-radius:50%; background:var(--accent); box-shadow:0 0 14px var(--accent); }
  .nav-links{ display:flex; gap:34px; list-style:none; justify-self:center; }
  .nav-links a{ font-size:14px; color:var(--ink-mid); text-decoration:none; transition:color .25s; }
  .nav-links a:hover{ color:var(--ink); }
  .nav-right{ justify-self:end; display:flex; align-items:center; gap:12px; }
  .nav-cta{
    font-size:13.5px;
    background:#fff; color:#0a0a0c;
    text-decoration:none; padding:10px 20px; border-radius:100px;
    font-weight:500; transition:transform .25s, box-shadow .25s;
    white-space:nowrap;
  }
  .nav-cta:hover{ transform:translateY(-1px); box-shadow:0 8px 28px rgba(255,255,255,.15); }
  .nav-toggle{
    display:none; flex-direction:column; justify-content:center; gap:4px;
    width:40px; height:40px; background:transparent;
    border:1px solid var(--line-strong); border-radius:8px; cursor:pointer;
  }
  .nav-toggle span{ display:block; width:16px; height:2px; background:var(--ink); margin:0 auto; border-radius:2px; transition:.3s; }
  nav.open .nav-toggle span:nth-child(1){ transform:translateY(6px) rotate(45deg); }
  nav.open .nav-toggle span:nth-child(2){ opacity:0; }
  nav.open .nav-toggle span:nth-child(3){ transform:translateY(-6px) rotate(-45deg); }

  /* ============================================================
     HERO — paisaje rocoso + luna líquida (como el referente)
     ============================================================ */
  .hero{
    position:relative;
    height:100vh; min-height:760px;
    display:flex; flex-direction:column;
    padding:96px 0 36px;
    overflow:hidden;
  }
  /* terreno lunar + cielo de niebla gris (como el referente) */
  .hero-photo{
    position:absolute; inset:0; z-index:0; pointer-events:none;
    background-image:url('https://images.unsplash.com/photo-1473580044384-7ba9967e16a0?w=2000&q=80&auto=format&fit=crop');
    background-size:cover;
    background-position:center bottom;
    filter:grayscale(1) brightness(.42) contrast(1.25);
  }
  .hero-photo::after{
    content:''; position:absolute; inset:0;
    background:
      linear-gradient(180deg,
        rgba(74,78,86,.96) 0%,
        rgba(58,62,70,.82) 22%,
        rgba(36,39,46,.42) 44%,
        rgba(10,11,15,.30) 66%,
        rgba(1,0,4,.62) 86%,
        rgba(1,0,4,.96) 100%),
      radial-gradient(ellipse 120% 40% at 50% 0%, rgba(110,114,124,.28), transparent 70%);
  }
  /* rocas lunares de encuadre: masas oscuras en las esquinas,
     por DELANTE del objeto (como el referente) */
  .hero-frame{
    position:absolute; bottom:-6%; height:52%; width:60%;
    z-index:2; pointer-events:none;
    background-image:url('https://images.unsplash.com/photo-1473580044384-7ba9967e16a0?w=2000&q=80&auto=format&fit=crop');
    background-size:190% auto;
    filter:grayscale(1) brightness(.14) contrast(1.5);
  }
  .hero-frame.l{
    left:-4%;
    background-position:18% 64%;
    -webkit-mask-image:radial-gradient(115% 105% at 0% 100%, #000 46%, transparent 71%);
    mask-image:radial-gradient(115% 105% at 0% 100%, #000 46%, transparent 71%);
  }
  .hero-frame.r{
    right:-4%;
    background-position:78% 58%;
    transform:scaleX(-1);
    -webkit-mask-image:radial-gradient(115% 105% at 0% 100%, #000 46%, transparent 71%);
    mask-image:radial-gradient(115% 105% at 0% 100%, #000 46%, transparent 71%);
  }
  /* estrellas sutiles */
  .hero-stars{
    position:absolute; inset:0; z-index:0; pointer-events:none;
    background-image:
      radial-gradient(1px 1px at 12% 18%, rgba(200,215,240,.5) 50%, transparent),
      radial-gradient(1px 1px at 28% 9%,  rgba(200,215,240,.35) 50%, transparent),
      radial-gradient(1.5px 1.5px at 41% 22%, rgba(200,215,240,.45) 50%, transparent),
      radial-gradient(1px 1px at 57% 12%, rgba(200,215,240,.4) 50%, transparent),
      radial-gradient(1px 1px at 71% 25%, rgba(200,215,240,.3) 50%, transparent),
      radial-gradient(1.5px 1.5px at 86% 15%, rgba(200,215,240,.5) 50%, transparent),
      radial-gradient(1px 1px at 93% 31%, rgba(200,215,240,.3) 50%, transparent),
      radial-gradient(1px 1px at 7% 38%,  rgba(200,215,240,.25) 50%, transparent);
  }
  /* niebla baja */
  .hero-fog{
    position:absolute; left:0; right:0; bottom:0; height:55%; z-index:2; pointer-events:none;
    background:
      linear-gradient(180deg, transparent 0%, rgba(120,150,200,0.05) 35%, rgba(80,100,140,0.08) 60%, rgba(1,0,4,0.4) 100%);
  }
  /* luna líquida — movimiento continuo en capas (tipo video) */
  .hero-moon-wrap{
    position:absolute; left:50%; top:45%; z-index:1;
    transform:translate(-50%,-50%);
    pointer-events:none;
  }
  .hero-moon-glow{
    position:absolute; left:50%; top:50%;
    width:170%; height:170%;
    transform:translate(-50%,-50%);
    background:radial-gradient(circle, rgba(140,170,230,0.26) 0%, rgba(77,142,255,0.12) 40%, transparent 68%);
    filter:blur(32px);
    border-radius:50%;
    animation:glowPulse 9s ease-in-out infinite;
  }
  @keyframes glowPulse{
    0%, 100%{ opacity:.75; }
    50%     { opacity:1; }
  }
  .hero-moon{
    position:relative;
    width:min(440px, 46vw);
    display:block;
    filter:drop-shadow(0 30px 90px rgba(77,142,255,0.32));
    animation:moonRock 17s ease-in-out infinite;
  }
  @keyframes moonRock{
    0%, 100%{ transform:rotate(-5deg) scale(1); }
    33%     { transform:rotate(2deg) scale(1.025); }
    66%     { transform:rotate(4.5deg) scale(1.04); }
  }
  /* figura geométrica 3D dark glass (canvas WebGL en el lugar de la luna) */
  .hero-geo{
    position:relative;
    width:min(720px, 92vw);
    aspect-ratio:1.45;
  }
  .hero-geo canvas{
    position:absolute; inset:0;
    width:100% !important; height:100% !important;
    display:block;
  }
  .hero-geo .hero-moon{ /* fallback si WebGL no está disponible */
    position:absolute; left:50%; top:50%;
    transform:translate(-50%,-50%);
  }
  .hero-geo .hero-moon[hidden]{ display:none; }
  /* viñeta inferior para legibilidad */
  .hero-vignette{
    position:absolute; inset:0; z-index:3; pointer-events:none;
    background:linear-gradient(180deg, rgba(1,0,4,0.45) 0%, transparent 22%, transparent 52%, rgba(1,0,4,0.92) 100%);
  }
  .hero-content{
    position:relative; z-index:4;
    flex:1;
    max-width:1240px; width:100%;
    margin:0 auto; padding:0 28px;
    display:flex; flex-direction:column; justify-content:space-between;
  }
  .hero-top{
    display:flex; justify-content:space-between; align-items:flex-start; gap:24px;
    padding-top:22px;
  }
  .hero-services{ list-style:none; display:flex; flex-direction:column; gap:9px; }
  .hero-services li{
    font-family:var(--mono); font-size:12px; letter-spacing:.12em; text-transform:uppercase;
    color:var(--ink-mid);
  }
  .hero-services li::before{ content:'/ '; color:var(--accent); }
  .hero-lede{
    max-width:330px; text-align:right;
    font-size:14.5px; color:var(--ink-mid); line-height:1.55;
  }
  .hero-lede strong{ color:var(--ink); font-weight:500; }
  .hero-bottom{
    display:flex; justify-content:space-between; align-items:flex-end; gap:28px;
  }
  .hero-headline .chip{
    display:inline-block;
    font-family:var(--mono); font-size:11.5px; letter-spacing:.14em; text-transform:uppercase;
    color:var(--ink);
    background:rgba(255,255,255,0.07);
    border:1px solid var(--line);
    backdrop-filter:blur(8px);
    padding:8px 14px; border-radius:4px;
    margin-bottom:18px;
  }
  .hero-headline h1{
    font-size:clamp(42px,5.8vw,76px);
    font-weight:400;
    letter-spacing:-0.05em;
    line-height:1.0;
  }
  .hero-card{
    background:rgba(10,10,14,0.72);
    border:1px solid var(--line);
    backdrop-filter:blur(14px);
    border-radius:12px;
    padding:12px;
    display:flex; align-items:center; gap:14px;
    min-width:300px;
  }
  .hero-card .av{
    width:62px; height:62px; border-radius:8px; flex-shrink:0;
    background:linear-gradient(145deg, #16233f, #0a1428);
    border:1px solid var(--line-strong);
    display:flex; align-items:center; justify-content:center;
    font-family:var(--mono); font-size:16px; color:var(--accent);
  }
  .hero-card .txt b{ display:block; font-size:14.5px; font-weight:600; letter-spacing:-0.01em; }
  .hero-card .txt span{
    display:block;
    font-family:var(--mono); font-size:10.5px; letter-spacing:.12em; text-transform:uppercase;
    color:var(--ink-dim); margin:3px 0 8px;
  }
  .hero-card .btn-mini{
    display:inline-block;
    background:#fff; color:#0a0a0c;
    font-size:12.5px; font-weight:500;
    padding:7px 14px; border-radius:100px; text-decoration:none;
    transition:transform .2s, box-shadow .2s;
  }
  .hero-card .btn-mini:hover{ transform:translateY(-1px); box-shadow:0 6px 20px rgba(255,255,255,.15); }

  /* ============================================================
     BOTONES
     ============================================================ */
  .btn{
    font-size:14.5px; font-weight:500;
    padding:14px 26px; border-radius:100px; text-decoration:none;
    transition:transform .25s, box-shadow .25s, border-color .25s, color .25s;
    display:inline-flex; align-items:center; gap:10px;
  }
  .btn-primary{ background:#fff; color:#0a0a0c; }
  .btn-primary:hover{ transform:translateY(-2px); box-shadow:0 10px 36px rgba(255,255,255,.16); }
  .btn-ghost{ border:1px solid var(--line-strong); color:var(--ink); }
  .btn-ghost:hover{ border-color:var(--accent); color:var(--accent); }
  /* glifos de la ola de código en hover */
  .scr{ color:var(--accent); font-family:var(--mono); }

  /* ============================================================
     CLIENTES STRIP
     ============================================================ */
  .clients{ padding:64px 0 84px; border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
  .clients-label{ text-align:center; font-family:var(--mono); font-size:12px; letter-spacing:.18em; text-transform:uppercase; color:var(--ink-mid); margin-bottom:40px; }
  /* grilla de logos con celdas (como el referente) */
  .logo-grid{
    display:grid; grid-template-columns:repeat(6,1fr);
    gap:1px; background:var(--line);
    border:1px solid var(--line);
  }
  .logo-cell{
    position:relative;
    background:var(--bg);
    min-height:118px;
    display:flex; align-items:center; justify-content:center;
    padding:26px 16px;
    text-align:center;
    color:#9aa0ab;
    transition:color .25s, background .25s, transform .25s, box-shadow .25s;
  }
  .logo-cell:hover{
    color:#fff;
    background:var(--surface-2);
    transform:scale(1.06);
    box-shadow:
      inset 0 0 0 1px var(--accent),
      0 0 34px rgba(77,142,255,.22),
      0 14px 40px rgba(0,0,0,.55);
    z-index:2;
  }
  /* tratamientos tipo wordmark para que cada marca se lea como logo */
  .logo-cell.s1{ font-weight:700; font-size:17px; letter-spacing:.02em; }
  .logo-cell.s2{ font-family:var(--mono); font-size:13px; font-weight:500; text-transform:uppercase; letter-spacing:.2em; }
  .logo-cell.s3{ font-weight:800; font-size:16px; text-transform:uppercase; letter-spacing:.08em; }
  .logo-cell.s4{ font-weight:300; font-size:17px; text-transform:uppercase; letter-spacing:.24em; }

  /* ============================================================
     PAIN — sticky con círculos concéntricos que reaccionan
     al scroll y textos que van apareciendo (como el referente)
     ============================================================ */
  .pain-scroll{ height:380vh; position:relative; padding:0; }
  .pain-stage{
    position:sticky; top:0;
    height:100vh; overflow:hidden;
    display:flex; align-items:center; justify-content:center;
  }
  .pain-rings{ position:absolute; left:50%; top:50%; transform:translate(-50%,-50%); z-index:0; }
  .pain-rings .ring{
    position:absolute; left:50%; top:50%;
    transform:translate(-50%,-50%) scale(0.4);
    border:1px solid rgba(255,255,255,0.26);
    border-radius:50%;
    box-shadow:0 0 32px rgba(77,142,255,0.10), inset 0 0 32px rgba(77,142,255,0.07);
    opacity:0;
    will-change:transform, opacity;
  }
  .pain-rings .r1{ width:200px; height:200px; }
  .pain-rings .r2{ width:380px; height:380px; }
  .pain-rings .r3{ width:580px; height:580px; }
  .pain-rings .r4{ width:800px; height:800px; }
  /* meteoros: estelas que orbitan el orbe central constantemente */
  .meteor{
    position:absolute; left:50%; top:50%;
    width:var(--d); height:var(--d);
    margin:calc(var(--d) / -2) 0 0 calc(var(--d) / -2);
    border-radius:50%;
    animation:meteorSpin var(--t) linear infinite;
    animation-delay:var(--dl, 0s);
  }
  .meteor.rev{ animation-direction:reverse; }
  .meteor::before{
    content:'';
    position:absolute; top:-1.5px; left:50%;
    width:34px; height:2.5px; border-radius:3px;
    background:linear-gradient(90deg, rgba(77,142,255,0), #9cc1ff);
    box-shadow:0 0 10px rgba(120,170,255,.9), 0 0 26px rgba(77,142,255,.5);
  }
  @keyframes meteorSpin{ to{ transform:rotate(360deg); } }
  .pain-rings .core{
    position:absolute; left:50%; top:50%;
    width:10px; height:10px; border-radius:50%;
    transform:translate(-50%,-50%);
    background:var(--accent);
    box-shadow:0 0 20px var(--accent), 0 0 60px rgba(77,142,255,.5);
  }
  .pain-copy{
    position:relative; z-index:1;
    text-align:center; max-width:680px; padding:0 28px;
  }
  .pain-copy .eyebrow{ justify-content:center; }
  .pain-heading{
    font-size:clamp(30px,4.4vw,50px);
    font-weight:500; letter-spacing:-0.04em; line-height:1.05;
    margin-bottom:34px;
  }
  /* textos dispersos por las órbitas de los meteoritos */
  .pain-items{ position:absolute; inset:0; z-index:1; pointer-events:none; }
  .pain-item{
    position:absolute;
    width:min(310px, 36vw);
    text-align:left;
    opacity:0; transform:translateY(16px);
    transition:opacity .5s ease, transform .5s ease;
    pointer-events:none;
  }
  .pain-item.on{ opacity:1; transform:none; }
  .pain-item.p1{ left:9%;  top:17%; }
  .pain-item.p2{ right:7%; top:23%; text-align:right; }
  .pain-item.p3{ left:7%;  bottom:15%; }
  .pain-item.p4{ right:9%; bottom:19%; text-align:right; }
  .pain-item h3{
    font-size:clamp(19px,2.2vw,25px); font-weight:600; letter-spacing:-0.02em;
    margin-bottom:8px;
  }
  .pain-item h3 .idx{ font-family:var(--mono); font-size:13px; color:var(--accent); vertical-align:super; margin-right:8px; }
  .pain-item p{ color:var(--ink-mid); font-size:14.5px; }
  /* (barra de progreso eliminada) */

  /* ============================================================
     CASOS — cards que se apilan/superponen al scrollear
     ============================================================ */
  .cases-stack{ margin-top:54px; }
  .stack-card{
    position:sticky;
    background:linear-gradient(180deg, var(--surface-2), var(--surface));
    border:1px solid var(--line-strong);
    border-radius:18px;
    padding:46px;
    margin-bottom:26px;
    display:grid; grid-template-columns:1.1fr 1fr; gap:36px; align-items:center;
    min-height:340px;
    box-shadow:0 -18px 60px rgba(0,0,0,0.5);
    will-change:transform;
    text-decoration:none;
  }
  .stack-card:nth-child(1){ top:96px; }
  .stack-card:nth-child(2){ top:116px; }
  .stack-card:nth-child(3){ top:136px; }
  .stack-card:nth-child(4){ top:156px; }
  .stack-card .cat{ font-family:var(--mono); font-size:11.5px; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-dim); display:block; margin-bottom:14px; }
  .stack-card h3{ font-size:clamp(22px,2.6vw,30px); font-weight:600; letter-spacing:-0.02em; margin-bottom:12px; }
  .stack-card p{ color:var(--ink-mid); font-size:15.5px; max-width:480px; }
  .stack-card .more{ font-family:var(--mono); font-size:13px; color:var(--ink-dim); display:inline-block; margin-top:18px; transition:color .25s; }
  .stack-card:hover .more{ color:var(--accent); }
  .stack-card .metric-box{
    text-align:right;
  }
  .stack-card .metric{
    font-size:clamp(44px,5.4vw,72px); font-weight:500; letter-spacing:-0.04em; line-height:1;
    color:var(--accent);
  }
  .stack-card .metric small{ display:block; font-size:15px; color:var(--ink-mid); font-weight:400; letter-spacing:0; margin-top:10px; }

  /* ============================================================
     PROCESO
     ============================================================ */
  .steps{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:54px; }
  .step{ border-top:1px solid var(--line-strong); padding-top:26px; }
  .step .n{ font-family:var(--mono); font-size:13px; color:var(--accent); display:block; margin-bottom:14px; }
  .step h3{ font-size:20px; font-weight:600; margin-bottom:10px; letter-spacing:-0.01em; }
  .step p{ color:var(--ink-mid); font-size:15px; }

  /* ============================================================
     SERVICIOS
     ============================================================ */
  /* SERVICIOS como el referente: intro sticky izq + cards oscuras der */
  .chip-label{
    display:inline-block;
    font-family:var(--mono); font-size:11.5px; letter-spacing:.14em; text-transform:uppercase;
    color:var(--ink);
    background:rgba(255,255,255,0.07);
    border:1px solid var(--line);
    padding:8px 14px; border-radius:4px;
    margin-bottom:22px;
  }
  .svc-grid{ display:grid; grid-template-columns:0.85fr 1.45fr; gap:64px; align-items:start; }
  .svc-intro{ position:sticky; top:110px; }
  .svc-cards{ display:flex; flex-direction:column; gap:26px; }
  .svc-card{
    background:#141417;
    border:1px solid var(--line);
    border-radius:18px;
    padding:38px;
    display:grid; grid-template-columns:1fr 290px;
    gap:36px; align-items:stretch;
    transition:border-color .3s, transform .3s;
  }
  .svc-card:hover{ border-color:var(--line-strong); transform:translateY(-3px); }
  .svc-num{ font-family:var(--mono); font-size:13px; color:var(--ink-mid); display:block; margin-bottom:12px; }
  .svc-card h3{ font-size:clamp(23px,2.5vw,31px); font-weight:600; letter-spacing:-0.02em; margin-bottom:8px; }
  .svc-lede{ color:var(--ink-mid); font-size:15px; margin-bottom:30px; }
  .svc-feats{ list-style:none; margin-top:auto; }
  .svc-feats li{
    padding:14px 2px;
    border-bottom:1px solid var(--line);
    color:var(--ink-mid);
    font-family:var(--mono); font-size:12px; letter-spacing:.1em; text-transform:uppercase;
    transition:color .25s, padding-left .25s;
  }
  .svc-feats li:last-child{ border-bottom:none; padding-bottom:2px; }
  .svc-feats li:hover{ color:var(--ink); padding-left:10px; }
  .svc-card-txt{ display:flex; flex-direction:column; }
  .svc-img{
    border-radius:12px; overflow:hidden;
    border:1px solid var(--line);
    background:linear-gradient(150deg, #0e1424, #06080f);
    min-height:300px;
    position:relative;
  }
  .svc-img img{
    position:absolute; inset:0;
    width:100%; height:100%;
    object-fit:cover;
    filter:grayscale(1) brightness(.78) contrast(1.12);
    transition:transform .8s cubic-bezier(.2,.7,.2,1), filter .4s ease;
  }
  .svc-card:hover .svc-img img{ transform:scale(1.06); filter:grayscale(.6) brightness(.88) contrast(1.1); }

  /* ============================================================
     COMPARATIVA
     ============================================================ */
  .compare{ margin-top:54px; border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; }
  .compare table{ width:100%; border-collapse:collapse; }
  .compare th, .compare td{
    padding:18px 22px; text-align:left; font-size:14.5px;
    border-bottom:1px solid var(--line);
  }
  .compare th{ font-family:var(--mono); font-size:12px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-dim); background:var(--surface); font-weight:500; }
  .compare th.hl{ color:var(--accent); }
  .compare td:first-child{ color:var(--ink-mid); }
  .compare td.hl{ background:var(--accent-soft); color:var(--ink); font-weight:500; }
  .compare tr:last-child td{ border-bottom:none; }
  .compare .ok{ color:var(--accent); }
  .compare .no{ color:var(--ink-dim); }

  /* ============================================================
     TESTIMONIOS
     ============================================================ */
  .quotes{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:54px; }
  .quote{
    background:var(--surface); border:1px dashed var(--line-strong);
    border-radius:var(--radius); padding:30px;
    display:flex; flex-direction:column; gap:18px;
  }
  .quote .txt{ font-size:15px; color:var(--ink-mid); font-style:italic; }
  .quote .who{ display:flex; align-items:center; gap:12px; margin-top:auto; }
  .quote .av{
    width:38px; height:38px; border-radius:50%;
    background:var(--surface-3); border:1px solid var(--line-strong);
    display:flex; align-items:center; justify-content:center;
    font-family:var(--mono); font-size:13px; color:var(--ink-mid);
  }
  .quote .who b{ font-size:14px; display:block; font-weight:600; }
  .quote .who span{ font-size:12.5px; color:var(--ink-dim); }
  .pending-note{ margin-top:18px; font-family:var(--mono); font-size:12.5px; color:var(--ink-dim); }

  /* ============================================================
     FAQ
     ============================================================ */
  .faq{ margin-top:54px; max-width:760px; }
  .faq details{ border-bottom:1px solid var(--line); }
  .faq summary{
    cursor:pointer; list-style:none;
    padding:24px 0; font-size:17px; font-weight:500; letter-spacing:-0.01em;
    display:flex; justify-content:space-between; align-items:center; gap:18px;
    transition:color .25s;
  }
  .faq summary::-webkit-details-marker{ display:none; }
  .faq summary::after{ content:'+'; font-family:var(--mono); color:var(--ink-dim); font-size:20px; transition:transform .3s, color .3s; flex-shrink:0; }
  .faq details[open] summary::after{ transform:rotate(45deg); color:var(--accent); }
  .faq details[open] summary{ color:var(--accent); }
  .faq .a{ padding:0 0 24px; color:var(--ink-mid); font-size:15px; max-width:640px; }

  /* ============================================================
     CTA FINAL + FOOTER
     ============================================================ */
  .cta-final{
    position:relative; text-align:center;
    padding:170px 0 190px;
    overflow:hidden;
  }
  .cta-bg{
    position:absolute; inset:0; z-index:0; pointer-events:none;
    background-image:url('https://images.unsplash.com/photo-1473580044384-7ba9967e16a0?w=2000&q=80&auto=format&fit=crop');
    background-size:cover;
    background-position:center bottom;
    filter:grayscale(1) brightness(.34) contrast(1.3);
  }
  .cta-bg::after{
    content:''; position:absolute; inset:0;
    background:
      linear-gradient(180deg, rgba(1,0,4,.96) 0%, rgba(20,22,28,.34) 34%, rgba(28,30,38,.22) 55%, rgba(1,0,4,.92) 100%),
      radial-gradient(ellipse 90% 45% at 50% 40%, rgba(110,116,128,.16), transparent 70%);
  }
  .cta-final .wrap{ position:relative; z-index:1; }
  .cta-final h2{
    font-size:clamp(36px,6vw,72px); font-weight:400; letter-spacing:-0.05em; line-height:1.04;
    max-width:820px; margin:0 auto 22px;
  }
  .cta-final .a{ color:var(--accent); }
  .cta-final p{ color:var(--ink-mid); max-width:540px; margin:0 auto 42px; }
  .cta-actions{ display:flex; gap:14px; justify-content:center; flex-wrap:wrap; align-items:center; }
  .cta-mail{
    display:block; margin-top:26px;
    font-family:var(--mono); font-size:13px; color:var(--ink-dim);
    text-decoration:none; transition:color .25s;
  }
  .cta-mail:hover{ color:var(--accent); }

  footer{ border-top:1px solid var(--line); padding:74px 0 34px; }
  .foot-big{
    font-size:clamp(54px,9vw,138px);
    font-weight:500; letter-spacing:-0.05em; line-height:0.98;
    margin-bottom:70px;
  }
  .foot-big .a{ color:var(--accent); }
  .socials{ display:flex; gap:10px; }
  .socials a{
    width:40px; height:40px; border-radius:10px;
    border:1px solid var(--line-strong);
    display:flex; align-items:center; justify-content:center;
    color:var(--ink-mid);
    transition:color .25s, border-color .25s, transform .25s;
  }
  .socials a:hover{ color:var(--ink); border-color:var(--accent); transform:translateY(-2px); }
  .socials svg{ width:17px; height:17px; fill:currentColor; }
  .foot-grid{ display:flex; justify-content:space-between; gap:34px; flex-wrap:wrap; margin-bottom:44px; }
  .foot-brand{ font-weight:600; letter-spacing:.12em; font-size:15px; display:flex; align-items:center; gap:10px; }
  .foot-brand .mark{ width:9px; height:9px; border-radius:50%; background:var(--accent); box-shadow:0 0 12px var(--accent); }
  .foot-col h4{ font-family:var(--mono); font-size:12px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-dim); margin-bottom:16px; font-weight:500; }
  .foot-col ul{ list-style:none; display:flex; flex-direction:column; gap:10px; }
  .foot-col a{ color:var(--ink-mid); text-decoration:none; font-size:14.5px; transition:color .25s; }
  .foot-col a:hover{ color:var(--accent); }
  .foot-bottom{
    border-top:1px solid var(--line); padding-top:26px;
    display:flex; justify-content:space-between; gap:14px; flex-wrap:wrap;
    font-family:var(--mono); font-size:12px; color:var(--ink-dim);
  }

  /* ============================================================
     TRANSICIÓN DE PÁGINA (cortina, como el referente)
     ============================================================ */
  .page-veil{
    position:fixed; inset:0; z-index:400;
    background:var(--bg);
    display:flex; align-items:center; justify-content:center;
    transform:translateY(101%);
    pointer-events:none;
  }
  .page-veil.anim{ transition:transform .55s cubic-bezier(.76,0,.24,1); }
  .page-veil.in{ transform:translateY(0); }
  .page-veil.in.up{ transform:translateY(-101%); }
  /* al ENTRAR a una página tras navegar: arranca cubierta (sin parpadeo) */
  html.veil-cover .page-veil{ transform:translateY(0); }
  .page-veil .vmark{
    display:flex; align-items:center; gap:12px;
    font-weight:600; letter-spacing:.14em; font-size:16px; color:var(--ink);
  }
  .page-veil .vmark .mark{
    width:10px; height:10px; border-radius:50%;
    background:var(--accent); box-shadow:0 0 18px var(--accent);
  }

  /* ============================================================
     NÚMEROS / STATS
     ============================================================ */
  .stats{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; margin-top:54px; }
  .stat{ border-top:1px solid var(--line-strong); padding-top:24px; }
  .stat h3{
    font-size:clamp(44px,5.4vw,76px);
    font-weight:500; letter-spacing:-0.04em; line-height:1;
    font-variant-numeric:tabular-nums;
  }
  .stat h3 .sx{ color:var(--accent); }
  .stat p{ color:var(--ink-mid); font-size:14.5px; margin-top:10px; }

  /* ============================================================
     BLOG PREVIEW
     ============================================================ */
  .posts{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:54px; }
  .post{
    background:var(--surface); border:1px solid var(--line);
    border-radius:var(--radius); padding:30px;
    text-decoration:none;
    display:flex; flex-direction:column; gap:14px;
    min-height:190px;
    transition:border-color .3s, transform .3s;
  }
  .post:hover{ border-color:var(--accent); transform:translateY(-3px); }
  .post .pk{ font-family:var(--mono); font-size:11.5px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-dim); }
  .post h3{ font-size:19px; font-weight:600; letter-spacing:-0.01em; line-height:1.3; }
  .post .more{ font-family:var(--mono); font-size:13px; color:var(--ink-dim); margin-top:auto; transition:color .25s; }
  .post:hover .more{ color:var(--accent); }

  /* ============================================================
     REVEAL ON SCROLL
     ============================================================ */
  .rv{ opacity:0; transform:translateY(22px); transition:opacity .7s ease, transform .7s ease; }
  .rv.in{ opacity:1; transform:none; }

  /* ============================================================
     RESPONSIVE
     ============================================================ */
  @media (max-width: 900px){
    .quotes, .steps{ grid-template-columns:1fr 1fr; }
    .logo-grid{ grid-template-columns:repeat(3,1fr); }
  }
  @media (max-width: 560px){
    .logo-grid{ grid-template-columns:repeat(2,1fr); }
    .logo-cell{ min-height:92px; padding:20px 12px; }
  }
  @media (max-width: 820px){
    section{ padding:80px 0; }
    .nav-inner{ grid-template-columns:auto auto; justify-content:space-between; }
    .nav-links{
      display:none;
      position:absolute; top:100%; left:0; right:0;
      flex-direction:column; gap:0;
      background:rgba(1,0,4,0.97); backdrop-filter:blur(18px);
      border-bottom:1px solid var(--line);
      padding:8px 24px 16px;
    }
    nav.open .nav-links{ display:flex; }
    .nav-links li{ width:100%; }
    .nav-links a{ display:block; padding:14px 2px; border-bottom:1px solid var(--line); font-size:14px; }
    .nav-links li:last-child a{ border-bottom:none; }
    .nav-toggle{ display:flex; }
    .nav-right .nav-cta{ display:none; }

    .hero{ min-height:680px; padding-bottom:24px; }
    .hero-moon{ width:min(300px, 70vw); }
    .hero-geo{ width:min(460px, 96vw); }
    .hero-moon-wrap{ top:38%; }
    .hero-top{ flex-direction:column; }
    .hero-lede{ text-align:left; max-width:420px; }
    .hero-bottom{ flex-direction:column; align-items:flex-start; gap:20px; }
    .hero-headline h1{ font-size:clamp(38px,10vw,56px); }
    .hero-card{ width:100%; min-width:0; }

    .pain-scroll{ height:340vh; }
    .pain-rings .r3{ width:440px; height:440px; }
    .pain-rings .r4{ width:600px; height:600px; }
    /* mobile: los textos vuelven al centro-abajo (dispersos no entran) */
    .pain-item.p1, .pain-item.p2, .pain-item.p3, .pain-item.p4{
      left:50%; right:auto; top:auto; bottom:9%;
      width:min(420px, 86vw);
      text-align:center;
      transform:translate(-50%, 16px);
    }
    .pain-item.on{ transform:translate(-50%, 0); }

    .stack-card{ grid-template-columns:1fr; gap:20px; padding:30px; min-height:0; }
    .stack-card .metric-box{ text-align:left; }

    .svc-grid{ grid-template-columns:1fr; gap:34px; }
    .svc-intro{ position:static; }
    .svc-card{ grid-template-columns:1fr; gap:24px; padding:26px; }
    .svc-img{ min-height:200px; }
    /* la imagen llena el recuadro (inset:0 + object-fit:cover heredados) */
    .cta-final{ padding:120px 0 130px; }
    .quotes, .steps{ grid-template-columns:1fr; }
    .stats{ grid-template-columns:1fr 1fr; }
    .posts{ grid-template-columns:1fr; }
    .compare{ overflow-x:auto; }
    .compare table{ min-width:640px; }

    .page-hero--scape{ min-height:clamp(440px,74vh,640px); }
    .page-hero--scape .wrap{ padding-top:128px; padding-bottom:58px; }
    .page-hero--scape .ph-frame{ height:40%; width:72%; }
    .page-hero--scape .ph-glow{ top:30%; width:96vw; }

    .integ{ padding:86px 0 96px; }
    .integ-marquee{ gap:12px; margin-bottom:44px; }
    .integ-tile{ width:62px; height:62px; margin-right:12px; border-radius:16px; }
    .integ-tile svg{ width:44%; height:44%; }

    #decision{ padding:80px 0; }
    .paths{ grid-template-columns:1fr; margin-top:40px; }
  }
  @media (prefers-reduced-motion: reduce){
    .hero-moon, .hero-moon-wrap, .hero-moon-glow, .meteor, .page-hero--scape .ph-glow, .integ-track{ animation:none !important; }
    .page-veil{ display:none !important; }
    .rv{ opacity:1 !important; transform:none !important; transition:none !important; }
    .pain-item{ transition:none !important; }
    /* problema: sin sticky-scroll, queda como lista legible */
    .pain-rings{ display:none !important; }
    .pain-scroll{ height:auto !important; }
    .pain-stage{ position:relative !important; height:auto !important; padding:90px 0 !important; align-items:flex-start; }
    .pain-items{ position:relative !important; inset:auto !important; display:flex; flex-direction:column; gap:26px; margin-top:34px; }
    .pain-item{ position:relative !important; inset:auto !important; opacity:1 !important; transform:none !important; width:100% !important; max-width:640px; text-align:left !important; }
    .stack-card{ transform:none !important; filter:none !important; }
  }

  /* foco visible por teclado (alto contraste sobre fondo oscuro) */
  a:focus-visible, button:focus-visible, summary:focus-visible,
  .filter-chip:focus-visible, .btn:focus-visible, .nav-cta:focus-visible,
  input:focus-visible, textarea:focus-visible{
    outline:2px solid var(--accent);
    outline-offset:3px;
    border-radius:6px;
  }
  /* ============================================================
     PÁGINAS INTERNAS (Nosotros / Contacto)
     ============================================================ */
  .page-hero{
    position:relative; overflow:hidden;
    padding:180px 0 90px;
    border-bottom:1px solid var(--line);
  }
  .page-hero .ph-bg{
    position:absolute; inset:0; z-index:0; pointer-events:none;
    background-image:url('https://images.unsplash.com/photo-1473580044384-7ba9967e16a0?w=2000&q=80&auto=format&fit=crop');
    background-size:cover; background-position:center 30%;
    filter:grayscale(1) brightness(.3) contrast(1.25);
  }
  .page-hero .ph-bg::after{
    content:''; position:absolute; inset:0;
    background:linear-gradient(180deg, rgba(1,0,4,.7) 0%, rgba(10,12,18,.5) 45%, rgba(1,0,4,.96) 100%);
  }
  .page-hero .wrap{ position:relative; z-index:1; }
  .page-hero h1{
    font-size:clamp(44px,7vw,96px); font-weight:400; letter-spacing:-0.05em; line-height:1.0;
    max-width:900px; margin-bottom:24px;
  }
  .page-hero h1 .a{ color:var(--accent); }
  .page-hero .lede{ color:var(--ink-mid); font-size:clamp(16px,2vw,20px); max-width:600px; }

  /* ---- variante PAISAJE del page-hero (Trabajo): mismo mundo del home, sin objeto 3D ---- */
  .page-hero--scape{
    padding:0;
    min-height:clamp(560px, 82vh, 860px);
    display:flex; align-items:flex-end;
    border-bottom:1px solid var(--line);
  }
  .page-hero--scape .wrap{
    position:relative; z-index:4;
    padding-top:160px; padding-bottom:84px;
  }
  /* terreno lunar — mismo planeta del home, recorte distinto (home usa center bottom) */
  .page-hero--scape .ph-photo{
    position:absolute; inset:0; z-index:0; pointer-events:none;
    background-image:url('https://images.unsplash.com/photo-1473580044384-7ba9967e16a0?w=2000&q=80&auto=format&fit=crop');
    background-size:cover; background-position:center 38%;
    filter:grayscale(1) brightness(.4) contrast(1.28);
  }
  .page-hero--scape .ph-photo::after{
    content:''; position:absolute; inset:0;
    background:
      linear-gradient(180deg,
        rgba(64,68,76,.92) 0%,
        rgba(48,52,60,.70) 26%,
        rgba(22,24,30,.36) 52%,
        rgba(1,0,4,.52) 80%,
        rgba(1,0,4,.97) 100%),
      radial-gradient(ellipse 110% 38% at 50% 0%, rgba(104,108,120,.26), transparent 70%);
  }
  /* estrellas sutiles (igual recipe que el home) */
  .page-hero--scape .ph-stars{
    position:absolute; inset:0; z-index:0; pointer-events:none;
    background-image:
      radial-gradient(1px 1px at 12% 18%, rgba(200,215,240,.5) 50%, transparent),
      radial-gradient(1px 1px at 28% 9%,  rgba(200,215,240,.35) 50%, transparent),
      radial-gradient(1.5px 1.5px at 41% 22%, rgba(200,215,240,.45) 50%, transparent),
      radial-gradient(1px 1px at 57% 12%, rgba(200,215,240,.4) 50%, transparent),
      radial-gradient(1px 1px at 71% 25%, rgba(200,215,240,.3) 50%, transparent),
      radial-gradient(1.5px 1.5px at 86% 15%, rgba(200,215,240,.5) 50%, transparent),
      radial-gradient(1px 1px at 93% 31%, rgba(200,215,240,.3) 50%, transparent),
      radial-gradient(1px 1px at 7% 38%,  rgba(200,215,240,.25) 50%, transparent);
  }
  /* glow azul de acento donde el home tiene el objeto (lo reemplaza, no lo dibuja) */
  .page-hero--scape .ph-glow{
    position:absolute; left:50%; top:32%; z-index:1;
    width:min(760px,86vw); aspect-ratio:1.7;
    transform:translate(-50%,-50%);
    background:radial-gradient(ellipse at center, rgba(77,142,255,.18) 0%, rgba(77,142,255,.06) 44%, transparent 70%);
    filter:blur(30px); pointer-events:none;
    animation:glowPulse 9s ease-in-out infinite;
  }
  /* rocas de encuadre — un poco más bajas/chicas que el home, otra posición */
  .page-hero--scape .ph-frame{
    position:absolute; bottom:-5%; height:48%; width:56%;
    z-index:2; pointer-events:none;
    background-image:url('https://images.unsplash.com/photo-1473580044384-7ba9967e16a0?w=2000&q=80&auto=format&fit=crop');
    background-size:200% auto;
    filter:grayscale(1) brightness(.13) contrast(1.5);
  }
  .page-hero--scape .ph-frame.l{
    left:-5%; background-position:24% 70%;
    -webkit-mask-image:radial-gradient(115% 105% at 0% 100%, #000 44%, transparent 70%);
    mask-image:radial-gradient(115% 105% at 0% 100%, #000 44%, transparent 70%);
  }
  .page-hero--scape .ph-frame.r{
    right:-5%; background-position:72% 62%; transform:scaleX(-1);
    -webkit-mask-image:radial-gradient(115% 105% at 0% 100%, #000 44%, transparent 70%);
    mask-image:radial-gradient(115% 105% at 0% 100%, #000 44%, transparent 70%);
  }
  /* niebla baja azulada */
  .page-hero--scape .ph-fog{
    position:absolute; left:0; right:0; bottom:0; height:52%; z-index:2; pointer-events:none;
    background:linear-gradient(180deg, transparent 0%, rgba(120,150,200,.05) 38%, rgba(80,100,140,.08) 62%, rgba(1,0,4,.42) 100%);
  }
  /* viñeta inferior para legibilidad del texto */
  .page-hero--scape .ph-vignette{
    position:absolute; inset:0; z-index:3; pointer-events:none;
    background:linear-gradient(180deg, rgba(1,0,4,.40) 0%, transparent 24%, transparent 50%, rgba(1,0,4,.93) 100%);
  }

  /* ============================================================
     INTEGRACIONES — carrusel de logos en bucle + spotlight
     ============================================================ */
  .integ{ position:relative; padding:120px 0 130px; text-align:center; overflow:hidden; }
  .integ .wrap{ position:relative; z-index:2; }
  .integ-marquee{
    position:relative; max-width:940px; margin:0 auto 56px;
    display:flex; flex-direction:column; gap:18px;
    -webkit-mask-image:linear-gradient(90deg, transparent, #000 11%, #000 89%, transparent);
    mask-image:linear-gradient(90deg, transparent, #000 11%, #000 89%, transparent);
  }
  .integ-row{ overflow:hidden; }
  .integ-track{ display:flex; width:max-content; will-change:transform; }
  .integ-row[data-dir="left"]  .integ-track{ animation:integScrollL 46s linear infinite; }
  .integ-row[data-dir="right"] .integ-track{ animation:integScrollR 60s linear infinite; }
  @keyframes integScrollL{ from{ transform:translateX(0); }    to{ transform:translateX(-50%); } }
  @keyframes integScrollR{ from{ transform:translateX(-50%); } to{ transform:translateX(0); } }
  .integ-tile{
    position:relative; flex:0 0 auto;
    width:86px; height:86px; margin-right:18px;
    display:flex; align-items:center; justify-content:center;
    border-radius:22px;
    background:linear-gradient(160deg, rgba(255,255,255,.05), rgba(255,255,255,.012));
    border:1px solid var(--line);
    color:#787c85;
    transition:color .3s ease, transform .3s ease, background .3s ease, border-color .3s ease, box-shadow .3s ease;
  }
  .integ-tile svg{ width:42%; height:42%; display:block; }
  .integ-tile:hover{
    color:#fff;
    border-color:rgba(255,255,255,.22);
    background:linear-gradient(160deg, rgba(255,255,255,.12), rgba(255,255,255,.03));
  }
  .integ-chip{
    display:inline-block; font-family:'Geist Mono',monospace;
    font-size:12px; letter-spacing:.22em; text-transform:uppercase;
    color:var(--ink); padding:6px 14px; border-radius:7px;
    background:rgba(255,255,255,.06); border:1px solid var(--line);
  }
  .integ-title{
    font-size:clamp(34px,5.4vw,68px); font-weight:400; letter-spacing:-0.045em;
    line-height:1.03; margin:26px 0 0;
  }
  .integ-sub{
    color:var(--ink-mid); max-width:560px; margin:22px auto 0;
    font-size:clamp(15px,1.7vw,18px); line-height:1.6;
  }

  /* ============================================================
     LA DECISIÓN — "¿Qué tipo de empresario querés ser?" (dos caminos)
     ============================================================ */
  #decision{ padding:120px 0; text-align:center; }
  .decision-q{
    font-size:clamp(34px,6vw,76px); font-weight:400; letter-spacing:-0.04em;
    line-height:1.04; max-width:920px; margin:18px auto 0;
  }
  .decision-q .a{ color:var(--accent); }
  .paths{
    display:grid; grid-template-columns:1fr 1fr; gap:18px;
    max-width:920px; margin:56px auto 0; text-align:left;
  }
  .path{
    border:1px solid var(--line); border-radius:16px; padding:34px 32px;
    background:var(--surface);
    transition:border-color .3s, transform .3s;
  }
  .path:hover{ transform:translateY(-3px); }
  .path-k{ font-family:var(--mono); font-size:11.5px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-dim); }
  .path h3{ font-size:24px; font-weight:500; letter-spacing:-0.02em; margin:14px 0 12px; }
  .path p{ color:var(--ink-mid); font-size:15px; line-height:1.6; }
  .path.on{
    border-color:rgba(77,142,255,.4);
    background:linear-gradient(160deg, rgba(77,142,255,.09), rgba(255,255,255,.012));
  }
  .path.on:hover{ border-color:rgba(77,142,255,.6); }
  .path.on .path-k{ color:var(--accent); }
  .decision-cta{ margin-top:46px; }

  /* equipo */
  .team{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:54px; }
  .person{
    background:var(--surface); border:1px solid var(--line);
    border-radius:var(--radius); padding:30px;
    transition:border-color .3s, transform .3s;
  }
  .person:hover{ border-color:var(--accent); transform:translateY(-3px); }
  .person .av{
    width:64px; height:64px; border-radius:14px;
    background:linear-gradient(145deg, #16233f, #0a1428);
    border:1px solid var(--line-strong);
    display:flex; align-items:center; justify-content:center;
    font-family:var(--mono); font-size:20px; color:var(--accent);
    margin-bottom:20px;
  }
  .person h3{ font-size:19px; font-weight:600; letter-spacing:-0.01em; }
  .person .role{ font-family:var(--mono); font-size:11.5px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-dim); margin-top:6px; }
  .person p{ color:var(--ink-mid); font-size:14.5px; margin-top:14px; }

  /* valores / manifiesto */
  .values{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:54px; }
  .value{ border-top:1px solid var(--line-strong); padding-top:24px; }
  .value .n{ font-family:var(--mono); font-size:12px; color:var(--accent); display:block; margin-bottom:14px; }
  .value h3{ font-size:19px; font-weight:600; letter-spacing:-0.01em; margin-bottom:10px; }
  .value p{ color:var(--ink-mid); font-size:15px; }

  .manifesto{ max-width:820px; }
  .manifesto p{ font-size:clamp(20px,2.6vw,28px); line-height:1.5; letter-spacing:-0.01em; color:var(--ink); }
  .manifesto p .dim{ color:var(--ink-dim); }

  /* ---- valores estilo referente: grilla bordeada con íconos de línea ---- */
  .vgrid{
    display:grid; grid-template-columns:repeat(4,1fr);
    border:1px solid var(--line); border-radius:16px; overflow:hidden;
    margin-top:54px; background:var(--surface);
  }
  .vcell{
    display:flex; flex-direction:column; justify-content:space-between; gap:40px;
    min-height:440px; padding:36px 30px;
    border-right:1px solid var(--line);
    transition:background .3s ease;
  }
  .vcell:last-child{ border-right:none; }
  .vcell:hover{ background:rgba(255,255,255,.025); }
  .vicon{ color:var(--ink); }
  .vicon svg{ width:38px; height:38px; display:block; }
  .vtxt h3{ font-size:25px; font-weight:500; letter-spacing:-0.025em; line-height:1.12; margin-bottom:14px; }
  .vtxt p{ color:var(--ink-mid); font-size:14.5px; line-height:1.55; max-width:235px; }

  /* ---- cita de fundador ---- */
  .founder-quote{ padding:34px 0 110px; }
  .founder-quote blockquote{
    margin:0; max-width:920px;
    font-size:clamp(24px,3.6vw,42px); font-weight:300; letter-spacing:-0.03em;
    line-height:1.25; color:var(--ink);
  }
  .founder-quote blockquote .a{ color:var(--accent); }
  .fq-by{ display:flex; align-items:center; gap:14px; margin-top:30px; }
  .fq-by .av{
    width:46px; height:46px; border-radius:50%;
    background:linear-gradient(145deg,#16233f,#0a1428); border:1px solid var(--line-strong);
    display:flex; align-items:center; justify-content:center;
    font-family:var(--mono); font-size:16px; color:var(--accent);
  }
  .fq-by b{ display:block; font-size:15px; font-weight:600; color:var(--ink); }
  .fq-by span{ color:var(--ink-dim); font-size:13px; }

  /* contacto: métodos */
  .contact-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:54px; }
  .contact-card{
    background:var(--surface); border:1px solid var(--line);
    border-radius:var(--radius); padding:34px;
    text-decoration:none; display:flex; flex-direction:column; gap:12px;
    min-height:200px;
    transition:border-color .3s, transform .3s;
  }
  .contact-card:hover{ border-color:var(--accent); transform:translateY(-3px); }
  .contact-card .ico{
    width:46px; height:46px; border-radius:12px;
    background:var(--accent-soft); border:1px solid var(--line);
    display:flex; align-items:center; justify-content:center; color:var(--accent);
    margin-bottom:8px;
  }
  .contact-card .ico svg{ width:22px; height:22px; fill:currentColor; }
  .contact-card h3{ font-size:19px; font-weight:600; letter-spacing:-0.01em; }
  .contact-card .cval{ color:var(--ink-mid); font-size:15px; }
  .contact-card .more{ font-family:var(--mono); font-size:13px; color:var(--ink-dim); margin-top:auto; }
  .contact-card:hover .more{ color:var(--accent); }

  /* formulario de contacto */
  .form{ margin-top:54px; max-width:680px; }
  .form .row{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
  .field{ margin-bottom:16px; }
  .field label{ display:block; font-family:var(--mono); font-size:11.5px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-dim); margin-bottom:8px; }
  .field input, .field textarea{
    width:100%; background:var(--surface); color:var(--ink);
    border:1px solid var(--line-strong); border-radius:10px;
    padding:14px 16px; font-family:var(--font); font-size:15px;
    transition:border-color .25s;
  }
  .field input:focus, .field textarea:focus{ outline:none; border-color:var(--accent); }
  .field textarea{ resize:vertical; min-height:130px; }

  @media (max-width: 820px){
    .team, .values, .contact-grid{ grid-template-columns:1fr; }
    .page-hero{ padding:140px 0 70px; }
    .form .row{ grid-template-columns:1fr; }
    .vgrid{ grid-template-columns:1fr 1fr; }
    .vcell{ min-height:300px; gap:28px; padding:28px 24px; }
    .vcell:nth-child(odd){ border-right:1px solid var(--line); }
    .vcell:nth-child(even){ border-right:none; }
    .vcell:nth-child(1), .vcell:nth-child(2){ border-bottom:1px solid var(--line); }
  }
  @media (max-width: 520px){
    .vgrid{ grid-template-columns:1fr; }
    .vcell{ min-height:0; border-right:none !important; border-bottom:1px solid var(--line); gap:22px; }
    .vcell:last-child{ border-bottom:none; }
  }

  /* ============================================================
     TRABAJO (portfolio) — grilla filtrable estilo nuevo
     ============================================================ */
  .filter-bar{ display:flex; gap:10px; flex-wrap:wrap; margin-top:46px; margin-bottom:8px; }
  .filter-chip{
    font-family:var(--mono); font-size:12px; letter-spacing:.06em;
    color:var(--ink-mid); background:transparent;
    border:1px solid var(--line-strong); border-radius:100px;
    padding:9px 18px; cursor:pointer;
    transition:color .25s, border-color .25s, background .25s;
  }
  .filter-chip:hover{ color:var(--ink); border-color:var(--ink-mid); }
  .filter-chip.on{ color:var(--accent-ink, #02101f); background:#fff; border-color:#fff; }
  .work-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:18px; margin-top:26px; }
  .work-card{
    background:var(--surface); border:1px solid var(--line);
    border-radius:var(--radius); padding:34px;
    display:flex; flex-direction:column; gap:14px;
    transition:border-color .3s, transform .3s, opacity .35s;
  }
  .work-card:hover{ border-color:var(--accent); transform:translateY(-3px); }
  .work-card .cat{ font-family:var(--mono); font-size:11.5px; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-dim); }
  .work-card .metric{ font-size:clamp(30px,3.6vw,46px); font-weight:500; letter-spacing:-0.04em; line-height:1; color:var(--accent); }
  .work-card .metric small{ display:block; font-size:14.5px; color:var(--ink-mid); font-weight:400; letter-spacing:0; margin-top:8px; }
  .work-card h3{ font-size:19px; font-weight:600; letter-spacing:-0.01em; }
  .work-card p{ color:var(--ink-mid); font-size:14.5px; }
  .work-card.is-hidden{ display:none; }

  /* ============================================================
     BLOG — post destacado
     ============================================================ */
  .post-featured{
    display:grid; grid-template-columns:1.2fr 1fr; gap:0;
    margin-top:54px; border:1px solid var(--line-strong); border-radius:18px; overflow:hidden;
    background:linear-gradient(180deg, var(--surface-2), var(--surface));
    transition:border-color .3s;
  }
  .post-featured:hover{ border-color:var(--accent); }
  .post-featured .pf-txt{ padding:46px; display:flex; flex-direction:column; gap:16px; }
  .post-featured .pk{ font-family:var(--mono); font-size:11.5px; letter-spacing:.12em; text-transform:uppercase; color:var(--accent); }
  .post-featured h3{ font-size:clamp(24px,3vw,36px); font-weight:600; letter-spacing:-0.02em; line-height:1.15; }
  .post-featured p{ color:var(--ink-mid); font-size:15.5px; }
  .post-featured .more{ font-family:var(--mono); font-size:13px; color:var(--ink-dim); margin-top:auto; }
  .post-featured .pf-img{
    background:
      radial-gradient(circle at 60% 30%, rgba(77,142,255,0.2), transparent 60%),
      linear-gradient(150deg, #0e1424, #06080f);
    min-height:280px; position:relative; overflow:hidden;
  }
  .post-featured .pf-img img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; filter:grayscale(1) brightness(.7) contrast(1.1); }

  @media (max-width: 820px){
    .work-grid{ grid-template-columns:1fr; }
    .post-featured{ grid-template-columns:1fr; }
    .post-featured .pf-img{ min-height:200px; order:-1; }
  }
