/* ==========================================================================
   IIG — styles.css   (Brand Package v1.0)
   Order: tokens → reset → base → layout → header → hero → components → footer
   → utilities → responsive → reduced-motion
   Token source of truth: docs/brand/design-tokens.md
   ========================================================================== */

/* --- Tokens ------------------------------------------------------------- */
:root{
  --c-ink:#0E1B2C; --c-gold:#C9A961; --c-steel:#2E5A88; --c-cream:#F5F2EC;
  --c-paper:#FBFAF6; --c-hair:#E2DCCE; --c-ink60:#3A4A5E; --c-sage:#7FA88F;
  --c-white:#FFFFFF;
  /* dark-surface helpers */
  --c-ink-2:#13243A; --c-ink-low:#0A1726; --c-ink-line:rgba(201,169,97,.22); --c-on-ink:#E8EDF3; --c-on-ink-dim:#A9B7C5;

  --font-display:"Space Grotesk","Inter",system-ui,sans-serif;
  --font-sans:"Inter",system-ui,"Helvetica Neue",Arial,sans-serif;
  --font-mono:"JetBrains Mono",ui-monospace,SFMono-Regular,Menlo,monospace;

  --fs-hero:3.5rem; --fs-900:2.75rem; --fs-800:2.25rem; --fs-700:1.75rem;
  --fs-600:1.375rem; --fs-500:1.125rem; --fs-400:1rem; --fs-300:.875rem; --fs-200:.75rem;
  --lh-tight:1.08; --lh-snug:1.25; --lh-body:1.6;

  --sp-1:.5rem; --sp-2:1rem; --sp-3:1.5rem; --sp-4:2rem; --sp-5:3rem;
  --sp-6:4rem; --sp-7:6rem; --sp-8:8rem;

  --maxw:1200px; --maxw-narrow:720px;
  --radius:12px; --radius-sm:8px;
  --border:1px solid var(--c-hair);
  --shadow:0 1px 2px rgba(14,27,44,.05),0 12px 32px rgba(14,27,44,.10);
  --ease:cubic-bezier(.2,.6,.2,1); --dur:220ms;
}

