/* ============================================================
   TEE MAJOR — Personal brand site
   Visual system: strict black & white, editorial, military-precise
   Type: Anton (display) / Oswald (labels) / Helvetica (body)
   ============================================================ */

/* ---------- Tokens ---------- */
:root{
  --black:#000;
  --near-black:#0a0a0a;
  --panel-2:#0e0e0e;
  --paper:#ffffff;
  --ash:#b9b9b9;
  --smoke:#8c8c8c;
  --steel:#5a5a5a;
  --hair:rgba(255,255,255,.16);
  --hair-soft:rgba(255,255,255,.08);

  --font-display:'Anton','Arial Narrow',sans-serif;
  --font-cond:'Oswald','Arial Narrow',sans-serif;
  --font-body:'Helvetica Neue',Helvetica,Arial,sans-serif;

  --hud-h:54px;
  --ease:cubic-bezier(.76,.01,.16,1);
  --ease-out:cubic-bezier(.22,.61,.36,1);
  --pad:clamp(22px,5.5vw,64px);

  /* photographic monochrome treatment (pure high-contrast B&W) */
  --mono:grayscale(1) contrast(1.12) brightness(1.02);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;height:100%;background:var(--black);}
body{
  font-family:var(--font-body);
  color:var(--paper);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow:hidden;
  position:fixed;
  inset:0;
  overscroll-behavior:none;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit}

/* unified photo treatment */
.ph{filter:var(--mono);}

/* ============================================================
   HUD — progress bars + brand mark (fixed top)
   ============================================================ */
.hud{
  position:fixed;top:0;left:0;right:0;z-index:60;
  height:var(--hud-h);
  display:flex;align-items:center;gap:14px;
  padding:0 var(--pad);
  pointer-events:none;
}
.hud::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(0,0,0,.72),rgba(0,0,0,0));
  z-index:-1;
}
.brand{
  display:flex;align-items:center;gap:9px;flex-shrink:0;
  pointer-events:auto;
}
.brand .mark{width:20px;height:20px;display:block}
.brand .mark path{fill:var(--paper)}
.brand b{
  font-family:var(--font-cond);font-weight:600;
  font-size:13px;letter-spacing:.26em;text-transform:uppercase;
  padding-left:2px;
}
.bars{
  display:flex;gap:5px;flex:1;align-items:center;
  pointer-events:auto;
}
.bar{
  position:relative;flex:1;height:2.5px;border-radius:2px;
  background:rgba(255,255,255,.26);cursor:pointer;
  overflow:hidden;transition:height .2s var(--ease-out);
}
.bar::after{content:"";position:absolute;inset:-9px 0;} /* easier hit target */
.bar-fill{
  position:absolute;left:0;top:0;bottom:0;width:0%;
  background:var(--paper);border-radius:2px;
  transition:width .12s linear;
}
.bar.done .bar-fill{width:100%}
.bar:hover{height:4px}
.counter{
  flex-shrink:0;font-family:var(--font-cond);font-weight:500;
  font-size:11px;letter-spacing:.22em;color:var(--ash);
  font-variant-numeric:tabular-nums;pointer-events:auto;
}

/* ============================================================
   STAGE / PANELS
   ============================================================ */
.stage{
  position:absolute;inset:0;overflow:hidden;background:var(--black);
}
.panel{
  position:absolute;inset:0;
  overflow-y:auto;overflow-x:hidden;
  -webkit-overflow-scrolling:touch;
  overscroll-behavior:contain;
  will-change:transform,opacity;
  backface-visibility:hidden;
  transition:transform .62s var(--ease), opacity .5s var(--ease);
  scrollbar-width:none;
}
.panel::-webkit-scrollbar{display:none}
.panel.dragging{transition:none}
/* fade & reveal modes hide non-active from interaction */
.stage[data-transition="fade"] .panel:not(.is-active),
.stage[data-transition="reveal"] .panel:not(.is-active){pointer-events:none}

