/* ============================================================
   ∆ STACK — shared base stylesheet
   Common design tokens + reusable components used across pages.
   Link from any page in a subfolder with:
     <link rel="stylesheet" href="../css/styles.css">
   From the root index.html, use:
     <link rel="stylesheet" href="css/styles.css">
   Page-specific styles stay in that page's own <style> block.
   ============================================================ */

:root{
  /* base surfaces — #050505 lifts just enough off pure black to allow
     real layering without the harsh near-void jumps of #010101 */
  --bg:#050505;
  --bg-2:#080809;
  --surface-1:#0c0c0e;
  --surface-2:#101013;
  --surface-3:#141417;

  /* light surfaces — for the occasional light "rhythm" band */
  --paper:#f5f5f7;
  --panel-light:#f5f5f3;
  --panel-light-2:#ebebe7;
  --ink:#0a0a0b;

  /* text */
  --text:#f5f5f7;
  --text-2:#c7c7cc;
  --muted:#86868b;
  --text-disabled:#4a4a50;

  /* lines */
  --line:#262629;
  --line-soft:#19191c;
  --line-strong:#3a3a40;

  /* accent — cyan-blue "Option B" */
  --accent:#2fb8d4;
  --accent-bright:#5fd0e6;
  --accent-faint:rgba(47,184,212,.14);
  --accent-ink:#021014;

  /* semantic */
  --good:#7bd88f;
  --good-line:#2c4a35;
  --bad:#ff5f56;

  --mono:'JetBrains Mono',ui-monospace,monospace;
  --display:'Space Grotesk',sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background-color:var(--bg);
  /* faint static dot-grid texture — reads as "quiet terminal / graph paper",
     kills the flat-void feeling without any motion or performance cost */
  background-image:radial-gradient(rgba(255,255,255,.035) 1px, transparent 1px);
  background-size:22px 22px;
  background-position:-1px -1px;
  color:var(--text);
  font-family:var(--mono);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
::selection{background:var(--accent);color:var(--accent-ink)}
a{color:inherit}
:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:3px}

/* ---------- shared animation ---------- */
@keyframes rise{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}

/* ---------- nav ---------- */
nav{
  position:sticky;top:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 32px;
  background:rgba(5,5,5,0.78);
  backdrop-filter:saturate(160%) blur(18px);
  -webkit-backdrop-filter:saturate(160%) blur(18px);
  border-bottom:1px solid var(--line-soft);
}
.logo{display:inline-flex;align-items:center;gap:10px;text-decoration:none}
.logo svg{height:28px;width:auto;display:block}
.logo .wm{font-family:var(--display);font-weight:700;letter-spacing:-.02em;font-size:17px}
.back{font-size:12px;color:var(--muted);text-decoration:none;letter-spacing:.04em;transition:color .18s}
.back:hover{color:var(--text)}

/* ---------- buttons ---------- */
/* default: light (paper) button */
.btn{font-family:var(--mono);font-weight:700;font-size:14px;letter-spacing:.03em;color:var(--bg);background:var(--paper);border:1px solid var(--paper);border-radius:999px;padding:14px 30px;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;gap:10px;transition:gap .2s,filter .2s,background .2s,color .2s,border-color .2s}
.btn:hover{gap:14px;filter:brightness(.92)}
.btn-ghost{margin-left:12px;background:transparent;color:var(--text);border-color:var(--line)}
.btn-ghost:hover{border-color:var(--text);filter:none}
/* accent variant — cyan-blue primary */
.btn-primary{background:var(--accent);color:var(--accent-ink);border-color:var(--accent)}
.btn-primary:hover{background:var(--accent-bright);border-color:var(--accent-bright);filter:none}

/* ---------- section label with trailing rule ---------- */
.sec-label{font-size:12px;letter-spacing:.26em;text-transform:uppercase;color:var(--muted);margin-bottom:28px;display:flex;align-items:center;gap:14px}
.sec-label::after{content:"";flex:1;height:1px;background:var(--line-soft)}

/* ---------- status badges ---------- */
.status,.more-status{font-size:9px;letter-spacing:.1em;text-transform:uppercase;font-weight:700;padding:3px 8px;border-radius:20px;white-space:nowrap}
.status.live,.more-status.live{color:var(--good);border:1px solid var(--good-line)}
.status.soon,.more-status.soon{color:var(--muted);border:1px solid var(--line)}

