/* ============================================================
   Pragma — Marketing site design system
   Porcelain kintsugi: white ground, cobalt painting, gold mends.
   ============================================================ */

:root{
  --bone:#ffffff; --paper:#ffffff; --paper-2:#f5f6fb; --paper-3:#eef0f9;
  --ink:#1b1d58; --ink-2:#4f5388; --ink-3:#9195bf;
  --line:rgba(40,35,130,.16); --line-2:rgba(40,35,130,.08);
  --cobalt:#282382; --cobalt-soft:#3a37a0; --cobalt-deep:#15154c;
  --slate:#4a4f8f;
  --gold:#d38e31; --gold-deep:#8f5d1a; --gold-hi:#ebad4a;
  --porcelain-fill:#ffffff;
  --accent:var(--cobalt);
  --maxw:1160px;
  --radius:5px;
  --offset:5px 5px 0 var(--gold);
  --display:'Fraunces',Georgia,serif;
  --sans:'Hanken Grotesk',system-ui,-apple-system,sans-serif;
  --mono:'Space Mono',ui-monospace,monospace;
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  margin:0; background:var(--bone); color:var(--ink);
  font-family:var(--sans); font-size:17px; line-height:1.6;
  -webkit-font-smoothing:antialiased; font-feature-settings:"ss01";
  overflow-x:hidden;
}
::selection{ background:var(--cobalt); color:#fff; }
img,svg{ max-width:100%; display:block; }
a{ color:inherit; }

/* RTL */
[dir="rtl"]{ --offset:-5px 5px 0 var(--gold); }
[dir="rtl"] body{ font-family:'Cairo',var(--sans); }

/* ---------- layout ---------- */
.wrap{ width:100%; max-width:var(--maxw); margin:0 auto; padding:0 28px; }
.wrap--narrow{ max-width:760px; }
.wrap--mid{ max-width:920px; }
section{ position:relative; }
.sec{ padding:84px 0; }
.sec--tight{ padding:56px 0; }
.bg-soft{ background:var(--paper-2); }
.bg-deep{ background:var(--cobalt-deep); color:#eef0fb; }
.bg-deep .pg-mono{ color:var(--gold-hi); }
.bg-deep h2,.bg-deep h3,.bg-deep .h-serif{ color:#fff; }

/* ---------- type ---------- */
.pg-mono{ font-family:var(--mono); font-size:12px; letter-spacing:.16em;
  text-transform:uppercase; color:var(--ink-2); font-weight:400; margin:0; }
.pg-mono.gold{ color:var(--gold-deep); }
.pg-mono.accent{ color:var(--cobalt); }
.eyebrow{ display:inline-flex; align-items:center; gap:9px; }
.eyebrow::before{ content:""; width:22px; height:1px; background:var(--gold); }

h1,h2,h3,h4{ font-family:var(--display); font-weight:400; color:var(--ink);
  letter-spacing:-.015em; margin:0; text-wrap:balance; font-optical-sizing:auto; }
h1{ font-size:clamp(40px,6vw,68px); line-height:1.02; font-weight:300; }
h2{ font-size:clamp(30px,4vw,46px); line-height:1.06; }
h3{ font-size:clamp(22px,2.4vw,27px); line-height:1.14; }
h4{ font-size:20px; line-height:1.2; }
.h-serif{ font-family:var(--display); }
.lede{ font-size:clamp(18px,2vw,21px); line-height:1.55; color:var(--ink-2); margin:0; text-wrap:pretty; }
p{ margin:0 0 1.1em; text-wrap:pretty; }
.prose p{ font-size:17.5px; line-height:1.7; color:var(--ink-2); }
.prose h2{ margin:1.6em 0 .5em; }
.prose h3{ margin:1.5em 0 .4em; color:var(--ink); }
.prose ul,.prose ol{ color:var(--ink-2); line-height:1.7; padding-left:1.2em; }
.prose li{ margin:.4em 0; }
.prose strong{ color:var(--ink); font-weight:600; }
.prose a{ color:var(--cobalt); text-decoration:underline; text-decoration-color:var(--line);
  text-underline-offset:3px; }
.prose a:hover{ text-decoration-color:var(--gold); }
.measure{ max-width:62ch; }

/* ---------- rules / kintsugi seam ---------- */
.rule{ height:1px; background:var(--line); border:0; margin:0; }
.seam{ width:100%; height:18px; display:block; }

/* ---------- buttons ---------- */
.btn{ display:inline-flex; align-items:center; justify-content:center; gap:9px;
  font-family:var(--sans); font-weight:600; font-size:16px; line-height:1;
  padding:16px 26px; min-height:54px; border-radius:var(--radius);
  border:1px solid var(--ink); background:var(--ink); color:#fff; cursor:pointer;
  text-decoration:none; transition:transform .14s ease, box-shadow .14s ease, background .16s; }
.btn--primary{ box-shadow:var(--offset); }
.btn--primary:hover{ transform:translate(2px,2px); box-shadow:2px 2px 0 var(--gold); }
.btn--accent{ background:var(--cobalt); border-color:var(--cobalt); }
.btn--ghost{ background:transparent; color:var(--ink); box-shadow:none; }
.btn--ghost:hover{ background:var(--ink); color:#fff; }
.btn--light{ background:#fff; color:var(--cobalt-deep); border-color:#fff; }
.btn--sm{ min-height:44px; padding:11px 18px; font-size:14px; }
.btn--lg{ min-height:58px; padding:18px 32px; font-size:17px; }
.btn-row{ display:flex; flex-wrap:wrap; gap:14px; align-items:center; }
.textlink{ color:var(--cobalt); font-weight:600; text-decoration:none;
  border-bottom:1.5px solid var(--line); padding-bottom:2px; transition:border-color .15s; }
.textlink:hover{ border-color:var(--gold); }
.textlink.arrow::after{ content:" →"; }

/* ---------- tags / chips ---------- */
.tag{ display:inline-flex; align-items:center; gap:7px; font-family:var(--mono);
  font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-2);
  border:1px solid var(--line); border-radius:999px; padding:6px 13px; }
.tag .dot{ width:6px; height:6px; border-radius:50%; background:var(--gold); }
.pill-store{ display:inline-flex; align-items:center; gap:10px; padding:11px 18px;
  border:1px solid var(--line); border-radius:10px; background:#fff; text-decoration:none;
  color:var(--ink); transition:border-color .15s, box-shadow .15s; min-width:170px; }
.pill-store:hover{ border-color:var(--ink); box-shadow:3px 3px 0 var(--gold); }
.pill-store .s1{ font-family:var(--mono); font-size:9.5px; letter-spacing:.12em;
  text-transform:uppercase; color:var(--ink-3); }
.pill-store .s2{ font-family:var(--display); font-size:18px; line-height:1; }

/* ---------- cards ---------- */
.card{ background:var(--paper); border:1px solid var(--line); border-radius:var(--radius);
  padding:28px; }
.card--hero{ border-color:var(--ink); box-shadow:var(--offset); }
.grid{ display:grid; gap:22px; }
.grid-2{ grid-template-columns:repeat(2,1fr); }
.grid-3{ grid-template-columns:repeat(3,1fr); }
.grid-4{ grid-template-columns:repeat(4,1fr); }

/* ---------- header / nav ---------- */
.site-header{ position:sticky; top:0; z-index:40; background:rgba(255,255,255,.86);
  backdrop-filter:saturate(140%) blur(12px); border-bottom:1px solid var(--line-2); }
.nav{ display:flex; align-items:center; justify-content:space-between; height:70px; gap:24px; }
.brand{ display:inline-flex; align-items:center; gap:11px; text-decoration:none; color:var(--ink); }
.brand .bmark{ width:34px; height:auto; flex:0 0 auto; }
.brand .bname{ font-family:var(--display); font-size:25px; letter-spacing:-.02em; }
.brand .bname .dot{ color:var(--gold); }
.hero h1 .dot, .cta-band h2 .dot, .art-head h1 .dot, .section-head h2 .dot{ color:var(--gold); font-style:normal; }
.nav-links{ display:flex; align-items:center; gap:7px; }
.nav-links a{ text-decoration:none; color:var(--ink-2); font-weight:500; font-size:15px;
  padding:9px 13px; border-radius:6px; transition:color .15s, background .15s; }
.nav-links a:hover{ color:var(--ink); background:var(--paper-2); }
.nav-cta{ display:flex; align-items:center; gap:12px; }
.nav-toggle{ display:none; }
.lang-switch{ position:relative; }
.lang-btn{ display:inline-flex; align-items:center; gap:7px; font-family:var(--mono);
  font-size:11px; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-2);
  background:transparent; border:1px solid var(--line); border-radius:999px;
  padding:8px 12px; cursor:pointer; }
.lang-menu{ position:absolute; top:calc(100% + 8px); right:0; background:#fff;
  border:1px solid var(--line); border-radius:8px; padding:6px; min-width:170px;
  box-shadow:0 16px 40px -16px rgba(21,21,76,.3); display:none; }
.lang-menu.open{ display:block; }
[dir="rtl"] .lang-menu{ right:auto; left:0; }
.lang-menu a{ display:flex; justify-content:space-between; gap:12px; text-decoration:none;
  color:var(--ink); padding:9px 11px; border-radius:6px; font-size:14px; }
.lang-menu a:hover{ background:var(--paper-2); }
.lang-menu a .nat{ color:var(--ink-3); font-family:var(--mono); font-size:11px; }

/* ---------- hero ---------- */
.hero{ padding:72px 0 60px; position:relative; overflow:hidden; }
.hero-grid{ display:grid; grid-template-columns:1.05fr .95fr; gap:54px; align-items:center; }
.hero h1{ margin-bottom:22px; }
.hero .lede{ margin-bottom:30px; max-width:36ch; }
.hero-trust{ display:flex; flex-wrap:wrap; gap:22px; margin-top:30px; align-items:center; }
.hero-trust .item{ display:flex; align-items:center; gap:9px; font-size:13.5px; color:var(--ink-2); }
.hero-trust .item svg{ width:18px; height:18px; flex:0 0 auto; color:var(--gold-deep); }
.hero-art{ position:relative; display:flex; align-items:center; justify-content:center; min-height:420px; }

/* phone mock for hero */
.phone{ width:300px; height:610px; border-radius:42px; background:#10122e; padding:11px;
  box-shadow:0 40px 90px -30px rgba(21,21,76,.5), 0 0 0 1px rgba(21,21,76,.1);
  position:relative; }
.phone-screen{ width:100%; height:100%; border-radius:32px; overflow:hidden; background:#fff;
  position:relative; display:flex; flex-direction:column; }
.phone-notch{ position:absolute; top:0; left:50%; transform:translateX(-50%); width:120px;
  height:26px; background:#10122e; border-radius:0 0 16px 16px; z-index:3; }

/* ---------- feature / step blocks ---------- */
.section-head{ max-width:680px; margin:0 auto 50px; text-align:center; }
.section-head.left{ margin-left:0; text-align:left; }
.section-head .eyebrow{ margin-bottom:16px; }
.section-head h2{ margin-bottom:16px; }
.steps{ counter-reset:step; }
.step{ display:grid; grid-template-columns:auto 1fr; gap:24px; padding:26px 0;
  border-top:1px solid var(--line); }
.step .num{ font-family:var(--mono); font-size:13px; color:var(--gold-deep); padding-top:5px; }
.feature{ display:flex; flex-direction:column; gap:13px; }
.feature .ic{ width:46px; height:46px; border-radius:10px; border:1px solid var(--line);
  display:flex; align-items:center; justify-content:center; color:var(--cobalt); }
.feature .ic svg{ width:24px; height:24px; }
.feature h3{ font-size:21px; }
.feature p{ color:var(--ink-2); font-size:15.5px; margin:0; }

/* method chips */
.methods{ display:flex; flex-wrap:wrap; gap:12px; }
.method{ border:1px solid var(--line); border-radius:999px; padding:10px 18px;
  display:flex; align-items:center; gap:10px; background:#fff; }
.method .ab{ font-family:var(--mono); font-size:11px; color:var(--gold-deep); }
.method .nm{ font-family:var(--display); font-size:17px; }

/* stat band */
.stat-band{ display:grid; grid-template-columns:repeat(4,1fr); gap:0;
  border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; }
.stat-band .st{ padding:28px 26px; border-right:1px solid var(--line); }
.stat-band .st:last-child{ border-right:0; }
.stat-band .big{ font-family:var(--display); font-size:40px; font-weight:300; line-height:1; }
.stat-band .lab{ margin-top:9px; }

/* pricing */
.price-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; align-items:stretch; }
.price{ background:#fff; border:1px solid var(--line); border-radius:8px; padding:30px 26px;
  display:flex; flex-direction:column; }
.price.featured{ border-color:var(--ink); box-shadow:var(--offset); }
.price .ribbon{ align-self:flex-start; font-family:var(--mono); font-size:10px; letter-spacing:.12em;
  text-transform:uppercase; color:#fff; background:var(--gold-deep); border-radius:999px;
  padding:5px 11px; margin-bottom:14px; }
.price .amt{ font-family:var(--display); font-size:48px; font-weight:300; line-height:1; }
.price .per{ color:var(--ink-3); font-size:14px; }
.price .billed{ margin-top:6px; color:var(--ink-2); font-size:14px; }
.price ul{ list-style:none; padding:0; margin:20px 0 24px; display:flex; flex-direction:column; gap:11px; }
.price li{ display:flex; gap:10px; font-size:15px; color:var(--ink-2); align-items:flex-start; }
.price li svg{ width:18px; height:18px; flex:0 0 auto; color:var(--gold-deep); margin-top:2px; }

/* FAQ accordion */
.faq{ border-top:1px solid var(--line); }
.faq details{ border-bottom:1px solid var(--line); }
.faq summary{ list-style:none; cursor:pointer; padding:22px 0; display:flex;
  justify-content:space-between; gap:20px; align-items:center; font-family:var(--display);
  font-size:20px; color:var(--ink); }
.faq summary::-webkit-details-marker{ display:none; }
.faq summary .chev{ width:22px; height:22px; flex:0 0 auto; color:var(--gold-deep);
  transition:transform .2s; }
.faq details[open] summary .chev{ transform:rotate(45deg); }
.faq .ans{ padding:0 0 24px; color:var(--ink-2); font-size:16px; line-height:1.65; max-width:68ch; }
.faq .ans p{ margin:0 0 .9em; }

/* quote / testimonial */
.quote{ font-family:var(--display); font-weight:300; font-size:clamp(22px,2.7vw,30px);
  line-height:1.32; letter-spacing:-.01em; }
.quote-card{ background:var(--paper-2); border:1px solid var(--line); border-radius:var(--radius);
  padding:30px; display:flex; flex-direction:column; gap:18px; }
.quote-card .who{ display:flex; align-items:center; gap:11px; }

/* CTA band */
.cta-band{ background:var(--cobalt-deep); color:#fff; border-radius:14px; padding:54px 48px;
  text-align:center; position:relative; overflow:hidden; }
.cta-band h2{ color:#fff; margin-bottom:14px; }
.cta-band .lede{ color:#c7cdf0; margin:0 auto 26px; max-width:46ch; }

/* breadcrumbs */
.crumbs{ font-family:var(--mono); font-size:11px; letter-spacing:.06em; text-transform:uppercase;
  color:var(--ink-3); padding:22px 0 0; display:flex; gap:8px; flex-wrap:wrap; }
.crumbs a{ color:var(--ink-2); text-decoration:none; }
.crumbs a:hover{ color:var(--cobalt); }
.crumbs span{ color:var(--ink-3); }

/* article header */
.art-head{ padding:30px 0 40px; border-bottom:1px solid var(--line); margin-bottom:40px; }
.art-head h1{ font-size:clamp(34px,5vw,52px); margin:16px 0 18px; }
.art-meta{ display:flex; gap:16px; flex-wrap:wrap; align-items:center; color:var(--ink-3);
  font-size:13px; }
.toc{ background:var(--paper-2); border:1px solid var(--line); border-radius:var(--radius);
  padding:22px 24px; margin:0 0 34px; }
.toc .pg-mono{ margin-bottom:12px; }
.toc ol{ margin:0; padding-left:1.2em; color:var(--cobalt); }
.toc a{ text-decoration:none; color:var(--cobalt); }
.toc a:hover{ text-decoration:underline; }
.callout{ border-left:3px solid var(--gold); background:var(--paper-2); padding:18px 22px;
  border-radius:0 var(--radius) var(--radius) 0; margin:24px 0; }
.callout .pg-mono{ margin-bottom:8px; }
[dir="rtl"] .callout{ border-left:0; border-right:3px solid var(--gold);
  border-radius:var(--radius) 0 0 var(--radius); }

/* related cards */
.related{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.related a{ text-decoration:none; color:inherit; }
.rcard{ border:1px solid var(--line); border-radius:var(--radius); padding:22px; height:100%;
  transition:border-color .15s, box-shadow .15s; }
.rcard:hover{ border-color:var(--ink); box-shadow:4px 4px 0 var(--gold); }
.rcard .pg-mono{ margin-bottom:10px; }
.rcard h3{ font-size:19px; margin-bottom:8px; }
.rcard p{ font-size:14.5px; color:var(--ink-2); margin:0; }

/* ---------- footer ---------- */
.site-footer{ background:var(--cobalt-deep); color:#dfe3f7; padding:60px 0 36px;
  box-shadow:inset 0 3px 0 var(--gold); }
.foot-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:34px; }
.site-footer .brand .bname{ color:#fff; }
.site-footer h5{ font-family:var(--mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase;
  color:var(--gold-hi); margin:0 0 16px; font-weight:400; }
.site-footer ul{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:11px; }
.site-footer a{ color:#dfe3f7; text-decoration:none; font-size:14.5px; transition:color .15s; }
.site-footer a:hover{ color:var(--gold-hi); }
.site-footer .brand:hover .bname{ color:#fff; }
.foot-lead{ color:#c4caee; font-size:14.5px; max-width:34ch; }
.foot-bottom{ display:flex; justify-content:space-between; gap:20px; flex-wrap:wrap;
  align-items:center; margin-top:46px; padding-top:24px; border-top:1px solid rgba(235,173,74,.28);
  font-size:13px; color:#b7bde6; }
.foot-disclaim{ max-width:68ch; line-height:1.65; margin:0; }
.foot-disclaim strong{ color:#eaedfb; font-weight:600; }

/* ---------- utilities ---------- */
.center{ text-align:center; }
.mt-s{ margin-top:14px; } .mt-m{ margin-top:26px; } .mt-l{ margin-top:44px; }
.muted{ color:var(--ink-3); }
.hide{ display:none !important; }
.nowrap{ white-space:nowrap; }
.fadein{ opacity:0; transform:translateY(14px); transition:opacity .6s ease, transform .6s ease; }
.fadein.in{ opacity:1; transform:none; }

/* ---------- motion / animation ---------- */
/* hero entrance on load */
.hero-copy > *{ transform:translateY(16px); }
.hero-art{ transform:translateY(20px); }
body.loaded .hero-copy > *{ animation:pgRise .7s cubic-bezier(.2,.75,.25,1) forwards; }
body.loaded .hero-copy > *:nth-child(1){ animation-delay:.04s; }
body.loaded .hero-copy > *:nth-child(2){ animation-delay:.12s; }
body.loaded .hero-copy > *:nth-child(3){ animation-delay:.20s; }
body.loaded .hero-copy > *:nth-child(4){ animation-delay:.28s; }
body.loaded .hero-copy > *:nth-child(5){ animation-delay:.36s; }
body.loaded .hero-art{ animation:pgRise .9s .22s cubic-bezier(.2,.75,.25,1) forwards; }
@keyframes pgRise{ to{ transform:none; } }
/* gentle phone float */
.phone{ animation:pgFloat 7s ease-in-out infinite; will-change:transform; }
@keyframes pgFloat{ 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(-11px); } }
/* gold seam draws itself in (the "mend") */
.seam svg{ clip-path:inset(0 100% 0 0); transition:none; }
.seam.drawn svg{ animation:pgSeam 1.15s cubic-bezier(.4,0,.2,1) forwards; }
@keyframes pgSeam{ to{ clip-path:inset(0 0 0 0); } }
/* method chips + feature cards subtle hover lift */
.method{ transition:border-color .15s, box-shadow .15s, transform .15s; }
.method:hover{ border-color:var(--ink); box-shadow:3px 3px 0 var(--gold); transform:translateY(-1px); }
.feature.card{ transition:border-color .15s, box-shadow .15s, transform .15s; }
.feature.card:hover{ border-color:var(--ink); box-shadow:5px 5px 0 var(--gold); transform:translateY(-2px); }
@media (prefers-reduced-motion: reduce){
  .hero-copy > *, .hero-art{ opacity:1 !important; transform:none !important; animation:none !important; }
  .phone{ animation:none !important; }
  .seam svg{ clip-path:none !important; animation:none !important; }
}
@media (prefers-reduced-motion: reduce){ .fadein{ opacity:1; transform:none; transition:none; } html{ scroll-behavior:auto; } }

/* ---------- responsive ---------- */
@media (max-width: 940px){
  .hero-grid{ grid-template-columns:1fr; gap:40px; }
  .hero-art{ min-height:auto; order:-1; }
  .grid-3,.grid-4{ grid-template-columns:repeat(2,1fr); }
  .price-grid{ grid-template-columns:1fr; max-width:460px; margin:0 auto; }
  .stat-band{ grid-template-columns:repeat(2,1fr); }
  .stat-band .st:nth-child(2){ border-right:0; }
  .stat-band .st:nth-child(-n+2){ border-bottom:1px solid var(--line); }
  .foot-grid{ grid-template-columns:1fr 1fr; gap:30px; }
  .related{ grid-template-columns:1fr; }
}
@media (max-width: 680px){
  body{ font-size:16px; }
  .sec{ padding:60px 0; }
  .wrap{ padding:0 20px; }
  .nav-links, .nav-desktop-only{ display:none; }
  .nav-toggle{ display:inline-flex; }
  .grid-2,.grid-3,.grid-4{ grid-template-columns:1fr; }
  .stat-band{ grid-template-columns:1fr; }
  .stat-band .st{ border-right:0; border-bottom:1px solid var(--line); }
  .stat-band .st:last-child{ border-bottom:0; }
  .foot-grid{ grid-template-columns:1fr; }
  .cta-band{ padding:40px 24px; }
  .mobile-nav.open{ display:block; }
}

/* ---------- blog 3-column reading layout ---------- */
.blog-layout{ display:grid; grid-template-columns:220px minmax(0,660px) 300px; gap:46px;
  justify-content:center; align-items:start; max-width:1280px; margin:0 auto; padding:26px 28px 0; }
.blog-aside{ position:sticky; top:90px; align-self:start; max-height:calc(100vh - 110px); overflow:auto; }
.blog-aside::-webkit-scrollbar{ width:0; }
.blog-toc{ border-left:1px solid var(--line); }
.blog-toc .pg-mono{ margin:0 0 12px; padding-left:17px; }
.blog-toc ol{ list-style:none; margin:0; padding:0; counter-reset:t; }
.blog-toc a{ display:block; text-decoration:none; color:var(--ink-3); font-size:14px;
  line-height:1.35; padding:8px 0 8px 17px; margin-left:-1px; border-left:2px solid transparent;
  transition:color .15s, border-color .15s; }
.blog-toc a:hover{ color:var(--ink); }
.blog-toc a.active{ color:var(--cobalt); border-color:var(--gold); font-weight:600; }
.blog-main{ min-width:0; }
.blog-main .art-head{ padding-top:0; }
.blog-promo{ position:relative; overflow:hidden; background:var(--cobalt-deep); color:#fff;
  border-radius:14px; padding:26px 22px; box-shadow:var(--offset); }
.blog-promo .pg-mono{ color:var(--gold-hi); margin:0 0 10px; }
.blog-promo h3{ color:#fff; font-size:22px; line-height:1.1; margin:0 0 10px; }
.blog-promo p{ color:#c2c8ee; font-size:14px; line-height:1.5; margin:0 0 18px; }
.blog-promo .btn{ width:100%; }
.blog-promo .fine{ margin:14px 0 0; font-size:12px; color:#9298d4; }
.blog-promo .promo-feats{ list-style:none; margin:0 0 18px; padding:0; display:flex; flex-direction:column; gap:9px; }
.blog-promo .promo-feats li{ display:flex; gap:9px; align-items:flex-start; font-size:13.5px; color:#dfe3f7; margin:0; }
.blog-promo .promo-feats svg{ width:16px; height:16px; flex:0 0 auto; color:var(--gold-hi); margin-top:2px; }
@media (max-width:1140px){
  .blog-layout{ grid-template-columns:200px minmax(0,1fr); }
  .blog-aside.right{ display:none; }
}
@media (max-width:820px){
  .blog-layout{ grid-template-columns:1fr; padding-top:8px; gap:24px; }
  .blog-aside{ position:static; max-height:none; }
  .blog-aside.left{ display:none; }
}

/* mobile slide nav */
.mobile-nav{ display:none; position:fixed; inset:70px 0 0; background:#fff; z-index:39;
  padding:24px 28px; overflow-y:auto; }
.mobile-nav a{ display:block; text-decoration:none; color:var(--ink); font-family:var(--display);
  font-size:24px; padding:14px 0; border-bottom:1px solid var(--line); }
