/* ═══════════════════ GEO.OS — xAI BRUTALIST MONOSPACE ═══════════════════
   Laws: #1f2228 canvas · mono everything · opacity = hierarchy (1/.7/.5/.3)
   zero radius · zero shadows · borders rgba(255,255,255,.1|.2)
   ONE accent, state/interactive only · hover DIMS to .5 · density > comfort */

@font-face{font-family:"Geist Mono";src:url(../assets/fonts/GeistMono-300.woff2) format('woff2');font-weight:300;font-display:swap}
@font-face{font-family:"Geist Mono";src:url(../assets/fonts/GeistMono-400.woff2) format('woff2');font-weight:400;font-display:swap}
@font-face{font-family:"Geist Mono";src:url(../assets/fonts/GeistMono-500.woff2) format('woff2');font-weight:500;font-display:swap}

:root{
  --bg:#1f2228;
  --fg:#ffffff;
  --acc:#3df59e;                       /* the ONE accent */
  --b1:rgba(255,255,255,.1);
  --b2:rgba(255,255,255,.2);
  --mono:"Geist Mono","SF Mono",Menlo,Consolas,monospace;
  --maxw:1200px;
  --gut:clamp(18px,4vw,56px);
  --fz-display:clamp(3rem,12.5vw,11rem);
  --fz-h2:clamp(1.4rem,3.6vw,2.6rem);
}

*{box-sizing:border-box;margin:0;padding:0;border-radius:0!important}
html{scroll-behavior:smooth}
body.os{
  background:var(--bg);color:var(--fg);
  font-family:var(--mono);font-weight:400;line-height:1.65;font-size:15px;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  cursor:none;                          /* custom cursor takes over */
}
/* character-matrix grid + scanlines */
body.os::before{
  content:"";position:fixed;inset:-80px;pointer-events:none;z-index:0;
  background:
    repeating-linear-gradient(0deg,transparent 0 63px,var(--b1) 63px 64px),
    repeating-linear-gradient(90deg,transparent 0 63px,var(--b1) 63px 64px);
  opacity:.5;
  transform:translate(var(--gx,0),var(--gy,0));
  will-change:transform;
}
body.os::after{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:1;
  background:repeating-linear-gradient(0deg,transparent 0 3px,rgba(0,0,0,.08) 3px 4px);
}
main,nav,.statusbar,.footer{position:relative;z-index:2}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--gut)}

/* opacity hierarchy */
.o7{opacity:.7}.o5{opacity:.5}.o3{opacity:.3}

/* hover law: interactive elements DIM */
a:hover,button:hover,.chip:hover,.stat:hover,.job:hover,.origin__row:hover{opacity:.5}

/* ── chrome ───────────────────────────────────────────────────── */
.progress{position:fixed;top:0;left:0;height:2px;width:0;z-index:60;background:var(--acc)}
.statusbar{
  position:sticky;top:0;z-index:50;display:flex;gap:22px;flex-wrap:wrap;
  padding:7px var(--gut);font-size:11px;letter-spacing:.08em;
  background:var(--bg);border-bottom:1px solid var(--b1);
}
.statusbar i{font-style:normal;color:var(--acc)}
.status-open{color:var(--acc);margin-left:auto}
.nav{
  position:sticky;top:30px;z-index:49;
  display:flex;align-items:center;justify-content:space-between;
  padding:13px var(--gut);background:var(--bg);border-bottom:1px solid var(--b1);
}
.nav__brand{font-weight:500;letter-spacing:.04em}
.nav__brand::after{content:"▍";color:var(--acc);animation:blink 1.1s steps(1) infinite}
.nav__links{display:flex;align-items:center;gap:26px;font-size:12px;letter-spacing:1.4px;text-transform:uppercase}
.nav__cta{border:1px solid var(--acc);color:var(--acc);padding:8px 16px}
.nav__toggle{display:none;background:none;border:1px solid var(--b2);color:var(--fg);font-size:1.3rem;padding:2px 10px;cursor:none}

/* buttons */
.btn{
  display:inline-block;padding:13px 24px;border:1px solid var(--b2);
  font-family:var(--mono);font-size:12px;font-weight:500;
  text-transform:uppercase;letter-spacing:1.4px;
  transition:opacity .15s,transform .12s;
  will-change:transform;
}
.btn--acc{border-color:var(--acc);color:var(--acc)}