/* inner column */
.wrap{
  min-height:100%;
  padding:calc(var(--hud-h) + 18px) var(--pad) clamp(90px,16vh,150px);
  display:flex;flex-direction:column;
}
.wrap.center{justify-content:center}

/* ---------- Editorial type primitives ---------- */
.kicker{
  font-family:var(--font-cond);font-weight:500;
  font-size:clamp(11px,1.5vw,13px);letter-spacing:.34em;text-transform:uppercase;
  color:var(--smoke);display:flex;align-items:center;gap:12px;
}
.kicker::before{
  content:"";width:26px;height:1px;background:var(--steel);display:inline-block;
}
.kicker.no-rule::before{display:none}

.display{
  font-family:var(--font-display);font-weight:400;
  line-height:.92;letter-spacing:.005em;text-transform:uppercase;
  margin:0;
}
h2.display{font-size:clamp(40px,9vw,104px)}
.lede{
  font-size:clamp(17px,2.5vw,23px);line-height:1.5;color:var(--ash);
  max-width:34ch;font-weight:300;
}
.body{
  font-size:clamp(15px,1.9vw,17.5px);line-height:1.65;color:var(--ash);
  max-width:60ch;font-weight:300;
}
.body strong{color:var(--paper);font-weight:500}
mark{background:var(--paper);color:var(--black);padding:0 .14em}

/* reveal animation */
[data-reveal]{
  opacity:0;transform:translateY(26px);
  transition:opacity .8s var(--ease-out),transform .8s var(--ease-out);
  transition-delay:var(--d,0ms);
}
[data-reveal].in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  [data-reveal]{opacity:1;transform:none;transition:none}
  .panel{transition:none}
}

/* ============================================================
   PANEL 1 — HERO (3 layouts via data-hero)
   ============================================================ */
.hero{position:relative;height:100%;width:100%;overflow:hidden}
.hero .wrap{padding:0}
.hero-photo{
  position:absolute;inset:0;
}
.hero-photo img{
  width:100%;height:100%;object-fit:cover;object-position:center 20%;
}
.hero-grad{position:absolute;inset:0}
.hero-copy{
  position:absolute;z-index:3;
  left:var(--pad);right:var(--pad);bottom:clamp(64px,11vh,120px);
}
.hero-name{
  font-family:var(--font-display);text-transform:uppercase;
  line-height:.84;letter-spacing:.01em;
  font-size:clamp(74px,21vw,250px);
  margin:0;
}
.hero-name .l2{display:block;-webkit-text-stroke:1.4px var(--paper);color:transparent}
.hero-tag{
  font-family:var(--font-cond);font-weight:300;
  font-size:clamp(18px,3vw,30px);letter-spacing:.02em;
  color:var(--paper);margin:.5em 0 0;max-width:24ch;
}
.hero-role{
  margin-top:18px;display:flex;flex-wrap:wrap;gap:8px 10px;align-items:center;
}
.chip{
  font-family:var(--font-cond);font-weight:500;
  font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--ash);border:1px solid var(--hair);
  padding:6px 11px;border-radius:100px;white-space:nowrap;
}

/* hero layout: profile (default) — full image, name lower-left */
.hero[data-hero="profile"] .hero-photo img{object-position:58% 18%}
.hero[data-hero="profile"] .hero-grad{
  background:
    linear-gradient(180deg,rgba(0,0,0,.45) 0%,rgba(0,0,0,0) 26%,rgba(0,0,0,0) 44%,rgba(0,0,0,.86) 100%),
    linear-gradient(90deg,rgba(0,0,0,.6) 0%,rgba(0,0,0,0) 55%);
}

