/* =====================================================================
   BIDODI — base.css
   Design tokens, shared header/footer, the polymorphic-acronym decoder,
   layout primitives, buttons. Palette derived from logo.png (navy + steel).
   ===================================================================== */

/* ---------- Fonts (CDN) loaded in each page <head> ---------- */
/* Inter (UI/body) + IBM Plex Mono (labels, badges, the acronym letters) */

/* ---------- Design tokens ---------- */
:root{
  /* Dark theme palette (logo navy/steel family, inverted for a dark UI) */
  --ink:        #eef2f8;   /* near-white — headings */
  --navy:       #5a82d8;   /* primary brand accent (buttons, acronym letters) */
  --navy-deep:  #2c447a;
  --blue:       #6f9bf0;   /* interactive / links */
  --blue-bright:#9bbcf7;   /* hover / focus glow */
  --steel:      #95a1b9;   /* muted body text */
  --silver:     #c2cad8;   /* chrome echo from logo lock */
  --line:       #25324a;   /* hairline borders */
  --line-soft:  #1b2538;
  --paper:      #0b1018;   /* page background */
  --surface:    #131c2c;   /* cards / raised panels */
  --surface-2:  #182234;
  --text:       #c7cfdd;   /* default body */
  --text-soft:  #95a1b9;

  /* Pillar accents (one per pillar, all in-family, lifted for dark) */
  --p1: #6f93d6;   /* Integrating Governance */
  --p2: #5aa6db;   /* Validating Defense */
  --p3: #97a4c6;   /* Securing Trust */

  /* Type */
  --sans: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  --mono: "IBM Plex Mono", ui-monospace, "SFMono-Regular", Menlo, monospace;

  /* Radii + shadow + motion */
  --r-sm: 8px;
  --r:    12px;
  --r-lg: 18px;
  --shadow-sm: 0 1px 2px rgba(0,0,0,.35), 0 1px 3px rgba(0,0,0,.30);
  --shadow:    0 4px 16px rgba(0,0,0,.45), 0 1px 3px rgba(0,0,0,.35);
  --shadow-lg: 0 18px 48px rgba(0,0,0,.60);
  --ease: cubic-bezier(.2,.7,.2,1);

  --maxw: 1140px;
  --gut: clamp(20px, 5vw, 40px);
}

/* ---------- Reset-ish ---------- */
*,*::before,*::after{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
@media (prefers-reduced-motion: reduce){
  html{ scroll-behavior:auto; }
  *,*::before,*::after{ animation-duration:.001ms!important; transition-duration:.001ms!important; }
}
body{
  margin:0;
  font-family:var(--sans);
  color:var(--text);
  background:var(--paper);
  line-height:1.6;
  font-size:16px;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{ max-width:100%; display:block; }
a{ color:var(--blue); text-decoration:none; }
a:hover{ color:var(--blue-bright); }
h1,h2,h3,h4{ color:var(--ink); line-height:1.15; letter-spacing:-.012em; margin:0; font-weight:700; }
p{ margin:0 0 1rem; }
:focus-visible{ outline:2px solid var(--blue-bright); outline-offset:3px; border-radius:4px; }

/* ---------- Layout primitives ---------- */
.container{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gut); }
.section{ padding-block:clamp(22px, 3.6vw, 42px); }
.section--tight{ padding-block:clamp(24px, 3.6vw, 43px); }
.section--alt{ background:var(--surface); border-block:1px solid var(--line); }
.stack > * + *{ margin-top:1rem; }
.center{ text-align:center; }
.measure{ max-width:64ch; }
.measure-narrow{ max-width:52ch; }

/* eyebrow label (mono) */
.eyebrow{
  font-family:var(--mono);
  font-size:.92rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--blue);
  font-weight:500;
  display:inline-flex; align-items:center; gap:.55rem;
  margin:0 0 .9rem;
}
.eyebrow::before{
  content:""; width:22px; height:1px; background:var(--silver); display:inline-block;
}

/* section heading block */
.section-head{ max-width:62ch; margin-bottom:clamp(28px,4vw,48px); }
.section-head h2{ font-size:clamp(1.55rem, 3.2vw, 2.15rem); }
.section-head p{ color:var(--text-soft); font-size:1.05rem; margin-top:.65rem; }

