/* ============================================================
   Dr. David E. Jackson II — Site Theme
   NAVY · CHARCOAL · GOLD on an editorial structure.
   (Palette restored from monochrome; editorial type/space/rhythm kept.)
   Single source of truth; change the system here.
   ============================================================ */

:root{
  /* ---- Brand palette ---- */
  --navy:#0F2440;
  --navy-deep:#0A1B30;
  --navy-darker:#070F1C;       /* footer */
  --charcoal:#23272F;
  --charcoal-deep:#191C22;
  --gold:#C49A45;
  --gold-soft:#D9BC7A;
  --gold-hover:#B2882F;
  --gold-dark:#9A7B3F;

  --paper:#F5F4F1;             /* warm neutral ground */
  --paper-warm:#FBFAF7;        /* alternating sections */
  --ink:#1A1D23;              /* primary text */
  --muted:#6B7280;            /* muted body text */
  --grey-1:#6B7280;
  --grey-2:#9AA0A8;
  --grey-3:#CFD3D8;
  --hairline:#E4E2DB;
  --line:#E4E2DB;
  --line-faint:rgba(255,255,255,.10);

  /* ---- Type families ---- */
  --display:"Fraunces","Georgia",serif;
  --body:"Hanken Grotesk","Helvetica Neue",Arial,sans-serif;
  --serif:var(--display);
  --sans:var(--body);
  --fr-axes:"opsz" 144,"SOFT" 0,"WONK" 0;

  /* ---- Fluid type scale ---- */
  --fs-eyebrow:clamp(.68rem,.62rem + .25vw,.78rem);
  --fs-body:clamp(1rem,.97rem + .15vw,1.0625rem);
  --fs-lead:clamp(1.18rem,1.06rem + .55vw,1.45rem);
  --fs-h3:clamp(1.25rem,1.07rem + .85vw,1.6rem);
  --fs-h2:clamp(1.8rem,1.35rem + 2.1vw,2.85rem);
  --fs-h1:clamp(2.6rem,1.7rem + 4.4vw,5rem);
  --fs-display:clamp(3rem,1.6rem + 6.6vw,6.5rem);

  /* ---- 8pt spacing ---- */
  --s-1:4px; --s0:8px; --s1:16px; --s2:24px; --s3:32px; --s4:48px;
  --s5:64px; --s6:96px; --s7:128px; --s8:160px;

  /* ---- Layout ---- */
  --maxw:1200px;
  --gutter:clamp(20px,5vw,48px);
  --measure:62ch;
  --radius:4px;
  --radius-sm:2px;
}

/* ---- Reset ---- */
*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  font-family:var(--body); color:var(--ink); background:var(--paper);
  font-size:var(--fs-body); line-height:1.6; font-weight:400;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
