/* ════════════════════════════════════════════════════════════════════
   STILLROOM — stillroom-core.css  ·  v0.17  ·  2026-05-04
   Shared chrome for /work.html, /about.html, /contact.html.
   Mirrors the canonical styles in brutalist-v3.html (the homepage).
   The homepage keeps everything inline; subpages link this file.
   When core styles change in brutalist-v3.html, propagate them here.
   ════════════════════════════════════════════════════════════════════ */

:root{
  --ink:#0a0a0a;
  --ink-2:#141414;
  --concrete:#1d1d1c;
  --paper:#f4f1ea;
  --paper-dim:#cfc8b8;
  --bone:#a8a194;
  --rust:#b85c2c;
  --brass:#c9a96e;
  --line:rgba(244,241,234,.18);
  --line-2:rgba(244,241,234,.06);
  --line-dark:rgba(10,10,10,.16);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
:target{scroll-margin-top:120px}
body{
  background:var(--ink);
  color:var(--paper);
  font-family:'Inter',system-ui,sans-serif;
  font-weight:300;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  cursor:none;
}
::selection{background:var(--rust);color:var(--paper)}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

.mono{font-family:'Space Mono',ui-monospace,monospace;font-size:11px;letter-spacing:.22em;text-transform:uppercase;font-weight:400}

.container{max-width:1480px;margin:0 auto;padding:0 32px}
@media(max-width:720px){.container{padding:0 18px}}

/* ── HATCH BRAND MARK ───────────────────────── */
.hatch{
  display:inline-block;
  vertical-align:middle;
  width:1em;height:1em;
  color:var(--rust);
  flex-shrink:0;
}
.hatch svg{width:100%;height:100%;display:block}
.hatch--spin svg{animation:hatchSpin 22s linear infinite}
.hatch--pulse{animation:hatchPulse 3.2s ease-in-out infinite}
@keyframes hatchSpin{from{transform:rotate(0)}to{transform:rotate(360deg)}}
@keyframes hatchPulse{0%,100%{opacity:.8;transform:scale(1)}50%{opacity:1;transform:scale(1.08)}}

/* ── CUSTOM CURSOR ───────────────────────────── */
.cursor{
  position:fixed;top:0;left:0;
  width:14px;height:14px;
  border:1px solid var(--paper);
  border-radius:50%;
  pointer-events:none;
  z-index:9999;
  transform:translate(-50%,-50%);
  transition:width .18s,height .18s,border-color .18s,background .18s;
  mix-blend-mode:difference;
}
.cursor.hover{width:48px;height:48px;background:var(--paper);border-color:var(--paper)}
.cursor-label{
  position:fixed;top:0;left:0;
  pointer-events:none;
  z-index:9999;
  transform:translate(20px,4px);
  font-family:'Space Mono',monospace;
  font-size:10px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--paper);
  mix-blend-mode:difference;
  opacity:0;
  transition:opacity .25s;
}
.cursor-label.show{opacity:.85}
@media(max-width:900px){body{cursor:auto}.cursor,.cursor-label{display:none}}

/* ── SCANLINE / GRAIN ─────────────────────────── */
.scanlines{
  position:fixed;inset:0;
  pointer-events:none;
  z-index:9000;
  background:repeating-linear-gradient(0deg,rgba(244,241,234,.012) 0 1px,transparent 1px 3px);
  mix-blend-mode:overlay;
}
.grain{
  position:fixed;inset:0;
  pointer-events:none;
  z-index:9001;
  opacity:.08;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='1.4' numOctaves='2'/><feColorMatrix values='0 0 0 0 .96  0 0 0 0 .94  0 0 0 0 .91  0 0 0 .9 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  mix-blend-mode:overlay;
}