/* ── hero ─────────────────────────────────────────────────────── */
.hero{border-bottom:1px solid var(--b1)}
.hero__inner{
  display:grid;grid-template-columns:1.25fr .75fr;gap:clamp(24px,4vw,64px);
  align-items:center;padding-top:clamp(40px,7vh,90px);padding-bottom:clamp(36px,6vh,72px);
}
.bootlog{display:grid;gap:3px;font-size:12px;margin-bottom:26px;min-height:84px}
.bootlog span{opacity:0;white-space:nowrap;overflow:hidden}
.bootlog span.on{opacity:.5}
.bootlog span.acc.on{opacity:1;color:var(--acc)}
.display{
  font-size:var(--fz-display);font-weight:300;line-height:.95;letter-spacing:-.02em;
  margin-bottom:18px;white-space:nowrap;
}
.typeline{font-size:clamp(1rem,2.2vw,1.5rem);margin-bottom:18px;color:var(--acc);min-height:1.7em}
.blink{animation:blink 1s steps(1) infinite}
.blinkslow{animation:blink 1.6s steps(1) infinite}
@keyframes blink{50%{opacity:0}}
.lead{font-size:clamp(1rem,2vw,1.25rem);opacity:.7;max-width:44ch;margin-bottom:16px}
.stat-chip{
  display:inline-block;border:1px solid var(--acc);color:var(--acc);
  font-size:13px;letter-spacing:.1em;padding:7px 14px;margin-bottom:26px;
}
.cta{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:24px}

.socials{display:flex;gap:10px}
.soc{
  display:grid;place-items:center;width:46px;height:46px;
  border:1px solid var(--b2);color:var(--fg);
  transition:opacity .15s,border-color .15s,transform .12s;will-change:transform;
}
.soc svg{width:20px;height:20px}
.soc:hover{border-color:var(--acc)}

.hero__art{justify-self:end}
.fig{position:relative;border:1px solid var(--b2);padding:10px;background:var(--bg)}
.fig img{width:min(340px,72vw);height:auto;filter:grayscale(.25) contrast(1.05)}
.fig__tick{position:absolute;width:14px;height:14px;border:1px solid var(--acc)}
.fig__tick--tl{top:-1px;left:-1px;border-right:0;border-bottom:0}
.fig__tick--br{bottom:-1px;right:-1px;border-left:0;border-top:0}
.fig__cap{
  display:flex;justify-content:space-between;gap:12px;
  border:1px solid var(--b1);border-top:0;padding:8px 12px;font-size:11px;letter-spacing:.08em;
}
/* photo glitch on hover — clip slices, no color outside palette */
.fig:hover img{animation:glitch .45s steps(2) infinite}
@keyframes glitch{
  0%{clip-path:inset(0 0 0 0);transform:translateX(0)}
  25%{clip-path:inset(12% 0 64% 0);transform:translateX(-4px)}
  50%{clip-path:inset(48% 0 22% 0);transform:translateX(4px)}
  75%{clip-path:inset(75% 0 4% 0);transform:translateX(-2px)}
  100%{clip-path:inset(0 0 0 0);transform:translateX(0)}
}

/* marquee */
.marquee{border-top:1px solid var(--b1);overflow:hidden;white-space:nowrap;padding:9px 0}
.marquee__track{display:inline-block;animation:tick 30s linear infinite;font-size:12px;letter-spacing:1.4px}
.marquee__track span{margin:0 14px;opacity:.5}
.marquee__track b{color:var(--acc);font-weight:400}
@keyframes tick{to{transform:translateX(-50%)}}

/* ── sections ─────────────────────────────────────────────────── */
.section{padding:clamp(56px,10vh,120px) 0;border-bottom:1px solid var(--b1)}
.sec-tag{font-size:12px;letter-spacing:1.4px;color:var(--acc);margin-bottom:8px}
.h2{font-size:var(--fz-h2);font-weight:300;letter-spacing:.02em;margin-bottom:38px}

/* stats */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:0;border:1px solid var(--b2)}
.stat{padding:26px 22px;border-right:1px solid var(--b1);border-bottom:1px solid var(--b1);transition:opacity .15s}
.stat__num{display:block;font-size:clamp(2.2rem,5vw,3.6rem);font-weight:300;line-height:1.05;color:var(--acc);margin-bottom:10px}
.stat__num i{font-style:normal}
.stat__label{font-size:12px;opacity:.5;line-height:1.5;display:block;text-transform:uppercase;letter-spacing:.06em}

/* manifesto */
.manifesto{font-size:clamp(1.15rem,2.6vw,1.8rem);font-weight:300;line-height:1.6;max-width:34em;opacity:.7}
.manifesto strong{font-weight:500;color:var(--acc);opacity:1}