img{ max-width:100%; display:block; }
a{ text-decoration:none; color:inherit; }
::selection{ background:var(--navy); color:#fff; }
:focus-visible{ outline:2px solid var(--gold); outline-offset:3px; }

.wrap{ max-width:var(--maxw); margin:0 auto; padding:0 var(--gutter); }
.serif{ font-family:var(--display); }

h1,h2,h3{
  font-family:var(--display); font-weight:600; line-height:1.05;
  letter-spacing:-.015em; font-variation-settings:var(--fr-axes);
}
h1{ font-size:var(--fs-h1); } h2{ font-size:var(--fs-h2); } h3{ font-size:var(--fs-h3); }

.kicker{
  font-family:var(--body); text-transform:uppercase; letter-spacing:.12em;
  font-size:var(--fs-eyebrow); font-weight:700; color:var(--gold);
  display:inline-flex; align-items:center; gap:10px;
}
.kicker::before{ content:""; width:24px; height:1px; background:var(--gold); display:inline-block; }

.skip-link{
  position:absolute; left:-9999px; top:0; background:var(--gold); color:#fff;
  padding:10px 16px; z-index:100; font-weight:600; border-radius:0 0 var(--radius) 0;
}
.skip-link:focus{ left:0; }

/* ============================================================ Buttons */
.btn{
  display:inline-block; font-family:var(--body); font-weight:600; font-size:.92rem;
  letter-spacing:.01em; padding:14px 28px; border-radius:var(--radius-sm);
  cursor:pointer; transition:background .2s,color .2s,border-color .2s; border:1px solid transparent;
  text-align:center;
}
.btn-gold{ background:var(--gold); color:#fff; border-color:var(--gold); }
.btn-gold:hover{ background:var(--gold-hover); border-color:var(--gold-hover); }
.btn-navy{ background:var(--navy); color:#fff; border-color:var(--navy); }
.btn-navy:hover{ background:var(--navy-deep); border-color:var(--navy-deep); }
.btn-outline{ background:transparent; color:var(--navy); border-color:var(--navy); }
.btn-outline:hover{ background:var(--navy); color:#fff; }
.btn-ghost{ background:transparent; border-color:rgba(255,255,255,.55); color:#fff; }
.btn-ghost:hover{ background:#fff; color:var(--navy); border-color:#fff; }
.btn-lg{ padding:17px 38px; font-size:1rem; }
.btn-block{ display:block; width:100%; }

/* ============================================================ Utility bar */
.util{ background:var(--navy-deep); color:#cdd7e6; font-size:.78rem; }
.util .wrap{ display:flex; justify-content:space-between; align-items:center;
  height:40px; letter-spacing:.04em; }
.util a{ color:#cdd7e6; margin-left:18px; transition:color .2s; }
.util a:hover{ color:#fff; }
.util .util-contact{ display:flex; align-items:center; }

/* ============================================================ Primary nav */
nav.main{ background:var(--navy); color:#fff; position:sticky; top:0; z-index:30;
  border-bottom:1px solid var(--line-faint); }
nav.main .wrap{ display:flex; align-items:center; height:76px; }
.brand{ font-family:var(--display); font-weight:600; font-size:1.3rem; letter-spacing:.5px;
  color:#fff; font-variation-settings:var(--fr-axes); }
.brand b{ color:var(--gold-soft); font-weight:600; }
.navlinks{ display:flex; gap:28px; margin-left:auto; font-size:.9rem; font-weight:500; }
.navlinks a{ color:#e6ebf3; padding:6px 0; border-bottom:2px solid transparent; transition:color .2s,border-color .2s; }
.navlinks a:hover{ color:var(--gold-soft); }
.navlinks a.active{ color:var(--gold-soft); border-bottom-color:var(--gold); }
.navcta{ display:flex; gap:12px; margin-left:30px; }
.nav-toggle{ display:none; margin-left:auto; background:none; border:0; cursor:pointer;
  width:42px; height:42px; padding:9px; }
.nav-toggle span{ display:block; height:2px; background:#fff; margin:5px 0; transition:.25s; }
.nav-toggle[aria-expanded="true"] span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] span:nth-child(2){ opacity:0; }
.nav-toggle[aria-expanded="true"] span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

/* ============================================================ Hero (home) */
.hero{ background:linear-gradient(160deg,#0A2A52 0%, #06203F 100%); color:#fff;
  position:relative; overflow:hidden; }
.hero::after{ content:""; position:absolute; right:-120px; top:-120px; width:420px;
  height:420px; border:1px solid rgba(196,154,69,.25); border-radius:50%; }
.hero .wrap{ display:grid; grid-template-columns:1.35fr .9fr; align-items:center; gap:clamp(32px,5vw,72px);
  padding:clamp(48px,7vw,104px) var(--gutter); position:relative; z-index:2; }
.hero-copy{ min-width:0; }
.hero h1{ font-size:var(--fs-display); margin:var(--s2) 0 var(--s2); letter-spacing:-.025em; }
.hero h1 .em{ color:var(--gold-soft); font-style:italic; font-weight:500; }
.hero p.sub{ font-size:var(--fs-lead); color:#cdd7e6; max-width:48ch; margin-bottom:var(--s3); line-height:1.45; }
.hero-cta{ display:flex; gap:14px; flex-wrap:wrap; }
.hero .kicker{ color:var(--gold-soft); }
.hero .kicker::before{ background:var(--gold-soft); }
.portrait{ display:flex; justify-content:center; }

/* Framed portrait (full colour) */
.medallion{ width:340px; max-width:80vw; border:1px solid rgba(196,154,69,.5);
  border-radius:var(--radius); background:rgba(255,255,255,.03); padding:12px; position:relative; }
.medallion::before{ content:""; position:absolute; inset:7px; border:1px solid rgba(196,154,69,.25);
  border-radius:3px; pointer-events:none; }
.medallion img{ width:100%; aspect-ratio:4/5; object-fit:cover; border-radius:3px; }
.medallion .ph-cap{ text-align:center; font-size:.7rem; letter-spacing:.14em;
  text-transform:uppercase; color:#8ea3c0; margin-top:12px; }

/* ============================================================ Trust strip */
.trust{ background:var(--navy-deep); color:#aebfd6; border-bottom:1px solid var(--line-faint); }
.trust .wrap{ display:flex; justify-content:center; gap:clamp(18px,3vw,40px); flex-wrap:wrap;
  padding:var(--s1) var(--gutter); font-size:.72rem; text-transform:uppercase; letter-spacing:.14em; }

/* ============================================================ Positioning band */
.posband{ padding:clamp(56px,8vw,112px) 0; border-bottom:1px solid var(--hairline); }
.posband .wrap{ max-width:980px; }
.posband h2{ font-size:clamp(1.9rem,1.2rem + 2.7vw,3.2rem); line-height:1.1; max-width:22ch; }
.posband h2 .g{ color:var(--gold); font-style:italic; font-weight:500; }

/* ============================================================ Section header */
#main{ counter-reset:sec; }
.sec-top{ margin-bottom:var(--s4); max-width:760px; counter-increment:sec; }
.sec-top::before{
  content:counter(sec,decimal-leading-zero);
  display:block; font-family:var(--display); font-variation-settings:var(--fr-axes);
  font-size:clamp(1.9rem,1.3rem + 1.8vw,2.75rem); font-weight:500; line-height:1;
  color:var(--gold); opacity:.55; margin-bottom:var(--s1); letter-spacing:-.02em;
}
.sec-top h2{ font-size:var(--fs-h2); margin-top:var(--s0); color:var(--navy); }
.sec-top p{ color:var(--muted); max-width:62ch; margin-top:var(--s1); }
.sec-top.center{ text-align:center; margin-left:auto; margin-right:auto; }

/* ============================================================ Cards */
.engage{ padding:clamp(56px,8vw,112px) 0; }
.cards{ display:grid; grid-template-columns:repeat(2,1fr); gap:24px; }
.cards.cols-3{ grid-template-columns:repeat(3,1fr); }
.card{ background:#fff; border:1px solid var(--hairline); border-radius:var(--radius);
  padding:var(--s4) var(--s3); transition:box-shadow .2s,transform .2s; }
.card:hover{ box-shadow:0 14px 40px rgba(10,42,82,.10); transform:translateY(-3px); }
.card .num{ font-family:var(--display); color:var(--gold); font-size:.95rem; letter-spacing:.1em;
  font-variation-settings:var(--fr-axes); }
.card h3{ font-size:var(--fs-h3); margin:var(--s1) 0 var(--s0); color:var(--navy); }
.card p{ color:var(--muted); margin-bottom:var(--s1); }
.card .lnk{ font-weight:600; font-size:.9rem; color:var(--navy);
  border-bottom:2px solid var(--gold); padding-bottom:2px; transition:color .2s; }
.card .lnk:hover{ color:var(--gold-hover); }

/* ============================================================ Book / feature band */
.book{ background:var(--navy); color:#fff; }
.book .wrap{ display:grid; grid-template-columns:230px 1fr; align-items:center; gap:clamp(32px,5vw,64px);
  padding:clamp(56px,8vw,104px) var(--gutter); }
.book-cover{ width:230px; height:330px; flex:none; background:linear-gradient(150deg,#123a6b,#06203F);
  border:1px solid rgba(196,154,69,.45); border-radius:3px; display:flex; flex-direction:column;
  align-items:center; justify-content:center; text-align:center; padding:26px; overflow:hidden; }
.book-cover img{ width:100%; height:100%; object-fit:cover; border-radius:3px; }
.book-cover .t{ font-family:var(--display); font-size:1.6rem; color:var(--gold-soft); line-height:1.14;
  font-variation-settings:var(--fr-axes); }
.book-cover .by{ font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; color:#aebfd6; margin-top:18px; }
.book-info h2{ font-size:var(--fs-h2); margin:var(--s0) 0 var(--s1); }
.book-info p{ color:#cdd7e6; font-size:1.05rem; max-width:54ch; margin-bottom:var(--s2); }
.book .kicker{ color:var(--gold-soft); }
.book .kicker::before{ background:var(--gold-soft); }

/* ============================================================ Circle / membership band */
.circle{ background:var(--paper); padding:clamp(56px,8vw,112px) 0; border-top:1px solid var(--hairline); }
.circle .panel{ background:#fff; border:1px solid var(--hairline); border-top:4px solid var(--gold);
  border-radius:var(--radius); padding:clamp(36px,5vw,60px); text-align:center; }
.circle h2{ font-size:var(--fs-h2); color:var(--navy); margin:var(--s0) 0 var(--s1); }
.circle p{ color:var(--muted); max-width:62ch; margin:0 auto var(--s2); }
.circle .feats{ display:flex; justify-content:center; gap:clamp(24px,4vw,48px); flex-wrap:wrap; margin-bottom:var(--s3); }
.circle .feat{ font-family:var(--display); color:var(--navy); font-size:1.1rem; font-variation-settings:var(--fr-axes); }
.circle .feat span{ display:block; font-family:var(--body); font-size:.7rem; letter-spacing:.14em;
  text-transform:uppercase; color:var(--gold); margin-top:6px; }

/* ============================================================ About / split */
.about{ padding:clamp(56px,8vw,112px) 0; }
.about .wrap{ display:grid; grid-template-columns:340px 1fr; gap:clamp(32px,5vw,72px); align-items:center; }
.about.reverse .wrap{ grid-template-columns:1fr 340px; }
.about.reverse .about-img{ order:2; }
.about-img{ border:1px solid var(--hairline); border-radius:var(--radius); overflow:hidden; background:#e8e2d4; }
.about-img img{ width:100%; aspect-ratio:4/5; object-fit:cover; }
.about-copy h2{ font-size:var(--fs-h2); color:var(--navy); margin:var(--s0) 0 var(--s2); }
.about-copy p{ color:#4b5159; margin-bottom:var(--s1); }

/* ============================================================ Email capture band */
.capture{ background:var(--navy-deep); color:#fff; text-align:center; padding:clamp(56px,8vw,104px) var(--gutter); }
.capture h2{ font-size:var(--fs-h2); margin-bottom:var(--s1); }
.capture p{ color:#aebfd6; margin-bottom:var(--s3); max-width:54ch; margin-left:auto; margin-right:auto; }
.capform{ display:flex; gap:10px; justify-content:center; flex-wrap:wrap; }
.capform input{ padding:14px 18px; border:none; border-radius:var(--radius-sm);
  width:320px; max-width:80vw; font-family:var(--body); font-size:.95rem; }

/* ============================================================ Page header (inner) */
.page-head{ background:linear-gradient(160deg,#0A2A52 0%, #06203F 100%); color:#fff; position:relative; overflow:hidden; }
.page-head::after{ content:""; position:absolute; right:-140px; top:-140px; width:380px; height:380px;
  border:1px solid rgba(196,154,69,.22); border-radius:50%; }
.page-head .wrap{ padding:clamp(56px,8vw,104px) var(--gutter); max-width:920px; position:relative; z-index:2; }
.page-head .kicker{ color:var(--gold-soft); }
.page-head .kicker::before{ background:var(--gold-soft); }
.page-head h1{ font-size:var(--fs-h1); margin:var(--s2) 0 var(--s1); }
.page-head p{ color:#cdd7e6; font-size:var(--fs-lead); max-width:60ch; }

/* ============================================================ Content section */
.section{ padding:clamp(56px,8vw,112px) 0; }
.section.tight{ padding:clamp(40px,5vw,64px) 0; }
.section.alt{ background:#fff; border-top:1px solid var(--hairline); border-bottom:1px solid var(--hairline); }
.prose{ max-width:var(--measure); }
.prose h2{ font-size:var(--fs-h2); color:var(--navy); margin:var(--s4) 0 var(--s1); }
.prose h3{ font-size:var(--fs-h3); color:var(--navy); margin:var(--s3) 0 var(--s0); }
.prose p{ color:#4b5159; margin-bottom:var(--s1); }
.prose ul{ margin:0 0 var(--s2) var(--s2); color:#4b5159; }
.prose li{ margin-bottom:var(--s0); }
.lead{ font-size:var(--fs-lead); color:var(--ink); line-height:1.45; }

.split{ display:grid; grid-template-columns:1.3fr 1fr; gap:clamp(32px,5vw,64px); align-items:flex-start; }

/* Feature list with gold tick */
.ticks{ list-style:none; margin:0; }
.ticks li{ position:relative; padding-left:30px; margin-bottom:var(--s1); color:#4b5159; }
.ticks li::before{ content:"✦"; position:absolute; left:0; top:0; color:var(--gold); }

/* Pricing / offer panel */
.offer{ background:#fff; border:1px solid var(--hairline); border-top:4px solid var(--gold);
  border-radius:var(--radius); padding:var(--s4) var(--s3); }
.offer .price{ font-family:var(--display); font-size:clamp(2.2rem,1.6rem + 2vw,3rem); color:var(--navy);
  font-variation-settings:var(--fr-axes); }
.offer .price small{ font-family:var(--body); font-size:.85rem; color:var(--muted); font-weight:500; }
.offer h3{ font-size:var(--fs-h3); color:var(--navy); margin-bottom:var(--s0); }

/* ============================================================ Forms */
.form-card{ background:#fff; border:1px solid var(--hairline); border-radius:var(--radius); padding:var(--s4) var(--s3); }
.form-row{ margin-bottom:var(--s1); }
.form-row.two{ display:grid; grid-template-columns:1fr 1fr; gap:var(--s1); }
label{ display:block; font-size:.72rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase;
  color:var(--navy); margin-bottom:7px; }
input,select,textarea{ width:100%; padding:13px 14px; border:1px solid var(--hairline);
  border-radius:var(--radius-sm); font-family:var(--body); font-size:1rem; color:var(--ink); background:#fff; }
input:focus,select:focus,textarea:focus{ outline:none; border-color:var(--gold); box-shadow:0 0 0 3px rgba(196,154,69,.15); }
textarea{ min-height:130px; resize:vertical; }
.form-note{ font-size:.8rem; color:var(--muted); margin-top:10px; }
.form-status{ margin-top:16px; font-size:.9rem; font-weight:600; display:none; }
.form-status.show{ display:block; }
.form-status.ok{ color:#1f7a4d; }
.form-status.err{ color:#b23b3b; }

/* ============================================================ Donate / payment (legacy) */
.pay-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:var(--s2); align-items:stretch; }
.pay-card{ background:#fff; border:1px solid var(--hairline); border-radius:var(--radius); padding:var(--s3); display:flex; flex-direction:column; }
.pay-card h3{ font-size:var(--fs-h3); color:var(--navy); margin-bottom:var(--s0); }
.pay-card p{ color:var(--muted); font-size:.95rem; margin-bottom:var(--s2); }
.pay-card .btn{ margin-top:auto; }
.amount-row{ display:flex; gap:10px; flex-wrap:wrap; margin-bottom:var(--s1); }
.amount-row .chip{ border:1px solid var(--hairline); border-radius:var(--radius-sm); padding:10px 18px; cursor:pointer;
  font-weight:600; color:var(--navy); background:#fff; transition:.15s; }
.amount-row .chip:hover,.amount-row .chip.sel{ background:var(--navy); color:#fff; border-color:var(--navy); }

.slot{ display:none; }

/* ============================================================ Book / shop grid */
.shop-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:var(--s3); }
.shop-item .cover{ aspect-ratio:230/330; border:1px solid var(--hairline); border-radius:3px; overflow:hidden;
  background:linear-gradient(150deg,#123a6b,#06203F); display:flex; align-items:center; justify-content:center; padding:22px; }
.shop-item .cover .t{ font-family:var(--display); color:var(--gold-soft); font-size:1.25rem; font-variation-settings:var(--fr-axes); }
.shop-item img{ width:100%; height:100%; object-fit:cover; }
.shop-item h3{ font-size:1.1rem; color:var(--navy); margin:var(--s1) 0 var(--s-1); }
.shop-item .author{ font-size:.8rem; color:var(--muted); margin-bottom:var(--s0); }

/* ============================================================ FAQ */
.faq{ max-width:820px; margin:0 auto; }
.faq details{ border-bottom:1px solid var(--hairline); padding:var(--s2) 0; }
.faq summary{ font-family:var(--display); font-size:1.2rem; color:var(--navy); cursor:pointer; list-style:none;
  display:flex; justify-content:space-between; align-items:center; gap:16px; font-variation-settings:var(--fr-axes); }
.faq summary::-webkit-details-marker{ display:none; }
.faq summary::after{ content:"+"; color:var(--gold); font-size:1.5rem; font-family:var(--body); transition:.2s; }
.faq details[open] summary::after{ transform:rotate(45deg); }
.faq details p{ color:#4b5159; margin-top:12px; }

/* ============================================================ CTA strip */
.cta-strip{ background:var(--navy); color:#fff; text-align:center; padding:clamp(48px,7vw,88px) var(--gutter); }
.cta-strip h2{ font-size:var(--fs-h2); margin-bottom:var(--s1); }
.cta-strip p{ color:#cdd7e6; max-width:56ch; margin:0 auto var(--s3); }

/* ============================================================ Contact info */
.info-list{ list-style:none; margin:0; }
.info-list li{ margin-bottom:var(--s2); }
.info-list .lbl{ font-size:.7rem; text-transform:uppercase; letter-spacing:.14em; color:var(--gold);
  font-weight:700; margin-bottom:4px; }
.info-list a,.info-list span{ font-size:1.05rem; color:var(--navy); font-family:var(--display); font-variation-settings:var(--fr-axes); }
.socials{ display:flex; gap:16px; margin-top:8px; }
.socials a{ font-size:.9rem; color:var(--navy); border-bottom:2px solid var(--gold); }

/* ============================================================ Footer */
footer{ background:var(--navy-darker); color:#9fb1c9; padding:var(--s5) 0 var(--s3); font-size:.9rem; }
footer .grid{ display:flex; justify-content:space-between; gap:var(--s4); flex-wrap:wrap;
  padding-bottom:var(--s3); border-bottom:1px solid var(--line-faint); }
footer h4{ color:#fff; font-family:var(--display); font-size:1.1rem; margin-bottom:var(--s1); font-weight:600;
  font-variation-settings:var(--fr-axes); }
footer a{ color:#9fb1c9; display:block; margin-bottom:7px; transition:color .2s; }
footer a:hover{ color:var(--gold-soft); }
.foot-bottom{ display:flex; justify-content:space-between; padding-top:var(--s2); font-size:.78rem;
  color:#6f82a0; flex-wrap:wrap; gap:10px; }
.credit{ color:var(--gold-soft); }

/* ============================================================ Motion */
@media (prefers-reduced-motion:no-preference){
  .reveal{ opacity:0; transform:translateY(16px); transition:opacity .6s ease, transform .6s ease; }
  .reveal.in{ opacity:1; transform:none; }
}

/* ============================================================ Responsive */
@media(max-width:980px){
  .shop-grid{ grid-template-columns:repeat(2,1fr); }
  .cards.cols-3{ grid-template-columns:1fr 1fr; }
}
@media(max-width:820px){
  .hero .wrap,.book .wrap,.about .wrap,.about.reverse .wrap,.split{ grid-template-columns:1fr; }
  .about.reverse .about-img{ order:0; }
  .portrait{ order:-1; }
  .cards,.cards.cols-3,.pay-grid{ grid-template-columns:1fr; }
  .book .wrap{ text-align:center; justify-items:center; }
  .navcta{ display:none; }
  .navlinks{
    display:none; position:absolute; top:76px; left:0; right:0; background:var(--navy);
    flex-direction:column; gap:0; padding:8px 0; border-bottom:1px solid var(--line-faint);
    box-shadow:0 18px 40px rgba(0,0,0,.3);
  }
  nav.main .wrap{ position:relative; flex-wrap:wrap; }
  .navlinks.open{ display:flex; }
  .navlinks a{ padding:14px var(--gutter); border-bottom:1px solid var(--line-faint); }
  .navlinks.open + .navcta,.navcta.open{ display:flex; padding:16px var(--gutter); gap:12px; }
  .nav-toggle{ display:block; }
  .util .wrap{ font-size:.72rem; }
}
@media(max-width:560px){
  .shop-grid{ grid-template-columns:1fr; }
  .cards.cols-3{ grid-template-columns:1fr; }
  .form-row.two{ grid-template-columns:1fr; }
  .util .util-org{ display:none; }
}
