/* ── TOKENS ─────────────────────────────────────────────── */
:root {
  --bg:      #080807;
  --surface: #0f0f0d;
  --border:  #1e1e1b;
  --dim:     #2e2e2a;
  --muted:   #505048;
  --mid:     #80807a;
  --body:    #a8a89e;
  --bright:  #d0d0c4;
  --white:   #ebebdf;
  --accent:  #b8ff00;
  --mono:    'IBM Plex Mono', monospace;
  --sans:    'DM Sans', sans-serif;
}

*, *::before, *::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; }

body {
  background:var(--bg);
  color:var(--body);
  font-family:var(--mono);
  font-size:11px;
  line-height:1.6;
  letter-spacing:.03em;
  overflow-x:hidden;
  cursor:none;
}

/* grain overlay */
body::after {
  content:''; position:fixed; inset:0;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='1'/%3E%3C/svg%3E");
  opacity:.04; pointer-events:none; z-index:9000;
}

/* ── CURSOR ─────────────────────────────────────────────── */
#cur {
  position:fixed; width:5px; height:5px;
  background:var(--accent); border-radius:50%;
  pointer-events:none; z-index:9998;
  transform:translate(-50%,-50%);
  transition:width .15s, height .15s, background .2s;
}
.ripple-ring {
  position:fixed; border-radius:50%;
  border:1px solid var(--accent);
  pointer-events:none; z-index:9996;
  transform:translate(-50%,-50%) scale(1);
  opacity:0;
}

/* ── PRELOADER ───────────────────────────────────────────── */
#loader {
  position:fixed; inset:0; z-index:8000;
  background:var(--bg);
  display:flex; align-items:center; justify-content:center;
  transition:opacity .6s ease;
}
#loader.out { opacity:0; pointer-events:none; }

.l-ring {
  position:relative;
  width:60vmin; height:60vmin; border-radius:50%;
  background:#030302; border:1px solid var(--border);
  display:flex; flex-direction:column;
  align-items:center; justify-content:center; gap:14px;
  transition:transform 1.5s cubic-bezier(.76,0,.24,1), opacity .5s ease;
}
#loader.out .l-ring { transform:scale(11); opacity:0; }

.l-ring::before {
  content:''; position:absolute; inset:-1px; border-radius:50%;
  background:conic-gradient(var(--accent) 0deg, transparent 120deg, transparent 360deg);
  -webkit-mask:radial-gradient(farthest-side, transparent calc(100% - 2px), white calc(100% - 1px));
  mask:radial-gradient(farthest-side, transparent calc(100% - 2px), white calc(100% - 1px));
  animation:spin 2.4s linear infinite;
}
@keyframes spin { to { transform:rotate(360deg); } }

.l-label { font-size:8px; color:var(--muted); letter-spacing:.22em; text-transform:uppercase; }
.l-num   { font-size:32px; font-weight:300; color:var(--accent); letter-spacing:-.03em; font-variant-numeric:tabular-nums; }
.l-bar   { width:72px; height:1px; background:var(--dim); position:relative; overflow:hidden; }
.l-bar::after { content:''; position:absolute; left:0; top:0; height:100%; background:var(--accent); animation:lbar 1.9s ease forwards; }
@keyframes lbar { from{width:0} to{width:100%} }
.l-id { font-size:9px; color:var(--mid); letter-spacing:.16em; font-style:italic; }

/* ── NAV ─────────────────────────────────────────────────── */
nav {
  position:fixed; top:0; left:0; right:0; z-index:500;
  padding:22px 32px;
  display:flex; align-items:flex-start; justify-content:space-between;
  pointer-events:none;
}
nav * { pointer-events:all; }

