/* ============================================================
   HashDT — Shared Design System (2026)
   ============================================================ */

/* Geist via Google Fonts */
@import url('https://fonts.googleapis.com/css2?family=Geist:wght@300..900&family=Geist+Mono:wght@300..700&display=swap');

:root{
  --lime:       #C6FF3D;
  --lime-2:     #A8E81B;
  --lime-soft:  #EFFFC8;
  --ink:        #0A0A0A;
  --ink-2:      #1A1A1A;
  --ink-3:      #2A2A2A;
  --paper:      #FFFFFF;
  --paper-2:    #FAFAFA;
  --paper-3:    #F2F2F2;
  --mute:       #6B7280;
  --mute-2:     #9CA3AF;
  --line:       #E5E7EB;
  --line-2:     #D1D5DB;
  --ok:         #16A34A;
}
*{box-sizing:border-box}
html,body{margin:0;background:var(--paper);color:var(--ink);}
body{
  font-family:'Geist', ui-sans-serif, system-ui, sans-serif;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
  letter-spacing:-.005em;
  position:relative;
}
::selection{background:var(--lime);color:var(--ink)}
a{color:inherit;text-decoration:none}
.mono{font-family:'Geist Mono', ui-monospace, monospace;font-feature-settings:"ss02"}
.container{max-width:1320px;margin:0 auto;padding:0 28px;position:relative;}

/* ============================================================
   GEOMETRIC BACKGROUND TEXTURE — site-wide
   Subtle two-layer system:
     (1) fine lime dot matrix (radial-gradient, 22px grid)
     (2) flowing diagonal lime sine-curve traces (inline SVG)
   Lives on body::before, fixed, pointer-events:none, z-index:-1
   ============================================================ */
body::before{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:-1;
  background-color:transparent;
  background-image:
    radial-gradient(rgba(198,255,61,.07) 1px, transparent 1.4px),
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='480' height='240' viewBox='0 0 480 240'><g fill='none' stroke='%23C6FF3D' stroke-opacity='0.09' stroke-width='1'><path d='M0 60 Q 60 20 120 60 T 240 60 T 360 60 T 480 60'/><path d='M0 120 Q 60 80 120 120 T 240 120 T 360 120 T 480 120'/><path d='M0 180 Q 60 140 120 180 T 240 180 T 360 180 T 480 180'/></g><g fill='none' stroke='%230A0A0A' stroke-opacity='0.025' stroke-width='1'><path d='M-40 30 Q 40 -10 120 30 T 280 30 T 440 30'/><path d='M-40 150 Q 40 110 120 150 T 280 150 T 440 150'/></g></svg>");
  background-size:
    22px 22px,
    480px 240px;
  background-position:
    0 0,
    0 0;
  background-repeat:repeat, repeat;
}
/* Dark sections need a different overlay — softer dots */
.bg-ink::before, .bg-lime::before { /* used by sections with own bg */ }

/* ============================================================
   COMPONENTS
   ============================================================ */