/* ── TICKERS ─────────────────────────────────── */
.ticker{
  background:rgba(244,241,234,.88);
  color:var(--ink);
  border-bottom:1px solid var(--line-dark);
  overflow:hidden;
  position:relative;z-index:60;
  height:36px;display:flex;align-items:center;
}
.ticker__track{
  display:flex;gap:48px;
  animation:slide 40s linear infinite;
  white-space:nowrap;
}
.ticker__track > span{display:inline-flex;align-items:center;gap:48px}
.ticker__track > span::after{content:"⌗";color:var(--rust);font-size:13px}
.ticker--dark{background:var(--ink);color:var(--paper-dim);border-bottom:1px solid var(--line);border-top:1px solid var(--line)}
.ticker-disciplines a{color:inherit;text-decoration:none;border-bottom:1px solid transparent;transition:border-color .25s,color .25s}
.ticker-disciplines a:hover{border-bottom-color:var(--rust);color:var(--rust)}
.ticker--rev .ticker__track{animation:slide-rev 50s linear infinite}
@keyframes slide{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@keyframes slide-rev{from{transform:translateX(-50%)}to{transform:translateX(0)}}

/* ── SITE HEADER (ticker + nav) ──────────────── */
.sitehead{
  position:fixed;
  top:0;left:0;right:0;
  z-index:60;
  pointer-events:none;
  transition:background .3s,backdrop-filter .3s,border-color .3s;
}
.sitehead > *{pointer-events:auto}
.sitehead .ticker{position:relative;z-index:auto}
.sitehead.scrolled{
  background:rgba(10,10,10,.78);
  backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line);
}
.sitehead.scrolled .ticker{background:rgba(244,241,234,.92)}

nav.top{
  position:relative;top:auto;left:0;right:0;
  z-index:auto;
  pointer-events:none;
  transition:padding .25s;
  padding:6px 0;
}
nav.top.scrolled{padding:8px 0}
nav.top .container{display:flex;justify-content:space-between;align-items:center}
nav.top a, nav.top button{pointer-events:auto}
nav.top.scrolled .wordmark{font-size:14px}

.wordmark{
  font-family:'Inter Tight',sans-serif;
  font-weight:300;
  font-size:18px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--paper);
  mix-blend-mode:difference;
  transition:letter-spacing 1.2s ease;
  padding:14px 0;
  display:inline-flex;
  align-items:center;
  gap:14px;
}
.wordmark .hatch{font-size:13px;font-size:1cap}
.wordmark:hover{letter-spacing:.32em}

.nav-links{
  display:flex;gap:36px;
  color:var(--paper);
  mix-blend-mode:difference;
}
.nav-links a{position:relative;padding:6px 0}
.nav-links a::after{
  content:"";position:absolute;
  left:0;bottom:0;width:0;height:1px;
  background:var(--brass);
  transition:width .25s;
}
.nav-links a:hover::after{width:100%}
.nav-links a.active{color:var(--rust)}
.nav-links a.active::after{width:100%;background:var(--rust)}
@media(max-width:780px){.nav-links{display:none}}

@media(max-width:780px){
  .nav-toggle{
    display:inline-flex;
    align-items:center;
    gap:8px;
    background:rgba(255,255,255,0.12);
    border:1px solid rgba(255,255,255,0.25);
    color:var(--paper);
    padding:9px 14px;
    font-family:'Space Mono',monospace;
    font-size:10px;letter-spacing:.18em;text-transform:uppercase;
    cursor:pointer;
    pointer-events:auto;
    backdrop-filter:blur(6px);
  }
  .nav-toggle .bars{display:flex;flex-direction:column;gap:3px}
  .nav-toggle .bars span{width:14px;height:1.5px;background:var(--paper);transition:.25s}
  .nav-toggle.open .bars span:nth-child(1){transform:translateY(4.5px) rotate(45deg)}
  .nav-toggle.open .bars span:nth-child(2){opacity:0}
  .nav-toggle.open .bars span:nth-child(3){transform:translateY(-4.5px) rotate(-45deg)}
  .nav-links{
    display:none !important;
    position:fixed;
    top:84px;left:0;right:0;
    background:rgba(10,10,10,.96);
    backdrop-filter:blur(18px);
    flex-direction:column;
    padding:18px 32px 28px;
    border-top:1px solid var(--line);
    border-bottom:1px solid var(--line);
    z-index:49;
    gap:0;
  }
  .nav-links.open{display:flex !important}
  .nav-links a{
    padding:18px 0;
    border-bottom:1px solid var(--line);
    font-size:13px;
    letter-spacing:.28em;
    min-height:44px;
  }
  .nav-links a:last-child{border-bottom:none}
}
@media(min-width:781px){.nav-toggle{display:none !important}}