.nav-id {
  font-size:10px; font-weight:500; color:var(--white);
  letter-spacing:.14em; text-decoration:none;
  cursor:none; position:relative; display:inline-block;
  min-width:160px; height:1.4em; overflow:visible;
}
.nav-id span {
  display:inline-block;
  transition:transform .3s cubic-bezier(.16,1,.3,1), opacity .2s ease;
  white-space:nowrap;
}
.nav-id:hover span { transform:translateY(-110%); opacity:0; }
.nav-id::after {
  content:'BE WATER MY FRIEND';
  position:absolute; left:0; top:0;
  width:max-content; display:flex; align-items:center;
  font-size:8px; letter-spacing:.18em; color:var(--accent);
  transform:translateY(110%); opacity:0;
  transition:transform .3s cubic-bezier(.16,1,.3,1), opacity .2s ease .05s;
  white-space:nowrap; pointer-events:none;
}
.nav-id:hover::after { transform:translateY(0); opacity:1; }

.nav-links { display:flex; gap:30px; list-style:none; }
.nav-links a { font-size:9px; color:var(--white); text-decoration:none; letter-spacing:.16em; text-transform:uppercase; transition:color .2s; }
.nav-links a:hover, .nav-links a.on { color:var(--accent); }
.nav-links a.cta { color:var(--white); }
.nav-links a.cta:hover { color:var(--accent); }

/* ── ENV PANEL ───────────────────────────────────────────── */
#env {
  position:fixed; top:72px; right:32px; z-index:501;
  text-align:right; line-height:2.1; font-size:8.5px; color:var(--muted);
  letter-spacing:.1em;
}
#env .v  { color:var(--mid); }
#env .hi { color:var(--accent); }

/* ── HERO ────────────────────────────────────────────────── */
#hero {
  position:relative; height:100vh;
  display:flex; align-items:center; justify-content:flex-start;
  overflow:hidden;
}
#ascii-wrap { position:absolute; inset:0; overflow:hidden; }
#asc {
  font-family:var(--mono);
  font-size:10px; line-height:1.2; letter-spacing:.06em;
  color:var(--dim); white-space:pre;
  user-select:none; pointer-events:none;
  display:block; width:100%; height:100%;
}
.hero-copy {
  position:relative; z-index:2;
  padding:0 32px;
  display:flex; flex-direction:column; gap:10px;
}
.hero-eyebrow {
  font-size:8.5px; color:var(--muted); letter-spacing:.22em; text-transform:uppercase;
  border:1px solid var(--border); padding:4px 10px; width:fit-content;
  background:rgba(8,8,7,.85);
}
.hero-h1 {
  font-family:var(--mono);
  font-size:clamp(38px,5.8vw,78px);
  font-weight:300; line-height:.93;
  color:var(--white); letter-spacing:-.025em;
  background:rgba(8,8,7,.72);
  padding:8px 14px;
  border-left:2px solid var(--accent);
}
.hero-h1 b { font-weight:400; color:var(--accent); }
.hero-sub {
  font-family:var(--sans); font-size:12px; font-weight:300;
  color:var(--mid); max-width:340px; line-height:1.7;
  background:rgba(8,8,7,.72); padding:6px 14px;
}
.hero-hint {
  position:absolute; bottom:28px; left:32px; z-index:2;
  font-size:8.5px; color:var(--accent); letter-spacing:.2em;
  display:flex; align-items:center; gap:14px;
}
.hero-hint::before { content:''; width:36px; height:1px; background:var(--accent); opacity:.7; }

/* ── PIN ─────────────────────────────────────────────────── */
#pin {
  position:sticky; top:0; height:100vh;
  overflow:hidden; background:var(--bg);
  border-top:1px solid var(--border);
  display:flex; flex-direction:column;
  justify-content:center;
}
.pin-line {
  font-family:var(--mono);
  font-size:clamp(36px,9.2vw,132px);
  font-weight:400; line-height:.88;
  color:var(--dim);
  letter-spacing:-.03em; text-transform:uppercase;
  padding:0 20px;
  transform:translateY(40px); opacity:0;
  transition:transform 1s cubic-bezier(.16,1,.3,1), opacity 1s ease;
  white-space:nowrap; overflow:hidden;
}
.pin-line.go { transform:translateY(0); opacity:1; }
.pin-line:nth-child(2) { transition-delay:.1s; }
.pin-line:nth-child(3) { transition-delay:.2s; }
.pin-line:nth-child(4) { transition-delay:.3s; }
.pin-line em { font-style:normal; color:var(--accent); }