/* hero layout: fullbleed — centered, heavy darken */
.hero[data-hero="fullbleed"] .hero-photo img{object-position:50% 16%}
.hero[data-hero="fullbleed"] .hero-grad{
  background:radial-gradient(120% 90% at 50% 36%,rgba(0,0,0,.18),rgba(0,0,0,.82));
}
.hero[data-hero="fullbleed"] .hero-copy{
  left:0;right:0;text-align:center;bottom:auto;top:50%;transform:translateY(-50%);
  padding:0 var(--pad);
}
.hero[data-hero="fullbleed"] .hero-tag{margin-left:auto;margin-right:auto}
.hero[data-hero="fullbleed"] .hero-role{justify-content:center}

/* hero layout: split — image right, black left with name */
.hero[data-hero="split"]{display:grid;grid-template-columns:1fr 1fr}
.hero[data-hero="split"] .hero-photo{left:50%}
.hero[data-hero="split"] .hero-photo img{object-position:50% 16%}
.hero[data-hero="split"] .hero-grad{
  background:linear-gradient(90deg,#000 0%,rgba(0,0,0,0) 62%);left:50%;
}
.hero[data-hero="split"] .hero-copy{
  position:relative;left:0;right:auto;bottom:auto;
  grid-column:1;align-self:center;
  padding:0 clamp(20px,4vw,56px);max-width:none;
}
.hero[data-hero="split"] .hero-name{font-size:clamp(58px,11vw,140px)}
@media (max-width:720px){
  .hero[data-hero="split"]{grid-template-columns:1fr}
  .hero[data-hero="split"] .hero-photo{left:0}
  .hero[data-hero="split"] .hero-photo img{object-position:58% 16%}
  .hero[data-hero="split"] .hero-grad{left:0;
    background:linear-gradient(180deg,rgba(0,0,0,.3),rgba(0,0,0,0) 40%,rgba(0,0,0,.9))}
  .hero[data-hero="split"] .hero-copy{position:absolute;align-self:end;bottom:clamp(64px,11vh,120px)}
}

.scrollcue{
  position:absolute;z-index:4;left:50%;transform:translateX(-50%);
  bottom:22px;display:flex;flex-direction:column;align-items:center;gap:7px;
  font-family:var(--font-cond);font-size:10px;letter-spacing:.3em;text-transform:uppercase;
  color:var(--smoke);
}
.scrollcue .ln{width:1px;height:30px;background:linear-gradient(var(--smoke),transparent);
  animation:cue 1.9s var(--ease) infinite}
@keyframes cue{0%{transform:scaleY(0);transform-origin:top}40%{transform:scaleY(1);transform-origin:top}
  60%{transform:scaleY(1);transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* ============================================================
   SECTION HEADERS (each panel opener)
   ============================================================ */
.head{margin-bottom:clamp(26px,5vh,52px)}
.head .kicker{margin-bottom:16px}
.head .display{margin-bottom:18px}

/* big lead statement */
.statement{
  font-family:var(--font-cond);font-weight:300;
  font-size:clamp(24px,4.4vw,46px);line-height:1.16;letter-spacing:.005em;
  max-width:18ch;
}
.statement strong{font-weight:600}

/* ============================================================
   GENERIC media + grids
   ============================================================ */
.figure{position:relative;overflow:hidden;background:var(--panel-2)}
.figure img{width:100%;height:100%;object-fit:cover}
.figure .cap{
  position:absolute;left:0;bottom:0;right:0;
  padding:14px 16px;font-family:var(--font-cond);
  font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--paper);
  background:linear-gradient(0deg,rgba(0,0,0,.78),rgba(0,0,0,0));
}
.parallax{will-change:transform}

.duo{display:grid;gap:14px}
@media (min-width:760px){.duo{grid-template-columns:1fr 1fr}}

/* big stat figure */
.bignum{
  font-family:var(--font-display);line-height:.9;
  font-size:clamp(56px,13vw,150px);font-variant-numeric:tabular-nums;
}
.bignum small{
  font-family:var(--font-cond);font-weight:500;font-size:.16em;
  letter-spacing:.18em;display:block;color:var(--smoke);text-transform:uppercase;
  margin-top:.4em;
}

/* ============================================================
   MISSION
   ============================================================ */
.mission-grid{display:grid;gap:clamp(26px,5vh,46px)}
.tenets{display:grid;gap:1px;background:var(--hair-soft);border-block:1px solid var(--hair-soft)}
.tenet{
  background:var(--black);padding:22px 4px;display:grid;
  grid-template-columns:46px 1fr;gap:18px;align-items:start;
}
.tenet .no{font-family:var(--font-cond);font-weight:600;font-size:13px;color:var(--steel);letter-spacing:.1em;padding-top:5px}
.tenet h3{font-family:var(--font-cond);font-weight:500;text-transform:uppercase;letter-spacing:.04em;
  font-size:clamp(19px,3vw,26px);margin:0 0 7px}
.tenet p{margin:0;color:var(--smoke);font-weight:300;font-size:15.5px;line-height:1.55;max-width:50ch}

/* ============================================================
   WHAT I'M BUILDING — Sqwod ecosystem
   ============================================================ */
.eco{display:grid;gap:16px}
@media (min-width:820px){.eco{grid-template-columns:1.1fr .9fr;align-items:stretch}}
.eco-feature{
  position:relative;min-height:clamp(360px,52vh,560px);overflow:hidden;
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:clamp(20px,3vw,32px);
}
.eco-feature img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.eco-feature .vg{position:absolute;inset:0;background:linear-gradient(0deg,rgba(0,0,0,.9) 4%,rgba(0,0,0,.15) 60%)}
.eco-feature>*{position:relative}
.eco-right{display:grid;gap:16px;grid-template-rows:auto}
.card{
  border:1px solid var(--hair);padding:clamp(20px,2.6vw,26px);
  display:flex;flex-direction:column;gap:9px;background:var(--near-black);
}
.card .tag{font-family:var(--font-cond);font-size:10.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--smoke)}
.card h3{font-family:var(--font-cond);font-weight:500;text-transform:uppercase;letter-spacing:.03em;
  font-size:clamp(20px,2.6vw,27px);margin:0}
.card p{margin:0;color:var(--smoke);font-weight:300;font-size:14.5px;line-height:1.55}
.card .stat{font-family:var(--font-display);font-size:clamp(26px,4vw,40px);margin-top:2px}
.eco-feature h3{font-family:var(--font-display);font-size:clamp(30px,5vw,52px);text-transform:uppercase;margin:6px 0 4px;line-height:.95}
.eco-feature p{margin:0;color:var(--ash);font-weight:300;max-width:40ch;font-size:15px}

.pipeline{display:grid;gap:1px;background:var(--hair-soft);margin-top:4px;border:1px solid var(--hair-soft)}
.pipe{background:var(--black);padding:18px 20px;display:grid;grid-template-columns:auto 1fr auto;gap:16px;align-items:center}
.pipe h4{font-family:var(--font-cond);font-weight:600;text-transform:uppercase;letter-spacing:.06em;font-size:16px;margin:0}
.pipe p{margin:0;color:var(--smoke);font-size:13.5px;font-weight:300}
.pipe .badge{font-family:var(--font-cond);font-size:10px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--ash);border:1px solid var(--hair);padding:5px 9px;border-radius:100px;white-space:nowrap}
.pipe .dot{width:7px;height:7px;border-radius:50%;background:var(--steel)}

