/* ============================================================
   TYMPO PARTNERS, LLC — VISUAL SYSTEM
   Token spec + component styles. Federal / clinical / institutional.
   ============================================================ */

/* ---------- 1. RAW PALETTE (brand-locked) ---------- */
:root{
  --navy:        #002349;  /* primary surfaces / headers */
  --gold:        #957C3D;  /* accents / CTAs / rules — sparingly */
  --federal:     #1E3A5F;
  --slate:       #2D5986;
  --gold-light:  #C4A35A;
  --off-white:   #F5F4F0;
  --warm-gray:   #D6D3CE;
  --ink:         #1C1C1E;
  --muted:       #6B6860;
  --white:       #FFFFFF;

  /* type families */
  --font-display: 'Cormorant Garamond', Georgia, 'Times New Roman', serif;
  --font-label:   'Barlow Condensed', 'Arial Narrow', sans-serif;
  --font-body:    'Lora', Georgia, serif;
  --font-mono:    'IBM Plex Mono', 'SFMono-Regular', Menlo, monospace;

  /* spacing scale (4-base) */
  --s-1: 4px;  --s-2: 8px;  --s-3: 12px; --s-4: 16px; --s-5: 24px;
  --s-6: 32px; --s-7: 48px; --s-8: 64px; --s-9: 96px; --s-10: 128px;

  /* radii — tight, federal */
  --r-sm: 2px; --r-md: 3px; --r-lg: 4px;

  /* layout */
  --maxw: 1200px;
  --maxw-text: 760px;
  --rule: 1px;

  /* motion */
  --ease: cubic-bezier(.22,.61,.36,1);
}

/* ---------- 2. SEMANTIC TOKENS — LIGHT (default) ---------- */
:root,
[data-theme="light"]{
  --bg:            var(--off-white);
  --bg-raised:     var(--white);
  --bg-inverse:    var(--navy);
  --bg-band:       #ECEAE3;          /* subtle texture band */
  --surface-line:  #DAD7D0;

  --text:          var(--ink);
  --text-soft:     #46453F;
  --text-muted:    var(--muted);
  --text-on-navy:  var(--off-white);
  --text-on-navy-soft: #AFC0D4;

  --accent:        var(--gold);
  --accent-bright: var(--gold-light);
  --link:          var(--slate);

  --header-bg:     var(--navy);
  --header-text:   var(--off-white);
  --footer-bg:     var(--navy);

  --card-bg:       var(--white);
  --card-border:   #E0DDD6;
  --hairline:      #DEDBD3;

  --shadow-sm: 0 1px 2px rgba(0,35,73,.06), 0 1px 1px rgba(0,35,73,.04);
  --shadow-md: 0 2px 4px rgba(0,35,73,.07), 0 8px 24px rgba(0,35,73,.06);

  --img-overlay: linear-gradient(180deg, rgba(0,35,73,.30), rgba(0,35,73,.62));
  --img-stripe:  #C9C5BC;
  --img-field:   #DDD9D0;
}

/* ---------- 3. SEMANTIC TOKENS — DARK (navy-dominant) ---------- */
[data-theme="dark"]{
  --bg:            #001B38;
  --bg-raised:     #002349;
  --bg-inverse:    #001022;
  --bg-band:       #00203F;
  --surface-line:  #143456;

  --text:          var(--off-white);
  --text-soft:     #D4D8DE;
  --text-muted:    #8C97A6;
  --text-on-navy:  var(--off-white);
  --text-on-navy-soft: #AFC0D4;

  --accent:        var(--gold-light);
  --accent-bright: var(--gold-light);
  --link:          #8FB4DD;

  --header-bg:     #001022;
  --header-text:   var(--off-white);
  --footer-bg:     #001022;

  --card-bg:       #02274F;
  --card-border:   #103056;
  --hairline:      #123254;

  --shadow-sm: 0 1px 2px rgba(0,0,0,.30);
  --shadow-md: 0 2px 4px rgba(0,0,0,.30), 0 10px 30px rgba(0,0,0,.34);

  --img-overlay: linear-gradient(180deg, rgba(0,16,34,.36), rgba(0,16,34,.74));
  --img-stripe:  #0C2D52;
  --img-field:   #06294F;
}