/* ── CONTAINER ───────────────────────────────────────────── */
.container {
  width:70%; max-width:1200px; min-width:320px; margin:0 auto;
}
@media (max-width:1100px) { .container { width:100%; padding:0 24px; } }
@media (max-width:600px)  { .container { padding:0 16px; } }

/* ── WORK ────────────────────────────────────────────────── */
#work {
  padding:88px 0;
  border-top:1px solid var(--border);
  background:var(--bg);
  position:relative; z-index:1;
}
.sec-head {
  display:flex; align-items:baseline; justify-content:space-between;
  border-bottom:1px solid var(--border); padding-bottom:18px; margin-bottom:52px;
}
.sec-label { font-size:8.5px; color:var(--muted); letter-spacing:.22em; text-transform:uppercase; }
.sec-count { font-size:8.5px; color:var(--dim); }

.proj-list { display:flex; flex-direction:column; }
.proj {
  display:grid; grid-template-columns:52px 1fr 80px;
  gap:24px; align-items:start;
  padding:26px 0; border-bottom:1px solid var(--border);
  text-decoration:none; color:inherit;
  position:relative; overflow:hidden;
  transition:padding-left .25s; cursor:none;
}
.proj::before {
  content:''; position:absolute; inset:0;
  background:var(--surface);
  transform:translateX(-100%); transition:transform .3s ease;
}
.proj:hover::before { transform:translateX(0); }
.proj:hover { padding-left:16px; }
.proj > * { position:relative; z-index:1; }

.p-num  { font-size:8.5px; color:var(--dim); padding-top:3px; letter-spacing:.1em; }
.p-title {
  font-family:var(--mono); font-size:15px; font-weight:400;
  color:var(--bright); letter-spacing:-.01em; margin-bottom:7px;
  transition:color .2s;
}
.proj:hover .p-title { color:var(--accent); }
.p-desc { font-family:var(--sans); font-size:12px; font-weight:300; color:var(--muted); line-height:1.75; max-width:560px; }
.p-tags { display:flex; flex-wrap:wrap; gap:6px; margin-top:11px; }
.ptag {
  font-size:7.5px; letter-spacing:.15em; text-transform:uppercase;
  color:var(--muted); border:1px solid var(--border); padding:2px 8px;
  transition:border-color .2s, color .2s;
}
.proj:hover .ptag { border-color:var(--dim); }
.ptag.on { border-color:var(--accent); color:var(--accent); }
.p-yr { font-size:8.5px; color:var(--dim); padding-top:3px; text-align:right; }
.p-arr {
  position:absolute; right:0; top:50%;
  transform:translateY(-50%) translateX(10px);
  font-size:11px; color:var(--accent); opacity:0;
  transition:opacity .2s, transform .2s;
}
.proj:hover .p-arr { opacity:1; transform:translateY(-50%) translateX(0); }

/* ── CAPABILITIES ────────────────────────────────────────── */
#caps {
  padding:88px 0;
  border-top:1px solid var(--border);
  background:var(--bg);
  position:relative; z-index:1;
}
.caps-inner { display:grid; grid-template-columns:1fr 1fr; gap:0; }
@media (max-width:700px) {
  .caps-inner { grid-template-columns:1fr; }
  .cap-col:first-child { border-right:none; border-bottom:1px solid var(--border); padding-right:0; padding-bottom:40px; margin-bottom:40px; }
  .cap-col:last-child  { padding-left:0; }
}
.cap-col:first-child { padding-right:44px; border-right:1px solid var(--border); }
.cap-col:last-child  { padding-left:44px; }
.cap-head { font-size:8.5px; color:var(--muted); letter-spacing:.22em; text-transform:uppercase; margin-bottom:30px; }
.cap-row {
  display:flex; align-items:center; gap:13px;
  padding:11px 0; border-bottom:1px solid var(--border);
  transition:padding-left .2s;
}
.cap-row:hover { padding-left:8px; }
.cap-dot { width:4px; height:4px; border-radius:50%; background:var(--dim); flex-shrink:0; transition:background .2s; }
.cap-row:hover .cap-dot { background:var(--accent); }
.cap-name { font-size:11px; color:var(--body); transition:color .2s; flex:1; }
.cap-row:hover .cap-name { color:var(--white); }
.cap-tag { font-size:7.5px; color:var(--dim); letter-spacing:.1em; }