/* work log */
.jobs{display:grid;gap:0;border:1px solid var(--b2)}
.job{padding:24px 26px;border-bottom:1px solid var(--b1);transition:opacity .15s}
.job:last-child{border-bottom:0}
.job__head{display:flex;flex-wrap:wrap;align-items:baseline;gap:6px 16px;margin-bottom:12px}
.job__idx{color:var(--acc);font-size:12px;letter-spacing:.1em}
.job__role{font-size:1.05rem;font-weight:500;letter-spacing:.04em}
.job__co{opacity:.7;font-size:.95rem}
.job__meta{margin-left:auto;font-size:11px;letter-spacing:.08em}
.job__bullets{list-style:none;display:grid;gap:7px}
.job__bullets li{position:relative;padding-left:18px;font-size:.92rem;opacity:.7}
.job__bullets li::before{content:">";position:absolute;left:0;color:var(--acc)}
.job__bullets strong{font-weight:500;color:var(--acc)}

/* origin */
.origin{border:1px solid var(--b2)}
.origin__row{
  display:grid;grid-template-columns:46px 170px 250px 1fr;gap:14px;align-items:baseline;
  padding:13px 20px;border-bottom:1px solid var(--b1);font-size:.88rem;transition:opacity .15s;
}
.origin__row:last-child{border-bottom:0}
.origin__co{font-weight:500;letter-spacing:.04em}

/* chips */
.chips{display:flex;flex-wrap:wrap;gap:10px}
.chip{
  border:1px solid var(--b2);padding:10px 16px;
  font-size:12px;letter-spacing:1.4px;transition:opacity .15s,border-color .15s,color .15s;
}
.chip:hover{border-color:var(--acc);color:var(--acc)}

/* video stub */
.video__stub{
  border:1px solid var(--b2);aspect-ratio:16/9;display:grid;place-items:center;
  background:repeating-linear-gradient(0deg,transparent 0 5px,rgba(255,255,255,.02) 5px 6px);
}
.video__stub span{font-size:clamp(.8rem,2.4vw,1.2rem);letter-spacing:.12em;color:var(--acc)}

/* contact */
.contact__mail{
  display:inline-block;font-size:clamp(1.3rem,4.6vw,3.2rem);font-weight:300;letter-spacing:0;
  border-bottom:1px solid var(--acc);color:var(--acc);margin-bottom:26px;word-break:break-all;
  transition:opacity .15s;
}
.contact__rest{list-style:none;display:flex;flex-wrap:wrap;gap:10px 34px;font-size:.95rem;margin-bottom:22px}

/* footer */
.footer{
  display:flex;gap:26px;flex-wrap:wrap;
  padding:26px var(--gut);font-size:11px;letter-spacing:.08em;border-top:1px solid var(--b1);
}

/* ── reveal engine ────────────────────────────────────────────── */
.reveal{opacity:0;transform:translateY(14px);transition:opacity .5s ease,transform .5s ease;transition-delay:var(--d,0s)}
.reveal.in{opacity:1;transform:none}
.reveal.in.o7{opacity:.7}.reveal.in.o5{opacity:.5}

/* ── cursor system (pointer:fine only; JS adds .cursor-on) ────── */
.cur,.cur-ring,.cur-meta,.pxl{display:none}
body.cursor-on .cur{
  display:block;position:fixed;z-index:100;width:6px;height:6px;background:var(--acc);
  pointer-events:none;transform:translate(-50%,-50%);
}
body.cursor-on .cur-ring{
  display:block;position:fixed;z-index:99;width:34px;height:34px;
  border:1px solid var(--b2);pointer-events:none;transform:translate(-50%,-50%);
}
body.cursor-on .cur-meta{
  display:block;position:fixed;z-index:99;pointer-events:none;
  font-family:var(--mono);font-size:10px;letter-spacing:.1em;color:var(--fg);opacity:.5;
  transform:translate(14px,18px);white-space:nowrap;
}
.pxl{
  position:fixed;z-index:98;pointer-events:none;font-family:var(--mono);
  font-size:10px;animation:pxl .9s ease-out forwards;
}
body.cursor-on .pxl{display:block}
@keyframes pxl{
  from{opacity:.6;transform:translate(-50%,-50%)}
  to{opacity:0;transform:translate(-50%,-220%)}
}

/* ── responsive ───────────────────────────────────────────────── */
@media(max-width:900px){
  .hero__inner{grid-template-columns:1fr}
  .hero__art{justify-self:start;order:-1}
  .display{white-space:normal}
  .job__meta{margin-left:0;width:100%}
  .origin__row{grid-template-columns:1fr;gap:3px}
  .nav__links{
    position:absolute;top:100%;left:0;right:0;flex-direction:column;align-items:flex-start;
    gap:16px;padding:20px var(--gut);background:var(--bg);border-bottom:1px solid var(--b2);display:none;
  }
  .nav__links.open{display:flex}
  .nav__toggle{display:block}
  body.os{cursor:auto}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto}
  body.os{cursor:auto}
  .bootlog span{opacity:.5}
  .bootlog span.acc{opacity:1}
}