.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-family:'Geist Mono', monospace;
  font-size:11px; letter-spacing:.14em; text-transform:uppercase;
  color:var(--ink); font-weight:500;
}
.eyebrow .dot{width:8px;height:8px;border-radius:99px;background:var(--lime);box-shadow:0 0 0 4px rgba(198,255,61,.25)}
.pill{
  display:inline-flex;align-items:center;gap:8px;
  padding:7px 12px;border-radius:99px;
  border:1px solid var(--line);
  font-family:'Geist Mono', monospace; font-size:11px;
  letter-spacing:.1em; text-transform:uppercase;
  background:var(--paper);
}
.pill.lime{background:var(--lime);border-color:var(--lime);color:var(--ink)}
.pill.dark{background:var(--ink);border-color:var(--ink);color:var(--paper)}
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:13px 20px;border-radius:99px;
  font-size:14px;font-weight:500;letter-spacing:-.005em;
  border:1px solid transparent; cursor:pointer; transition:.18s ease;
  line-height:1;
}
.btn .arr{display:inline-block;transition:transform .25s ease}
.btn:hover .arr{transform:translateX(3px)}
.btn.lime{background:var(--lime);color:var(--ink);}
.btn.lime:hover{background:var(--lime-2)}
.btn.dark{background:var(--ink);color:var(--paper);}
.btn.dark:hover{background:#000}
.btn.ghost{border-color:var(--line-2);color:var(--ink);background:transparent}
.btn.ghost:hover{border-color:var(--ink);background:var(--paper-3)}
.btn.big{padding:17px 26px;font-size:15px}

/* ANNOUNCE */
.announce{background:var(--ink); color:#EDEDED; font-family:'Geist Mono', monospace; font-size:11px; letter-spacing:.1em; text-transform:uppercase;}
.announce-inner{max-width:1320px;margin:0 auto;padding:10px 28px;display:flex;justify-content:space-between;align-items:center;gap:24px;}
.announce .lime-dot{display:inline-flex;align-items:center;gap:8px}
.announce .lime-dot::before{content:"";width:8px;height:8px;border-radius:99px;background:var(--lime);box-shadow:0 0 0 4px rgba(198,255,61,.18); animation:pulse 2.4s ease-in-out infinite;}
@keyframes pulse{50%{transform:scale(1.15);box-shadow:0 0 0 6px rgba(198,255,61,.08)}}
.announce a{opacity:.85}
.announce a:hover{opacity:1;color:var(--lime)}

/* NAV */
header.nav{position:sticky; top:0; z-index:30; background:rgba(255,255,255,.85); backdrop-filter:saturate(160%) blur(10px); border-bottom:1px solid var(--line);}
.nav-inner{max-width:1320px;margin:0 auto;padding:16px 28px;display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:32px;}
.brand{display:flex;align-items:center;gap:11px;font-weight:800;letter-spacing:-.035em;font-size:20px;}

/* Nav brand as a black lockup — white wordmark on black, matching the logo icon */
header.nav .brand{
  background:var(--ink); color:var(--paper);
  padding:7px 14px 7px 8px; border-radius:13px;
  font-size:18px; gap:9px;
  transition:.2s ease;
}
header.nav .brand:hover{background:#000; transform:translateY(-1px);}
header.nav .brand .brand-mark{width:26px;height:26px;}
.brand-mark{
  width:32px;height:32px;border-radius:9px;
  display:grid;place-items:center;
  position:relative; overflow:hidden;
  background:transparent;
}
.brand-mark img, .brand-mark svg{width:100%;height:100%;display:block}
nav.links{display:flex;gap:32px;justify-self:center}
nav.links a{font-size:14px;color:var(--ink-2);font-weight:500;position:relative;transition:.18s}
nav.links a:hover{color:var(--ink)}
nav.links a::after{content:"";position:absolute;left:0;right:100%;bottom:-22px;height:2px;background:var(--lime);transition:right .25s ease}
nav.links a:hover::after{right:0}
nav.links a[aria-current="page"]{color:var(--ink); font-weight:600}
nav.links a[aria-current="page"]::after{right:0}
.nav-cta{display:flex;gap:10px;align-items:center}

/* HERO (homepage) */
.hero{position:relative; padding:72px 0 100px; overflow:hidden;}
.hero-grid{display:grid;grid-template-columns:1.25fr .95fr; gap:60px; align-items:center;}
h1.hero-h{
  font-weight:700;
  font-size:clamp(54px, 8vw, 132px);
  line-height:.92;
  letter-spacing:-.045em;
  margin:24px 0 0;
  color:var(--ink);
}
h1.hero-h .hl{
  background:var(--lime);
  padding:0 .12em;
  margin:0 -.06em;
  border-radius:14px;
  display:inline-block;
  transform:rotate(-1.2deg);
  box-shadow:0 6px 0 -2px var(--lime-2);
}
h1.hero-h .strike{position:relative;color:var(--mute-2);font-weight:500}
h1.hero-h .strike::after{
  content:"";position:absolute;left:-2%;right:-2%;top:55%;height:4px;
  background:var(--lime);border-radius:2px;transform:rotate(-2deg);
}
.hero-sub{font-size:19px; line-height:1.5; color:var(--ink-2); max-width:520px; margin:32px 0 0; font-weight:400;}
.hero-cta{display:flex;gap:12px;margin-top:36px;flex-wrap:wrap;align-items:center}
.hero-meta{display:flex;gap:16px;align-items:center;margin-top:28px;color:var(--mute);font-size:13px;flex-wrap:wrap;font-family:'Geist Mono',monospace;letter-spacing:.04em;}
.hero-meta .d{width:4px;height:4px;background:var(--line-2);border-radius:99px}

/* HERO VISUAL — phone + payment success */
.hero-vis{position:relative; aspect-ratio: 1/1.05; max-width:520px; justify-self:end; width:100%;}
.vis-bg{
  position:absolute; inset:0;
  background:
    radial-gradient(circle at 70% 30%, rgba(198,255,61,.55), transparent 55%),
    radial-gradient(circle at 20% 80%, rgba(198,255,61,.30), transparent 55%),
    var(--paper-3);
  border-radius:32px;
  overflow:hidden;
}
.vis-bg::before{
  content:""; position:absolute; inset:0;
  background-image:
    radial-gradient(rgba(0,0,0,.04) 1px, transparent 1px);
  background-size:14px 14px;
  mask-image: linear-gradient(180deg, transparent, black 25%, black 75%, transparent);
}
.phone{
  position:absolute;
  top:8%; left:50%; transform:translateX(-50%) rotate(-3deg);
  width:62%; aspect-ratio: 195/400;
  background:var(--ink);
  border-radius:38px;
  padding:8px;
  box-shadow:
    0 30px 60px -20px rgba(0,0,0,.45),
    0 0 0 1px rgba(255,255,255,.04) inset;
}
.phone .screen{
  width:100%; height:100%;
  background:var(--paper);
  border-radius:30px;
  overflow:hidden;
  position:relative;
  display:flex; flex-direction:column;
}
.phone .notch{
  position:absolute; top:10px; left:50%; transform:translateX(-50%);
  width:30%; height:18px; background:var(--ink); border-radius:99px;
}
.phone .scr-top{
  display:flex; justify-content:space-between; padding:12px 22px 0;
  font-family:'Geist Mono',monospace; font-size:9px; color:var(--ink);font-weight:500;
}
.phone .scr-bar{
  padding:36px 18px 14px;
  display:flex; justify-content:space-between; align-items:center;
  font-size:11px; color:var(--mute);
}
.phone .scr-bar b{color:var(--ink); font-size:13px; font-weight:600;}
.phone .scr-card{
  margin:6px 18px; padding:14px; border-radius:14px;
  background:var(--ink); color:var(--paper);
  display:flex; flex-direction:column; gap:14px;
  position:relative; overflow:hidden;
  aspect-ratio: 1.586/1;
}
.phone .scr-card .ct{display:flex;justify-content:space-between;align-items:center;font-family:'Geist Mono',monospace;font-size:9px;letter-spacing:.18em;text-transform:uppercase;opacity:.75}
.phone .scr-card .cn{font-family:'Geist Mono',monospace;font-size:11px;letter-spacing:.18em;margin-top:auto}
.phone .scr-card .cb{display:flex;justify-content:space-between;font-family:'Geist Mono',monospace;font-size:8px;letter-spacing:.12em;opacity:.7;text-transform:uppercase}
.phone .scr-card .mc{position:absolute; right:14px; bottom:14px;display:flex;align-items:center;}
.phone .scr-card .mc i{width:18px;height:18px;border-radius:99px;display:inline-block}
.phone .scr-card .mc i:first-child{background:#EB001B;margin-right:-6px}
.phone .scr-card .mc i:last-child{background:#F79E1B}
.phone .done-wrap{display:flex; flex-direction:column; align-items:center; gap:8px; margin-top:auto; padding:0 18px 28px}
.phone .check{
  width:60px;height:60px;border-radius:99px;
  background:var(--lime);
  display:grid;place-items:center;
  box-shadow:0 0 0 8px rgba(198,255,61,.22);
  animation: bounce 2.2s ease-in-out infinite;
}
@keyframes bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
.phone .check svg{width:30px;height:30px}
.phone .done-txt{font-size:18px;font-weight:600;letter-spacing:-.02em;color:var(--ink)}
.phone .done-sub{font-family:'Geist Mono',monospace;font-size:10px;color:var(--mute);letter-spacing:.08em;}
.float-chip{
  position:absolute; background:var(--paper); border:1px solid var(--line);
  border-radius:14px; padding:10px 14px;
  box-shadow:0 12px 30px -10px rgba(0,0,0,.18);
  display:flex; gap:10px; align-items:center;
  font-size:13px; font-weight:500;
  animation: float 6s ease-in-out infinite;
}
.float-chip .ico{
  width:28px;height:28px;border-radius:99px;background:var(--ink);color:var(--lime);
  display:grid; place-items:center; font-family:'Geist Mono',monospace;font-size:11px;font-weight:700;
}
.float-chip .ico.lime{background:var(--lime);color:var(--ink)}
.float-chip small{display:block;font-family:'Geist Mono',monospace;font-size:10px;color:var(--mute);letter-spacing:.06em;text-transform:uppercase;font-weight:400;margin-top:2px;}
.fc-1{top:7%; right:-10%; animation-delay:-1s}
.fc-2{bottom:18%; left:-6%; animation-delay:-3s}
.fc-3{bottom:-2%; right:6%; animation-delay:-2s}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}

/* MARQUEE */
.marquee{border-top:1px solid var(--line);border-bottom:1px solid var(--line);overflow:hidden; padding:22px 0;background:var(--ink); color:var(--paper);}
.marquee-track{display:flex;gap:48px; white-space:nowrap;animation: scroll 50s linear infinite;width:max-content;}
.marquee-item{display:inline-flex;gap:14px;align-items:center;font-family:'Geist Mono',monospace;font-size:14px;letter-spacing:.08em;text-transform:uppercase;font-weight:500;}
.marquee-item .sep{color:var(--lime); font-size:18px}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* STORY */
.story{padding:120px 0; position:relative}
.story-grid{display:grid;grid-template-columns:.85fr 1.4fr; gap:80px; align-items:start}
.story h2{font-weight:700; font-size:clamp(40px,5vw,72px);line-height:.95; letter-spacing:-.04em; margin:18px 0 0; color:var(--ink);}
.story h2 .hl{background:var(--lime); padding:0 .12em; border-radius:10px; margin:0 -.06em;}
.story p.lede{font-size:22px; line-height:1.4; color:var(--ink-2); margin:0 0 18px; letter-spacing:-.015em; font-weight:500;}
.story p{font-size:16px;line-height:1.6;color:var(--mute);margin:0;max-width:58ch}
.story .col-side{position:sticky;top:100px}
.story-stats{margin-top:60px; display:grid;grid-template-columns:repeat(3,1fr); gap:0;padding-top:40px;border-top:1px solid var(--line);}
.story-stats .stat{padding-right:24px; position:relative;}
.story-stats .stat:not(:last-child)::after{content:"";position:absolute;right:0;top:0;bottom:0;width:1px;background:var(--line)}
.story-stats .stat:not(:first-child){padding-left:24px}
.story-stats .stat .n{font-weight:700; font-size:64px; letter-spacing:-.05em; line-height:.9; color:var(--ink);}
.story-stats .stat .n .hl{background:var(--lime); padding:0 .1em; border-radius:8px;}
.story-stats .stat .l{font-size:13px;color:var(--mute);margin-top:16px;line-height:1.5; font-family:'Geist Mono',monospace; letter-spacing:.04em;}

/* STACK / MODULES */
.stack{padding:30px 0 130px; background:var(--paper-2)}
.stack-header{display:flex;justify-content:space-between;align-items:end;margin-bottom:50px;gap:30px;flex-wrap:wrap; padding-top:80px}
.stack-header h2{font-weight:700;font-size:clamp(40px,5vw,72px); line-height:.95;letter-spacing:-.04em;margin:14px 0 0;max-width:16ch;}
.stack-header h2 .hl{background:var(--lime); padding:0 .12em; border-radius:10px; margin:0 -.06em;}
.stack-header p{max-width:36ch;color:var(--mute);font-size:16px;line-height:1.55;margin:0}
.modules{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;}
.mod{
  background:var(--paper);border:1px solid var(--line);
  border-radius:24px; padding:28px;
  display:flex; flex-direction:column; gap:18px;
  transition:.25s ease; position:relative; overflow:hidden;
  min-height:280px;
}
.mod:hover{transform:translateY(-4px); border-color:var(--ink); box-shadow:0 24px 50px -25px rgba(0,0,0,.16)}
.mod:hover .mod-no{background:var(--lime); color:var(--ink);}
.mod .mod-no{
  width:42px;height:42px;border-radius:12px;
  background:var(--paper-3);color:var(--ink);
  display:grid;place-items:center;
  font-family:'Geist Mono',monospace;font-size:14px;font-weight:600;letter-spacing:-.02em;
  transition:.25s;
}
.mod h3{font-weight:700;font-size:24px;line-height:1.05;letter-spacing:-.025em;margin:0;}
.mod p{font-size:14px;line-height:1.5;color:var(--mute);margin:0;flex:1;}
.mod ul{margin:0;padding:0;list-style:none;display:grid;gap:6px;border-top:1px dashed var(--line);padding-top:14px;}
.mod ul li{font-size:12.5px;color:var(--ink-2);position:relative;padding-left:16px;font-family:'Geist Mono',monospace;letter-spacing:.02em;}
.mod ul li::before{content:"→"; position:absolute; left:0; color:var(--lime-2); font-weight:700;}

/* WHITE LABEL */
.wl{padding:130px 0; background:var(--paper)}
.wl-grid{display:grid;grid-template-columns:1fr 1.1fr; gap:80px; align-items:center}
.wl h2{font-weight:700;font-size:clamp(40px,5vw,72px); letter-spacing:-.04em; line-height:.95;margin:18px 0 22px;}
.wl h2 .hl{background:var(--lime); padding:0 .12em; border-radius:10px; margin:0 -.06em;}
.wl .lede{font-size:19px;line-height:1.5;color:var(--ink-2);margin:0 0 30px;font-weight:500;max-width:38ch;letter-spacing:-.01em}
.wl-points{display:grid;gap:0;margin-bottom:32px}
.wl-points .point{display:grid;grid-template-columns:36px 1fr;gap:14px;align-items:start;padding:18px 0; border-bottom:1px solid var(--line);}
.wl-points .point:first-child{border-top:1px solid var(--line)}
.wl-points .point .ck{width:28px;height:28px;border-radius:99px;background:var(--lime);display:grid;place-items:center; margin-top:2px;}
.wl-points .point b{font-weight:600;font-size:16px;display:block;letter-spacing:-.015em}
.wl-points .point span{font-size:14px;color:var(--mute);line-height:1.5;display:block;margin-top:4px}

/* DASHBOARD MOCK */
.mock{background:var(--paper); border:1px solid var(--line);border-radius:22px; overflow:hidden;box-shadow:0 40px 80px -45px rgba(0,0,0,.30);position:relative;}
.mock-bar{display:flex;align-items:center;gap:10px;padding:14px 18px;border-bottom:1px solid var(--line);background:var(--paper-2);}
.mock-bar .dots{display:flex;gap:6px}
.mock-bar .dots span{width:10px;height:10px;border-radius:99px;background:var(--line-2)}
.mock-bar .url{margin-left:8px; font-family:'Geist Mono',monospace; font-size:11px;color:var(--mute);background:var(--paper); padding:6px 14px;border-radius:99px;border:1px solid var(--line);}
.mock-bar .yourlogo{margin-left:auto;font-weight:600;font-size:14px;color:var(--ink); display:flex;align-items:center;gap:6px}
.mock-bar .yourlogo .br{width:18px;height:18px;border-radius:6px;background:var(--lime); display:grid;place-items:center; font-family:'Geist Mono',monospace; font-size:10px; font-weight:700;}
.mock-body{display:grid;grid-template-columns:180px 1fr; min-height:380px;}
.mock-side{background:var(--paper-2); border-right:1px solid var(--line);padding:20px 14px; display:flex;flex-direction:column;gap:4px;font-size:13px; color:var(--ink-2); font-weight:500;}
.mock-side .item{padding:8px 12px;border-radius:8px;cursor:pointer; display:flex;align-items:center;gap:10px;}
.mock-side .item::before{content:""; width:6px;height:6px;border-radius:99px;background:var(--line-2)}
.mock-side .item.active{background:var(--ink);color:var(--paper)}
.mock-side .item.active::before{background:var(--lime)}
.mock-main{padding:24px;display:grid;gap:16px}
.mock-main h4{font-weight:700;font-size:22px;margin:0; letter-spacing:-.025em}
.mock-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.mock-cards .mc{border:1px solid var(--line); border-radius:14px; padding:14px; background:var(--paper);}
.mock-cards .mc .lbl{font-family:'Geist Mono',monospace;font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--mute);}
.mock-cards .mc .v{font-weight:700;font-size:26px;margin-top:8px;letter-spacing:-.03em;}
.mock-cards .mc .delta{font-family:'Geist Mono',monospace;font-size:11px;color:var(--ok);margin-top:4px;}
.mock-chart{border:1px solid var(--line); border-radius:14px; height:160px; background:var(--paper); position:relative; overflow:hidden;}
.mock-chart svg{position:absolute;inset:0;width:100%;height:100%}

/* DEVELOPER */
.dev{padding:130px 0; background:var(--ink); color:#EDEDED; position:relative;}
.dev::before{
  content:""; position:absolute; inset:0; pointer-events:none;
  background-image:
    radial-gradient(rgba(198,255,61,.06) 1px, transparent 1.4px),
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='480' height='240' viewBox='0 0 480 240'><g fill='none' stroke='%23C6FF3D' stroke-opacity='0.06' stroke-width='1'><path d='M0 60 Q 60 20 120 60 T 240 60 T 360 60 T 480 60'/><path d='M0 140 Q 60 100 120 140 T 240 140 T 360 140 T 480 140'/></g></svg>");
  background-size:22px 22px, 480px 240px;
  mask-image: linear-gradient(180deg, transparent, black 12%, black 88%, transparent);
}
.dev .container{position:relative; z-index:2}
.dev-grid{display:grid;grid-template-columns:1fr 1.15fr; gap:60px; align-items:start}
.dev .eyebrow{color:var(--lime)}
.dev .eyebrow .dot{background:var(--lime);box-shadow:0 0 0 4px rgba(198,255,61,.15)}
.dev h2{font-weight:700;font-size:clamp(40px,5vw,72px); letter-spacing:-.04em; line-height:.95;margin:18px 0 22px; color:var(--paper);}
.dev h2 .hl{background:var(--lime); color:var(--ink); padding:0 .12em; border-radius:10px; margin:0 -.06em;}
.dev .lede{font-size:19px;line-height:1.5;color:#BFBFBF;margin:0 0 30px; font-weight:500; max-width:38ch;}

.codetabs{background:#0A0A0A; color:#E7E2D6; border-radius:22px;overflow:hidden; border:1px solid #1F1F1F;box-shadow:0 40px 80px -40px rgba(0,0,0,.6);}
.codetabs .tabs{display:flex;gap:0; border-bottom:1px solid #1F1F1F; background:#0A0A0A;font-family:'Geist Mono',monospace;font-size:11px;letter-spacing:.08em;text-transform:uppercase;}
.codetabs .tab{padding:14px 20px; color:#6D6D6D; cursor:pointer;border-right:1px solid #1A1A1A;transition:.18s; font-weight:500;}
.codetabs .tab:hover{color:#BBB}
.codetabs .tab.active{color:var(--ink); background:var(--lime);}
.codetabs pre{margin:0; padding:26px; font-family:'Geist Mono',monospace; font-size:13px; line-height:1.7;overflow:auto; max-height:480px;}
.code-block{display:none}
.code-block.active{display:block}
.codetabs .tk-kw{color:#C68AFF}
.codetabs .tk-str{color:#C6FF3D}
.codetabs .tk-num{color:#FFD16A}
.codetabs .tk-com{color:#5F6470;font-style:italic}
.codetabs .tk-fn{color:#7DD3FC}
.codetabs .tk-prop{color:#E7E2D6}

.featgrid{display:grid;grid-template-columns:repeat(2,1fr); gap:12px; margin-top:28px}
.feat{padding:18px;border:1px solid #1F1F1F;background:#0F0F0F; border-radius:14px; transition:.2s;}
.feat:hover{border-color:var(--lime)}
.feat .ico{
  width:34px;height:34px;border-radius:10px;background:var(--lime);color:var(--ink);
  display:grid;place-items:center;font-family:'Geist Mono',monospace;font-size:14px;font-weight:700;margin-bottom:14px;
}
.feat h5{font-weight:700;font-size:16px;margin:0 0 4px;letter-spacing:-.015em;color:var(--paper)}
.feat p{font-size:13px;color:#9CA3AF;margin:0;line-height:1.5;}

/* AUDIENCE */
.who{padding:130px 0; background:var(--paper)}
.who-head{display:flex; justify-content:space-between; align-items:end; gap:30px;flex-wrap:wrap;margin-bottom:40px;}
.who-head h2{font-weight:700;font-size:clamp(40px,5vw,72px);letter-spacing:-.04em;line-height:.95;margin:18px 0 0;}
.who-head h2 .hl{background:var(--lime); padding:0 .12em; border-radius:10px; margin:0 -.06em;}
.who-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.who-card{
  background:var(--paper); border:1px solid var(--line); border-radius:22px;
  padding:24px; min-height:240px;
  display:flex;flex-direction:column;justify-content:space-between;
  transition:.25s ease;position:relative;overflow:hidden;
  cursor:default;
}
.who-card:hover{transform:translateY(-4px); background:var(--ink); color:var(--paper); border-color:var(--ink)}
.who-card:hover .role{color:var(--lime)}
.who-card:hover h4 .hl{background:var(--lime); color:var(--ink)}
.who-card:hover p{color:#BFBFBF}
.who-card:hover .arrow{background:var(--lime); color:var(--ink)}
.who-card .role{font-family:'Geist Mono',monospace;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--mute); transition:.2s;}
.who-card h4{font-weight:700;font-size:24px;line-height:1.1;letter-spacing:-.025em;margin:16px 0 10px;}
.who-card h4 .hl{background:var(--paper-3); padding:0 .12em; border-radius:8px; margin:0 -.06em; transition:.2s;}
.who-card p{font-size:13.5px;color:var(--mute);margin:0;line-height:1.5; transition:.2s;}
.who-card .arrow{
  margin-top:18px; width:36px;height:36px;border-radius:99px;
  background:var(--paper-3); color:var(--ink);
  display:grid;place-items:center;
  transition:.2s; font-size:18px;
}

/* SPEED */
.speed{padding:130px 0; background:var(--lime); color:var(--ink); position:relative; overflow:hidden;}
.speed::before{
  content:""; position:absolute; inset:0;
  background-image:radial-gradient(rgba(0,0,0,.06) 1px, transparent 1px);
  background-size:18px 18px;
  mask-image: linear-gradient(180deg, transparent, black 30%, black 70%, transparent);
}
.speed .container{position:relative;z-index:2}
.speed .row{display:grid;grid-template-columns:1.05fr 1fr;gap:60px;align-items:center}
.speed h2{font-weight:700;font-size:clamp(54px,7vw,108px);letter-spacing:-.05em;line-height:.9;margin:18px 0 0;}
.speed h2 .strike{position:relative;display:inline-block;color:var(--ink-3);font-weight:500;}
.speed h2 .strike::after{content:"";position:absolute;left:-2%;right:-2%;top:55%;height:6px;background:var(--ink);border-radius:3px;transform:rotate(-2deg);}
.speed .lede{font-size:20px;line-height:1.4;color:var(--ink-2);margin:24px 0 0;font-weight:500;max-width:32ch}

.compare{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.col-c{border:1px solid var(--ink); border-radius:18px; padding:24px;background:transparent;}
.col-c.you{background:var(--ink);color:var(--paper);}
.col-c .lbl{font-family:'Geist Mono',monospace;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-3);margin-bottom:12px; font-weight:500;}
.col-c.you .lbl{color:var(--lime)}
.col-c h5{font-weight:700;font-size:24px;margin:0 0 18px;letter-spacing:-.025em}
.col-c ul{margin:0;padding:0;list-style:none;display:grid;gap:10px}
.col-c ul li{font-size:14.5px;display:grid;grid-template-columns:22px 1fr;gap:10px;align-items:start;line-height:1.5; font-weight:500;}
.col-c .x, .col-c .ck{
  width:22px;height:22px; border-radius:99px;display:grid;place-items:center;font-size:11px; font-weight:700; margin-top:1px;
}
.col-c .x{background:rgba(0,0,0,.08); color:var(--ink)}
.col-c.you .x{background:rgba(255,255,255,.1); color:var(--paper)}
.col-c .ck{background:var(--lime); color:var(--ink)}
.col-c .num{font-weight:700;font-size:64px;margin-top:20px;line-height:.9;letter-spacing:-.04em}
.col-c.you .num{color:var(--lime)}
.col-c .num small{font-family:'Geist Mono',monospace; font-size:12px;color:var(--ink-3); display:block;margin-top:8px;letter-spacing:.1em;text-transform:uppercase; font-weight:500;}
.col-c.you .num small{color:#888}

/* FAQ */
.faq{padding:130px 0 60px; background:var(--paper)}
.faq-grid{display:grid;grid-template-columns:1fr 1.8fr;gap:80px;align-items:start}
.faq h2{font-weight:700;font-size:clamp(40px,5vw,72px);letter-spacing:-.04em;line-height:.95;margin:18px 0 0;}
.faq h2 .hl{background:var(--lime); padding:0 .12em; border-radius:10px; margin:0 -.06em;}
details{border-top:1px solid var(--line); padding:24px 0;}
details:last-of-type{border-bottom:1px solid var(--line)}
details summary{
  cursor:pointer;list-style:none;
  display:flex;justify-content:space-between;align-items:center;gap:20px;
  font-size:20px;font-weight:600;letter-spacing:-.02em;
}
details summary::-webkit-details-marker{display:none}
details summary .ic{
  width:32px;height:32px;border-radius:99px;
  background:var(--paper-3); display:grid;place-items:center;
  color:var(--ink); transition:.25s;
  font-family:'Geist Mono',monospace;font-size:16px;font-weight:700;
  flex:none;
}
details[open] summary .ic{transform:rotate(45deg); background:var(--lime);}
details .ans{margin-top:14px;color:var(--mute);font-size:15px;line-height:1.6;max-width:62ch}

/* CTA */
.cta{padding:140px 0 120px;text-align:center;position:relative; background:var(--paper);}
.cta h2{font-weight:700;font-size:clamp(56px,10vw,168px); line-height:.86;letter-spacing:-.055em;margin:30px 0 0;}
.cta h2 .hl{background:var(--lime); padding:0 .12em; border-radius:18px; margin:0 -.06em; display:inline-block;}
.cta .lede{font-size:22px;color:var(--ink-2);margin:30px auto 0;max-width:44ch;letter-spacing:-.01em;line-height:1.4; font-weight:500;}
.cta-actions{margin-top:40px;display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.cta-mini{margin-top:50px;font-family:'Geist Mono',monospace;font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--mute);display:flex;gap:24px;justify-content:center;flex-wrap:wrap;align-items:center; font-weight:500;}
.cta-mini span{display:inline-flex;align-items:center;gap:8px}
.cta-mini .d{width:6px;height:6px;border-radius:99px;background:var(--lime)}

/* FOOTER */
footer{background:var(--ink); color:#BFBFBF; padding:80px 0 32px;position:relative; overflow:hidden;}
footer::before{
  content:""; position:absolute; inset:0; pointer-events:none;
  background-image:
    radial-gradient(rgba(198,255,61,.05) 1px, transparent 1.4px);
  background-size:22px 22px;
  mask-image: linear-gradient(180deg, transparent, black 8%, black 92%, transparent);
}
footer .container{position:relative; z-index:2}
footer .top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr 1fr;gap:50px;margin-bottom:60px}
footer .brand-block .brand{color:var(--paper);font-size:24px}
footer .brand-block .brand-mark{width:34px;height:34px}
footer .tag-foot{margin-top:20px;color:#9CA3AF;font-size:14px;max-width:28ch;line-height:1.55}
footer h6{font-family:'Geist Mono',monospace;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:#6B7280;margin:0 0 16px;font-weight:500}
footer ul{list-style:none;padding:0;margin:0;display:grid;gap:10px}
footer ul a{font-size:14px;color:#E5E5E5; transition:.2s}
footer ul a:hover{color:var(--lime)}
footer .bottom{display:flex;justify-content:space-between;align-items:center;padding-top:30px;border-top:1px solid #1F1F1F;font-family:'Geist Mono',monospace;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:#6B7280;flex-wrap:wrap;gap:14px;}
footer .ws{display:flex;gap:10px;align-items:center}
footer .ws a{
  display:inline-grid;place-items:center;width:36px;height:36px;border-radius:99px;
  border:1px solid #1F1F1F;color:#E5E5E5;background:transparent;transition:.2s;
}
footer .ws a:hover{background:var(--lime);border-color:var(--lime);color:var(--ink);transform:translateY(-2px)}
footer .ws a svg{width:16px;height:16px;display:block;fill:currentColor}
.bigword{
  font-weight:700;font-size:clamp(120px,22vw,340px);line-height:.85;letter-spacing:-.06em;
  color:transparent; -webkit-text-stroke:1px #1A1A1A;
  margin:0 0 -10px; user-select:none;
  position:relative;
}
.bigword .lime{color:var(--lime); -webkit-text-stroke:0;}

/* ============================================================
   GENERIC PAGE HERO (used by sub-pages)
   ============================================================ */
.page-hero{position:relative; padding:80px 0 80px; overflow:hidden;}
.page-hero h1{
  font-weight:700;
  font-size:clamp(48px,7vw,116px);
  line-height:.92;
  letter-spacing:-.045em;
  margin:24px 0 0;
}
.page-hero h1 .hl{
  background:var(--lime); padding:0 .12em; margin:0 -.06em;
  border-radius:14px; display:inline-block;
}
.page-hero .lede{
  font-size:20px;line-height:1.5;color:var(--ink-2);
  max-width:60ch; margin:30px 0 0; font-weight:400;
}
.page-hero-cta{display:flex;gap:12px;margin-top:36px;flex-wrap:wrap;align-items:center}

/* PAGE STRIP — neutral subsection block */
.strip{padding:110px 0; background:var(--paper);}
.strip.alt{background:var(--paper-2)}
.strip-head{margin-bottom:50px; max-width:780px}
.strip-head h2{font-weight:700;font-size:clamp(36px,4.4vw,60px);letter-spacing:-.04em;line-height:.98;margin:14px 0 16px;}
.strip-head h2 .hl{background:var(--lime); padding:0 .12em; border-radius:10px; margin:0 -.06em;}
.strip-head p{font-size:17px;line-height:1.55;color:var(--mute);margin:0;max-width:62ch}

/* GENERIC GRID OF FEATURE CARDS (white) */
.cards-3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.cards-2{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.fcard{
  background:var(--paper);border:1px solid var(--line);
  border-radius:24px; padding:28px;
  display:flex; flex-direction:column; gap:14px;
  transition:.25s ease;
}
.fcard:hover{transform:translateY(-3px); border-color:var(--ink); box-shadow:0 24px 50px -25px rgba(0,0,0,.16)}
.fcard .badge{
  width:42px;height:42px;border-radius:12px;background:var(--lime);
  display:grid;place-items:center;color:var(--ink);
  font-family:'Geist Mono',monospace;font-size:14px;font-weight:700;
}
.fcard h3{font-weight:700;font-size:22px;line-height:1.1;letter-spacing:-.025em;margin:0;}
.fcard p{font-size:14.5px;line-height:1.55;color:var(--mute);margin:0}

/* TABLE-LIKE FEATURE LIST */
.spec{display:grid;grid-template-columns:240px 1fr;gap:14px;align-items:start;padding:22px 0;border-top:1px solid var(--line);}
.spec:last-of-type{border-bottom:1px solid var(--line)}
.spec .k{font-family:'Geist Mono',monospace;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--mute);padding-top:4px;}
.spec .v{font-size:16px;line-height:1.55;color:var(--ink-2)}
.spec .v b{font-weight:600;color:var(--ink);display:block;margin-bottom:4px;font-size:17px;letter-spacing:-.015em}

/* DARK PANEL (for code samples on any page) */
.dark-panel{background:var(--ink);color:#EDEDED;border-radius:24px;padding:36px;position:relative;overflow:hidden}
.dark-panel h3{color:var(--paper);font-weight:700;font-size:26px;letter-spacing:-.025em;margin:0 0 8px}
.dark-panel p{color:#BFBFBF;font-size:15px;line-height:1.55;margin:0 0 20px;max-width:54ch}

/* ============================================================
   LEGAL PAGES (Terms / Privacy)
   ============================================================ */
.legal{padding:20px 0 110px; background:var(--paper);}
.legal-grid{display:grid;grid-template-columns:280px 1fr;gap:72px;align-items:start;}

/* sticky table of contents */
.legal-toc{position:sticky;top:100px;}
.legal-toc .toc-label{font-family:'Geist Mono',monospace;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--mute);margin:0 0 16px;font-weight:500;}
.legal-toc nav{display:grid;gap:2px;border-left:1px solid var(--line);}
.legal-toc nav a{
  display:flex;gap:12px;align-items:baseline;
  padding:9px 0 9px 18px;margin-left:-1px;
  font-size:13.5px;color:var(--mute);line-height:1.4;
  border-left:2px solid transparent;transition:.18s;
}
.legal-toc nav a .tn{font-family:'Geist Mono',monospace;font-size:11px;color:var(--line-2);flex:none;}
.legal-toc nav a:hover{color:var(--ink);border-left-color:var(--line-2);}
.legal-toc nav a.active{color:var(--ink);font-weight:500;border-left-color:var(--lime);}
.legal-toc nav a.active .tn{color:var(--lime-2);}
.legal-toc .toc-foot{margin-top:24px;padding:16px;border:1px solid var(--line);border-radius:14px;background:var(--paper-2);}
.legal-toc .toc-foot .ef{font-family:'Geist Mono',monospace;font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--mute);margin:0 0 6px;}
.legal-toc .toc-foot .ed{font-size:14px;font-weight:600;letter-spacing:-.015em;color:var(--ink);margin:0;}

/* prose body */
.legal-body{max-width:760px;}
.legal-body .intro{font-size:19px;line-height:1.55;color:var(--ink-2);font-weight:500;letter-spacing:-.01em;margin:0 0 12px;}
.legal-body p{font-size:16px;line-height:1.7;color:var(--ink-2);margin:0 0 20px;text-wrap:pretty;}
.legal-body a{color:var(--ink);font-weight:500;text-decoration:underline;text-decoration-color:var(--lime-2);text-underline-offset:3px;text-decoration-thickness:2px;}
.legal-body a:hover{background:var(--lime);text-decoration:none;}
.legal-body section{scroll-margin-top:90px;padding-top:44px;}
.legal-body section + section{margin-top:8px;border-top:1px solid var(--line);}
.legal-body section .kicker{font-family:'Geist Mono',monospace;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--mute);margin:0 0 10px;display:block;}
.legal-body h2{font-weight:700;font-size:clamp(26px,3vw,34px);letter-spacing:-.03em;line-height:1.05;margin:0 0 22px;color:var(--ink);}
.legal-body h3{font-weight:700;font-size:18px;letter-spacing:-.02em;margin:28px 0 12px;color:var(--ink);}
.legal-body ul{list-style:none;margin:0 0 20px;padding:0;display:grid;gap:12px;}
.legal-body ul li{position:relative;padding-left:26px;font-size:16px;line-height:1.6;color:var(--ink-2);}
.legal-body ul li::before{content:"";position:absolute;left:2px;top:9px;width:9px;height:9px;border-radius:99px;background:var(--lime);box-shadow:0 0 0 3px rgba(198,255,61,.25);}
.legal-body .callout{
  border:1px solid var(--line);border-left:3px solid var(--lime);
  background:var(--paper-2);border-radius:0 14px 14px 0;
  padding:18px 22px;margin:0 0 20px;
  font-size:15px;line-height:1.6;color:var(--ink-2);
}
.legal-body .callout b{color:var(--ink);font-weight:600;}

@media (max-width: 980px){
  .legal-grid{grid-template-columns:1fr;gap:36px;}
  .legal-toc{position:relative;top:0;}
  .legal-toc nav{grid-template-columns:1fr 1fr;display:grid;}
}
@media (max-width: 560px){
  .legal-toc nav{grid-template-columns:1fr;}
}

/* ============================================================
   COUNTRY LIST PAGE
   ============================================================ */
.ctry-wrap{padding:10px 0 110px; background:var(--paper);}
.ctry-controls{
  display:flex;align-items:center;gap:16px;flex-wrap:wrap;
  margin-bottom:14px;
}
.seg{display:inline-flex;border:1px solid var(--line-2);border-radius:99px;padding:4px;background:var(--paper);}
.seg button{
  appearance:none;border:0;cursor:pointer;background:transparent;
  font-family:'Geist Mono',monospace;font-size:12px;letter-spacing:.04em;
  padding:9px 18px;border-radius:99px;color:var(--mute);font-weight:500;
  display:inline-flex;align-items:center;gap:8px;transition:.18s;
}
.seg button .c{font-size:11px;color:var(--mute-2);}
.seg button.active{background:var(--ink);color:var(--paper);}
.seg button.active .c{color:var(--lime);}
.ctry-search{
  flex:1;min-width:220px;position:relative;
}
.ctry-search input{
  width:100%;font-family:'Geist',sans-serif;font-size:15px;
  padding:13px 16px 13px 42px;border:1px solid var(--line);border-radius:12px;
  background:var(--paper-2);color:var(--ink);outline:none;transition:.18s;
}
.ctry-search input:focus{border-color:var(--ink);background:var(--paper);}
.ctry-search .si{position:absolute;left:15px;top:50%;transform:translateY(-50%);color:var(--mute-2);font-size:15px;}
.ctry-count{font-family:'Geist Mono',monospace;font-size:12px;color:var(--mute);letter-spacing:.04em;white-space:nowrap;}
.ctry-count b{color:var(--ink);font-weight:600;}

.ctry-note{
  display:flex;gap:12px;align-items:flex-start;
  border:1px solid var(--line);border-left:3px solid var(--lime);
  background:var(--paper-2);border-radius:0 14px 14px 0;
  padding:16px 20px;margin:0 0 24px;font-size:14.5px;line-height:1.55;color:var(--ink-2);
}
.ctry-note.restricted{border-left-color:var(--ink);}
.ctry-note b{color:var(--ink);font-weight:600;}

.ctry-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));
  gap:2px;border:1px solid var(--line);border-radius:18px;overflow:hidden;background:var(--line);
}
.ctry{
  display:flex;align-items:center;gap:12px;
  padding:14px 18px;background:var(--paper);
  font-size:14.5px;color:var(--ink-2);transition:.15s;min-width:0;
}
.ctry:hover{background:var(--lime-soft);color:var(--ink);}
.ctry .flag{font-size:20px;line-height:1;flex:none;width:26px;text-align:center;}
.ctry .flag.badge{
  font-family:'Geist Mono',monospace;font-size:9px;font-weight:700;letter-spacing:.02em;
  width:26px;height:18px;border-radius:4px;background:var(--paper-3);color:var(--mute);
  display:inline-flex;align-items:center;justify-content:center;
}
.ctry .nm{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.ctry-empty{padding:50px 20px;text-align:center;color:var(--mute);font-family:'Geist Mono',monospace;font-size:13px;}

@media (max-width: 560px){
  .ctry-grid{grid-template-columns:1fr 1fr;}
  .ctry{padding:12px;gap:9px;font-size:13px;}
}

/* RESPONSIVE */
@media (max-width: 1080px){
  .modules,.cards-3{grid-template-columns:repeat(2,1fr)}
}
@media (max-width: 980px){
  .nav-inner{grid-template-columns:auto auto; gap:14px}
  nav.links{display:none}
  .hero-grid{grid-template-columns:1fr; gap:60px}
  .hero-vis{justify-self:center}
  .story-grid{grid-template-columns:1fr;gap:40px}
  .story .col-side{position:relative;top:0}
  .wl-grid,.dev-grid,.speed .row,.faq-grid{grid-template-columns:1fr;gap:50px}
  .who-cards{grid-template-columns:repeat(2,1fr)}
  footer .top{grid-template-columns:1fr 1fr; gap:30px}
  .featgrid{grid-template-columns:1fr}
  .announce-inner span.hide-m{display:none}
  .story-stats{grid-template-columns:1fr; gap:20px}
  .story-stats .stat{padding:20px 0;border-bottom:1px solid var(--line)}
  .story-stats .stat::after{display:none !important}
  .story-stats .stat:not(:first-child){padding-left:0}
  .spec{grid-template-columns:1fr;gap:6px}
  .cards-2{grid-template-columns:1fr}
}
@media (max-width: 560px){
  .modules,.cards-3{grid-template-columns:1fr}
  .who-cards{grid-template-columns:1fr}
  .compare{grid-template-columns:1fr}
  footer .top{grid-template-columns:1fr}
  .container{padding:0 20px}
  .float-chip{transform:scale(.85)}
  .dark-panel{padding:24px}
}