/* ── ABOUT ───────────────────────────────────────────────── */
#about {
  padding:88px 0;
  border-top:1px solid var(--border);
  background:var(--bg);
  position:relative; z-index:1;
}
.abt-inner { display:flex; flex-direction:column; gap:0; }
.abt-label { font-size:8.5px; color:var(--muted); letter-spacing:.22em; text-transform:uppercase; margin-bottom:28px; }
.abt-body {
  font-family:var(--sans); font-size:13.5px; font-weight:300;
  line-height:1.9; color:var(--body); max-width:100%;
}
.abt-body strong, .abt-body p strong { font-weight:400; color:var(--bright); }
.abt-body p { margin-bottom:1em; }
.abt-stats {
  margin-top:48px;
  display:grid; grid-template-columns:repeat(3,1fr);
  border-top:1px solid var(--border); padding-top:28px;
  gap:0;
}
@media (max-width:600px) { .abt-stats { grid-template-columns:1fr 1fr; gap:24px; } }
.stat-n { font-family:var(--mono); font-size:28px; font-weight:300; color:var(--white); letter-spacing:-.03em; }
.stat-n span { color:var(--accent); }
.stat-l { font-size:8.5px; color:var(--muted); letter-spacing:.12em; text-transform:uppercase; margin-top:4px; }

/* ── FOOTER ──────────────────────────────────────────────── */
footer {
  border-top:1px solid var(--border);
  background:var(--bg);
  position:relative; z-index:1;
}
.f-top {
  padding:44px 0 36px;
  display:flex; align-items:center; justify-content:space-between;
  border-bottom:1px solid var(--border);
}
@media (max-width:600px) { .f-top { flex-direction:column; align-items:flex-start; gap:20px; } }
.f-location { display:flex; align-items:center; gap:6px; font-size:8.5px; color:var(--muted); letter-spacing:.14em; }
.f-loc-sep { color:var(--dim); }
.f-loc-val { color:var(--mid); }
.f-avail { display:flex; align-items:center; gap:10px; font-size:9px; color:var(--muted); letter-spacing:.14em; }
.f-avail-dot {
  width:6px; height:6px; border-radius:50%;
  background:var(--accent); box-shadow:0 0 8px var(--accent);
  animation:pulse-dot 2.4s ease-in-out infinite;
}
@keyframes pulse-dot {
  0%,100% { opacity:1; transform:scale(1); }
  50%      { opacity:.5; transform:scale(.7); }
}
.f-avail-link { color:var(--accent); text-decoration:none; margin-left:4px; transition:color .2s; }
.f-avail-link:hover { color:var(--white); }
.f-bottom { padding:22px 0; display:flex; justify-content:space-between; align-items:center; }
@media (max-width:600px) { .f-bottom { flex-direction:column; align-items:flex-start; gap:16px; } }
.f-left { font-size:8.5px; color:var(--dim); letter-spacing:.1em; }
.f-links { display:flex; gap:26px; }
.f-links a { font-size:8.5px; color:var(--muted); text-decoration:none; letter-spacing:.12em; transition:color .2s; }
.f-links a:hover { color:var(--accent); }