/* ---------- live app phone ---------- */
.eco-phone{display:flex;flex-direction:column;gap:16px;align-items:center;justify-content:center;height:100%}
.eco-phone-stage{
  width:340px;max-width:100%;height:702px;position:relative;overflow:hidden;
  display:flex;align-items:flex-start;justify-content:center;
}
.eco-phone-frame{
  width:430px;height:884px;border:0;background:transparent;flex:0 0 auto;
  transform:scale(.79);transform-origin:top center;
}
.eco-phone-cap{
  display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:center;text-align:center;
  font-family:var(--font-cond);font-size:11.5px;letter-spacing:.04em;color:var(--smoke);max-width:36ch;
}
.eco-phone-cap .live{
  display:inline-flex;align-items:center;gap:6px;font-size:10px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--ash);border:1px solid var(--hair);border-radius:100px;padding:3px 10px;
}
.eco-phone-cap .live i{width:6px;height:6px;border-radius:50%;background:#4ADE80;
  box-shadow:0 0 0 3px rgba(74,222,128,.18);animation:livePulse 2.4s ease-in-out infinite}
@keyframes livePulse{0%,100%{opacity:1}50%{opacity:.4}}
@media (max-width:520px){
  .eco-phone-stage{width:296px;height:612px}
  .eco-phone-frame{transform:scale(.688)}
}