/* ---------- "More from ∆ Stack" related-tools block ---------- */
.more{max-width:1000px;margin:0 auto;padding:60px 32px 10px}
.more-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media(max-width:760px){.more-grid{grid-template-columns:1fr}}
.more-card{display:flex;flex-direction:column;border:1px solid var(--line);border-radius:14px;padding:22px 20px;background:var(--surface-1);text-decoration:none;color:var(--text);transition:transform .25s cubic-bezier(.2,.7,.2,1),border-color .25s}
.more-card:hover{transform:translateY(-3px);border-color:var(--line-strong)}
.more-card.soon{opacity:.6}
.more-card.soon:hover{transform:none;border-color:var(--line)}
.more-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;gap:10px}
.more-tag{font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.more-card h4{font-family:var(--display);font-weight:700;font-size:17px;letter-spacing:-.01em;line-height:1.15}
.more-card p{color:var(--muted);font-size:12.5px;margin-top:8px;flex:1}
.more-card .go{margin-top:14px;font-size:12px;font-weight:700;color:var(--muted);letter-spacing:.03em;display:inline-flex;align-items:center;gap:7px;transition:color .2s,gap .2s}
.more-card:hover .go{color:var(--accent);gap:10px}

/* ---------- footer ---------- */
footer{max-width:1000px;margin:60px auto 0;padding:36px 32px 56px;border-top:1px solid var(--line-soft);display:flex;justify-content:space-between;flex-wrap:wrap;gap:20px;color:var(--muted);font-size:12.5px}
footer a{color:var(--muted);text-decoration:none}
footer a:hover{color:var(--text)}
.fcol{display:flex;flex-direction:column;gap:7px}

/* ============================================================
   HOMEPAGE LAYOUT  (index.html)
   ============================================================ */
.nav-links{display:flex;gap:30px;font-size:13px;letter-spacing:.02em}
.nav-links a{color:var(--muted);text-decoration:none;transition:color .18s}
.nav-links a:hover{color:var(--text)}
@media(max-width:640px){.nav-links{display:none}}

.hero-intro{max-width:1100px;margin:0 auto;padding:96px 32px 56px;text-align:center}
.eyebrow{font-size:12px;letter-spacing:.34em;text-transform:uppercase;color:var(--muted);margin-bottom:26px;opacity:0;animation:rise .7s .05s forwards}
h1.headline{font-family:var(--display);font-weight:700;font-size:clamp(40px,8vw,88px);line-height:.96;letter-spacing:-.035em;opacity:0;animation:rise .8s .15s forwards}
.subhead{color:var(--muted);font-size:clamp(15px,2.2vw,19px);margin-top:24px;max-width:54ch;margin-left:auto;margin-right:auto;opacity:0;animation:rise .8s .3s forwards}

.showcase{max-width:1180px;margin:0 auto;padding:24px 32px 40px}
.showcase-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.card{grid-column:span 1;background:var(--surface-1);border:1px solid var(--line);border-radius:18px;overflow:hidden;display:flex;flex-direction:column;opacity:0;animation:rise .8s forwards;transition:transform .3s cubic-bezier(.2,.7,.2,1),border-color .3s}
.card:hover{transform:translateY(-4px);border-color:var(--line-strong)}
.card.big{grid-column:span 2;animation-delay:.4s}
.card.small.left{animation-delay:.52s}
.card.small.right{animation-delay:.62s}

.slot{position:relative;width:100%;background:#070708;overflow:hidden;border-bottom:1px solid var(--line)}
.card.big .slot{aspect-ratio:21/9}
.card.small .slot{aspect-ratio:16/10}
.slot img{width:100%;height:100%;object-fit:contain;object-position:center;display:block;background:#070708}
.slot .placeholder{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;color:#3c3c42;text-align:center;padding:20px;background:repeating-linear-gradient(45deg,#050505,#050505 14px,#0b0b0d 14px,#0b0b0d 28px)}
.slot .placeholder .pico{font-size:30px;opacity:.7}
.slot .placeholder code{font-size:12px;color:#5a5a62;background:#0e0e10;border:1px solid var(--line);padding:4px 10px;border-radius:6px}
.slot .placeholder span{font-size:11px;letter-spacing:.05em}

.card-body{padding:24px 26px 26px;display:flex;flex-direction:column;flex:1}
.tagrow{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;gap:10px}
.card .tag{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted)}
.card h3{font-family:var(--display);font-weight:700;letter-spacing:-.02em;line-height:1.08}
.card.big h3{font-size:clamp(26px,3.6vw,38px)}
.card.small h3{font-size:22px}
.card .caption{color:var(--muted);font-size:14px;margin-top:12px;flex:1}
.card.big .caption{font-size:15px;max-width:62ch}
.card h5.caption{flex:none;margin-top:4px;font-size:12px;letter-spacing:.04em;text-transform:uppercase;font-weight:500}

.readmore{align-self:flex-start;margin-top:22px;font-family:var(--mono);font-weight:700;font-size:13px;letter-spacing:.03em;color:var(--text);background:transparent;border:1px solid var(--line);border-radius:999px;padding:11px 22px;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;gap:9px;transition:background .2s,color .2s,border-color .2s,gap .2s}
.readmore:hover{background:var(--accent);color:var(--accent-ink);border-color:var(--accent);gap:13px}
.readmore .arw{transition:transform .2s}
.readmore:hover .arw{transform:translateX(2px)}

@media(max-width:760px){.showcase-grid{grid-template-columns:1fr}.card.big,.card.small{grid-column:span 1}}

/* districts */
.districts{max-width:1180px;margin:0 auto;padding:64px 32px 40px}
.dgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.district{border:1px solid var(--line);border-radius:14px;padding:28px 24px;background:var(--surface-1);transition:border-color .25s,transform .25s}
.district:hover{border-color:var(--line-strong);transform:translateY(-3px)}
.district .num{font-family:var(--mono);font-size:12px;color:var(--accent);letter-spacing:.1em}
.district h4{font-family:var(--display);font-weight:700;font-size:22px;margin:14px 0 8px;letter-spacing:-.01em}
.district p{color:var(--muted);font-size:13.5px}
.district .price{margin-top:16px;font-size:12px;letter-spacing:.04em;color:var(--text);border-top:1px dashed var(--line);padding-top:14px}
@media(max-width:760px){.dgrid{grid-template-columns:1fr}}
