/* ============================================================
   The 66th — Shared Canonical Stylesheet
   ============================================================
   Single source of truth for tokens, base styles, type system,
   layout primitives, and chrome components (nav, marquee,
   section heads, footer, CTA, utilities).

   Page-specific styles stay in each page's inline <style> block.

   FONT SIZE CONTROL
   -----------------
   The entire type system scales from `:root { font-size }`.
   Change ONE value to scale every body text size site-wide.

      :root { font-size: 16px }   ← default
      :root { font-size: 17px }   ← +6.25% bigger everywhere
      :root { font-size: 15px }   ← -6.25% smaller everywhere

   All component font sizes use rem. Display/hero sizes
   stay in clamp(px, vw, px) since they're viewport-relative.
   ============================================================ */

:root{
  /* Type scale base (controls all rem) */
  font-size: 16px;

  /* Surface */
  --bg:#0A0A0B;
  --bg-2:#0E0E10;
  --ink:#EDE8DE;          /* warm off-white */
  --ink-dim:#8A857A;      /* secondary */
  --ink-mute:#55524C;     /* tertiary, labels */
  --line:rgba(237,232,222,.08);
  --line-2:rgba(237,232,222,.14);

  /* Brand */
  --accent: oklch(78% 0.12 72);          /* warm amber — focal */
  --accent-2: oklch(88% 0.06 72);        /* pale champagne — italic */
  --glow: oklch(78% 0.12 72 / 0.35);     /* shadow / halo */
  --good: #7FB28F;                       /* positive deltas only */

  /* Type families */
  --f-sans: 'Geist', system-ui, sans-serif;
  --f-serif: 'Instrument Serif', serif;
  --f-mono: 'Geist Mono', monospace;

  /* Motion */
  --motion-fast: 240ms;
  --motion-base: 600ms;
  --motion-slow: 1200ms;
  --ease-out: cubic-bezier(.2,.8,.2,1);
  --ease-inout: cubic-bezier(.65,0,.35,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{
  background:var(--bg);
  color:var(--ink);
  font-family:var(--f-sans);
  -webkit-font-smoothing:antialiased;
  font-feature-settings:"ss01","cv11";
}
html{scroll-behavior:auto}
body{
  overflow-x:hidden;
  line-height:1.45;
  font-size:1rem;            /* = root font-size, scales with --text-scale */
  letter-spacing:-0.005em;
}
::selection{background:var(--accent);color:#0A0A0B}

/* ============ GRAIN OVERLAY ============ */
.grain{
  position:fixed;inset:0;pointer-events:none;z-index:100;opacity:.06;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/></filter><rect width='100%25' height='100%25' filter='url(%23n)' opacity='.9'/></svg>");
}

/* ============ CONTAINER ============ */
.wrap{max-width:1440px;margin:0 auto;padding:0 40px}
@media (max-width:800px){.wrap{padding:0 20px}}

/* ============ HAIRLINES ============ */
.hr{height:1px;background:var(--line);width:100%}
.vline{width:1px;background:var(--line);height:100%}

/* ============ TYPE UTILITIES ============ */
.mono{
  font-family:var(--f-mono);
  font-weight:400;
  letter-spacing:0.04em;
  text-transform:uppercase;
  font-size:0.75rem;         /* 12px @ root 16px — readability rule minimum for mono labels */
  color:var(--ink-dim);
}
.serif{
  font-family:var(--f-serif);
  font-weight:400;
  font-style:italic;
  letter-spacing:-0.01em;
}
.display{
  font-family:var(--f-sans);
  font-weight:500;
  letter-spacing:-0.035em;
  line-height:0.95;
}

/* ============ NAV (canonical floating-island) ============ */
nav.top{
  position:fixed;top:18px;left:50%;transform:translateX(-50%);
  z-index:50;display:flex;align-items:center;gap:8px;
  padding:8px 8px 8px 22px;
  background:rgba(13,13,16,.78);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border:1px solid var(--line-2);border-radius:999px;
  box-shadow:0 18px 40px rgba(0,0,0,.5), inset 0 1px 0 rgba(237,232,222,.06);
  transition:padding .35s cubic-bezier(.32,.72,0,1), top .35s cubic-bezier(.32,.72,0,1), background .35s;
}
nav.top.scrolled{top:14px;background:rgba(13,13,16,.92)}
.nav-left{display:flex;align-items:center;gap:22px;padding-right:14px;border-right:1px solid var(--line);height:36px}
.logo{display:flex;align-items:center;gap:10px;font-family:var(--f-mono);font-size:0.75rem;letter-spacing:0.04em;color:var(--ink);text-decoration:none}
.logo-mark{width:26px;height:26px;border:1px solid var(--line-2);border-radius:50%;display:grid;place-items:center;position:relative;overflow:hidden}
.logo-mark::before{content:"";position:absolute;inset:3px;border-radius:50%;background:conic-gradient(from 0deg,var(--accent),transparent 60%);opacity:.5}
.logo-mark span{position:relative;font-size:0.5625rem;font-weight:500;color:var(--ink)}
.navlinks{display:flex;gap:6px;align-items:center}
.navlinks a{padding:9px 14px;border-radius:999px;font-size:0.8125rem;color:#C9C2B5;text-decoration:none;white-space:nowrap;transition:all .35s cubic-bezier(.32,.72,0,1)}
.navlinks a:hover{color:var(--ink);background:rgba(237,232,222,.05)}
.navlinks a.active{color:var(--ink);background:rgba(237,232,222,.06);box-shadow:inset 0 0 0 1px var(--line-2)}
.nav-cta{display:inline-flex;align-items:center;gap:8px;padding:7px 7px 7px 16px;background:var(--ink);color:var(--bg);border-radius:999px;font-family:var(--f-mono);font-size:0.6875rem;letter-spacing:0.05em;text-transform:uppercase;font-weight:500;text-decoration:none;white-space:nowrap;flex-shrink:0;transition:transform .35s cubic-bezier(.32,.72,0,1), background .35s}
.nav-cta .arr{width:24px;height:24px;border-radius:50%;background:var(--bg);color:var(--ink);display:grid;place-items:center;font-size:0.6875rem;transition:transform .35s cubic-bezier(.32,.72,0,1)}
.nav-cta:hover{background:var(--accent)}
.nav-cta:hover .arr{transform:rotate(-12deg) translate(2px,-2px)}
.nav-cta .dot{width:6px;height:6px;border-radius:50%;background:var(--accent);box-shadow:0 0 12px var(--glow)}
.nav-burger{display:none;width:40px;height:40px;border:1px solid var(--line-2);border-radius:50%;flex-direction:column;justify-content:center;align-items:center;gap:5px;padding:0;background:none;cursor:pointer}
.nav-burger span{display:block;width:14px;height:1.5px;background:var(--ink);transition:transform .35s, opacity .35s}
.nav-burger.open span:nth-child(1){transform:translateY(3px) rotate(45deg)}
.nav-burger.open span:nth-child(2){opacity:0}
.nav-burger.open span:nth-child(3){transform:translateY(-4px) rotate(-45deg)}
.mobile-menu{display:none;position:fixed;inset:0;background:rgba(8,8,10,.96);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);z-index:49;padding:96px 24px 32px;flex-direction:column;opacity:0;pointer-events:none;transition:opacity .4s ease}
.mobile-menu.open{opacity:1;pointer-events:auto}
.mobile-menu a{display:flex;justify-content:space-between;align-items:center;padding:24px 0;border-bottom:1px solid var(--line);font-size:1.5rem;color:var(--ink);text-decoration:none;letter-spacing:-0.02em}
.mobile-menu a::after{content:"→";font-family:var(--f-mono);font-size:0.875rem;color:var(--ink-mute)}
@media (max-width:1000px){
  .navlinks{display:none}
  .nav-left{padding-right:0;border-right:none}
  nav.top{padding:6px 6px 6px 18px}
  .nav-burger{display:flex}
  .mobile-menu{display:flex}
  .nav-cta span:not(.arr):not(.dot){display:none}
  .nav-cta{padding:6px 6px 6px 14px}
}

/* ============ MARQUEE ============ */
.marquee{padding:60px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);overflow:hidden;position:relative;background:var(--bg-2)}
.marquee::before,.marquee::after{content:"";position:absolute;top:0;bottom:0;width:200px;z-index:2;pointer-events:none}
.marquee::before{left:0;background:linear-gradient(90deg,var(--bg-2),transparent)}
.marquee::after{right:0;background:linear-gradient(-90deg,var(--bg-2),transparent)}
.marquee-track{display:flex;gap:96px;width:max-content;animation:scroll 50s linear infinite;align-items:center}
.marquee-item{display:flex;align-items:center;white-space:nowrap;flex:0 0 auto}
.marquee-item img{height:42px;width:auto;max-width:170px;object-fit:contain;opacity:.55;filter:grayscale(1) brightness(1.6) contrast(1.1);transition:opacity .35s ease,filter .35s ease}
.marquee-item:hover img{opacity:1;filter:grayscale(0) brightness(1) contrast(1)}
@media (max-width:700px){.marquee-track{gap:64px}.marquee-item img{height:32px}}
@keyframes scroll{to{transform:translateX(-50%)}}

/* ============ SECTION HEADERS ============ */
.section{padding:140px 40px;position:relative}
.section-head{display:grid;grid-template-columns:200px 1fr;gap:60px;margin-bottom:80px;align-items:start}
.section-head .label{font-family:var(--f-mono);font-size:0.75rem;letter-spacing:0.15em;text-transform:uppercase;color:var(--ink-dim);padding-top:18px;border-top:1px solid var(--accent);display:inline-block;align-self:start}
.section-head h2{font-family:var(--f-sans);font-weight:400;font-size:clamp(36px,5vw,72px);line-height:1.02;letter-spacing:-0.035em;max-width:22ch}
.section-head h2 .it{font-family:var(--f-serif);font-style:italic;color:var(--accent-2)}
.section-head .intro{margin-top:24px;color:#B8B2A7;font-size:clamp(1rem,1.2vw,1.1875rem);max-width:52ch;line-height:1.6}  /* readability: bigger + lighter dim */
@media (max-width:900px){.section{padding:100px 20px}.section-head{grid-template-columns:1fr;gap:24px;margin-bottom:48px}}

/* ============ FOOTER ============ */
footer{border-top:1px solid var(--line);padding:80px 40px 40px;background:var(--bg-2)}
.footer-top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:60px;margin-bottom:80px}
.footer-brand h3{font-family:var(--f-sans);font-weight:400;font-size:4.5rem;line-height:1;letter-spacing:-0.04em;margin-bottom:24px}
.footer-brand h3 .it{font-family:var(--f-serif);font-style:italic;color:var(--accent-2)}
.footer-brand p{color:#B8B2A7;font-size:0.9375rem;max-width:32ch;line-height:1.6}    /* 15px, lighter dim */
.footer-col h4{font-family:var(--f-mono);font-size:0.75rem;color:var(--ink-dim);letter-spacing:0.15em;text-transform:uppercase;margin-bottom:24px}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.footer-col a{color:var(--ink);text-decoration:none;font-size:0.9375rem;transition:color .2s}    /* 15px, was 14px */
.footer-col a:hover{color:var(--accent)}
.footer-bot{display:flex;justify-content:space-between;align-items:center;padding-top:32px;border-top:1px solid var(--line);font-family:var(--f-mono);font-size:0.75rem;color:var(--ink-mute);letter-spacing:0.1em;text-transform:uppercase}
@media (max-width:900px){.footer-top{grid-template-columns:1fr;gap:40px}footer{padding:60px 20px 32px}.footer-bot{flex-direction:column;gap:12px}}

/* ============ REVEAL ANIMATIONS ============ */
.reveal{opacity:0;transform:translateY(30px)}
.reveal-word{display:inline-block;overflow:hidden}
.reveal-word > span{display:inline-block;transform:translateY(110%)}
.mask{overflow:hidden}
.mask > *{display:inline-block;transform:translateY(110%)}

/* ============ SCROLLBAR ============ */
::-webkit-scrollbar{width:8px;height:8px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--line-2);border-radius:4px}
::-webkit-scrollbar-thumb:hover{background:var(--ink-mute)}