/* ---------- pod locations ---------- */
.pod-locs{margin-top:clamp(22px,4vh,40px)}
.pod-loc-grid{display:grid;gap:12px;grid-template-columns:1fr;margin-top:12px}
@media (min-width:620px){.pod-loc-grid{grid-template-columns:1fr 1fr}}
.pod-loc{position:relative;margin:0;overflow:hidden;aspect-ratio:16/10;background:var(--panel-2)}
.pod-loc img{width:100%;height:100%;object-fit:cover}
.pod-loc figcaption{
  position:absolute;left:0;right:0;bottom:0;padding:16px;display:flex;flex-direction:column;gap:3px;
  background:linear-gradient(0deg,rgba(0,0,0,.88) 6%,rgba(0,0,0,0) 78%);
}
.pod-loc figcaption b{font-family:var(--font-cond);text-transform:uppercase;letter-spacing:.05em;font-weight:600;font-size:18px;line-height:1}
.pod-loc figcaption span{font-family:var(--font-cond);font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--smoke)}

/* ---------- B2B / Gym-as-a-Service ---------- */
.gaas{margin-top:14px;border:1px solid var(--hair);background:var(--near-black);padding:clamp(22px,3vw,34px)}
.gaas-tag{font-family:var(--font-cond);font-size:10.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--ash)}
.gaas-h{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.01em;line-height:.95;
  font-size:clamp(24px,3.6vw,40px);margin:8px 0 10px}
.gaas p{margin:0;color:var(--smoke);font-weight:300;font-size:15px;line-height:1.6;max-width:62ch}
.gaas strong{color:var(--paper);font-weight:500}
.gaas-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:18px}
.gaas-chip{font-family:var(--font-cond);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--ash);
  border:1px solid var(--hair);border-radius:100px;padding:6px 13px}

/* ---------- AI thesis ---------- */
.ai-thesis{margin-top:clamp(34px,7vh,64px)}
.ai-h{font-family:var(--font-display);text-transform:uppercase;line-height:.95;letter-spacing:.005em;
  font-size:clamp(30px,5.4vw,58px);margin:0 0 4px}
.ai-pillars{
  display:grid;gap:1px;background:var(--hair-soft);border:1px solid var(--hair-soft);
  margin-top:clamp(20px,3.4vh,32px);
}
@media (min-width:820px){.ai-pillars{grid-template-columns:repeat(3,1fr)}}
.ai-pillar{background:var(--black);padding:clamp(22px,2.6vw,32px);display:flex;flex-direction:column;gap:12px}
.ai-pillar .no{font-family:var(--font-cond);font-size:10.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--steel)}
.ai-pillar h4{font-family:var(--font-cond);text-transform:uppercase;letter-spacing:.03em;font-weight:600;
  font-size:clamp(18px,2.1vw,22px);margin:0;line-height:1.05}
.ai-pillar p{margin:0;color:var(--smoke);font-weight:300;font-size:14px;line-height:1.62}
.ai-pillar strong{color:var(--paper);font-weight:500}

/* ============================================================
   TIMELINE
   ============================================================ */