/* ---------- 4. RESET / BASE ---------- */
*{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
body{
  margin:0;
  background:var(--bg);
  color:var(--text);
  font-family:var(--font-body);
  font-size:18px;
  line-height:1.65;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  transition:background-color .4s var(--ease), color .4s var(--ease);
}
img{ max-width:100%; display:block; }
a{ color:var(--link); text-decoration:none; }
a:hover{ text-decoration:underline; text-underline-offset:3px; }
::selection{ background:var(--gold); color:#fff; }

/* ---------- 5. LAYOUT ---------- */
.wrap{ max-width:var(--maxw); margin:0 auto; padding-inline:clamp(20px,5vw,56px); }
.wrap-text{ max-width:var(--maxw-text); }
.section{ padding-block:clamp(56px,9vw,112px); }
.section-tight{ padding-block:clamp(40px,6vw,72px); }
.band{ background:var(--bg-band); }
.band-navy{ background:var(--navy); color:var(--text-on-navy); }
.band-navy .eyebrow{ color:var(--gold-light); }
.band-navy h2,.band-navy h3{ color:var(--off-white); }
.band-navy p{ color:var(--text-on-navy-soft); }

/* ---------- 6. TYPOGRAPHY ---------- */
.display{
  font-family:var(--font-display); font-weight:700;
  font-size:clamp(44px,6.4vw,84px); line-height:1.02;
  letter-spacing:-.01em; margin:0;
}
h1,.h1{ font-family:var(--font-display); font-weight:700; font-size:clamp(36px,4.6vw,60px); line-height:1.06; letter-spacing:-.01em; margin:0 0 var(--s-4); }
h2,.h2{ font-family:var(--font-display); font-weight:600; font-size:clamp(28px,3.4vw,44px); line-height:1.1; letter-spacing:-.005em; margin:0 0 var(--s-4); }
h3,.h3{ font-family:var(--font-display); font-weight:600; font-size:clamp(22px,2.4vw,30px); line-height:1.15; margin:0 0 var(--s-3); }
p{ margin:0 0 var(--s-4); max-width:68ch; text-wrap:pretty; }
.lead{ font-size:clamp(20px,2vw,24px); line-height:1.5; color:var(--text-soft); }
strong{ font-weight:600; }

.eyebrow{
  font-family:var(--font-label); text-transform:uppercase;
  letter-spacing:.13em; font-weight:600; font-size:14px;
  color:var(--accent); margin:0 0 var(--s-4); display:inline-block;
}
.eyebrow-num{ color:var(--text-muted); margin-right:var(--s-3); }
.mono{ font-family:var(--font-mono); font-size:13px; letter-spacing:.01em; }
.label{ font-family:var(--font-label); text-transform:uppercase; letter-spacing:.12em; font-weight:600; }

/* heartbeat divider — signature motif, used sparingly */
.hr-beat{ border:0; height:18px; margin:var(--s-6) 0; color:var(--accent);
  background:none; display:flex; align-items:center; }
.hr-beat svg{ width:100%; height:18px; display:block; }

.rule-gold{ width:56px; height:2px; background:var(--accent); border:0; margin:0 0 var(--s-5); }

/* ---------- 7. BUTTONS ---------- */
.btn{
  font-family:var(--font-label); text-transform:uppercase; letter-spacing:.12em;
  font-weight:600; font-size:15px; line-height:1;
  display:inline-flex; align-items:center; gap:var(--s-3);
  padding:16px 26px; border-radius:var(--r-md); cursor:pointer;
  border:1px solid transparent; transition:all .25s var(--ease);
}
.btn-gold{ background:var(--gold); color:#fff; }
.btn-gold:hover{ background:#a98c45; text-decoration:none; }
.btn-ghost{ background:transparent; color:var(--text); border-color:var(--surface-line); }
.btn-ghost:hover{ border-color:var(--accent); color:var(--accent); text-decoration:none; }
.band-navy .btn-ghost,.hero .btn-ghost{ color:var(--off-white); border-color:rgba(196,163,90,.5); }
.band-navy .btn-ghost:hover,.hero .btn-ghost:hover{ border-color:var(--gold-light); color:var(--gold-light); }
.btn .arrow{ font-family:var(--font-body); font-size:18px; transform:translateY(-1px); }

/* ---------- 8. HEADER ---------- */
.site-header{
  position:sticky; top:0; z-index:50;
  background:var(--header-bg); color:var(--header-text);
  border-bottom:1px solid rgba(149,124,61,.28);
}
.site-header .wrap{ display:flex; align-items:center; justify-content:space-between; height:84px; gap:var(--s-5); }
.brand-lockup{ display:flex; align-items:center; }
.brand-lockup img{ height:46px; width:auto; }
.brand-lockup .tp{ display:none; height:42px; }
.nav{ display:flex; align-items:center; gap:clamp(18px,1.5vw,28px); white-space:nowrap; }
.nav a{
  font-family:var(--font-label); text-transform:uppercase; letter-spacing:.12em;
  font-weight:500; font-size:14px; color:var(--text-on-navy-soft);
  padding-block:6px; position:relative; white-space:nowrap;
}
.nav a:hover{ color:var(--off-white); text-decoration:none; }
.nav a.active{ color:var(--off-white); }
.nav a.active::after{ content:""; position:absolute; left:0; right:0; bottom:-2px; height:2px; background:var(--gold); }
.header-tools{ display:flex; align-items:center; gap:var(--s-4); }
.theme-toggle{
  background:transparent; border:1px solid rgba(196,163,90,.4); color:var(--off-white);
  width:40px; height:40px; border-radius:var(--r-md); cursor:pointer; display:grid; place-items:center;
  transition:all .25s var(--ease);
}
.theme-toggle:hover{ border-color:var(--gold-light); color:var(--gold-light); }
.theme-toggle svg{ width:18px; height:18px; }
.theme-toggle .i-sun{ display:none; }
[data-theme="dark"] .theme-toggle .i-sun{ display:block; }
[data-theme="dark"] .theme-toggle .i-moon{ display:none; }
.nav-toggle{ display:none; background:none; border:1px solid rgba(196,163,90,.4); color:var(--off-white);
  width:40px; height:40px; border-radius:var(--r-md); cursor:pointer; }

/* ---------- 9. HERO ---------- */
.hero{ position:relative; background:var(--navy); color:var(--off-white); overflow:hidden; }
.hero-media{ position:absolute; inset:0; }
.hero-media .ph{ width:100%; height:100%; }
.hero-media::after{ content:""; position:absolute; inset:0; background:var(--img-overlay); }
.hero-inner{ position:relative; z-index:2; padding-block:clamp(80px,13vw,168px); }
.hero h1{ color:var(--off-white); max-width:18ch; }
.hero .lead{ color:var(--text-on-navy-soft); max-width:52ch; }
.hero .eyebrow{ color:var(--gold-light); }
.hero-cta{ display:flex; flex-wrap:wrap; gap:var(--s-4); margin-top:var(--s-6); }
.hero-beat{ position:absolute; left:0; right:0; bottom:0; z-index:3; height:3px;
  background:linear-gradient(90deg,transparent,var(--gold) 18%,var(--gold-light) 50%,var(--gold) 82%,transparent); opacity:.85; }

/* ---------- 10. IMAGE PLACEHOLDER (navy-duotone slot) ---------- */
.ph{
  position:relative; background:
    repeating-linear-gradient(135deg, var(--img-stripe) 0 1px, transparent 1px 11px),
    var(--img-field);
  display:grid; place-items:center; overflow:hidden; border-radius:var(--r-sm);
}
.ph .ph-cap{
  font-family:var(--font-mono); font-size:11.5px; letter-spacing:.04em; text-transform:uppercase;
  color:var(--navy); background:rgba(245,244,240,.82); padding:6px 12px; border-radius:var(--r-sm);
  border:1px solid rgba(0,35,73,.18); text-align:center; max-width:80%;
}
[data-theme="dark"] .ph .ph-cap{ color:var(--off-white); background:rgba(0,16,34,.7); border-color:rgba(196,163,90,.3); }
.ph.on-navy .ph-cap{ color:var(--off-white); background:rgba(0,16,34,.55); border-color:rgba(196,163,90,.35); }
.ph-duotone{ box-shadow:inset 0 0 0 9999px rgba(0,35,73,.18); }

/* ---------- 11. EYEBROW + SECTION HEAD ---------- */
.sec-head{ margin-bottom:var(--s-7); max-width:46ch; }
.sec-head.center{ margin-inline:auto; text-align:center; }
.kicker-row{ display:flex; align-items:baseline; gap:var(--s-3); margin-bottom:var(--s-4); }

/* ---------- 12. CAPABILITY CARDS (asymmetric, no icon circles) ---------- */
.cap-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:1px; background:var(--hairline);
  border:1px solid var(--hairline); border-radius:var(--r-lg); overflow:hidden; }
.cap-card{
  background:var(--card-bg); padding:var(--s-7) var(--s-6); position:relative;
  transition:background .3s var(--ease);
}
.cap-card:hover{ background:var(--bg-raised); }
.cap-card .cap-no{ font-family:var(--font-mono); font-size:12px; color:var(--accent); letter-spacing:.06em; }
.cap-card h3{ margin-top:var(--s-3); }
.cap-card p{ color:var(--text-soft); font-size:16.5px; margin-bottom:0; }
.cap-card .cap-tag{ margin-top:var(--s-5); font-family:var(--font-label); text-transform:uppercase;
  letter-spacing:.1em; font-size:12.5px; color:var(--text-muted); display:flex; align-items:center; gap:var(--s-2); }
.cap-card .cap-tag b{ color:var(--accent); font-weight:600; }
.cap-card::before{ content:""; position:absolute; top:0; left:0; width:0; height:3px; background:var(--gold);
  transition:width .35s var(--ease); }
.cap-card:hover::before{ width:48px; }

/* ---------- 13. ATTRIBUTION TABLE (capability -> member firm) ---------- */
.attr-table{ width:100%; border-collapse:collapse; font-size:16px; }
.attr-table thead th{
  font-family:var(--font-label); text-transform:uppercase; letter-spacing:.12em; font-weight:600;
  font-size:13px; color:var(--text-muted); text-align:left; padding:var(--s-3) var(--s-4);
  border-bottom:2px solid var(--accent);
}
.attr-table td{ padding:var(--s-4); border-bottom:1px solid var(--hairline); vertical-align:top; color:var(--text-soft); }
.attr-table tbody tr:hover{ background:var(--bg-band); }
.attr-table .firm-pill{ font-family:var(--font-label); text-transform:uppercase; letter-spacing:.08em; font-weight:600;
  font-size:12.5px; padding:4px 10px; border-radius:var(--r-sm); display:inline-block; }
.firm-pill.mksg{ background:rgba(0,35,73,.08); color:var(--navy); border:1px solid rgba(0,35,73,.2); }
.firm-pill.fsp{ background:rgba(149,124,61,.1); color:var(--gold); border:1px solid rgba(149,124,61,.32); }
[data-theme="dark"] .firm-pill.mksg{ background:rgba(143,180,221,.12); color:#AFC0D4; border-color:rgba(143,180,221,.3); }
.attr-table .cap-name{ font-family:var(--font-display); font-weight:600; font-size:19px; color:var(--text); }

/* ---------- 14. MEMBER-FIRM CARDS (two distinct entities) ---------- */
.firm-grid{ display:grid; grid-template-columns:1fr 1fr; gap:var(--s-5); }
.firm-card{ background:var(--card-bg); border:1px solid var(--card-border); border-radius:var(--r-lg);
  padding:var(--s-7); box-shadow:var(--shadow-sm); display:flex; flex-direction:column; }
.firm-card .firm-role{ font-family:var(--font-label); text-transform:uppercase; letter-spacing:.13em;
  font-size:12.5px; font-weight:600; color:var(--accent); margin-bottom:var(--s-5); }
.firm-card .firm-name{ font-family:var(--font-display); font-weight:700; font-size:30px; line-height:1.05; margin:0 0 var(--s-2); }
.firm-card .firm-sub{ font-family:var(--font-label); text-transform:uppercase; letter-spacing:.08em; font-size:13px; color:var(--text-muted); margin-bottom:var(--s-5); }
.firm-card p{ color:var(--text-soft); font-size:16px; }
/* MKSG variant — carries wordmark + mono credential strip */
.firm-card.mksg{ border-top:3px solid var(--navy); }
.firm-card .mksg-lockup{ display:flex; align-items:center; gap:var(--s-4); margin-bottom:var(--s-5); }
.firm-card .mksg-lockup img{ width:54px; height:54px; border-radius:var(--r-sm); border:1px solid rgba(149,124,61,.32); }
.firm-card .mksg-word{ font-family:var(--font-label); text-transform:uppercase; letter-spacing:.1em; font-weight:700; font-size:17px; line-height:1.1; color:var(--text); }
.cred-strip{ margin-top:auto; border-top:1px solid var(--hairline); padding-top:var(--s-4); display:flex; flex-wrap:wrap; gap:var(--s-2) var(--s-5); }
.cred-strip .cred{ font-family:var(--font-mono); font-size:12px; color:var(--text-muted); }
.cred-strip .cred b{ color:var(--accent); font-weight:600; }
/* FSP variant — plain, no borrowed branding */
.firm-card.fsp{ border-top:3px solid var(--gold); }

/* ---------- 15. GATED STATUS CALLOUT ---------- */
.gated{
  border:1px solid var(--accent); border-left:3px solid var(--accent);
  background:var(--card-bg); border-radius:var(--r-md); padding:var(--s-6) var(--s-7);
  display:flex; gap:var(--s-6); align-items:flex-start;
}
.gated .gated-mark{ font-family:var(--font-mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase;
  color:var(--accent); border:1px solid var(--accent); border-radius:var(--r-sm); padding:6px 10px; white-space:nowrap; }
.gated h3{ margin:0 0 var(--s-2); font-size:24px; }
.gated p{ margin:0; color:var(--text-soft); font-size:16px; }
.status-pending{ color:var(--gold); font-family:var(--font-mono); font-size:12px; letter-spacing:.08em; }

/* ---------- 16. CONTACT BLOCK ---------- */
.contact-block{ font-family:var(--font-mono); font-size:14px; line-height:1.9; color:var(--text-soft); }
.contact-block .org{ font-family:var(--font-display); font-size:24px; font-weight:600; color:var(--text); display:block; margin-bottom:var(--s-3); font-style:normal; }
.contact-block a{ color:var(--link); }
.contact-block .ct-label{ color:var(--text-muted); }

/* ---------- 17. FOOTER ---------- */
.site-footer{ background:var(--footer-bg); color:var(--text-on-navy-soft); padding-block:var(--s-8) var(--s-6);
  border-top:3px solid var(--gold); }
.footer-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:var(--s-7); margin-bottom:var(--s-7); }
.site-footer .tp-mark{ width:56px; height:56px; margin-bottom:var(--s-4); }
.site-footer h4{ font-family:var(--font-label); text-transform:uppercase; letter-spacing:.12em; font-size:13px;
  font-weight:600; color:var(--gold-light); margin:0 0 var(--s-4); }
.site-footer a{ color:var(--text-on-navy-soft); display:block; padding:3px 0; font-size:15px; }
.site-footer a:hover{ color:var(--off-white); text-decoration:none; }
.site-footer .contact-block{ color:var(--text-on-navy-soft); font-size:13px; }
.site-footer .contact-block .org{ color:var(--off-white); }
.footer-beat{ height:14px; margin:var(--s-5) 0; opacity:.6; }
.footer-beat svg{ width:100%; height:14px; }
.footer-legal{ border-top:1px solid rgba(196,163,90,.22); padding-top:var(--s-5); display:flex; justify-content:space-between;
  flex-wrap:wrap; gap:var(--s-4); font-family:var(--font-mono); font-size:11.5px; color:#7E8EA0; letter-spacing:.02em; }
.footer-legal p{ margin:0; max-width:none; }
.footer-disclaimer{ font-family:var(--font-mono); font-size:11.5px; line-height:1.75; color:#90A0B2; letter-spacing:.02em;
  max-width:none; margin:0 0 var(--s-4); }

/* ---------- 18. MISC PAGE PARTS ---------- */
.pagehead{ background:var(--navy); color:var(--off-white); padding-block:clamp(56px,9vw,104px) clamp(40px,6vw,72px); position:relative; }
.pagehead .eyebrow{ color:var(--gold-light); }
.pagehead h1{ color:var(--off-white); }
.pagehead .lead{ color:var(--text-on-navy-soft); }
.pagehead-beat{ position:absolute; left:0; right:0; bottom:0; height:3px;
  background:linear-gradient(90deg,transparent,var(--gold) 18%,var(--gold-light) 50%,var(--gold) 82%,transparent); }
.crumbs{ font-family:var(--font-mono); font-size:12px; color:var(--text-on-navy-soft); letter-spacing:.04em; margin-bottom:var(--s-5); }
.crumbs a{ color:var(--gold-light); }

.two-col{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(32px,5vw,80px); align-items:start; }
.three-col{ display:grid; grid-template-columns:repeat(3,1fr); gap:var(--s-6); }
.placeholder-note{ font-family:var(--font-mono); font-size:12px; color:var(--text-muted); border:1px dashed var(--surface-line);
  border-radius:var(--r-sm); padding:var(--s-3) var(--s-4); display:inline-block; }

.figure{ display:flex; flex-direction:column; gap:var(--s-3); }
.figure .fig-cap{ font-family:var(--font-mono); font-size:11.5px; color:var(--text-muted); letter-spacing:.03em; }

/* governance / list rows */
.gov-row{ display:grid; grid-template-columns:200px 1fr; gap:var(--s-6); padding:var(--s-5) 0; border-bottom:1px solid var(--hairline); }
.gov-row .gov-k{ font-family:var(--font-label); text-transform:uppercase; letter-spacing:.1em; font-weight:600; font-size:14px; color:var(--accent); }
.gov-row .gov-v{ color:var(--text-soft); }
.gov-row .gov-v p:last-child{ margin-bottom:0; }

/* leadership card */
.leader{ display:grid; grid-template-columns:200px 1fr; gap:var(--s-6); }
.leader .lead-photo{ aspect-ratio:3/4; overflow:hidden; border-radius:var(--r-sm); background:var(--bg-band); }
.leader .lead-photo img{ width:100%; height:100%; object-fit:cover; object-position:50% 10%; display:block; }
.leader h3{ margin-bottom:2px; }
.leader .lead-title{ font-family:var(--font-label); text-transform:uppercase; letter-spacing:.1em; font-size:13px; color:var(--accent); margin-bottom:var(--s-4); }

/* cert / list cards */
.cert-list{ display:grid; grid-template-columns:repeat(2,1fr); gap:var(--s-5); }
.cert-item{ background:var(--card-bg); border:1px solid var(--card-border); border-left:3px solid var(--gold);
  border-radius:var(--r-md); padding:var(--s-5) var(--s-6); }
.cert-item .cert-name{ font-family:var(--font-display); font-weight:600; font-size:21px; margin-bottom:2px; }
.cert-item .cert-meta{ font-family:var(--font-mono); font-size:12px; color:var(--text-muted); }
.cert-item .cert-status{ margin-top:var(--s-3); font-family:var(--font-label); text-transform:uppercase; letter-spacing:.1em; font-size:12px; }
.cert-status.active{ color:var(--slate); }
.cert-status.pending{ color:var(--gold); }

/* past performance entries */
.pp-entry{ display:grid; grid-template-columns:120px 1fr; gap:var(--s-6); padding:var(--s-6) 0; border-bottom:1px solid var(--hairline); }
.pp-entry .pp-meta{ font-family:var(--font-mono); font-size:12px; color:var(--text-muted); line-height:1.8; }
.pp-entry h3{ margin-bottom:var(--s-2); }

/* form (contact) */
.field{ display:flex; flex-direction:column; gap:var(--s-2); margin-bottom:var(--s-5); }
.field label{ font-family:var(--font-label); text-transform:uppercase; letter-spacing:.1em; font-size:12.5px; font-weight:600; color:var(--text-muted); }
.field input,.field textarea,.field select{
  font-family:var(--font-body); font-size:16px; color:var(--text); background:var(--bg-raised);
  border:1px solid var(--surface-line); border-radius:var(--r-md); padding:13px 14px; transition:border-color .2s; }
.field input:focus,.field textarea:focus,.field select:focus{ outline:none; border-color:var(--accent); }

/* ---------- 19. RESPONSIVE ---------- */
@media (max-width:1180px){
  .nav{ display:none; }
  .nav-toggle{ display:grid; place-items:center; }
}
@media (max-width:880px){
  .cap-grid,.firm-grid,.two-col,.three-col,.cert-list{ grid-template-columns:1fr; }
  .footer-grid{ grid-template-columns:1fr; gap:var(--s-6); }
  .gov-row,.leader,.pp-entry{ grid-template-columns:1fr; gap:var(--s-3); }
  .brand-lockup img.full{ display:none; }
  .brand-lockup .tp{ display:block; }
  .gated{ flex-direction:column; gap:var(--s-4); }
}
@media (max-width:560px){
  body{ font-size:17px; }
}

/* mobile nav drawer */
.nav.open{ display:flex; position:absolute; top:84px; left:0; right:0; flex-direction:column; gap:0;
  background:var(--header-bg); padding:var(--s-4) clamp(20px,5vw,56px) var(--s-5); border-bottom:1px solid rgba(149,124,61,.28); }
.nav.open a{ padding:13px 0; border-bottom:1px solid rgba(255,255,255,.06); }

@media (prefers-reduced-motion:reduce){ *{ transition:none!important; scroll-behavior:auto; } }
