/* ============================================================
   JUAN SARAVIA — edition 2026
   warm paper · ink · one terracotta accent · extreme type scale
   ============================================================ */
/* fuentes: cargadas via <link> en el <head> (paralelo, no bloquea el render) */
:root{
  --paper:#F7F5F2;
  --paper2:#EFECE6;
  --ink:#161512;
  --body:#403E39;
  --mute:#6E6A60;
  --hair:rgba(22,21,18,.12);
  --acc:#C04F2C;
  --dark:#131210;
  --dark-ink:#F4F2EE;
  --ease:cubic-bezier(.16,1,.3,1);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
html,body{overflow-x:clip}
body{
  font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  font-optical-sizing:auto;
  background:var(--paper); color:var(--body);
  -webkit-font-smoothing:antialiased;
  line-height:1.6; font-size:16px;
  transition:background-color 1s var(--ease);
}
/* film grain over everything */
body::after{content:"";position:fixed;inset:0;z-index:200;pointer-events:none;opacity:.05;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='160' height='160' filter='url(%23n)'/%3E%3C/svg%3E");}
h1,h2,h3,h4{color:var(--ink);font-weight:550;letter-spacing:-.03em;}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
/* foco visible consistente (teclado) */
:focus-visible{outline:2.5px solid var(--acc);outline-offset:3px;border-radius:6px;}
.pill:focus-visible,.mailbtn:focus-visible,.lng a:focus-visible,.burger:focus-visible,
.car-btn:focus-visible,.lb-x:focus-visible,.lb-btn:focus-visible,.gx:focus-visible{outline-offset:2px;border-radius:99px;}
/* saltar al contenido: invisible hasta recibir foco */
.skip{position:fixed;top:10px;left:10px;z-index:300;background:var(--ink);color:var(--paper);
  font-weight:600;font-size:13.5px;padding:11px 20px;border-radius:99px;
  transform:translateY(-200%);transition:transform .25s var(--ease);}
.skip:focus{transform:none;}
::selection{background:var(--acc);color:#fff}
.mono{font-family:'Inter',sans-serif;font-weight:600;}
.lbl{font-family:'Inter',sans-serif;font-weight:600;font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--mute);}
.wrap{max-width:1280px;margin:0 auto;padding:0 clamp(20px,4vw,56px);}
.wrap-md{max-width:980px;margin:0 auto;padding:0 clamp(20px,4vw,56px);}

/* ---------- nav ---------- */
nav.site{position:fixed;top:0;left:0;right:0;z-index:90;
  display:flex;align-items:center;justify-content:space-between;
  padding:calc(20px + env(safe-area-inset-top,0px)) clamp(20px,4vw,56px) 20px;
  transition:background .4s,backdrop-filter .4s,box-shadow .4s;}
nav.site.solid{background:rgba(247,245,242,.86);backdrop-filter:blur(16px) saturate(160%);box-shadow:0 1px 0 var(--hair);}
/* tapa la franja del status bar en iOS: nada de contenido se asoma encima del nav */
nav.site::before{content:"";position:absolute;left:0;right:0;bottom:99%;height:120px;
  background:transparent;transition:background .4s;pointer-events:none;}
nav.site.solid::before{background:rgba(247,245,242,.97);}
nav.site .nm{font-weight:600;font-size:15px;color:var(--ink);letter-spacing:-.01em;}
nav.site .lnks{display:flex;gap:32px;align-items:center;}
nav.site .lnks a{font-size:14px;font-weight:500;color:var(--body);position:relative;}
nav.site .lnks a::after{content:"";position:absolute;left:0;bottom:-5px;height:1.5px;width:0;background:var(--acc);transition:width .35s var(--ease);}
nav.site .lnks a:hover{color:var(--ink)} nav.site .lnks a:hover::after{width:100%}
nav.site .lnks a[aria-current]{color:var(--ink)} nav.site .lnks a[aria-current]::after{width:100%}
nav.site .right{display:flex;align-items:center;gap:14px;}
nav.site .lng{font-family:'Inter',sans-serif;font-weight:600;font-size:11.5px;display:flex;gap:2px;border:1px solid var(--hair);border-radius:99px;padding:3px;}
nav.site .lng a{padding:4px 10px;border-radius:99px;color:var(--mute);}
nav.site .lng a.on{background:var(--ink);color:var(--paper);}
/* light nav over dark hero (home top) */
body.dark-top nav.site:not(.solid) .nm,
body.dark-top nav.site:not(.solid) .lnks a{color:var(--dark-ink);}
body.dark-top nav.site:not(.solid) .lng{border-color:rgba(244,242,238,.25);}
body.dark-top nav.site:not(.solid) .lng a{color:rgba(244,242,238,.6);}
body.dark-top nav.site:not(.solid) .lng a.on{background:var(--dark-ink);color:var(--ink);}
body.dark-top nav.site:not(.solid) .burger{border-color:rgba(244,242,238,.25);}
body.dark-top nav.site:not(.solid) .burger span{background:var(--dark-ink);}
/* menu open: force ink on paper overlay + burger becomes X (must come after dark-top rules) */
body.menu-open nav.site:not(.solid) .nm,
body.menu-open nav.site .nm{color:var(--ink);}
body.menu-open nav.site:not(.solid) .lng{border-color:var(--hair);}
body.menu-open nav.site:not(.solid) .lng a{color:var(--mute);}
body.menu-open nav.site:not(.solid) .lng a.on{background:var(--ink);color:var(--paper);}
body.menu-open nav.site:not(.solid) .burger{border-color:var(--hair);}
body.menu-open nav.site:not(.solid) .burger span,
body.menu-open nav.site .burger span{background:var(--ink);}
.burger.x span:nth-child(1){transform:translateY(5.1px) rotate(45deg);}
.burger.x span:nth-child(2){opacity:0;}
.burger.x span:nth-child(3){transform:translateY(-5.1px) rotate(-45deg);}
.burger{display:none;width:42px;height:42px;border:1px solid var(--hair);border-radius:50%;background:transparent;cursor:pointer;}
.burger span{display:block;width:16px;height:1.6px;background:var(--ink);margin:3.5px auto;transition:.3s var(--ease);}
.mnav{display:flex;position:fixed;inset:0;z-index:80;background:var(--paper);
  flex-direction:column;justify-content:center;gap:8px;padding:0 clamp(24px,6vw,56px);
  opacity:0;visibility:hidden;transform:scale(1.045);
  transition:opacity .32s var(--ease),transform .5s var(--ease),visibility 0s .32s;}
.mnav.open{opacity:1;visibility:visible;transform:none;
  transition:opacity .26s var(--ease),transform .5s var(--ease);}
.mnav a{font-size:clamp(34px,9vw,54px);font-weight:560;color:var(--ink);letter-spacing:-.03em;padding:6px 0;border-bottom:1px solid var(--hair);
  opacity:0;transform:translateY(26px);transition:opacity .3s ease,transform .45s var(--ease);}
.mnav.open a{opacity:1;transform:none;}
.mnav.open a:nth-child(1){transition-delay:.08s}
.mnav.open a:nth-child(2){transition-delay:.15s}
.mnav.open a:nth-child(3){transition-delay:.22s}
.mnav.open a:nth-child(4){transition-delay:.29s}
.mnav.open a:nth-child(5){transition-delay:.36s}

/* entrada de pagina suave */
@keyframes pageFade{from{opacity:0}}
@keyframes pageUp{from{opacity:0;transform:translateY(18px)}}
body{animation:pageFade .4s ease-out;}
nav.site ~ section:first-of-type{animation:pageUp .6s var(--ease) .04s both;}
@media (prefers-reduced-motion:reduce){
  body,nav.site ~ section:first-of-type{animation:none;}
  .mnav,.mnav a{transition:none;}
}

/* ---------- buttons / chips ---------- */
.pill{display:inline-flex;align-items:center;gap:11px;font-weight:580;font-size:15.5px;color:var(--ink);
  border:1px solid var(--hair);border-radius:99px;padding:15px 28px;transition:.35s var(--ease);}
.pill:hover{background:var(--ink);color:var(--paper);transform:translateY(-2px);}
.pill.solid{background:var(--ink);color:var(--paper);border-color:var(--ink);}
.pill.solid:hover{background:var(--acc);border-color:var(--acc);color:#fff;}
.meta-pills{display:flex;flex-wrap:wrap;gap:8px;}
.meta-pills span{font-size:12.5px;font-weight:500;border:1px solid var(--hair);border-radius:99px;padding:6px 13px;color:var(--body);}
.golink{display:inline-flex;align-items:center;gap:10px;font-weight:550;font-size:15px;color:var(--ink);}
.golink .cir{width:34px;height:34px;border-radius:50%;border:1px solid var(--hair);display:grid;place-items:center;transition:.35s var(--ease);}
.golink:hover .cir{background:var(--acc);border-color:var(--acc);color:#fff;transform:translateX(4px);}

/* ---------- hero (home) ---------- */
.hero{min-height:calc(100svh - 42px);display:flex;flex-direction:column;justify-content:flex-end;
  padding:0 clamp(20px,4vw,56px) 48px;position:relative;overflow:hidden;}
.hero .avail{position:absolute;top:104px;left:clamp(20px,4vw,56px);display:inline-flex;align-items:center;gap:9px;font-size:13.5px;font-weight:500;color:var(--ink);}
.hero .avail i{width:8px;height:8px;border-radius:50%;background:#2C8C4C;display:block;animation:pulse 2.4s infinite;}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(44,140,76,.35)}50%{box-shadow:0 0 0 7px rgba(44,140,76,0)}}
.hero .geo{position:absolute;top:104px;right:clamp(20px,4vw,56px);text-align:right;}
.hero{--pw:min(29vw,372px,calc((100svh - 512px)*.75));}
/* dark hero variant */
.hero.dk{background:
  radial-gradient(900px 500px at 80% -10%, rgba(192,79,44,.16), transparent 60%),
  linear-gradient(170deg,#191713 0%, #131210 70%, #100F0D 100%);
  border-radius:0 0 30px 30px;}
.hero.dk::before{content:"";position:absolute;inset:0;pointer-events:none;
  background-image:linear-gradient(rgba(244,242,238,.045) 1px,transparent 1px),linear-gradient(90deg,rgba(244,242,238,.045) 1px,transparent 1px);
  background-size:72px 72px;}
.hero.dk h1{color:var(--dark-ink);}
.hero.dk .sub p{color:rgba(244,242,238,.74);}
.hero.dk .avail{color:var(--dark-ink);}
.hero.dk .geo .lbl{color:rgba(244,242,238,.45);}
.hero.dk .scroll{color:rgba(244,242,238,.45);}
.hero.dk .scroll i{background:rgba(244,242,238,.18);}
.hero-dots{position:absolute;left:0;right:0;top:13%;z-index:0;pointer-events:none;opacity:.95;overflow:visible;}
.hero-dots circle{transform-box:fill-box;transform-origin:center;transform:scale(0);animation:dotpop .6s var(--ease) forwards;}
@keyframes dotpop{to{transform:scale(1)}}
.hero-photo{position:absolute;right:clamp(20px,4vw,56px);bottom:305px;width:var(--pw);aspect-ratio:3/4;
  border-radius:6px;overflow:hidden;z-index:2;border:8px solid #FCFBF9;border-bottom-width:34px;
  transform:rotate(2.5deg);box-shadow:0 40px 80px -30px rgba(0,0,0,.65);background:#FCFBF9;}
.hero-photo .tag{position:absolute;left:0;right:0;bottom:-30px;text-align:center;font-family:'Inter',sans-serif;font-weight:600;
  font-size:10.5px;color:#6b665d;letter-spacing:.06em;}
.hero-sticker{position:absolute;right:calc(clamp(20px,4vw,56px) + var(--pw)*.78);bottom:calc(305px + var(--pw)*1.1);
  z-index:3;background:var(--acc);color:#fff;font-weight:650;font-size:13px;letter-spacing:-.01em;
  padding:9px 16px;border-radius:99px;transform:rotate(-8deg);box-shadow:0 14px 30px -12px rgba(192,79,44,.6);
  opacity:0;animation:fadein .7s var(--ease) .9s forwards;}
.hero-photo img{width:100%;height:100%;object-fit:cover;object-position:center 18%;transform:scale(1.12);transition:transform 1.4s var(--ease);}
/* terminal card (home hero) */
.hero-term{position:absolute;right:clamp(20px,4vw,56px);bottom:300px;width:min(34vw,452px);z-index:2;
  background:#16130F;border:1px solid rgba(244,242,238,.12);border-radius:14px;transform:rotate(1.6deg);
  box-shadow:0 44px 90px -32px rgba(0,0,0,.7);opacity:0;animation:fadein .8s var(--ease) .45s forwards;}
.hero-term .tbar{height:36px;display:flex;align-items:center;gap:7px;padding:0 14px;border-bottom:1px solid rgba(244,242,238,.08);}
.hero-term .tbar i{width:11px;height:11px;border-radius:50%;display:block;}
.hero-term .tbar i:nth-child(1){background:#FF5F57}
.hero-term .tbar i:nth-child(2){background:#FEBC2E}
.hero-term .tbar i:nth-child(3){background:#28C840}
.hero-term .tbar span{margin-left:8px;font-family:'Inter',sans-serif;font-weight:600;font-size:10.5px;color:rgba(244,242,238,.4);letter-spacing:.04em;}
.hero-term .tbody{padding:16px 18px 18px;font-family:'Inter',sans-serif;font-weight:600;font-size:12.5px;line-height:1.7;
  color:rgba(244,242,238,.85);min-height:150px;}
.hero-term .tp{color:#E08A6B;}
.hero-term .tout{color:rgba(244,242,238,.78);}
.hero-term .tout b{color:#fff;font-weight:600;}
.tcur{display:inline-block;width:8px;height:14px;background:#E08A6B;vertical-align:-2px;margin-left:1px;
  animation:blink 1.05s steps(1) infinite;}
@keyframes blink{50%{opacity:0}}
.hero-ava{position:absolute;top:-34px;right:-24px;width:106px;height:106px;
  filter:drop-shadow(0 16px 30px rgba(0,0,0,.5));
  animation:avafloat 4.5s ease-in-out infinite;}
@keyframes avafloat{50%{transform:translateY(-9px) rotate(3deg)}}
.hero-photo.in img{transform:scale(1);}
.hero-photo::after{content:"";position:absolute;inset:0;background:var(--paper);transform:translateY(0);transition:transform 1s var(--ease) .15s;}
.hero.dk .hero-photo::after{background:#FCFBF9;}
.hero-photo.in::after{transform:translateY(101%);}
.hero h1{font-size:clamp(50px,8.6vw,128px);line-height:1.04;letter-spacing:-.04em;font-weight:560;}
.hero h1 .ln{display:block;overflow:hidden;padding-bottom:.08em;margin-bottom:-.08em;}
.hero h1 .ln span{display:block;transform:translateY(115%);animation:rise 1.1s var(--ease) forwards;white-space:nowrap;}
.hero h1 .ln:nth-child(2) span{animation-delay:.1s}
.hero h1 .ln:nth-child(3) span{animation-delay:.2s}
.hero h1 em{font-style:normal;color:var(--acc);}
@keyframes rise{to{transform:translateY(0)}}
.hero .sub{margin-top:24px;display:flex;align-items:flex-end;justify-content:space-between;gap:30px;flex-wrap:wrap;}
.hero .sub p{font-size:17px;max-width:44ch;color:var(--body);opacity:0;animation:fadein .9s var(--ease) .55s forwards;}
.hero .scroll{font-family:'Inter',sans-serif;font-weight:600;font-size:11.5px;color:var(--mute);letter-spacing:.12em;text-transform:uppercase;
  display:flex;align-items:center;gap:10px;opacity:0;animation:fadein .9s var(--ease) .75s forwards;}
.hero .scroll i{display:block;width:1px;height:34px;background:var(--hair);position:relative;overflow:hidden;}
.hero .scroll i::after{content:"";position:absolute;left:0;top:-100%;width:100%;height:100%;background:var(--acc);animation:drip 1.8s var(--ease) infinite;}
@keyframes drip{to{top:100%}}
@keyframes fadein{to{opacity:1}}

/* ---------- page hero (subpages) ---------- */
.phead{padding:calc(clamp(96px,11.5vh,128px) + env(safe-area-inset-top,0px)) 0 0;}
.phead .lbl{display:block;}
.phead h1{font-size:clamp(44px,7vw,96px);line-height:1.02;letter-spacing:-.04em;font-weight:560;
  overflow:hidden;padding-bottom:.1em;margin-bottom:-.06em;}
.phead h1>span{display:block;transform:translateY(115%);animation:rise 1s var(--ease) .05s forwards;}
.phead .intro{margin-top:22px;font-size:17.5px;max-width:58ch;opacity:0;animation:fadein .9s var(--ease) .45s forwards;}
/* dark page header (home style) */
.phead.dk{background:
  radial-gradient(720px 380px at 85% -12%, rgba(192,79,44,.15), transparent 62%),
  linear-gradient(168deg,#191713 0%, #131210 75%, #100F0D 100%);
  border-radius:0 0 26px 26px;padding-bottom:clamp(44px,6vw,76px);position:relative;overflow:hidden;}
.phead.dk::before{content:"";position:absolute;inset:0;pointer-events:none;
  background-image:linear-gradient(rgba(244,242,238,.045) 1px,transparent 1px),linear-gradient(90deg,rgba(244,242,238,.045) 1px,transparent 1px);
  background-size:72px 72px;}
.phead.dk>*{position:relative;}
.phead.dk h1{color:var(--dark-ink);}
.phead.dk .intro{color:rgba(244,242,238,.75);}
.phead.dk .lbl{color:rgba(244,242,238,.5);}
.phead.dk a.lbl:hover{color:#E08A6B;}
.phead.dk .pill{border-color:rgba(244,242,238,.28);color:var(--dark-ink);}
.phead.dk .pill:hover{background:var(--paper);color:var(--ink);}
.phead.dk .pill.solid{background:var(--paper);color:var(--ink);border-color:var(--paper);}
.phead.dk .pill.solid:hover{background:var(--acc);color:#fff;border-color:var(--acc);}
.phead.dk.deep{padding-bottom:clamp(84px,10vw,128px);}
.phead.dk.deep h1{font-size:clamp(38px,5.4vw,72px);}
.phead.dk.deep .intro{margin-top:14px;font-size:16px;}
.case-pull{margin-top:calc(-1*clamp(56px,8vw,112px));position:relative;z-index:6;}
.case-pull .case-hero{margin-top:0;box-shadow:0 36px 80px -30px rgba(22,21,18,.35);}

/* ---------- marquee ---------- */
.marq{border-top:1px solid var(--hair);border-bottom:1px solid var(--hair);overflow:hidden;padding:16px 0;}
.marq .track{display:flex;width:max-content;animation:scrollx 46s linear infinite;}
.marq:hover .track{animation-play-state:paused;}
.marq span{font-size:14.5px;font-weight:500;color:var(--mute);white-space:nowrap;display:flex;align-items:center;}
.marq span::after{content:"·";margin:0 26px;color:var(--acc);}
@keyframes scrollx{to{transform:translateX(-50%)}}
/* terracotta construction-tape band */
.marq.acc{background:var(--acc);border:0;transform:rotate(-1.4deg) scale(1.03);margin:-44px 0 10px;padding:15px 0;
  box-shadow:0 18px 40px -20px rgba(192,79,44,.5);position:relative;z-index:5;}
.marq.acc span{color:#fff;font-weight:650;font-size:15px;letter-spacing:.01em;}
.marq.acc span::after{color:rgba(255,255,255,.55);}

/* ---------- custom cursor ---------- */
@media (pointer:fine){
  .cursor-on, .cursor-on a, .cursor-on button, .cursor-on .game-panel{cursor:none;}
  .cur-dot{position:fixed;z-index:300;width:7px;height:7px;border-radius:50%;background:var(--acc);
    pointer-events:none;transform:translate(-50%,-50%);}
  .cur-ring{position:fixed;z-index:299;width:34px;height:34px;border-radius:50%;border:1.5px solid var(--acc);
    pointer-events:none;transform:translate(-50%,-50%);transition:width .3s var(--ease),height .3s var(--ease),background-color .3s,border-color .3s;
    display:flex;align-items:center;justify-content:center;font-family:'Inter',sans-serif;font-weight:600;font-size:0;color:#fff;}
  .cur-ring.grow{width:58px;height:58px;background:rgba(192,79,44,.14);}
  .cur-ring.label{width:74px;height:74px;background:var(--acc);border-color:var(--acc);font-size:11px;letter-spacing:.05em;}
}
@media (pointer:coarse){.cur-dot,.cur-ring{display:none!important;}}

/* ---------- floating game badge + modal ---------- */
.play-badge{position:fixed;right:26px;bottom:26px;z-index:120;width:96px;height:96px;border-radius:50%;
  background:var(--acc);color:#fff;border:0;cursor:pointer;display:grid;place-items:center;
  box-shadow:0 18px 44px -16px rgba(192,79,44,.65);
  opacity:0;transform:translateY(20px) scale(.85);pointer-events:none;
  transition:opacity .5s var(--ease),transform .5s var(--ease);}
.play-badge.show{opacity:1;transform:none;pointer-events:auto;}
.play-badge:hover{transform:scale(1.07);}
.play-badge svg.spin{position:absolute;inset:6px;animation:rot 16s linear infinite;}
.play-badge svg.spin text{fill:rgba(255,255,255,.92);font-family:'Inter',sans-serif;font-weight:600;font-size:10.2px;letter-spacing:.18em;}
.play-badge .blocks{display:flex;flex-direction:column;gap:2.5px;align-items:center;}
.play-badge .blocks i{display:block;height:5px;border-radius:1.5px;background:#fff;}
.play-badge .blocks i:nth-child(1){width:12px}.play-badge .blocks i:nth-child(2){width:18px}.play-badge .blocks i:nth-child(3){width:24px}
@keyframes rot{to{transform:rotate(360deg)}}
.game-modal{position:fixed;inset:0;z-index:150;display:none;align-items:center;justify-content:center;padding:22px;
  background:rgba(19,18,16,.6);backdrop-filter:blur(8px);}
.game-modal.open{display:flex;}
.game-box{width:min(560px,100%);background:var(--paper);border-radius:22px;padding:22px;position:relative;
  box-shadow:0 50px 120px -30px rgba(0,0,0,.6);}
.game-box .gx{position:absolute;top:14px;right:14px;width:38px;height:38px;border-radius:50%;border:1px solid var(--hair);
  background:transparent;color:var(--ink);font-size:17px;cursor:pointer;transition:.3s;}
.game-box .gx:hover{background:var(--ink);color:var(--paper);}
.game-box h3{font-size:21px;letter-spacing:-.02em;margin-bottom:4px;}
.game-box .gsub{font-size:13.5px;color:var(--mute);margin-bottom:14px;}
.game-box .game-panel{height:min(58vh,440px);}
.game-box .gfoot{display:flex;justify-content:space-between;margin-top:12px;font-family:'Inter',sans-serif;font-weight:600;
  font-size:11px;color:var(--mute);letter-spacing:.06em;text-transform:uppercase;}
.game-box .gfoot b{color:var(--acc);}

/* ---------- reveal variants ---------- */
.js .rv-l{opacity:0;transform:translateX(-34px);transition:opacity .9s var(--ease),transform .9s var(--ease);}
.js .rv-r{opacity:0;transform:translateX(34px);transition:opacity .9s var(--ease),transform .9s var(--ease);}
.js .rv-l.in,.js .rv-r.in{opacity:1;transform:none;}
.js .pop{opacity:0;transform:scale(.7);transition:opacity .55s var(--ease),transform .55s var(--ease);}
.js .pop.in{opacity:1;transform:scale(1);}
.proj .vis{will-change:transform;transition:transform .35s ease-out;transform-style:preserve-3d;}

/* ---------- sections ---------- */
.sec{padding:clamp(90px,11vw,160px) 0 0;}
.sec-head{display:flex;align-items:baseline;justify-content:space-between;gap:20px;margin-bottom:clamp(36px,5vw,60px);}
.sec-head h2{font-size:clamp(32px,4.4vw,56px);line-height:1.03;}
.sec-head .cnt{font-family:'Inter',sans-serif;font-weight:600;font-size:13px;color:var(--mute);font-variant-numeric:tabular-nums;}

/* ---------- project rows (home) ---------- */
.proj{display:grid;grid-template-columns:1fr 1fr;gap:clamp(24px,4vw,64px);align-items:center;
  padding:clamp(38px,5vw,68px) 0;border-top:1px solid var(--hair);}
.proj:last-of-type{border-bottom:1px solid var(--hair);}
.proj .vis{border-radius:18px;overflow:hidden;background:linear-gradient(135deg,var(--tint,#E9E4DC),var(--tint2,var(--tint,#E9E4DC)));aspect-ratio:4/3.1;
  display:flex;align-items:center;justify-content:center;position:relative;}
.proj .vis .reveal-mask{position:absolute;inset:0;background:var(--paper);transform:translateY(0);transition:transform 1s var(--ease);z-index:3;}
.proj.in .vis .reveal-mask{transform:translateY(101%);}
.proj .vis img{transition:transform .9s var(--ease);}
.proj .vis:hover img{transform:scale(1.03);}
.proj .vis .ph{width:min(44%,210px);border-radius:26px;border:5px solid #181818;overflow:hidden;background:#181818;
  box-shadow:0 30px 60px -22px rgba(22,21,18,.45);}
.proj .vis .br{width:84%;border-radius:10px;overflow:hidden;box-shadow:0 26px 56px -24px rgba(22,21,18,.5);}
/* duo: two phones, identical frame proportions */
.proj .vis.duo{gap:5%;}
.proj .vis.duo .ph{width:29%;aspect-ratio:9/19.4;border-radius:22px;transition:transform .8s var(--ease);}
.proj .vis.duo .ph img{width:100%;height:100%;object-fit:cover;object-position:center top;}
.proj .vis .ph.real{border:0;background:transparent;border-radius:0;overflow:visible;aspect-ratio:903/1863;box-shadow:none;}
.proj .vis .ph.real img{object-fit:contain;filter:drop-shadow(0 30px 48px rgba(22,21,18,.42));}
.proj .vis.duo .ph.a{transform:rotate(-4deg) translateY(-3%);}
.proj .vis.duo .ph.b{transform:rotate(3.5deg) translateY(5%);}
.proj .vis.duo:hover .ph.a{transform:rotate(-4.6deg) translateY(-4.5%);}
.proj .vis.duo:hover .ph.b{transform:rotate(4.2deg) translateY(3.5%);}
/* banner decorations: ghost number + sticker */
.proj .vis .pnum{position:absolute;left:3%;bottom:-5%;z-index:1;pointer-events:none;
  font-weight:800;font-size:clamp(110px,13vw,180px);line-height:1;letter-spacing:-.04em;
  color:transparent;-webkit-text-stroke:1.5px rgba(22,21,18,.14);}
.proj .vis.dkp .pnum{-webkit-text-stroke:1.5px rgba(244,242,238,.16);}
.proj .vis .stick{position:absolute;top:7%;right:6%;z-index:4;background:var(--paper);color:var(--ink);
  font-weight:650;font-size:12.5px;padding:8px 15px;border-radius:99px;transform:rotate(6deg);
  box-shadow:0 12px 26px -10px rgba(22,21,18,.35);transition:transform .5s var(--ease);}
.proj .vis:hover .stick{transform:rotate(2deg) scale(1.06);}
.proj .vis .ph{position:relative;z-index:2;}
.proj.flip .vis{order:2}
.proj .txt .pn{font-family:'Inter',sans-serif;font-weight:600;font-size:12px;color:var(--acc);letter-spacing:.1em;}
.proj .txt h3{font-size:clamp(26px,3.2vw,40px);margin-top:12px;line-height:1.05;}
.proj .txt .ds{margin-top:14px;font-size:16px;max-width:46ch;}
.proj .txt .meta-pills{margin-top:22px;}
.proj .txt .golink{margin-top:26px;}
.more-work{display:flex;justify-content:center;padding:clamp(38px,5vw,60px) 0 0;}

/* ---------- icons ---------- */
.ico{width:1.05em;height:1.05em;stroke:currentColor;fill:none;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round;vertical-align:-0.18em;display:inline-block;}

/* ---------- work index list ---------- */
.windex{border-top:1px solid var(--hair);margin-top:8px;}
.wrow{display:grid;grid-template-columns:64px 250px 1fr 260px;align-items:center;gap:clamp(14px,2.5vw,34px);
  padding:clamp(22px,3vw,34px) 6px;border-bottom:1px solid var(--hair);position:relative;transition:.35s var(--ease);}
.wrow .no{font-family:'Inter',sans-serif;font-weight:600;font-size:13px;color:var(--mute);font-variant-numeric:tabular-nums;transition:.3s;}
.wrow .ti{font-size:clamp(22px,2.8vw,34px);font-weight:560;color:var(--ink);letter-spacing:-.03em;line-height:1.05;transition:transform .35s var(--ease);}
.wrow .de{font-size:14.5px;color:var(--body);max-width:52ch;}
.wrow .yr{font-family:'Inter',sans-serif;font-weight:600;font-size:12px;color:var(--mute);white-space:nowrap;display:flex;align-items:center;gap:16px;justify-content:flex-end;}
.wrow .yr .arr{width:34px;height:34px;border-radius:50%;border:1px solid var(--hair);display:grid;place-items:center;color:var(--ink);transition:.35s var(--ease);font-size:15px;}
.wrow:hover{padding-left:18px;}
.wrow:hover .no{color:var(--acc);}
.wrow:hover .arr{background:var(--acc);border-color:var(--acc);color:#fff;}
.wrow .thumb{position:absolute;right:110px;top:50%;transform:translateY(-50%) scale(.92);width:170px;border-radius:12px;overflow:hidden;
  opacity:0;pointer-events:none;transition:.4s var(--ease);box-shadow:0 24px 50px -20px rgba(22,21,18,.4);z-index:5;}
.wrow:hover .thumb{opacity:1;transform:translateY(-50%) scale(1);}

/* ---------- case study (project detail) ---------- */
.case-hero{margin-top:clamp(28px,4vw,48px);border-radius:20px;overflow:hidden;
  background:
    radial-gradient(circle at 18% 18%, rgba(255,255,255,.34), transparent 46%),
    linear-gradient(135deg,var(--tint,#E9E4DC),var(--tint2,var(--tint,#E9E4DC)));
  min-height:clamp(300px,46vw,520px);display:flex;align-items:center;justify-content:center;gap:clamp(18px,3vw,44px);
  padding:clamp(28px,4vw,56px);position:relative;}
.case-hero.imgbg{background-size:cover;background-position:center;}
.case-hero.imgbg::before{display:none;}
.case-hero::before{content:"";position:absolute;inset:0;pointer-events:none;opacity:.5;
  background-image:radial-gradient(circle,rgba(22,21,18,.07) 1.4px,transparent 1.4px);background-size:26px 26px;
  -webkit-mask-image:radial-gradient(90% 90% at 50% 50%,#000 30%,transparent 100%);
          mask-image:radial-gradient(90% 90% at 50% 50%,#000 30%,transparent 100%);}
/* floating UI cards */
.fcard{position:absolute;z-index:7;background:rgba(255,255,255,.94);backdrop-filter:blur(6px);color:var(--ink);
  font-size:clamp(11.5px,1.2vw,14px);font-weight:500;padding:11px 16px;border-radius:13px;
  box-shadow:0 18px 40px -14px rgba(22,21,18,.35);max-width:34ch;line-height:1.45;
  animation:ffloat 5.2s ease-in-out infinite;}
.fcard b{font-weight:700;}
.fcard.f1{left:4.5%;top:13%;transform:rotate(-4deg);}
.fcard.f2{right:4%;bottom:11%;transform:rotate(3deg);animation-delay:1.4s;}
@keyframes ffloat{50%{translate:0 -10px;}}
.spark{position:absolute;color:var(--acc);font-size:clamp(16px,2vw,24px);z-index:6;animation:twinkle 3.4s ease-in-out infinite;}
.spark.s1{left:11%;bottom:20%;}
.spark.s2{right:12%;top:14%;animation-delay:1.2s;font-size:clamp(12px,1.4vw,17px);}
@keyframes twinkle{0%,100%{opacity:.35;transform:scale(.85) rotate(0deg)}50%{opacity:1;transform:scale(1.15) rotate(40deg)}}
/* screens carousel */
.car-wrap{position:relative;margin-top:18px;}
.car{display:flex;gap:16px;overflow-x:auto;scroll-snap-type:x mandatory;padding:6px 2px 14px;cursor:grab;
  scrollbar-width:none;}
.car.drag{cursor:grabbing;scroll-snap-type:none;}
.car::-webkit-scrollbar{display:none;height:0;}
.car::-webkit-scrollbar-thumb{background:var(--acc);border-radius:3px;}
.car::-webkit-scrollbar-track{background:rgba(22,21,18,.07);border-radius:3px;}
.car .g{flex:0 0 auto;scroll-snap-align:start;border-radius:14px;background:var(--paper2);padding:16px;
  display:flex;align-items:center;justify-content:center;border:0;font:inherit;color:inherit;}
.car .g img{height:clamp(280px,36vw,420px);width:auto;border-radius:10px;box-shadow:0 16px 36px -16px rgba(22,21,18,.35);
  pointer-events:none;user-select:none;}
.case-hero .ph{width:clamp(150px,18vw,235px);border-radius:28px;border:6px solid #181818;overflow:hidden;background:#181818;
  box-shadow:0 36px 70px -26px rgba(22,21,18,.5);}
.case-hero .ph.real{border:0;border-radius:0;background:transparent;overflow:visible;box-shadow:none;
  filter:drop-shadow(0 36px 58px rgba(22,21,18,.5));}
/* demo en video dentro del marco de iPhone */
.ph.vid{position:relative;aspect-ratio:903/1863;}
.ph.vid .dvid{position:absolute;left:3.1%;top:1.72%;width:94.2%;height:97.1%;
  object-fit:cover;border-radius:10% / 4.85%;background:#0c0c0c;}
.ph.vid .frm{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;}
.case-hero .ph+.ph{transform:translateY(26px);}
.case-hero .br{width:min(78%,860px);border-radius:12px;overflow:hidden;box-shadow:0 30px 64px -26px rgba(22,21,18,.5);}
.case-grid{display:grid;grid-template-columns:330px 1fr;gap:clamp(34px,5vw,80px);align-items:start;margin-top:clamp(48px,6vw,80px);}
.case-side{position:sticky;top:110px;display:flex;flex-direction:column;gap:0;border-top:1px solid var(--hair);}
.case-side .kv{display:flex;justify-content:space-between;gap:14px;padding:15px 2px;border-bottom:1px solid var(--hair);font-size:13.5px;}
.case-side .kv b{color:var(--ink);font-weight:550;}
.case-side .kv span{color:var(--mute);}
.case-side .links{display:flex;flex-direction:column;gap:10px;margin-top:22px;}
.case-body h2{font-size:clamp(24px,3vw,36px);margin:clamp(40px,5vw,56px) 0 18px;line-height:1.1;}
.case-body h2:first-child{margin-top:0;}
.case-body p{font-size:16.5px;max-width:62ch;}
.case-body p+p{margin-top:14px;}
.feat{list-style:none;display:flex;flex-direction:column;gap:13px;margin-top:8px;}
.feat li{position:relative;padding-left:24px;font-size:15.5px;line-height:1.5;}
.feat li::before{content:"";position:absolute;left:0;top:11px;width:13px;height:2px;background:var(--acc);}
.feat li b{color:var(--ink);font-weight:600;}
.spec3{display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid var(--hair);margin-top:10px;}
.spec3 .c{padding:18px 20px 10px 0;border-right:1px solid var(--hair);}
.spec3 .c:last-child{border-right:0}
.spec3 .c:not(:first-child){padding-left:20px}
.spec3 .c .lbl{margin-bottom:11px;display:block;color:var(--acc);}
.tagrow{display:flex;flex-wrap:wrap;gap:7px;}
.tagrow span{font-size:12.5px;padding:5px 11px;border-radius:99px;border:1px solid var(--hair);color:var(--body);}
.flow{display:flex;align-items:center;gap:9px;flex-wrap:wrap;margin-top:8px;}
.case-body .flow{margin-top:26px;}
.flow .node{font-family:'Inter',sans-serif;font-weight:600;font-size:12px;padding:8px 13px;border-radius:9px;
  background:rgba(192,79,44,.07);border:1px solid rgba(192,79,44,.25);color:var(--ink);white-space:nowrap;}
.flow .arr{color:var(--acc);}
.gal{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-top:18px;}
.gal .g{border-radius:14px;overflow:hidden;background:var(--paper2);display:flex;align-items:center;justify-content:center;padding:20px;}
.gal .g img{border-radius:10px;box-shadow:0 18px 40px -18px rgba(22,21,18,.35);max-height:380px;width:auto;}
.pn-nav{display:grid;grid-template-columns:1fr 1fr;border-top:1px solid var(--hair);margin-top:clamp(70px,9vw,120px);}
.pn-nav a{padding:clamp(26px,3.6vw,44px) 6px;display:flex;flex-direction:column;gap:8px;transition:.3s var(--ease);}
.pn-nav a:last-child{text-align:right;align-items:flex-end;border-left:1px solid var(--hair);}
.pn-nav a:hover{background:rgba(22,21,18,.025);}
.pn-nav .ti{font-size:clamp(20px,2.6vw,30px);font-weight:560;color:var(--ink);letter-spacing:-.03em;}

/* ---------- about / experience ---------- */
.ab{display:grid;grid-template-columns:minmax(280px,430px) 1fr;gap:clamp(36px,6vw,90px);align-items:center;}
.ab .pic{border-radius:18px;overflow:hidden;aspect-ratio:3/4;position:relative;}
.ab .pic img{width:100%;height:100%;object-fit:cover;}
.ab .pic .stamp{position:absolute;left:14px;bottom:14px;background:rgba(247,245,242,.92);backdrop-filter:blur(8px);
  border-radius:11px;padding:11px 15px;font-size:13.5px;font-weight:560;color:var(--ink);}
.ab .pic .stamp small{display:block;font-weight:400;color:var(--mute);font-size:11.5px;margin-top:1px;}
.ab h2{font-size:clamp(28px,3.6vw,46px);line-height:1.08;max-width:20ch;text-wrap:balance;}
.ab .bio{margin-top:18px;font-size:16.5px;max-width:56ch;}
.stats{display:flex;gap:clamp(28px,4vw,60px);border-top:1px solid var(--hair);padding-top:26px;margin-top:32px;}
.stats .s b{font-size:clamp(28px,3vw,42px);font-weight:580;color:var(--ink);letter-spacing:-.03em;font-variant-numeric:tabular-nums;display:block;line-height:1;}
.stats .s i{font-style:normal;font-size:13px;color:var(--mute);margin-top:7px;display:block;}
.cap-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px;}
.cap{border:1px solid var(--hair);border-radius:16px;padding:24px;transition:.35s var(--ease);background:rgba(255,255,255,.4);}
.cap:hover{transform:translateY(-4px);border-color:rgba(192,79,44,.4);}
.cap .no{font-family:'Inter',sans-serif;font-weight:600;font-size:12px;color:var(--acc);}
.cap h3{font-size:19px;margin-top:10px;}
.cap p{font-size:14px;margin-top:8px;color:var(--body);}

/* timeline (trayectoria) */
.tl{border-left:1.5px solid var(--hair);margin-left:6px;padding-left:clamp(24px,4vw,44px);display:flex;flex-direction:column;gap:clamp(40px,5vw,56px);}
.tl .it{position:relative;}
.tl .it::before{content:"";position:absolute;left:calc(-1 * clamp(24px,4vw,44px) - 12px);top:7px;width:11px;height:11px;border-radius:50%;
  background:var(--paper);border:2.5px solid var(--acc);}
.tl .when{font-family:'Inter',sans-serif;font-weight:600;font-size:12px;color:var(--mute);letter-spacing:.04em;}
.tl h3{font-size:clamp(20px,2.4vw,27px);margin-top:8px;line-height:1.15;}
.tl .org{font-size:14.5px;color:var(--acc);font-weight:560;margin-top:3px;}
.tl p{font-size:15.5px;margin-top:10px;max-width:62ch;}
.tl ul{list-style:none;margin-top:12px;display:flex;flex-direction:column;gap:8px;}
.tl ul li{font-size:14.5px;padding-left:20px;position:relative;color:var(--body);}
.tl ul li::before{content:"";position:absolute;left:0;top:10px;width:10px;height:2px;background:var(--acc);}
.tl .tools{margin-top:14px;}
.edu-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px;}
.edu{border:1px solid var(--hair);border-radius:16px;padding:22px;background:rgba(255,255,255,.4);}
.edu .when{font-family:'Inter',sans-serif;font-weight:600;font-size:11.5px;color:var(--mute);}
.edu h3{font-size:17px;margin-top:9px;line-height:1.25;}
.edu p{font-size:13.5px;color:var(--body);margin-top:5px;}

/* ---------- contact ---------- */
.fact-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;}
.fact{border:1px solid var(--hair);border-radius:16px;padding:22px;background:rgba(255,255,255,.4);}
.fact .lbl{display:block;margin-bottom:9px;}
.fact .v{font-size:15.5px;color:var(--ink);font-weight:550;word-break:break-word;}

/* ---------- popup resultados/grupos del mundial ---------- */
.wc-btns{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end;}
.wc-btns .pill{padding:12px 22px;font-size:14px;}
.wc-modal{position:fixed;inset:0;z-index:160;display:none;align-items:center;justify-content:center;padding:22px;
  background:rgba(19,18,16,.6);backdrop-filter:blur(8px);}
.wc-modal::before{content:"";position:absolute;left:0;right:0;top:-140px;bottom:-140px;background:rgba(19,18,16,.7);z-index:-1;}
.wc-modal.open{display:flex;}
.wc-box{width:min(620px,100%);max-height:min(78vh,720px);display:flex;flex-direction:column;
  background:var(--paper);border-radius:22px;padding:22px 22px 8px;position:relative;
  box-shadow:0 50px 120px -30px rgba(0,0,0,.6);}
.wc-box .wcx{position:absolute;top:14px;right:14px;width:38px;height:38px;border-radius:50%;border:1px solid var(--hair);
  background:transparent;color:var(--ink);font-size:17px;cursor:pointer;transition:.3s;z-index:2;}
.wc-box .wcx:hover{background:var(--ink);color:var(--paper);}
.wc-box h3{font-size:21px;letter-spacing:-.02em;margin-bottom:12px;}
.wc-tabs{display:flex;gap:6px;border:1px solid var(--hair);border-radius:99px;padding:4px;width:max-content;margin-bottom:14px;}
.wct{border:0;background:transparent;font-family:'Inter',sans-serif;font-weight:600;font-size:12.5px;letter-spacing:.04em;
  color:var(--mute);border-radius:99px;padding:8px 18px;cursor:pointer;transition:.25s;}
.wct.on{background:var(--ink);color:var(--paper);}
.wc-pane{overflow-y:auto;padding:2px 4px 18px;flex:1;}
.wc-pane .day{margin:14px 0 8px;}
.wc-pane .day:first-child{margin-top:2px;}
.wc-row{display:flex;align-items:center;justify-content:center;gap:9px;padding:8px 10px;border-bottom:1px solid var(--hair);
  font-size:14px;font-weight:550;color:var(--ink);}
.wc-row img{width:20px;height:15px;border-radius:2px;}
.wc-row .s{font-weight:700;min-width:46px;text-align:center;}
.wc-row .st{font-size:11px;color:var(--mute);font-weight:600;min-width:34px;text-align:right;}
.wc-row .st.lv{color:var(--acc);}
.wc-row .tn{min-width:44px;}
.wc-row .tn.a{text-align:right;}
.grp-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px 22px;}
.grp h4{font-family:'Inter',sans-serif;font-weight:650;font-size:12px;letter-spacing:.1em;text-transform:uppercase;
  color:var(--acc);margin-bottom:6px;}
.grp table{width:100%;border-collapse:collapse;font-size:13px;}
.grp td,.grp th{padding:5px 4px;border-bottom:1px solid var(--hair);text-align:center;font-weight:500;color:var(--body);}
.grp th{font-size:10.5px;font-weight:650;letter-spacing:.08em;color:var(--mute);text-transform:uppercase;}
.grp td:first-child,.grp th:first-child{text-align:left;}
.grp .tm{display:flex;align-items:center;gap:7px;font-weight:600;color:var(--ink);}
.grp .tm img{width:18px;height:13.5px;border-radius:2px;}
.grp tr.q td{background:rgba(192,79,44,.05);}
.wc-load{padding:30px 0;text-align:center;color:var(--mute);font-size:14px;}
@media (max-width:920px){
  .grp-grid{grid-template-columns:1fr;}
  .wc-btns{flex-direction:column;align-items:stretch;gap:12px;width:100%;}
  .wc-btns .pill{justify-content:center;}
  .wc-box{max-height:82vh;}
}

/* ---------- toast de email copiado ---------- */
.copy-toast{position:fixed;left:50%;bottom:26px;transform:translate(-50%,16px);background:var(--ink);color:var(--paper);
  font-family:'Inter',sans-serif;font-weight:600;font-size:13.5px;padding:11px 22px;border-radius:99px;
  opacity:0;pointer-events:none;z-index:120;transition:.35s var(--ease);box-shadow:0 12px 30px rgba(0,0,0,.28);}
.copy-toast.show{opacity:1;transform:translate(-50%,0);}

/* ---------- como construyo con IA ---------- */
.how{background:var(--dark);color:var(--dark-ink);border-radius:26px;padding:clamp(30px,4.4vw,60px);
  background-image:radial-gradient(640px 320px at 88% -10%, rgba(192,79,44,.22), transparent 62%);}
.how-head h2{font-size:clamp(26px,3.4vw,44px);letter-spacing:-.03em;color:var(--dark-ink);}
.how-head p{margin-top:10px;color:rgba(244,242,238,.62);max-width:56ch;font-size:clamp(14.5px,1.5vw,17px);}
.how-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(18px,2.4vw,30px);margin-top:clamp(28px,3.6vw,46px);}
.how .st .no{font-family:'Inter',sans-serif;font-weight:650;font-size:12px;color:var(--acc);letter-spacing:.12em;}
.how .st h3{font-size:clamp(15.5px,1.6vw,18.5px);margin:9px 0 7px;color:var(--dark-ink);letter-spacing:-.01em;}
.how .st p{font-size:13.8px;line-height:1.62;color:rgba(244,242,238,.58);}
.how-stack{display:flex;flex-wrap:wrap;gap:8px;margin-top:clamp(28px,3.6vw,44px);padding-top:clamp(20px,2.6vw,30px);
  border-top:1px solid rgba(244,242,238,.12);}
.how-stack i{font-style:normal;font-family:'Inter',sans-serif;font-weight:600;font-size:11.5px;letter-spacing:.05em;
  color:rgba(244,242,238,.72);border:1px solid rgba(244,242,238,.16);border-radius:99px;padding:7px 14px;}

/* ---------- dark CTA footer ---------- */
.cta{margin-top:clamp(100px,13vw,180px);background:var(--dark);color:var(--dark-ink);
  padding:clamp(80px,10vw,140px) 0 0;border-radius:32px 32px 0 0;}
.cta .lbl{color:rgba(244,242,238,.45)}
.cta h2{color:var(--dark-ink);font-size:clamp(44px,7.4vw,104px);line-height:1.02;letter-spacing:-.04em;max-width:13ch;margin-top:18px;}
.cta h2 em{font-style:normal;color:var(--acc);}
.cta .row{display:flex;align-items:flex-end;justify-content:space-between;gap:34px;flex-wrap:wrap;margin-top:40px;}
.cta .mailbtn{display:inline-flex;align-items:center;gap:12px;background:var(--paper);color:var(--ink);
  font-weight:580;font-size:clamp(15px,1.6vw,18px);border-radius:99px;padding:18px 32px;transition:.35s var(--ease);}
.cta .mailbtn:hover{background:var(--acc);color:#fff;transform:translateY(-3px);}
.cta .also{display:flex;gap:24px;flex-wrap:wrap;}
.cta .also a{font-size:14.5px;color:rgba(244,242,238,.65);border-bottom:1px solid transparent;transition:.25s;}
.cta .also a:hover{color:#fff;border-color:var(--acc);}
.cta .base{margin-top:clamp(60px,8vw,100px);border-top:1px solid rgba(244,242,238,.12);
  padding:24px 0 30px;display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;}
.cta .base span{font-family:'Inter',sans-serif;font-weight:600;font-size:11.5px;color:rgba(244,242,238,.58);letter-spacing:.06em;}

/* ---------- tower game ---------- */
.game-grid{display:grid;grid-template-columns:1fr 1.15fr;gap:clamp(34px,5vw,80px);align-items:center;}
.game-grid h2{font-size:clamp(30px,4vw,50px);line-height:1.04;}
.game-grid .gp{margin-top:16px;font-size:16.5px;max-width:48ch;}
.game-chips{display:flex;gap:10px;margin-top:26px;flex-wrap:wrap;}
.game-chips .chip{display:inline-flex;align-items:center;gap:8px;font-family:'Inter',sans-serif;font-weight:600;font-size:11.5px;
  letter-spacing:.06em;text-transform:uppercase;border:1px solid var(--hair);border-radius:99px;padding:9px 16px;color:var(--body);}
.game-chips .chip b{color:var(--acc);font-weight:600;}
.game-panel{position:relative;border:1px solid var(--hair);border-radius:20px;overflow:hidden;
  background:linear-gradient(180deg,#F2EFE9,#EAE5DC);height:clamp(380px,44vw,520px);cursor:pointer;
  touch-action:manipulation;user-select:none;}
.game-panel canvas{display:block;width:100%;height:100%;}
.game-ui{position:absolute;inset:0;display:none;flex-direction:column;align-items:center;justify-content:center;gap:12px;
  background:rgba(247,245,242,.82);backdrop-filter:blur(6px);text-align:center;padding:24px;}
.game-ui.show{display:flex;}
.game-ui b{font-size:clamp(22px,2.6vw,32px);font-weight:600;color:var(--ink);letter-spacing:-.02em;}
.game-ui span{font-size:14.5px;color:var(--body);max-width:34ch;}
.game-ui .pill{margin-top:8px;cursor:pointer;font-family:inherit;background:var(--ink);color:var(--paper);border:0;}

/* ---------- reveals ---------- */
.rv{transition:opacity .9s var(--ease),transform .9s var(--ease);}
.js .rv{opacity:0;transform:translateY(26px);}
.js .rv.in{opacity:1;transform:none;}

/* ---------- responsive ---------- */
@media (max-width:920px){
  nav.site .lnks{display:none}
  .burger{display:block}
  nav.site .lng a{padding:9px 13px;}
  .hero{justify-content:flex-start;padding-top:calc(88px + env(safe-area-inset-top,0px));min-height:auto;padding-bottom:42px;}
  .hero-photo{position:relative;right:auto;bottom:auto;width:min(70%,300px);margin:18px 0 40px;transform:rotate(2deg);}
  .hero-term{position:relative;right:auto;bottom:auto;width:100%;max-width:440px;margin:34px 0 8px;transform:rotate(0deg);order:5;}
  .hero-ava{width:84px;height:84px;top:-26px;right:-8px;}
  .hero-dots,.hero-sticker{display:none;}
  .marq.acc{transform:rotate(-1.4deg) scale(1.06);margin:-16px 0 8px;}
  .play-badge{width:78px;height:78px;right:18px;bottom:18px;}
  .proj .vis.duo .ph{width:31%;}
  .game-grid{grid-template-columns:1fr;gap:26px;}
  .game-panel{height:min(72vw,440px);}
  .hero .avail{position:static;display:inline-flex;margin-bottom:4px;}
  .hero .geo{display:none}
  .hero h1{font-size:clamp(40px,11.5vw,72px);}
  .hero h1 .ln span{white-space:normal;}
  .proj{grid-template-columns:1fr;gap:20px;}
  .proj.flip .vis{order:0}
  .wrow{grid-template-columns:44px 1fr auto;}
  .wrow .de{display:none}
  .wrow .thumb{display:none}
  .case-grid{grid-template-columns:1fr;}
  .case-side{position:static;}
  .case-hero .ph+.ph{display:none;}
  .fcard{font-size:10.5px;max-width:23ch;padding:8px 12px;}
  .fcard.f1{top:6%;}
  .fcard.f2{bottom:5%;}
  .car .g{padding:10px;}
  .car .g img{height:min(62vw,360px);}
  .spec3{grid-template-columns:1fr;}
  .spec3 .c{border-right:0;border-bottom:1px solid var(--hair);padding:14px 0;}
  .spec3 .c:last-child{border-bottom:0}
  .ab{grid-template-columns:1fr;}
  .ab .pic{max-width:360px;}
  .pn-nav{grid-template-columns:1fr;}
  .pn-nav a:last-child{border-left:0;border-top:1px solid var(--hair);align-items:flex-start;text-align:left;}
}
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;}
  .js .rv,.js .rv-l,.js .rv-r,.js .pop,.hero h1 .ln span,.phead h1>span{opacity:1!important;transform:none!important;}
  .hero-photo::after,.proj .vis .reveal-mask{display:none!important;}
  .hero-photo img{transform:none!important;}
  .hero-dots circle{transform:none!important;}
  .hero-sticker,.hero-term{opacity:1!important;}
  .cur-dot,.cur-ring{display:none!important;}
}

/* terminal keeps mono (it's a terminal) */
.hero-term .tbody,.hero-term .tbar span{font-family:'JetBrains Mono',monospace;font-weight:400;}
.hero-term .tbody b{font-weight:700;}

/* carousel arrows */
.car-btn{position:absolute;top:50%;transform:translateY(-50%);z-index:8;width:46px;height:46px;border-radius:50%;
  background:var(--paper);border:1px solid var(--hair);color:var(--ink);cursor:pointer;display:grid;place-items:center;
  box-shadow:0 12px 28px -10px rgba(22,21,18,.35);transition:.3s var(--ease);}
.car-btn:hover{background:var(--acc);border-color:var(--acc);color:#fff;}
.car-btn.prev{left:-12px;}
.car-btn.next{right:-12px;}
.car-btn:disabled{opacity:.3;pointer-events:none;}
.car-btn .ico{width:1.2em;height:1.2em;}
.car .g{cursor:zoom-in;}
/* lightbox */
.lb{position:fixed;inset:0;z-index:180;display:none;align-items:center;justify-content:center;
  background:rgba(19,18,16,.92);backdrop-filter:blur(10px);
  padding:calc(30px + env(safe-area-inset-top,0px)) 30px calc(30px + env(safe-area-inset-bottom,0px));}
/* estira el fondo mas alla del viewport (barras dinamicas de iOS) */
.lb::before{content:"";position:absolute;left:0;right:0;top:-140px;bottom:-140px;background:rgba(19,18,16,.96);z-index:-1;}
/* iOS 26 pinta el contenido scrolleable bajo el status bar ignorando capas fijas:
   con overlay abierto se oculta el contenido para que esa franja muestre solo fondo */
body.lb-open{background:#131210!important;}
body.lb-open main,body.lb-open .cta{visibility:hidden;}
body.menu-open main,body.menu-open .cta{visibility:hidden;transition:visibility 0s .34s;}
.lb.open{display:flex;}
.lb img{max-width:min(92vw,1100px);max-height:84vh;border-radius:14px;box-shadow:0 50px 120px -30px rgba(0,0,0,.7);}
.lb .lb-x{position:absolute;top:calc(22px + env(safe-area-inset-top,0px));right:24px;width:46px;height:46px;border-radius:50%;border:1px solid rgba(244,242,238,.3);
  background:transparent;color:var(--dark-ink);font-size:19px;cursor:pointer;transition:.3s;}
.lb .lb-x:hover{background:var(--acc);border-color:var(--acc);}
.lb .lb-btn{position:absolute;top:50%;transform:translateY(-50%);width:52px;height:52px;border-radius:50%;
  border:1px solid rgba(244,242,238,.3);background:rgba(247,245,242,.08);color:var(--dark-ink);cursor:pointer;
  display:grid;place-items:center;transition:.3s;}
.lb .lb-btn:hover{background:var(--acc);border-color:var(--acc);}
.lb .lb-btn.prev{left:22px;}
.lb .lb-btn.next{right:22px;}
.lb .lb-n{position:absolute;bottom:calc(24px + env(safe-area-inset-bottom,0px));left:50%;transform:translateX(-50%);font-weight:600;font-size:12.5px;
  letter-spacing:.1em;color:rgba(244,242,238,.6);}
/* terminal mas grande, solo desktop */
@media (min-width:921px){
  .hero-term{width:min(38vw,532px);}
  .hero-term .tbody{font-size:14px;line-height:1.78;padding:18px 22px 20px;min-height:172px;}
  .hero-term .tbar{height:40px;}
  .hero-term .tbar span{font-size:11.5px;}
  .hero-ava{width:122px;height:122px;top:-40px;right:-30px;}
  .tcur{width:9px;height:16px;}
}
/* world cup card (home) */
.wc{margin-top:clamp(46px,6vw,70px);}
.wc-card{display:flex;align-items:center;gap:clamp(18px,3vw,34px);flex-wrap:wrap;
  border:1px solid var(--hair);border-radius:20px;padding:clamp(18px,2.6vw,28px) clamp(20px,3vw,34px);
  background:linear-gradient(120deg,#FFF8EC, #F2F7EC 55%, #EAF3F7);position:relative;overflow:hidden;}
.wc-card::before{content:"";position:absolute;inset:0;pointer-events:none;opacity:.5;
  background-image:radial-gradient(circle,rgba(192,79,44,.12) 1.6px,transparent 1.6px);background-size:22px 22px;}
.wc-ava{width:auto;height:clamp(120px,12vw,164px);
  filter:drop-shadow(0 16px 28px rgba(22,21,18,.3));animation:avafloat 4.5s ease-in-out infinite;position:relative;}
.wc-txt{flex:1;min-width:230px;position:relative;}
.wc-txt h3{font-size:clamp(20px,2.3vw,28px);letter-spacing:-.02em;}
.wc-txt .cd{margin-top:4px;font-weight:600;color:var(--acc);font-size:clamp(14px,1.5vw,17px);font-variant-numeric:tabular-nums;}
.wc-right{display:flex;flex-direction:column;align-items:flex-end;gap:14px;position:relative;}
.wc-fix{display:flex;flex-wrap:wrap;gap:9px;max-width:480px;justify-content:flex-end;}
.wc-fix .fx{display:flex;align-items:center;gap:9px;background:rgba(255,255,255,.85);border:1px solid var(--hair);
  border-radius:99px;padding:8px 15px;font-size:13px;font-weight:600;color:var(--ink);}
.wc-fix .fx img{width:22px;height:16px;border-radius:3px;object-fit:cover;}
.wc-fix .fx i{font-style:normal;color:var(--mute);font-weight:500;font-size:11.5px;margin-left:3px;}
.wc-fix .fx .sco{font-weight:700;color:var(--ink);margin:0 2px;}
.wc-fix .fx .lv{color:var(--acc);font-weight:700;font-size:12px;display:inline-flex;align-items:center;gap:5px;}
.wc-fix .fx .ld{width:7px;height:7px;border-radius:50%;background:#D2402B;display:inline-block;animation:lblink 1.4s ease infinite;}
@keyframes lblink{50%{opacity:.2}}
.wc-card .pill{position:relative;}
/* timeline avatares por edad */
.tl .it{padding-right:clamp(190px,22vw,290px);min-height:330px;}
.tl .ava{position:absolute;right:clamp(80px,10vw,122px);top:50%;transform:translate(50%,-50%);
  height:clamp(230px,25vw,320px);width:auto;
  filter:drop-shadow(0 22px 30px rgba(22,21,18,.25));}
/* logos educacion */
.edu .elogo{height:44px;width:auto;max-width:120px;object-fit:contain;margin-bottom:12px;}
.cat-t i{font-style:normal;}
.cat-t .cs{display:none;}
@media (max-width:920px){
  .phead .intro{font-size:15px;}
  .cat-t{display:inline-block;max-width:30vw;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;vertical-align:bottom;}
  .cat-t .cl{display:none;}
  .cat-t .cs{display:inline;}
  .wrow{grid-template-columns:40px 1fr auto;}
  .car-btn.prev{left:6px;}
  .car-btn.next{right:6px;}
  .lb img{max-width:74vw;max-height:62vh;}
  .lb .lb-btn{width:42px;height:42px;}
  .lb .lb-btn.prev{left:8px;}
  .lb .lb-btn.next{right:8px;}
  .lb .lb-x{top:14px;right:14px;}
  .wc-card{gap:14px;flex-direction:column;align-items:center;text-align:center;}
  .wc-txt .cd{margin-top:6px;}
  .wc-right{width:100%;align-items:center;}
  .wc-fix{width:100%;justify-content:center;}
  .wc-fix .fx{justify-content:center;}
  .cta{margin-top:72px;padding-top:60px;}
  .cta .row{margin-top:30px;}
  .cta .base{margin-top:38px;padding:18px 0 22px;}
  .proj .vis .br{width:96%;}
  .case-hero .br{width:94%;}
  .how-grid{grid-template-columns:1fr 1fr;}
  .tl .it{padding-right:0;min-height:0;}
  .tl .ava{display:none;}
}