.timeline{position:relative;margin-top:8px;padding-left:0}
.tl-item{
  position:relative;display:grid;grid-template-columns:96px 1fr;gap:clamp(16px,3vw,34px);
  padding:clamp(20px,3.4vh,34px) 0;border-top:1px solid var(--hair);
}
.tl-item:last-child{border-bottom:1px solid var(--hair)}
.tl-year{font-family:var(--font-cond);font-weight:600;font-size:14px;letter-spacing:.04em;color:var(--smoke);
  padding-top:5px;font-variant-numeric:tabular-nums}
.tl-role{font-family:var(--font-cond);font-weight:500;text-transform:uppercase;letter-spacing:.02em;
  font-size:clamp(20px,3vw,29px);line-height:1.08;margin:0 0 3px}
.tl-org{font-family:var(--font-cond);font-weight:400;color:var(--ash);font-size:15px;letter-spacing:.02em;margin:0 0 12px}
.tl-org em{font-style:normal;color:var(--smoke)}
.tl-points{margin:0;padding:0;list-style:none;display:grid;gap:7px}
.tl-points li{position:relative;padding-left:18px;color:var(--smoke);font-weight:300;font-size:14.5px;line-height:1.5;max-width:54ch}
.tl-points li::before{content:"";position:absolute;left:0;top:9px;width:6px;height:1px;background:var(--steel)}
.tl-points li strong{color:var(--paper);font-weight:500}

.creds{display:grid;gap:14px;margin-top:clamp(26px,5vh,46px)}
@media (min-width:680px){.creds{grid-template-columns:1fr 1fr}}
.cred{border:1px solid var(--hair);padding:22px 24px}
.cred .k{font-family:var(--font-cond);font-size:10.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--smoke);margin-bottom:10px}
.cred h4{font-family:var(--font-cond);font-weight:500;text-transform:uppercase;font-size:20px;margin:0 0 5px;letter-spacing:.02em}
.cred p{margin:0;color:var(--smoke);font-size:14px;font-weight:300;line-height:1.5}

/* ============================================================
   FITNESS — image-rich mosaic
   ============================================================ */
.mosaic{display:grid;gap:12px;grid-template-columns:repeat(6,1fr);grid-auto-flow:dense}
.mosaic .figure{min-height:0}
.m-tall{grid-column:span 3;grid-row:span 2;aspect-ratio:3/4}
.m-wide{grid-column:span 3;aspect-ratio:3/2}
.m-sq{grid-column:span 2;aspect-ratio:1}
.m-big{grid-column:span 4;grid-row:span 2;aspect-ratio:4/5}
.m-port{grid-column:span 2;aspect-ratio:2/3}
@media (max-width:760px){
  .mosaic{grid-template-columns:repeat(2,1fr);gap:9px}
  .m-tall,.m-wide,.m-sq,.m-big,.m-port{grid-column:span 1;grid-row:auto}
  .m-tall{aspect-ratio:3/4}.m-wide{grid-column:span 2;aspect-ratio:3/2}
  .m-big{grid-column:span 2;aspect-ratio:4/5}.m-sq{aspect-ratio:1}.m-port{aspect-ratio:2/3}
}
.proof-row{display:flex;flex-wrap:wrap;gap:10px 28px;margin-top:clamp(22px,4vh,40px);
  padding-top:24px;border-top:1px solid var(--hair)}
.proof{display:flex;flex-direction:column;gap:3px}
.proof b{font-family:var(--font-display);font-size:clamp(28px,4.5vw,44px);line-height:1}
.proof span{font-family:var(--font-cond);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--smoke)}

/* ============================================================
   BERLIN / LIFE
   ============================================================ */