/* ── BACKGROUND HATCH ORBITS (rotating, ambient) ─ */
.hatch-orbit{
  position:fixed;
  z-index:0;
  pointer-events:none;
  color:var(--rust);
  opacity:.06;
  width:200px;height:200px;
}
.hatch-orbit.h1{right:5%;top:30%;transform-origin:center;animation:orbit1 36s linear infinite}
.hatch-orbit.h2{left:3%;bottom:20%;width:140px;height:140px;transform-origin:center;animation:orbit2 28s linear infinite reverse;opacity:.05}
@keyframes orbit1{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
@keyframes orbit2{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
@media(max-width:640px){.hatch-orbit{display:none}}

/* ── BUTTONS ─────────────────────────────────── */
.btn{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:14px 22px;
  border:1px solid var(--paper);
  background:transparent;
  color:var(--paper);
  font-family:'Space Mono',monospace;
  font-size:10px;letter-spacing:.28em;text-transform:uppercase;
  cursor:pointer;
  transition:.25s;
  min-height:44px;
}
.btn:hover{background:var(--paper);color:var(--ink)}
.btn--rust{border-color:var(--rust);color:var(--rust)}
.btn--rust:hover{background:var(--rust);color:var(--paper)}
.btn--brass{border-color:var(--brass);color:var(--brass)}
.btn--brass:hover{background:var(--brass);color:var(--ink)}

/* ── REVEAL + INTERSECTION ───────────────────── */
[data-reveal]{
  opacity:0;
  transform:translateY(36px);
  transition:opacity .9s ease,transform 1s cubic-bezier(.16,1,.3,1);
}
[data-reveal].visible{opacity:1;transform:none}

/* ── SECTION HEAD ────────────────────────────── */
.section-head{
  display:flex;
  flex-direction:column;
  gap:20px;
  padding-bottom:48px;
  border-bottom:1px solid var(--line);
  margin-bottom:60px;
}
.section-head .mono{color:var(--bone)}
.section-head .mono .hatch{font-size:13px}
.section-head h2{
  font-family:'Inter Tight',sans-serif;
  font-weight:200;
  font-size:clamp(48px,7.2vw,108px);
  letter-spacing:-.0075em;
  line-height:.95;
  color:var(--paper);
}
.section-head h2 em{font-style:normal;color:var(--brass);font-weight:300}

/* ── SUBPAGE HERO ────────────────────────────── */
.subhero{
  position:relative;
  padding:200px 0 80px;
  border-bottom:1px solid var(--line);
  background:radial-gradient(ellipse 80% 60% at 50% 30%,#181614 0%,#0a0908 70%,#000 100%);
  overflow:hidden;
}
.subhero::before{
  content:"";
  position:absolute;
  inset:0;
  background:repeating-linear-gradient(0deg,transparent 0 2px,rgba(244,241,234,.018) 2px 3px);
  pointer-events:none;
  animation:scanA 9s linear infinite;
}
@keyframes scanA{0%{background-position:0 0}100%{background-position:0 600px}}
.subhero .container{position:relative;z-index:2}
.subhero__label{
  display:inline-flex;
  align-items:center;
  gap:10px;
  color:var(--bone);
  margin-bottom:36px;
}
.subhero__label .hatch{font-size:14px}
.subhero h1{
  font-family:'Inter Tight',sans-serif;
  font-weight:200;
  font-size:clamp(56px,11vw,180px);
  letter-spacing:-.01em;
  line-height:.92;
  color:var(--paper);
  max-width:1280px;
}
.subhero h1 em{font-style:normal;color:var(--brass);font-weight:300}
.subhero h1 .hatch{font-size:.62em;color:var(--rust);margin:0 .08em}
.subhero__strap{
  margin-top:36px;
  font-size:clamp(16px,1.6vw,22px);
  line-height:1.6;
  color:var(--paper-dim);
  max-width:760px;
}
.subhero__meta{
  margin-top:48px;
  display:flex;
  flex-wrap:wrap;
  gap:32px;
  color:var(--bone);
  font-family:'Space Mono',monospace;
  font-size:11px;
  letter-spacing:.22em;
  text-transform:uppercase;
}
.subhero__meta span .hatch{font-size:11px;color:var(--rust);margin-right:8px}
@media(max-width:640px){
  .subhero{padding:140px 0 60px}
  .subhero__strap{font-size:15px;margin-top:24px}
  .subhero__meta{margin-top:32px;gap:18px;font-size:9px;letter-spacing:.18em}
}

/* ── WALLPAPER HASH PATTERN — section ::before ── */
.has-hash{position:relative;overflow:hidden}
.has-hash::before{
  content:"";
  position:absolute;
  inset:0;
  z-index:0;
  pointer-events:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 800 800'><defs><symbol id='h' viewBox='0 0 24 24'><rect x='3' y='0' width='3' height='24'/><rect x='18' y='0' width='3' height='24'/><rect x='0' y='3' width='24' height='3'/><rect x='0' y='18' width='24' height='3'/></symbol></defs><g fill='%23f4f1ea'><use href='%23h' x='40' y='30' width='14' height='14' opacity='.24' transform='rotate(15 47 37)'/><use href='%23h' x='180' y='50' width='18' height='18' opacity='.22' transform='rotate(42 189 59)'/><use href='%23h' x='320' y='30' width='16' height='16' opacity='.20' transform='rotate(72 328 38)'/><use href='%23h' x='460' y='80' width='20' height='20' opacity='.22' transform='rotate(125 470 90)'/><use href='%23h' x='620' y='30' width='14' height='14' opacity='.26' transform='rotate(8 627 37)'/><use href='%23h' x='730' y='90' width='18' height='18' opacity='.24' transform='rotate(55 739 99)'/><use href='%23h' x='80' y='400' width='16' height='16' opacity='.22' transform='rotate(95 88 408)'/><use href='%23h' x='280' y='350' width='14' height='14' opacity='.24' transform='rotate(150 287 357)'/><use href='%23h' x='550' y='420' width='20' height='20' opacity='.20' transform='rotate(218 560 430)'/><use href='%23h' x='670' y='620' width='14' height='14' opacity='.26' transform='rotate(48 677 627)'/><use href='%23h' x='90' y='720' width='16' height='16' opacity='.24' transform='rotate(280 98 728)'/><use href='%23h' x='250' y='720' width='18' height='18' opacity='.22' transform='rotate(312 259 729)'/><use href='%23h' x='100' y='160' width='32' height='32' opacity='.14' transform='rotate(28 116 176)'/><use href='%23h' x='240' y='180' width='38' height='38' opacity='.12' transform='rotate(108 259 199)'/><use href='%23h' x='420' y='200' width='30' height='30' opacity='.14' transform='rotate(192 435 215)'/><use href='%23h' x='580' y='180' width='42' height='42' opacity='.10' transform='rotate(64 601 201)'/><use href='%23h' x='180' y='480' width='34' height='34' opacity='.12' transform='rotate(142 197 497)'/><use href='%23h' x='370' y='560' width='30' height='30' opacity='.14' transform='rotate(258 385 575)'/><use href='%23h' x='540' y='670' width='42' height='42' opacity='.10' transform='rotate(335 561 691)'/><use href='%23h' x='710' y='320' width='32' height='32' opacity='.13' transform='rotate(82 726 336)'/><use href='%23h' x='220' y='270' width='62' height='62' opacity='.08' transform='rotate(35 251 301)'/><use href='%23h' x='480' y='420' width='66' height='66' opacity='.07' transform='rotate(115 513 453)'/><use href='%23h' x='80' y='560' width='58' height='58' opacity='.08' transform='rotate(202 109 589)'/><use href='%23h' x='620' y='540' width='70' height='70' opacity='.07' transform='rotate(292 655 575)'/><use href='%23h' x='350' y='80' width='56' height='56' opacity='.08' transform='rotate(165 378 108)'/><use href='%23h' x='360' y='360' width='140' height='140' opacity='.05' transform='rotate(15 430 430)'/><use href='%23h' x='10' y='220' width='130' height='130' opacity='.06' transform='rotate(225 75 285)'/><use href='%23h' x='550' y='30' width='150' height='150' opacity='.04' transform='rotate(75 625 105)'/><use href='%23h' x='600' y='620' width='160' height='160' opacity='.05' transform='rotate(170 680 700)'/><use href='%23h' x='40' y='40' width='220' height='220' opacity='.03' transform='rotate(50 150 150)'/></g><g fill='%23b85c2c'><use href='%23h' x='340' y='460' width='30' height='30' opacity='.42' transform='rotate(33 355 475)'/></g></svg>");
  background-size:800px 800px;
  background-repeat:repeat;
  background-position:0 0;
  opacity:.55;
  animation:hashDrift 170s linear infinite;
}
.has-hash--alt::before{
  animation:hashDriftAlt 200s linear infinite reverse -55s;
  opacity:.5;
  background-size:920px 920px;
}
.has-hash > .container{position:relative;z-index:1}
@keyframes hashDrift{0%{background-position:0 0}100%{background-position:800px 800px}}
@keyframes hashDriftAlt{0%{background-position:0 0}100%{background-position:-800px 800px}}

/* ── TEXT DRIFT (subtle) ─────────────────────── */
@keyframes textDrift{0%{transform:translateX(-4px)}50%{transform:translateX(8px)}100%{transform:translateX(-4px)}}
@keyframes textDriftAlt{0%{transform:translateX(6px)}50%{transform:translateX(-6px)}100%{transform:translateX(6px)}}

/* ── DIVIDER BLOCK (decorative break) ────────── */
.div-block{
  position:relative;
  height:140px;
  background:var(--ink);
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  overflow:hidden;
}
.div-block .slab{position:absolute;background:var(--paper);opacity:.05}
.div-block .slab.s1{left:18%;top:30%;width:6px;height:55%}
.div-block .slab.s2{right:24%;top:18%;width:32px;height:62%;background:var(--rust);opacity:.18}
.div-block .div-hatch{position:absolute;color:var(--rust);pointer-events:none;opacity:.55}
.div-block .div-hatch svg{width:100%;height:100%;display:block}
.div-block .div-hatch.dh1{left:6%;top:18%;width:34px;height:34px;transform-origin:center;animation:divHatchA 32s linear infinite}
.div-block .div-hatch.dh2{left:46%;top:42%;width:48px;height:48px;color:var(--brass);opacity:.45;transform-origin:center;animation:divHatchB 38s linear infinite -12s}
.div-block .div-hatch.dh3{right:22%;top:14%;width:28px;height:28px;color:var(--paper);opacity:.40;transform-origin:center;animation:divHatchC 26s linear infinite -7s}
@keyframes divHatchA{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
@keyframes divHatchB{from{transform:rotate(0deg)}to{transform:rotate(-360deg)}}
@keyframes divHatchC{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
@media(max-width:640px){.div-block{height:90px}.div-block .div-hatch.dh3{display:none}}

/* ── SOCIAL ICONS (footer) ───────────────────── */
.socials{
  display:flex;
  flex-wrap:wrap;
  gap:18px;
  justify-content:center;
  margin:48px 0 36px;
  padding:32px 0 26px;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  position:relative;
}
.socials__head{
  position:absolute;
  top:-9px;left:50%;transform:translateX(-50%);
  background:#000;
  padding:0 16px;
  display:inline-flex;
  align-items:center;
  gap:8px;
  color:var(--bone);
}
.socials__head .hatch{font-size:11px}
.social{
  position:relative;
  width:78px;height:78px;
  display:inline-flex;
  align-items:center;justify-content:center;
  border:1px solid var(--line);
  color:var(--paper-dim);
  background:rgba(244,241,234,.02);
  transition:.3s;
}
.social::before{
  content:"";position:absolute;
  left:6px;top:6px;
  width:6px;height:6px;
  background:var(--rust);border-radius:50%;
  box-shadow:0 0 8px var(--rust);
  opacity:.45;
  animation:socialOrbit 6s linear infinite;
  transform-origin:36px 36px;
}
.social:hover{
  color:var(--brass);
  background:rgba(201,169,110,.06);
  border-color:var(--brass);
  transform:translateY(-2px);
}
.social:hover::before{opacity:.55;border-color:var(--brass)}
.social svg{width:34px;height:34px;display:block;position:relative;z-index:1}
.social__label{
  position:absolute;
  bottom:-22px;left:0;right:0;
  text-align:center;
  font-family:'Space Mono',monospace;
  font-size:8px;letter-spacing:.28em;text-transform:uppercase;
  color:var(--bone);
  transition:opacity .25s;
  opacity:0;
}
.social:hover .social__label{opacity:1}
.social[data-edge]{border-color:var(--rust);color:var(--rust)}
.social[data-edge]::before{border-color:var(--rust);opacity:.4}
@keyframes socialOrbit{
  0%   {transform:rotate(0)   translateX(34px) rotate(0);   opacity:.30}
  50%  {transform:rotate(180deg) translateX(34px) rotate(-180deg); opacity:.65}
  100% {transform:rotate(360deg) translateX(34px) rotate(-360deg); opacity:.30}
}
@media(max-width:640px){
  .socials{gap:12px;margin:36px 0 24px}
  .social{width:64px;height:64px}
  .social svg{width:26px;height:26px}
}

/* ── FOOTER ───────────────────────────────────── */
footer{padding:80px 0 32px;border-top:1px solid var(--line);background:#000;overflow:hidden;position:relative}
footer::before{
  content:"";
  position:absolute;
  inset:0;
  z-index:0;
  pointer-events:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 800 800'><defs><symbol id='h' viewBox='0 0 24 24'><rect x='3' y='0' width='3' height='24'/><rect x='18' y='0' width='3' height='24'/><rect x='0' y='3' width='24' height='3'/><rect x='0' y='18' width='24' height='3'/></symbol></defs><g fill='%23f4f1ea'><use href='%23h' x='100' y='100' width='32' height='32' opacity='.10' transform='rotate(28 116 116)'/><use href='%23h' x='420' y='200' width='44' height='44' opacity='.08' transform='rotate(192 442 222)'/><use href='%23h' x='620' y='480' width='38' height='38' opacity='.10' transform='rotate(64 639 499)'/><use href='%23h' x='180' y='580' width='56' height='56' opacity='.06' transform='rotate(142 208 608)'/><use href='%23h' x='480' y='640' width='40' height='40' opacity='.08' transform='rotate(258 500 660)'/></g></svg>");
  background-size:980px 980px;
  background-repeat:repeat;
  opacity:.45;
  animation:hashDriftAlt 220s linear infinite -200s;
}
footer > .container{position:relative;z-index:1}
.foot-mark{
  font-family:'Inter Tight',sans-serif;
  font-weight:200;
  font-size:clamp(96px,21vw,330px);
  letter-spacing:.12em;
  text-transform:uppercase;
  line-height:.85;
  color:var(--paper);
  text-align:center;margin-bottom:48px;
  position:relative;
  display:flex;align-items:center;justify-content:center;gap:.16em;
}
.foot-mark .hatch{font-size:.55em;font-size:1cap;color:var(--rust)}
footer .grid{
  display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:48px;
  margin-bottom:64px;
  border-top:1px solid var(--line);padding-top:48px;
}
footer h5{
  font-family:'Space Mono',monospace;
  font-size:10px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--brass);margin-bottom:18px;
}
footer ul{list-style:none;display:flex;flex-direction:column;gap:8px}
footer li{font-size:13px;color:var(--bone)}
footer li a:hover{color:var(--paper)}
footer .colophon{
  border-top:1px solid var(--line);padding-top:24px;
  display:flex;justify-content:space-between;color:var(--bone);
  flex-wrap:wrap;gap:16px;
}
@media(max-width:900px){footer .grid{grid-template-columns:1fr 1fr;gap:32px}}
@media(max-width:640px){
  footer{padding:60px 0 24px;overflow:hidden;max-width:100vw}
  footer .container{overflow:hidden;max-width:100%;box-sizing:border-box}
  .foot-mark{
    font-size:clamp(34px,11vw,90px);
    margin-bottom:24px;
    letter-spacing:.04em;
    gap:.08em;
    max-width:100%;
    padding:0 8px;
    box-sizing:border-box;
    white-space:nowrap;
    overflow:hidden;
  }
  .foot-mark .hatch{font-size:.55em !important;font-size:1cap !important}
  footer .grid{grid-template-columns:1fr;gap:28px;padding-top:32px;margin-bottom:36px}
  footer .colophon{flex-direction:column;align-items:flex-start;gap:8px;font-size:10px}
  .ticker__track{gap:32px}
  .ticker__track > span{gap:32px}
}
@media(max-width:420px){
  .foot-mark{font-size:clamp(28px,9.5vw,64px);letter-spacing:.02em;gap:.06em}
  .foot-mark .hatch{font-size:.5em !important;font-size:1cap !important}
}

/* ── SMALLPRINT — fine-print legal/nav row at very bottom of footer ── */
.smallprint{
  margin-top:24px;
  padding-top:20px;
  border-top:1px solid var(--line);
  text-align:center;
  font-family:'Space Mono',ui-monospace,monospace;
  font-size:9px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:rgba(244,241,234,.42);
  line-height:1.9;
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  align-items:center;
  gap:2px 8px;
}
.smallprint a{
  color:inherit;
  border-bottom:1px solid transparent;
  transition:color .25s,border-color .25s;
  padding:1px 0;
}
.smallprint a:hover{
  color:var(--paper);
  border-bottom-color:var(--brass);
}
.smallprint .sep{
  color:var(--rust);
  opacity:.55;
  font-size:10px;
  user-select:none;
}
.smallprint .sep--em{
  color:var(--rust);
  opacity:.75;
  margin:0 4px;
  font-size:9px;
}
.smallprint .reg,
.smallprint .copy{color:rgba(244,241,234,.55)}
.smallprint .reg strong{color:var(--paper);font-weight:400}
@media(max-width:640px){
  .smallprint{
    font-size:8px;
    letter-spacing:.18em;
    gap:1px 6px;
    line-height:2.1;
    padding-top:18px;
  }
  .smallprint .sep{font-size:9px}
}
@media(max-width:420px){
  .smallprint{font-size:7.5px;letter-spacing:.14em;gap:0 5px}
}

/* ── REDUCED MOTION ──────────────────────────── */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:.001ms !important;
    animation-iteration-count:1 !important;
    transition-duration:.01ms !important;
  }
  .ticker__track,.hatch-orbit,.has-hash::before,.div-hatch{animation:none !important}
}