/* type scale helpers */
.lead{ font-size:clamp(1.05rem,1.6vw,1.22rem); color:var(--text-soft); }
.small{ font-size:.9rem; }
.tag{
  font-family:var(--mono); font-size:.7rem; letter-spacing:.12em; text-transform:uppercase;
  color:var(--steel); background:var(--surface-2); border:1px solid var(--line);
  padding:.28rem .55rem; border-radius:6px; display:inline-block;
}

/* ---------- Buttons ---------- */
.btn{
  --bg:var(--navy); --fg:#fff; --bd:var(--navy);
  display:inline-flex; align-items:center; gap:.5rem;
  font-family:var(--sans); font-weight:600; font-size:.95rem; line-height:1;
  padding:.8rem 1.15rem; border-radius:var(--r-sm);
  background:var(--bg); color:var(--fg); border:1px solid var(--bd);
  cursor:pointer; transition:transform .15s var(--ease), box-shadow .2s var(--ease), background .2s var(--ease);
  box-shadow:var(--shadow-sm); white-space:nowrap;
}
.btn:hover{ color:#fff; background:var(--blue); border-color:var(--blue); transform:translateY(-1px); box-shadow:var(--shadow); }
.btn:active{ transform:translateY(0); }
.btn .arrow{ transition:transform .2s var(--ease); }
.btn:hover .arrow{ transform:translateX(3px); }
.btn--ghost{ --bg:transparent; --fg:var(--navy); --bd:var(--line); box-shadow:none; }
.btn--ghost:hover{ background:var(--surface-2); color:var(--navy); border-color:var(--silver); }
.btn--lg{ padding:.95rem 1.45rem; font-size:1rem; }
.btn-row{ display:flex; flex-wrap:wrap; gap:.75rem; }

/* ---------- Header ---------- */
.site-header{
  position:sticky; top:0; z-index:60;
  background:rgba(11,16,24,.82);
  backdrop-filter:saturate(140%) blur(12px);
  border-bottom:1px solid var(--line);
}
.site-header .bar{
  display:flex; align-items:center; gap:1.5rem;
  height:66px;
}
.brand{ display:flex; align-items:center; gap:.6rem; margin-right:auto; }
.brand img{ height:30px; width:auto; }
.brand .brand-sub{
  font-family:var(--mono); font-size:.62rem; letter-spacing:.14em; text-transform:uppercase;
  color:var(--steel); border-left:1px solid var(--line); padding-left:.6rem; line-height:1.25;
}
.nav{ display:flex; align-items:center; gap:.35rem; }
.nav a{
  font-size:.92rem; font-weight:500; color:var(--steel);
  padding:.5rem .7rem; border-radius:7px; transition:color .15s, background .15s;
  position:relative;
}
.nav a:hover{ color:var(--ink); background:var(--surface-2); }
.nav a.active{ color:var(--navy); }   /* same weight as inactive — no width change */
.nav a.active::after{
  content:""; position:absolute; left:.7rem; right:.7rem; bottom:1px;
  height:2px; border-radius:2px; background:var(--blue);
}
.nav > .btn{ display:none; }        /* desktop: CTA lives in .header-cta */
.nav > .btn.active::after{ display:none; }
.header-cta{ display:flex; align-items:center; gap:.6rem; }

/* hamburger */
.nav-toggle{
  display:none; width:42px; height:42px; border:1px solid var(--line); border-radius:9px;
  background:var(--surface); cursor:pointer; align-items:center; justify-content:center;
}
.nav-toggle span, .nav-toggle span::before, .nav-toggle span::after{
  content:""; display:block; width:18px; height:2px; background:var(--ink); border-radius:2px;
  transition:transform .25s var(--ease), opacity .2s;
}
.nav-toggle span{ position:relative; }
.nav-toggle span::before{ position:absolute; top:-6px; }
.nav-toggle span::after{ position:absolute; top:6px; }
.nav-toggle[aria-expanded="true"] span{ background:transparent; }
.nav-toggle[aria-expanded="true"] span::before{ transform:translateY(6px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] span::after{ transform:translateY(-6px) rotate(-45deg); }

@media (max-width: 880px){
  .nav-toggle{ display:inline-flex; }
  .header-cta .btn{ display:none; }       /* CTA moves into mobile menu */
  .nav{
    position:fixed; inset:66px 0 auto 0;
    flex-direction:column; align-items:stretch; gap:.15rem;
    background:var(--surface); border-bottom:1px solid var(--line);
    padding:1rem var(--gut) 1.4rem;
    box-shadow:var(--shadow-lg);
    transform:translateY(-12px); opacity:0; visibility:hidden;
    transition:transform .25s var(--ease), opacity .2s var(--ease), visibility .2s;
  }
  .nav.open{ transform:translateY(0); opacity:1; visibility:visible; }
  .nav a{ padding:.8rem .5rem; font-size:1.02rem; border-bottom:1px solid var(--line-soft); }
  .nav a.active::after{ display:none; }
  .nav a.active{ color:var(--blue); }
  .nav .btn{ display:inline-flex; margin-top:.8rem; justify-content:center; }
}

/* ---------- Footer ---------- */
.site-footer{
  background:#070b13; color:#c5cde0;
  padding-block:clamp(44px,6vw,68px) 28px;
}
.site-footer a{ color:#c5cde0; }
.site-footer a:hover{ color:#fff; }
.footer-grid{
  display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:2rem;
  padding-bottom:2rem; border-bottom:1px solid rgba(255,255,255,.1);
}
.footer-brand img{ height:30px; width:auto; opacity:.95; }
.footer-logo{ display:inline-flex; align-items:center; gap:.55rem; }
.footer-sub{
  font-family:var(--mono); font-size:.62rem; letter-spacing:.14em; text-transform:uppercase;
  color:#c5cde0; border-left:1px solid rgba(255,255,255,.28); padding-left:.55rem; line-height:1.25;
}
.footer-brand .headline{
  font-family:var(--mono); font-size:.82rem; letter-spacing:.02em; color:#fff;
  margin-top:1rem; line-height:1.7; max-width:34ch;
}
.footer-col h4{ color:#fff; font-size:.78rem; font-family:var(--mono); letter-spacing:.14em; text-transform:uppercase; margin-bottom:.9rem; font-weight:500; }
.footer-col ul{ list-style:none; margin:0; padding:0; }
.footer-col li{ margin-bottom:.55rem; }
.footer-col a{ font-size:.94rem; }
.footer-contact{ font-size:.94rem; line-height:1.9; }
.footer-social{ display:flex; flex-direction:row; gap:.65rem; margin-top:.9rem; }
.footer-social a{
  display:inline-flex; align-items:center; justify-content:center;
  width:36px; height:36px; border:1px solid rgba(255,255,255,.18); border-radius:9px;
  color:#c5cde0; transition:color .2s, border-color .2s, background .2s;
}
.footer-social a:hover{ color:#fff; border-color:rgba(255,255,255,.5); background:rgba(255,255,255,.06); }
.footer-social svg{ width:18px; height:18px; display:block; }
.footer-bottom{
  display:flex; flex-wrap:wrap; gap:.6rem 1.5rem; justify-content:space-between;
  padding-top:1.4rem; font-size:.82rem; color:#8b97b5;
}
.footer-bottom a{ color:#8b97b5; }
@media (max-width:760px){
  .footer-grid{ grid-template-columns:1fr 1fr; }
  .footer-brand{ grid-column:1 / -1; }
}

/* =====================================================================
   SIGNATURE COMPONENT — the polymorphic acronym "decoder"
   B-I-D-O-D-I → six words → three pillars. Changes per page.
   ===================================================================== */
.decoder{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:clamp(14px,2vw,22px);
}
.pillar{
  position:relative;
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:var(--r);
  padding:clamp(18px,2.2vw,26px);
  box-shadow:var(--shadow-sm);
  --acc:var(--p1);
  transition:box-shadow .25s var(--ease), transform .25s var(--ease), border-color .25s;
}
.pillar:nth-child(2){ --acc:var(--p2); }
.pillar:nth-child(3){ --acc:var(--p3); }
.pillar::before{
  content:""; position:absolute; left:0; top:18px; bottom:18px; width:3px;
  background:var(--acc); border-radius:3px;
}
.pillar:hover{ transform:translateY(-3px); box-shadow:var(--shadow); border-color:var(--silver); }

/* the two letter+word rows inside each pillar */
.glyphs{ display:flex; gap:.65rem; margin-bottom:1rem; }
.glyph{ display:flex; align-items:baseline; gap:.55rem; }
.glyph .ltr{
  font-family:var(--mono); font-weight:600;
  font-size:clamp(1.7rem,3vw,2.3rem); line-height:1;
  color:var(--acc); letter-spacing:0;
}
.glyph .wrd{
  font-family:var(--sans); font-weight:600; font-size:1rem; color:var(--ink);
}
.glyphs .plus{ align-self:center; color:var(--silver); font-family:var(--mono); }

.pillar .pillar-name{
  font-family:var(--mono); font-size:.74rem; letter-spacing:.1em; text-transform:uppercase;
  color:var(--acc); font-weight:500; margin-bottom:.4rem;
}
.pillar p{ color:var(--text-soft); font-size:.95rem; margin:0; }

@media (max-width:820px){
  .decoder{ grid-template-columns:1fr; }
}

/* compact inline decoder (used in hero band + footer-ish strips) */
.decoder-strip{
  display:grid; grid-template-columns:repeat(3,1fr); gap:1px;
  background:var(--line); border:1px solid var(--line); border-radius:var(--r);
  overflow:hidden;
}
.decoder-strip .cell{
  background:var(--surface); padding:1rem 1.15rem;
}
.decoder-strip .cell .pair{ font-family:var(--mono); font-size:.95rem; color:var(--navy); font-weight:600; }
.decoder-strip .cell .pair b{ color:var(--blue); }
.decoder-strip .cell .nm{
  font-family:var(--mono); font-size:.66rem; letter-spacing:.12em; text-transform:uppercase;
  color:var(--steel); margin-top:.3rem;
}
@media (max-width:760px){ .decoder-strip{ grid-template-columns:1fr; } }

/* ---------- Generic card grid ---------- */
.grid{ display:grid; gap:clamp(16px,2vw,22px); }
.grid.cols-3{ grid-template-columns:repeat(3,1fr); }
.grid.cols-2{ grid-template-columns:repeat(2,1fr); }
.grid.cols-4{ grid-template-columns:repeat(4,1fr); }
@media (max-width:920px){ .grid.cols-3,.grid.cols-4{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:600px){ .grid.cols-2,.grid.cols-3,.grid.cols-4{ grid-template-columns:1fr; } }

.card{
  background:var(--surface); border:1px solid var(--line); border-radius:var(--r);
  padding:clamp(20px,2.4vw,28px); box-shadow:var(--shadow-sm);
  transition:transform .22s var(--ease), box-shadow .22s var(--ease), border-color .22s;
}
.card:hover{ transform:translateY(-3px); box-shadow:var(--shadow); border-color:var(--silver); }
.card h3{ font-size:1.12rem; margin-bottom:.5rem; }
.card p{ color:var(--text-soft); font-size:.96rem; margin:0; }
.card .kicker{
  font-family:var(--mono); font-size:.68rem; letter-spacing:.14em; text-transform:uppercase;
  color:var(--blue); margin-bottom:.7rem;
}
.card ul{ margin:.6rem 0 0; padding-left:1.1rem; color:var(--text-soft); font-size:.95rem; }
.card ul li{ margin-bottom:.4rem; }

/* service list inside pillar columns */
.svc-col{ background:var(--surface); border:1px solid var(--line); border-radius:var(--r); overflow:hidden; box-shadow:var(--shadow-sm); }
.svc-col .head{ padding:1.3rem 1.4rem; border-bottom:1px solid var(--line); background:var(--surface-2); }
.svc-col .head .pillar-name{ font-family:var(--mono); font-size:.72rem; letter-spacing:.1em; text-transform:uppercase; font-weight:500; margin-bottom:.35rem; }
.svc-col .head h3{ font-size:1.18rem; }
.svc-col .head .acro{ font-family:var(--mono); font-size:.8rem; color:var(--steel); margin-top:.45rem; }
.svc-col .head .acro b{ color:var(--blue); }
.svc-col .body{ padding:1.3rem 1.4rem; }
.svc-item{ padding:.9rem 0; border-bottom:1px solid var(--line-soft); }
.svc-item:last-child{ border-bottom:0; padding-bottom:0; }
.svc-item h4{ font-size:1rem; margin-bottom:.25rem; }
.svc-item p{ font-size:.92rem; color:var(--text-soft); margin:0; }
.svc-col.p1 .pillar-name{ color:var(--p1); } .svc-col.p1 .head{ box-shadow:inset 3px 0 var(--p1); }
.svc-col.p2 .pillar-name{ color:var(--p2); } .svc-col.p2 .head{ box-shadow:inset 3px 0 var(--p2); }
.svc-col.p3 .pillar-name{ color:var(--p3); } .svc-col.p3 .head{ box-shadow:inset 3px 0 var(--p3); }

/* ---------- Hero ---------- */
.hero{ position:relative; overflow:hidden; background:var(--surface); border-bottom:1px solid var(--line); }
.hero::before{
  content:""; position:absolute; inset:0; pointer-events:none; opacity:.5;
  background:
    radial-gradient(900px 360px at 78% -8%, rgba(79,116,196,.10), transparent 60%),
    linear-gradient(transparent 31px, rgba(255,255,255,.045) 32px),
    linear-gradient(90deg, transparent 31px, rgba(255,255,255,.045) 32px);
  background-size:auto, 32px 32px, 32px 32px;
  -webkit-mask-image:linear-gradient(180deg,#000,transparent 88%);
          mask-image:linear-gradient(180deg,#000,transparent 88%);
}
.hero .container{ position:relative; padding-block:clamp(24px,4vw,46px); }
.hero h1{
  font-size:clamp(2.1rem, 5.2vw, 3.5rem);
  letter-spacing:-.02em; line-height:1.06; max-width:18ch;
}
.hero h1 .seg{ display:inline; }
.hero h1 .seg b{ color:var(--blue); font-weight:700; }
.hero .lead{ margin-top:1.2rem; max-width:54ch; }
.hero .btn-row{ margin-top:1.8rem; }
.hero-eyebrow .tag{ margin-bottom:1.1rem; }

/* page header (interior pages) */
.page-hero{ background:var(--surface); border-bottom:1px solid var(--line); }
.page-hero .container{ padding-block:clamp(40px,6vw,72px); }
.page-hero h1{ font-size:clamp(1.9rem,4.4vw,2.9rem); max-width:20ch; }
.page-hero .lead{ margin-top:1rem; max-width:60ch; }

/* ---------- Logo / membership strip ---------- */
.memberships{ background:var(--surface); border-block:1px solid var(--line); }
.member-grid{
  display:flex; flex-wrap:wrap; justify-content:center; gap:12px;
}
.member{
  flex:1 1 calc(25% - 12px); max-width:calc(25% - 12px);
  background:var(--surface); border:1px solid var(--line); border-radius:var(--r);
  padding:1.4rem 1.2rem; display:flex; flex-direction:column;
  align-items:center; justify-content:center; gap:.8rem; text-align:center; min-height:120px;
  transition:background .2s, border-color .2s, box-shadow .2s;
}
.member:hover{ background:var(--surface-2); border-color:var(--silver); box-shadow:var(--shadow-sm); }
.member .logo-wrap{ height:54px; display:flex; align-items:center; justify-content:center; }
.member img{ max-height:48px; width:auto; object-fit:contain; }
.member img.tall{ max-height:84px; }
.member .lbl{ font-size:.8rem; color:var(--steel); line-height:1.4; font-weight:500; }
@media (max-width:820px){
  .member{ flex:1 1 calc(50% - 12px); max-width:calc(50% - 12px); }
}
@media (max-width:480px){
  .member{ flex:1 1 100%; max-width:100%; }
}

/* ---------- Misc ---------- */
.split{ display:grid; grid-template-columns:1.15fr .85fr; gap:clamp(28px,5vw,64px); align-items:start; }
@media (max-width:880px){ .split{ grid-template-columns:1fr; } }

.callout{
  background:linear-gradient(180deg, var(--navy), var(--navy-deep));
  color:#eef2fb; border-radius:var(--r-lg); padding:clamp(30px,4vw,52px);
  box-shadow:var(--shadow-lg); position:relative; overflow:hidden;
}
.callout::after{
  content:""; position:absolute; right:-60px; top:-60px; width:260px; height:260px; border-radius:50%;
  background:radial-gradient(circle, rgba(255,255,255,.10), transparent 70%);
}
.callout h2{ color:#fff; font-size:clamp(1.5rem,3vw,2rem); max-width:22ch; }
.callout p{ color:#c7d2ea; max-width:56ch; margin-top:.7rem; }
.callout .btn{ --bg:#fff; --fg:var(--navy); --bd:#fff; margin-top:1.4rem; }
.callout .btn:hover{ --bg:var(--blue-bright); --fg:#fff; --bd:var(--blue-bright); }
.callout .eyebrow{ color:#9fc0ff; }
.callout .eyebrow::before{ background:rgba(255,255,255,.4); }

/* phased framework (AI page) */
.phases{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--line); border:1px solid var(--line); border-radius:var(--r); overflow:hidden; }
@media (max-width:820px){ .phases{ grid-template-columns:1fr 1fr; } }
@media (max-width:480px){ .phases{ grid-template-columns:1fr; } }
.phase{ background:var(--surface); padding:1.4rem 1.3rem; }
.phase .step{ font-family:var(--mono); font-size:.72rem; letter-spacing:.1em; color:var(--blue); }
.phase h4{ margin:.5rem 0 .4rem; font-size:1.05rem; }
.phase p{ font-size:.9rem; color:var(--text-soft); margin:0; }

/* contact rows */
.contact-row{ display:flex; gap:1rem; align-items:flex-start; padding:1.3rem 0; border-bottom:1px solid var(--line); }
.contact-row:last-child{ border-bottom:0; }
.contact-row .ic{ flex:0 0 auto; width:42px; height:42px; border-radius:10px; background:var(--surface-2); border:1px solid var(--line); display:flex; align-items:center; justify-content:center; color:var(--blue); }
.contact-row .k{ font-family:var(--mono); font-size:.7rem; letter-spacing:.12em; text-transform:uppercase; color:var(--steel); }
.contact-row .v{ font-size:1.08rem; color:var(--ink); font-weight:600; margin-top:.2rem; }
.contact-row .v a{ color:var(--navy); }

/* leadership / profile */
.profile{ display:grid; grid-template-columns:200px 1fr; gap:clamp(22px,3vw,40px); align-items:start; }
.profile img{ width:200px; height:200px; border-radius:var(--r); object-fit:cover; border:1px solid var(--line); box-shadow:var(--shadow); }
.profile .role{ font-family:var(--mono); font-size:.74rem; letter-spacing:.1em; text-transform:uppercase; color:var(--blue); }
.profile h3{ font-size:1.4rem; margin:.3rem 0 1rem; }
.profile p{ color:var(--text-soft); font-size:.98rem; }
@media (max-width:620px){ .profile{ grid-template-columns:1fr; } .profile img{ width:140px; height:140px; } }

/* framework table */
.fw-table{ width:100%; border-collapse:collapse; background:var(--surface); border:1px solid var(--line); border-radius:var(--r); overflow:hidden; }
.fw-table th, .fw-table td{ text-align:left; padding:.95rem 1.1rem; border-bottom:1px solid var(--line-soft); vertical-align:top; font-size:.94rem; }
.fw-table th{ font-family:var(--mono); font-size:1.1rem; letter-spacing:.08em; text-transform:uppercase; color:var(--steel); background:var(--surface-2); font-weight:500; }
.fw-table tr:last-child td{ border-bottom:0; }
.fw-table td .pn{ font-weight:600; color:var(--ink); }
.fw-pill{ display:inline-block; font-family:var(--mono); font-size:.74rem; padding:.2rem .5rem; border-radius:5px; border:1px solid var(--line); color:var(--navy); background:var(--surface-2); margin:.15rem .25rem .15rem 0; }
@media (max-width:680px){ .fw-table thead{ display:none; } .fw-table td{ display:block; border:0; padding:.4rem 1.1rem; } .fw-table tr{ display:block; border-bottom:1px solid var(--line); padding:.7rem 0; } }

/* ---------- Legal / privacy prose ---------- */
.legal{ max-width:72ch; }
.legal .updated{ font-family:var(--mono); font-size:.78rem; letter-spacing:.04em; color:var(--steel); margin-bottom:2.2rem; }
.legal h2{ font-size:1.18rem; margin:2.4rem 0 .7rem; color:var(--ink); letter-spacing:-.01em; }
.legal h2:first-of-type{ margin-top:0; }
.legal h2 .n{ font-family:var(--mono); font-size:.82rem; color:var(--blue); margin-right:.5rem; font-weight:600; }
.legal h3{ font-size:1rem; margin:1.4rem 0 .5rem; color:var(--navy); }
.legal p{ color:var(--text-soft); margin:0 0 1rem; line-height:1.7; }
.legal ul{ color:var(--text-soft); margin:0 0 1.1rem; padding-left:1.2rem; line-height:1.7; }
.legal li{ margin-bottom:.4rem; }
.legal a{ color:var(--blue); }
.legal strong{ color:var(--ink); font-weight:600; }