.life-grid{display:grid;gap:14px}
@media (min-width:820px){.life-grid{grid-template-columns:1.4fr 1fr;align-items:end}}
.life-main{position:relative;aspect-ratio:4/5;overflow:hidden}
.life-main img{width:100%;height:100%;object-fit:cover}
.life-side{display:grid;gap:14px}
.life-quote{
  font-family:var(--font-cond);font-weight:300;font-size:clamp(22px,3.4vw,34px);
  line-height:1.22;letter-spacing:.005em;
}
.life-quote strong{font-weight:600}
.placeholder{
  position:relative;background:
    repeating-linear-gradient(135deg,#0d0d0d 0 11px,#111 11px 22px);
  border:1px solid var(--hair);display:flex;align-items:center;justify-content:center;
  aspect-ratio:1;
}
.placeholder span{font-family:'Courier New',monospace;font-size:11px;letter-spacing:.1em;
  text-transform:uppercase;color:var(--steel);text-align:center;padding:14px}

/* ============================================================
   CONNECT
   ============================================================ */
.connect{justify-content:center}
.reach{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--hair-soft);
  border:1px solid var(--hair-soft);margin:clamp(24px,5vh,44px) 0}
@media (min-width:680px){.reach{grid-template-columns:repeat(4,1fr)}}
.reach .cell{background:var(--black);padding:clamp(20px,3vw,30px) 18px;display:flex;flex-direction:column;gap:6px}
.reach .cell b{font-family:var(--font-display);font-size:clamp(34px,5.5vw,60px);line-height:.92;font-variant-numeric:tabular-nums}
.reach .cell span{font-family:var(--font-cond);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--smoke)}
.reach-note{font-family:'Courier New',monospace;font-size:11px;color:var(--steel);letter-spacing:.04em;margin-top:-18px;margin-bottom:8px}

.links{display:grid;gap:1px;background:var(--hair-soft);border-top:1px solid var(--hair-soft);border-bottom:1px solid var(--hair-soft)}
.link{
  background:var(--black);display:grid;grid-template-columns:auto 1fr auto;gap:18px;align-items:center;
  padding:18px 6px;cursor:pointer;transition:background .25s var(--ease-out),padding .25s var(--ease-out);
}
.link:hover{background:var(--near-black);padding-left:18px;padding-right:18px}
.link .net{font-family:var(--font-cond);font-weight:500;text-transform:uppercase;letter-spacing:.05em;font-size:clamp(18px,2.6vw,24px)}
.link .handle{font-family:var(--font-body);font-weight:300;color:var(--smoke);font-size:14.5px;justify-self:start}
.link .go{font-family:var(--font-cond);font-size:11px;letter-spacing:.2em;color:var(--steel);text-transform:uppercase;
  transition:color .25s,transform .25s var(--ease-out)}
.link:hover .go{color:var(--paper);transform:translateX(4px)}
@media (max-width:560px){.link{grid-template-columns:1fr auto}.link .handle{grid-column:1;grid-row:2;justify-self:start}}

.signoff{margin-top:clamp(30px,6vh,54px);display:flex;flex-wrap:wrap;gap:14px 26px;align-items:baseline;justify-content:space-between}
.signoff .mono{font-family:'Courier New',monospace;font-size:11px;color:var(--steel);letter-spacing:.06em}

/* ============================================================
   NAV arrows + hint + grain
   ============================================================ */
.nav{
  position:fixed;top:50%;transform:translateY(-50%);z-index:55;
  width:46px;height:46px;border-radius:50%;
  border:1px solid var(--hair);background:rgba(0,0,0,.35);
  -webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);
  color:var(--paper);cursor:pointer;display:grid;place-items:center;
  transition:background .25s,border-color .25s,opacity .35s,transform .25s var(--ease-out);
}
.nav:hover{background:rgba(255,255,255,.1);border-color:var(--paper)}
.nav svg{width:16px;height:16px}
.nav.prev{left:16px}.nav.next{right:16px}
.nav.prev:hover{transform:translateY(-50%) translateX(-3px)}
.nav.next:hover{transform:translateY(-50%) translateX(3px)}
.nav[disabled]{opacity:0;pointer-events:none}
@media (max-width:760px),(pointer:coarse){.nav{display:none}}