/* ── PROJECT MODAL ───────────────────────────────────────── */
#modal-bg {
  position:fixed; inset:0; z-index:2000;
  background:rgba(8,8,7,.92);
  backdrop-filter:blur(6px);
  opacity:0; pointer-events:none;
  transition:opacity .4s ease;
}
#modal-bg.open { opacity:1; pointer-events:all; }

#modal {
  position:fixed;
  top:50%; left:50%;
  transform:translate(-50%,-48%);
  width:min(860px, 92vw);
  max-height:82vh;
  background:var(--surface);
  border:1px solid var(--border);
  z-index:2001;
  overflow-y:auto;
  opacity:0; pointer-events:none;
  transition:opacity .4s ease, transform .4s cubic-bezier(.16,1,.3,1);
  scrollbar-width:thin;
  scrollbar-color:var(--dim) transparent;
}
#modal.open { opacity:1; pointer-events:all; transform:translate(-50%,-50%); }

.modal-header {
  position:sticky; top:0;
  background:var(--surface);
  border-bottom:1px solid var(--border);
  padding:20px 28px;
  display:flex; align-items:center; justify-content:space-between;
  z-index:1;
}
.modal-num { font-size:8.5px; color:var(--muted); letter-spacing:.15em; }
.modal-close {
  width:28px; height:28px; border:1px solid var(--border);
  background:none; color:var(--mid); font-size:14px;
  cursor:none; display:flex; align-items:center; justify-content:center;
  transition:border-color .2s, color .2s;
}
.modal-close:hover { border-color:var(--accent); color:var(--accent); }
.modal-body { padding:36px 28px 40px; }
.modal-title {
  font-family:var(--mono); font-size:clamp(20px,3vw,32px);
  font-weight:300; color:var(--white); letter-spacing:-.02em;
  line-height:1.1; margin-bottom:20px;
}
.modal-meta { display:flex; flex-wrap:wrap; gap:8px; margin-bottom:28px; }
.modal-tag {
  font-size:7.5px; letter-spacing:.15em; text-transform:uppercase;
  color:var(--accent); border:1px solid rgba(184,255,0,.35);
  padding:3px 9px;
}
.modal-tag.plain { color:var(--muted); border-color:var(--border); }
.modal-divider { height:1px; background:var(--border); margin:28px 0; }
.modal-section-label { font-size:8.5px; color:var(--muted); letter-spacing:.2em; text-transform:uppercase; margin-bottom:14px; }
.modal-text { font-family:var(--sans); font-size:13px; font-weight:300; color:var(--body); line-height:1.85; max-width:680px; }
.modal-text + .modal-text { margin-top:14px; }
.modal-grid { display:grid; grid-template-columns:1fr 1fr; gap:24px; margin-top:28px; }
.modal-stat { padding:16px; border:1px solid var(--border); }
.modal-stat-n { font-family:var(--mono); font-size:22px; font-weight:300; color:var(--white); letter-spacing:-.02em; }
.modal-stat-n span { color:var(--accent); }
.modal-stat-l { font-size:8.5px; color:var(--muted); letter-spacing:.12em; text-transform:uppercase; margin-top:4px; }
.modal-img-placeholder {
  width:100%; aspect-ratio:16/7;
  background:var(--dim); border:1px solid var(--border);
  display:flex; align-items:center; justify-content:center;
  color:var(--muted); font-size:8.5px; letter-spacing:.18em;
  margin-bottom:28px;
}
.modal-img-placeholder img { width:100%; height:100%; object-fit:cover; }

/* ── REVEAL ──────────────────────────────────────────────── */
.rv { opacity:0; transform:translateY(18px); transition:opacity .75s ease, transform .75s ease; }
.rv.in { opacity:1; transform:translateY(0); }

/* ── WP ADMIN BAR FIX ────────────────────────────────────── */
.admin-bar nav { top:32px; }
.admin-bar #env { top:104px; }
@media (max-width:782px) { .admin-bar nav { top:46px; } .admin-bar #env { top:118px; } }