/* --- Reset -------------------------------------------------------------- */
*,*::before,*::after{box-sizing:border-box}
*{margin:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
ul{list-style:none;padding:0}
button{font:inherit;cursor:pointer;color:inherit}

/* --- Base --------------------------------------------------------------- */
body{
  font-family:var(--font-sans);font-size:var(--fs-400);line-height:var(--lh-body);
  color:var(--c-on-ink);background:var(--c-ink-low);-webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4{font-family:var(--font-display);line-height:var(--lh-tight);
  font-weight:700;letter-spacing:-.02em;color:var(--c-white)}
:focus-visible{outline:3px solid var(--c-gold);outline-offset:3px;border-radius:3px}
::selection{background:var(--c-gold);color:var(--c-ink)}

/* --- Layout ------------------------------------------------------------- */
.container{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:var(--sp-3)}
.section{padding-block:var(--sp-7)}
.section--tight{padding-block:var(--sp-5)}
.skip-link{position:absolute;left:-999px;top:0;z-index:200;background:var(--c-gold);
  color:var(--c-ink);font-weight:600;padding:.6rem 1rem;border-radius:0 0 var(--radius-sm) 0}
.skip-link:focus{left:0}

/* surfaces — three dark shades for section rhythm */
.surf-base{background:var(--c-ink)}
.surf-low{background:var(--c-ink-low)}
.surf-high{background:var(--c-ink-2)}
.band-ink{background:var(--c-ink)}      /* legacy alias */
.band-paper{background:var(--c-ink-2)}  /* legacy alias (now dark) */

/* --- Shared bits -------------------------------------------------------- */
.eyebrow{font-family:var(--font-mono);font-size:var(--fs-200);letter-spacing:.22em;
  text-transform:uppercase;color:var(--c-gold);margin-bottom:var(--sp-2)}
.section__head{max-width:var(--maxw-narrow);margin-bottom:var(--sp-5)}
.section__title{font-size:var(--fs-800);margin-bottom:var(--sp-2)}
.section__lead{font-size:var(--fs-500);color:var(--c-on-ink-dim)}
.rule{height:2px;width:64px;background:var(--c-gold);border:0;margin:var(--sp-3) 0}

/* icons */
.ico{display:inline-flex;align-items:center;justify-content:center;width:1.5em;height:1.5em;flex:none}
.ico svg,.ico-svg{width:100%;height:100%;display:block}
.mate .ico,.sector .ico{display:flex}

/* --- Buttons ------------------------------------------------------------ */
.btn{display:inline-flex;align-items:center;gap:.55rem;font-family:var(--font-sans);
  font-weight:600;font-size:var(--fs-300);padding:.78rem 1.25rem;border-radius:var(--radius-sm);
  border:1.5px solid transparent;transition:transform var(--dur) var(--ease),
  background var(--dur) var(--ease),border-color var(--dur) var(--ease),color var(--dur) var(--ease)}
.btn .ico{width:1.05em;height:1.05em}
.btn:hover{transform:translateY(-1px)}
.btn--primary{background:var(--c-gold);color:var(--c-ink)}
.btn--primary:hover{background:#d8b977}
.btn--ghost{border-color:var(--c-ink);color:var(--c-ink);background:transparent}
.btn--ghost:hover{background:var(--c-ink);color:var(--c-cream)}
.btn--on-ink{border-color:rgba(232,237,243,.3);color:var(--c-on-ink);background:transparent}
.btn--on-ink:hover{border-color:var(--c-gold);color:var(--c-white)}
/* Keep button text colors from being overridden by .nav__links a (specificity fix) */
.nav__links .btn--primary,.nav__links .btn--primary:hover{color:var(--c-ink)}
.nav__links .btn--on-ink:hover{color:var(--c-white)}

/* --- Header / nav ------------------------------------------------------- */
.site-header{position:sticky;top:0;z-index:100;background:rgba(14,27,44,.92);
  backdrop-filter:saturate(140%) blur(10px);border-bottom:1px solid var(--c-ink-line);color:var(--c-on-ink)}
.nav{display:flex;align-items:center;gap:var(--sp-4);height:68px}
.nav__logo{color:var(--c-white);display:inline-flex}
.nav__logo img{height:32px;width:auto}
.nav__links{display:flex;gap:var(--sp-3);margin-left:auto;align-items:center}
.nav__links a{font-size:var(--fs-300);color:var(--c-on-ink-dim);font-weight:500;
  transition:color var(--dur) var(--ease)}
.nav__links a:hover{color:var(--c-white)}
.nav__toggle{display:none;background:none;border:0;padding:.5rem;color:var(--c-on-ink)}
.nav__toggle svg{height:24px;width:24px}

/* --- Hero (dark, dramatic) --------------------------------------------- */
.hero{position:relative;background:var(--c-ink);color:var(--c-on-ink);overflow:hidden;
  padding-block:var(--sp-7) var(--sp-6)}
.hero__bg{position:absolute;inset:0;z-index:0;pointer-events:none}
.hero__bg::before{content:"";position:absolute;inset:0;
  background:radial-gradient(58% 70% at 82% 12%,rgba(201,169,97,.16),transparent 62%)}
.hero__grid{position:absolute;inset:0;opacity:.5;
  background-image:linear-gradient(var(--c-ink-line) 1px,transparent 1px),
    linear-gradient(90deg,var(--c-ink-line) 1px,transparent 1px);
  background-size:34px 34px;
  mask-image:radial-gradient(70% 70% at 75% 20%,#000,transparent 80%);
  -webkit-mask-image:radial-gradient(70% 70% at 75% 20%,#000,transparent 80%)}
.hero .container{position:relative;z-index:1}
.hero__layout{display:grid;grid-template-columns:1.05fr .95fr;gap:var(--sp-5);align-items:center}
.hero h1{font-size:var(--fs-hero);color:var(--c-white);margin-bottom:var(--sp-3)}
.hero h1 .accent{color:var(--c-gold);display:block}
.hero__sub{font-size:var(--fs-500);color:var(--c-on-ink-dim);max-width:52ch;margin-bottom:var(--sp-4)}
.hero__cta{display:flex;gap:var(--sp-2);flex-wrap:wrap}

/* validation score card */
.score{position:relative;background:var(--c-ink-2);border:1px solid var(--c-ink-line);
  border-radius:var(--radius);padding:var(--sp-4);box-shadow:0 24px 60px rgba(0,0,0,.35)}
.score__label{font-family:var(--font-mono);font-size:var(--fs-200);letter-spacing:.18em;
  text-transform:uppercase;color:var(--c-on-ink-dim)}
.score__value{font-family:var(--font-display);font-weight:700;font-size:3.25rem;color:var(--c-white);
  line-height:1;margin:.4rem 0 .2rem}
.score__value span{color:var(--c-gold);font-size:1.5rem}
.score__bar{margin-top:var(--sp-3);height:auto}
.score__bar svg{width:100%;height:48px;display:block}
.score__foot{display:flex;justify-content:space-between;margin-top:var(--sp-3);
  font-family:var(--font-mono);font-size:var(--fs-200);color:var(--c-sage);letter-spacing:.05em}

/* --- KPI ticker (hero marquee) ----------------------------------------- */
.ticker{position:relative;margin-top:var(--sp-6);border-top:1px solid var(--c-ink-line);border-bottom:1px solid var(--c-ink-line);
  overflow:hidden;background:rgba(19,36,58,.4)}
/* fade edges */
.ticker::before,.ticker::after{content:"";position:absolute;top:0;bottom:0;width:80px;z-index:2;pointer-events:none}
.ticker::before{left:0;background:linear-gradient(90deg,var(--c-ink),transparent)}
.ticker::after{right:0;background:linear-gradient(270deg,var(--c-ink),transparent)}
.ticker__track{display:flex;align-items:center;width:max-content;gap:var(--sp-5);padding:var(--sp-3) var(--sp-4)}
.kpi{display:flex;align-items:center;gap:.7rem;white-space:nowrap;
  padding-right:var(--sp-5);border-right:1px solid var(--c-ink-line)}
.kpi__label{font-family:var(--font-mono);font-size:var(--fs-200);letter-spacing:.14em;
  text-transform:uppercase;color:var(--c-on-ink-dim)}
.kpi__value{font-family:var(--font-display);font-weight:700;font-size:1.5rem;color:var(--c-white);line-height:1}
.kpi__value small{font-size:.8rem;color:var(--c-gold);font-weight:500;margin-left:1px}
.kpi__spark{width:80px;height:24px}
@media (prefers-reduced-motion:no-preference){
  .ticker__track{animation:iig-marquee 38s linear infinite}
  .ticker:hover .ticker__track{animation-play-state:paused}
  @keyframes iig-marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
}
@media (prefers-reduced-motion:reduce){
  .ticker{overflow-x:auto}
}

/* --- Product lines (mates) --------------------------------------------- */
.mates{display:grid;grid-template-columns:repeat(5,1fr);gap:var(--sp-3)}
.mate{background:var(--c-ink);border:1px solid var(--c-ink-line);border-top:3px solid var(--c-gold);
  border-radius:var(--radius);padding:var(--sp-4);
  transition:transform var(--dur) var(--ease),box-shadow var(--dur) var(--ease),border-color var(--dur) var(--ease)}
.mate:hover{transform:translateY(-4px);box-shadow:0 18px 40px rgba(0,0,0,.35)}
.mate .ico{width:2rem;height:2rem;color:var(--c-gold);margin-bottom:var(--sp-2)}
.mate__name{font-size:var(--fs-600);margin-bottom:.15rem}
.mate__tag{font-family:var(--font-mono);font-size:var(--fs-200);letter-spacing:.08em;
  text-transform:uppercase;color:var(--c-gold)}
.mate__body{color:var(--c-on-ink-dim);margin-top:var(--sp-2);font-size:var(--fs-300)}

/* --- Sectors (dark band, gold icons) ----------------------------------- */
.sectors{display:grid;grid-template-columns:repeat(6,1fr);gap:var(--sp-3)}
.sector{display:flex;flex-direction:column;align-items:center;text-align:center;gap:.6rem;
  padding:var(--sp-3) var(--sp-1);border:1px solid var(--c-ink-line);border-radius:var(--radius);
  background:var(--c-ink-2)}
.sector .ico{width:2rem;height:2rem;color:var(--c-gold)}
.sector span{font-size:var(--fs-300);color:var(--c-on-ink)}

/* --- How it works steps ------------------------------------------------- */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--sp-4)}
.step{border-top:2px solid var(--c-gold);padding-top:var(--sp-3)}
.step__n{font-family:var(--font-mono);font-size:var(--fs-200);letter-spacing:.12em;color:var(--c-gold)}
.step__t{font-size:var(--fs-600);margin:.3rem 0}
.step__b{color:var(--c-on-ink-dim)}

/* --- Stats -------------------------------------------------------------- */
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--sp-4)}
.stat{border-left:3px solid var(--c-gold);padding-left:var(--sp-3)}
.stat__value{display:block;font-family:var(--font-display);font-weight:700;font-size:var(--fs-900);
  color:var(--c-white);line-height:1}
.stat__label{color:var(--c-on-ink-dim);font-size:var(--fs-300);margin-top:.4rem}

/* --- CTA band ----------------------------------------------------------- */
.cta{text-align:center}
.cta h2{font-size:var(--fs-800);margin-bottom:var(--sp-2)}
.cta p{color:var(--c-on-ink-dim);max-width:54ch;margin:0 auto var(--sp-4)}

/* --- Footer ------------------------------------------------------------- */
.site-footer{background:var(--c-ink);color:var(--c-on-ink-dim);padding-block:var(--sp-6) var(--sp-4);
  border-top:1px solid var(--c-ink-line)}
.footer__top{display:grid;grid-template-columns:1.7fr repeat(3,1fr);gap:var(--sp-4)}
.footer__brand .nav__logo{color:var(--c-white)}
.footer__brand .nav__logo img,.footer__brand .nav__logo svg{height:36px}
.footer__org{font-style:normal;margin-top:var(--sp-2);font-size:var(--fs-300);line-height:1.8;color:var(--c-on-ink-dim)}
.footer__org strong{color:var(--c-white);font-weight:600}
.footer__org a{color:var(--c-gold)}
.footer__legalrow{display:flex;flex-wrap:wrap;gap:.4rem var(--sp-2);font-size:var(--fs-300)}
.footer__legalrow a{color:var(--c-on-ink-dim)} .footer__legalrow a:hover{color:var(--c-white)}
.footer__tag{margin-top:var(--sp-2);font-size:var(--fs-300);max-width:34ch;color:var(--c-on-ink-dim)}
.site-footer h4{color:var(--c-white);font-family:var(--font-mono);font-size:var(--fs-200);
  text-transform:uppercase;letter-spacing:.14em;margin-bottom:var(--sp-2);font-weight:500}
.footer__top > div:not(.footer__brand):not(.footer__social) a{display:block;font-size:var(--fs-300);line-height:2;color:var(--c-on-ink-dim)}
.footer__top > div:not(.footer__brand) a:hover{color:var(--c-white)}
.footer__bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:var(--sp-2);
  margin-top:var(--sp-5);padding-top:var(--sp-3);border-top:1px solid var(--c-ink-line);
  font-family:var(--font-mono);font-size:var(--fs-200);letter-spacing:.08em;color:var(--c-on-ink-dim)}
.footer__bottom .motto{color:var(--c-gold)}

/* --- Footer social / email icons --------------------------------------- */
.footer__social a{display:flex;align-items:center;gap:.55rem;font-size:var(--fs-300);line-height:2;white-space:nowrap}
.footer__social .ico{width:1.05em;height:1.05em;color:var(--c-gold);flex:none}
.footer__org a{display:inline-flex;align-items:center;gap:.4rem}
.footer__org a .ico{width:1em;height:1em;color:var(--c-gold);flex:none}
.cta__fallback{margin-top:var(--sp-2);font-size:var(--fs-300);color:var(--c-on-ink-dim)}
.cta__fallback a{color:var(--c-gold);text-decoration:underline}

/* --- Dialog (request access) ------------------------------------------- */
.dialog{margin:auto;border:1px solid var(--c-ink-line);border-radius:var(--radius);padding:0;max-width:520px;width:calc(100% - 2rem);
  max-height:calc(100dvh - 2rem);background:var(--c-ink-2);color:var(--c-on-ink);box-shadow:0 24px 80px rgba(0,0,0,.5)}
.dialog::backdrop{background:rgba(6,12,20,.7);backdrop-filter:blur(3px)}
.dialog__form{padding:var(--sp-4)}
.dialog__head{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--sp-2)}
.dialog__head h2{font-size:var(--fs-700)}
.dialog__close{background:none;border:0;color:var(--c-on-ink-dim);padding:.25rem;line-height:0;border-radius:var(--radius-sm)}
.dialog__close .ico{width:1.5rem;height:1.5rem}
.dialog__close:hover{color:var(--c-white)}
.dialog__intro{color:var(--c-on-ink-dim);font-size:var(--fs-300);margin:.25rem 0 var(--sp-3)}
.field{margin-bottom:var(--sp-2)}
.field label{display:block;font-size:var(--fs-300);font-weight:600;margin-bottom:.3rem;color:var(--c-on-ink)}
.field .req{color:var(--c-gold)} .field .opt{color:var(--c-on-ink-dim);font-weight:400}
.field input,.field textarea{width:100%;font:inherit;font-size:var(--fs-400);color:var(--c-white);
  background:var(--c-ink);border:1px solid var(--c-ink-line);border-radius:var(--radius-sm);
  padding:.6rem .7rem;transition:border-color var(--dur) var(--ease)}