.hint{
  position:fixed;left:50%;bottom:18px;transform:translateX(-50%);z-index:54;
  display:flex;align-items:center;gap:10px;
  font-family:var(--font-cond);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--smoke);
  background:rgba(0,0,0,.4);border:1px solid var(--hair-soft);border-radius:100px;padding:8px 16px;
  -webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);
  transition:opacity .6s var(--ease-out);pointer-events:none;
}
.hint.gone{opacity:0}
.hint .swp{display:inline-flex;gap:3px}
.hint .swp i{width:5px;height:5px;border-radius:50%;background:var(--steel);animation:blink 1.4s infinite}
.hint .swp i:nth-child(2){animation-delay:.2s}.hint .swp i:nth-child(3){animation-delay:.4s}
@keyframes blink{0%,100%{opacity:.3}50%{opacity:1;background:var(--paper)}}

/* film grain */
.grain{
  position:fixed;inset:-50%;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='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  animation:grain 1s steps(3) infinite;
}
.grain[hidden]{display:none}
@keyframes grain{0%{transform:translate(0,0)}33%{transform:translate(-4%,3%)}66%{transform:translate(3%,-2%)}100%{transform:translate(0,0)}}

/* ============================================================
   Tweaks panel (vanilla, host-protocol driven)
   ============================================================ */
#tweaks{
  position:fixed;right:16px;bottom:16px;z-index:2147483646;width:248px;
  background:rgba(12,12,12,.86);color:#fff;
  -webkit-backdrop-filter:blur(20px) saturate(150%);backdrop-filter:blur(20px) saturate(150%);
  border:1px solid var(--hair);border-radius:13px;
  box-shadow:0 20px 60px rgba(0,0,0,.6);
  font-family:var(--font-body);display:none;flex-direction:column;overflow:hidden;
}
#tweaks.show{display:flex}
.tw-hd{display:flex;align-items:center;justify-content:space-between;padding:13px 12px 11px 16px;cursor:move;
  border-bottom:1px solid var(--hair-soft)}
.tw-hd b{font-family:var(--font-cond);font-weight:600;font-size:12px;letter-spacing:.2em;text-transform:uppercase}
.tw-x{appearance:none;border:0;background:transparent;color:var(--smoke);width:24px;height:24px;border-radius:6px;cursor:pointer;font-size:14px}
.tw-x:hover{background:rgba(255,255,255,.08);color:#fff}
.tw-body{padding:14px 16px 16px;display:flex;flex-direction:column;gap:15px}
.tw-row{display:flex;flex-direction:column;gap:7px}
.tw-lbl{font-family:var(--font-cond);font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--ash)}
.tw-seg{display:flex;gap:3px;background:rgba(255,255,255,.06);border-radius:8px;padding:3px}
.tw-seg button{flex:1;appearance:none;border:0;background:transparent;color:var(--smoke);
  font-family:var(--font-cond);font-size:11px;letter-spacing:.08em;text-transform:uppercase;
  padding:7px 4px;border-radius:6px;cursor:pointer;transition:background .2s,color .2s}
.tw-seg button[data-on="1"]{background:#fff;color:#000;font-weight:600}
.tw-field{appearance:none;width:100%;background:rgba(255,255,255,.06);border:1px solid var(--hair);
  color:#fff;border-radius:7px;padding:9px 10px;font-family:var(--font-body);font-size:13px;outline:none}
.tw-field:focus{border-color:var(--smoke)}
.tw-toggle{position:relative;width:36px;height:20px;border:0;border-radius:100px;background:rgba(255,255,255,.18);cursor:pointer;padding:0;flex-shrink:0}
.tw-toggle[data-on="1"]{background:#fff}
.tw-toggle i{position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:#fff;transition:transform .18s}
.tw-toggle[data-on="1"] i{background:#000;transform:translateX(16px)}
.tw-row.inline{flex-direction:row;align-items:center;justify-content:space-between}