.field input::placeholder,.field textarea::placeholder{color:var(--c-on-ink-dim)}
.field input:focus,.field textarea:focus{border-color:var(--c-gold);outline:3px solid var(--c-gold);outline-offset:1px}
.field input[aria-invalid="true"],.field textarea[aria-invalid="true"]{border-color:#FF6B6B}
.field__err{color:#FF8A8A;font-size:var(--fs-300);margin-top:.3rem}
.dialog__status{min-height:1.2em;font-size:var(--fs-300);color:var(--c-on-ink-dim);margin:var(--sp-2) 0 0}
.dialog__actions{display:flex;justify-content:flex-end;gap:var(--sp-2);margin-top:var(--sp-3)}

/* --- Cookie banner ------------------------------------------------------ */
.cookie{position:fixed;left:0;right:0;bottom:0;z-index:150;background:var(--c-ink-2);
  border-top:2px solid var(--c-gold);box-shadow:0 -12px 40px rgba(0,0,0,.4);color:var(--c-on-ink)}
.cookie[hidden]{display:none}
.cookie__inner{max-width:var(--maxw);margin-inline:auto;padding:var(--sp-3) var(--sp-3);
  display:flex;align-items:center;gap:var(--sp-4);flex-wrap:wrap}
.cookie__title{font-family:var(--font-display);font-weight:700;color:var(--c-white);margin-bottom:.2rem}
.cookie__desc{font-size:var(--fs-300);color:var(--c-on-ink-dim);max-width:70ch}
.cookie__desc a{color:var(--c-gold);text-decoration:underline}
.cookie__actions{display:flex;gap:var(--sp-2);margin-left:auto;flex-wrap:wrap}

/* --- Legal pages (dark theme, matches site) ----------------------------- */
.legal-page{background:var(--c-ink);color:var(--c-on-ink)}
.legal-back{margin-left:auto;font-size:var(--fs-300);color:var(--c-on-ink-dim)}
.legal-back:hover{color:var(--c-white)}
.legal{padding-block:var(--sp-6) var(--sp-7)}
.legal .container{max-width:var(--maxw-narrow)}
.legal h1{font-size:var(--fs-900);margin-bottom:var(--sp-1);color:var(--c-white)}
.legal h2{font-size:var(--fs-600);margin-top:var(--sp-4);margin-bottom:var(--sp-1);color:var(--c-white)}
.legal .updated{font-family:var(--font-mono);font-size:var(--fs-200);letter-spacing:.08em;
  text-transform:uppercase;color:var(--c-on-ink-dim);margin-bottom:var(--sp-3)}
.legal p{margin-bottom:var(--sp-2);color:var(--c-on-ink)}
.legal ul{margin:0 0 var(--sp-2) 1.2rem;list-style:disc} .legal li{margin-bottom:.4rem;color:var(--c-on-ink)}
.legal strong{color:var(--c-white)}
.legal a{color:var(--c-gold);text-decoration:underline}
.legal table{width:100%;border-collapse:collapse;margin:var(--sp-2) 0 var(--sp-3);font-size:var(--fs-300)}
.legal th,.legal td{text-align:left;padding:.6rem .75rem;border:1px solid var(--c-ink-line);vertical-align:top;color:var(--c-on-ink)}
.legal th{font-family:var(--font-mono);font-size:var(--fs-200);text-transform:uppercase;
  letter-spacing:.06em;background:var(--c-ink-2);color:var(--c-white)}

/* --- Reveal ------------------------------------------------------------- */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.reveal.is-in{opacity:1;transform:none}

/* --- Animations (only when motion is welcome; never hide content otherwise) */
@media (prefers-reduced-motion:no-preference){
  /* Hero entrance on load, lightly staggered (transform/opacity only) */
  .hero .eyebrow,.hero h1,.hero__sub,.hero__cta,.score{opacity:0;animation:iig-rise .7s var(--ease) both}
  .hero .eyebrow{animation-delay:.05s}
  .hero h1{animation-delay:.13s}
  .hero__sub{animation-delay:.24s}
  .hero__cta{animation-delay:.34s}
  .score{animation-delay:.42s}
  @keyframes iig-rise{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}

  /* Staggered children inside revealed grids */
  .mates .mate,.sectors .sector,.steps .step,.stats .stat{opacity:0;transform:translateY(14px);
    transition:opacity .5s var(--ease),transform .5s var(--ease)}
  .mates.is-in .mate,.sectors.is-in .sector,.steps.is-in .step,.stats.is-in .stat{opacity:1;transform:none}
  .mates.is-in .mate:nth-child(2),.sectors.is-in .sector:nth-child(2),.steps.is-in .step:nth-child(2),.stats.is-in .stat:nth-child(2){transition-delay:.08s}
  .mates.is-in .mate:nth-child(3),.sectors.is-in .sector:nth-child(3),.steps.is-in .step:nth-child(3),.stats.is-in .stat:nth-child(3){transition-delay:.16s}
  .mates.is-in .mate:nth-child(4),.sectors.is-in .sector:nth-child(4){transition-delay:.24s}
  .sectors.is-in .sector:nth-child(5){transition-delay:.32s}
  .sectors.is-in .sector:nth-child(6){transition-delay:.4s}

  /* Validation-score line draws in */
  .score__bar polyline{stroke-dasharray:640;stroke-dashoffset:640;animation:iig-draw 1.5s var(--ease) .5s forwards}
  @keyframes iig-draw{to{stroke-dashoffset:0}}

  /* Subtle lift on the score card hover */
  .score{transition:transform var(--dur) var(--ease),box-shadow var(--dur) var(--ease)}
  .score:hover{transform:translateY(-3px)}
}

/* --- Utilities ---------------------------------------------------------- */
.mono{font-family:var(--font-mono)}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;
  clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* --- Responsive --------------------------------------------------------- */
@media (max-width:980px){
  .hero__layout{grid-template-columns:1fr;gap:var(--sp-4)}
  .mates{grid-template-columns:repeat(2,1fr)}
  .sectors{grid-template-columns:repeat(3,1fr)}
  .footer__top{grid-template-columns:1fr 1fr}
  .cookie__actions{margin-left:0}
}
@media (max-width:680px){
  :root{--fs-hero:2.5rem;--fs-900:2rem;--fs-800:1.875rem}
  .section{padding-block:var(--sp-5)}
  .hero{padding-block:var(--sp-5) var(--sp-5)}
  .mates,.sectors,.steps,.stats,.footer__top{grid-template-columns:1fr}
  .sectors{grid-template-columns:repeat(2,1fr)}
  .trust ul{margin-left:0}
  .nav__toggle{display:inline-flex;margin-left:auto}
  .nav__links{position:fixed;inset:68px 0 auto 0;flex-direction:column;align-items:flex-start;
    gap:0;background:var(--c-ink);padding:var(--sp-2) var(--sp-3);
    border-bottom:1px solid var(--c-ink-line);display:none}
  .nav__links.is-open{display:flex}
  .nav__links a{padding:.7rem 0;width:100%}
  .nav__links .btn{margin-top:var(--sp-1)}
}
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  .reveal{opacity:1;transform:none;transition:none}
  .btn:hover,.mate:hover{transform:none}
}
