/* K12 Atlas — editorial system, MOBILE-FIRST.
   Adapted from Safety Atlas design tokens (cream paper / Fraunces serif /
   IBM Plex mono-sans) with one deliberate upgrade: every component is
   designed at 375px first and scales UP via min-width queries.
   Accent shifted rust -> deep marine ink (distinct product, same family). */

:root{
  --paper:#f5efe2; --paper-2:#ede4d0; --paper-3:#fbf6ea; --paper-4:#f0e7d4;
  --ink:#0d0d0d; --ink-2:#3a3632; --ink-3:#6b6560; --ink-4:#9a9489;
  --brand:#14507a; --brand-2:#2f6f9f; --brand-3:#8fb3cc;
  --good:#3a5a40;
  --hairline:rgba(13,13,13,.16); --hairline-2:rgba(13,13,13,.08);
  --serif:"Fraunces",Georgia,serif;
  --sans:"IBM Plex Sans",system-ui,sans-serif;
  --mono:"IBM Plex Mono",ui-monospace,monospace;
  --gutter:20px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
html,body{background:var(--paper);color:var(--ink);max-width:100vw;overflow-x:hidden}
body{font-family:var(--sans);font-size:16px;line-height:1.55;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
body::before{ /* newsprint grain */
  content:"";position:fixed;inset:0;pointer-events:none;opacity:.22;z-index:1;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='180' height='180'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.92' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 .35 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
  mix-blend-mode:multiply;
}
a{color:inherit;text-decoration:none}
img,svg{max-width:100%;height:auto}
/* Grid/flex items default to min-width:auto, so an intrinsically-wide child
   (a <pre>, a long mono line) silently widens its column past 320px viewports.
   Every layout grid child collapses instead. */
.hero-grid>*,.report-grid>*,.suite-hero .wrap>*,.price-grid>*,.strip>*,.facts>*,.mprin>*,.ft-grid>*{min-width:0}
.mono{font-family:var(--mono)}
.serif{font-family:var(--serif);font-optical-sizing:auto}

/* Reveal — only hides content when JS is present (html.js). No-JS = visible. */
html.js .rv{opacity:0;transform:translateY(14px);transition:opacity .9s cubic-bezier(.2,.7,.2,1),transform .9s cubic-bezier(.2,.7,.2,1)}
html.js .rv.in{opacity:1;transform:none}
html.js .rv.d1{transition-delay:.06s}html.js .rv.d2{transition-delay:.12s}html.js .rv.d3{transition-delay:.18s}
@media (prefers-reduced-motion:reduce){html.js .rv{opacity:1;transform:none;transition:none}}

.skip-link{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}
.skip-link:focus{position:fixed;top:8px;left:8px;width:auto;height:auto;padding:12px 16px;background:var(--ink);color:var(--paper);font-family:var(--mono);font-size:12px;letter-spacing:.08em;z-index:9999}

.wrap{max-width:1240px;margin:0 auto;padding:0 var(--gutter);position:relative;z-index:2}

/* ───────── Masthead: phone gets a real hamburger ───────── */
header.mast{position:relative;z-index:50;border-bottom:1px solid var(--hairline);padding:12px var(--gutter);display:flex;align-items:center;justify-content:space-between;gap:16px;background:var(--paper)}
.wordmark{font-family:var(--serif);font-weight:700;font-size:19px;letter-spacing:-.01em;display:inline-flex;align-items:center;gap:7px;min-height:44px}
.wordmark .dot{width:6px;height:6px;background:var(--brand);border-radius:50%;animation:beat 3.2s ease-in-out infinite}
@keyframes beat{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.6);opacity:.55}}
.mast .edn{display:none;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-2)}
.navtoggle{display:inline-flex;flex-direction:column;justify-content:center;gap:5px;width:48px;height:48px;padding:12px;border:1px solid var(--hairline);background:var(--paper-3);cursor:pointer}
.navtoggle span{display:block;height:2px;width:100%;background:var(--ink);transition:transform .3s,opacity .3s}
.navtoggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.navtoggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.navtoggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
nav.primary{display:none;position:absolute;top:100%;left:0;right:0;background:var(--paper);border-bottom:1px solid var(--hairline);padding:8px var(--gutter) 16px;flex-direction:column;z-index:60}
nav.primary.open{display:flex}
nav.primary a{font-size:15px;color:var(--ink-2);padding:13px 4px;min-height:44px;display:flex;align-items:center;border-bottom:1px solid var(--hairline-2)}
nav.primary a:last-child{border-bottom:none}
nav.primary a:hover{color:var(--brand)}
@media (min-width:800px){
  .navtoggle{display:none}
  .mast .edn{display:block}
  nav.primary{display:flex;position:static;flex-direction:row;gap:26px;border:none;padding:0;background:transparent}
  nav.primary a{font-size:13px;padding:4px 0;min-height:0;border-bottom:none;position:relative}
  nav.primary a::after{content:"";position:absolute;left:0;right:100%;bottom:-3px;height:1px;background:var(--brand);transition:right .4s cubic-bezier(.2,.7,.2,1)}
  nav.primary a:hover::after{right:0}
}

/* ───────── Hero ───────── */
.hero{position:relative;border-bottom:1px solid var(--hairline);background:radial-gradient(circle at 78% 10%,rgba(20,80,122,.14),transparent 36%),linear-gradient(150deg,var(--paper),var(--paper-2))}
.hero-grid{position:relative;z-index:2;display:grid;grid-template-columns:1fr;gap:36px;max-width:1240px;margin:0 auto;padding:44px var(--gutter) 40px}
.eyebrow{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--brand);margin-bottom:22px;display:flex;align-items:center;gap:12px}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--brand);flex-shrink:0}
h1.headline{font-family:var(--serif);font-weight:500;font-size:clamp(34px,9.4vw,74px);line-height:1.04;letter-spacing:-.022em;margin-bottom:22px}
h1 em{font-style:italic;color:var(--brand);font-weight:400}
.deck{font-size:clamp(15.5px,4.3vw,17px);line-height:1.6;color:var(--ink-2);max-width:46ch;margin-bottom:26px}
.cta-row{display:flex;flex-direction:column;gap:12px;margin-bottom:8px}
.btn{font-family:var(--sans);font-weight:500;font-size:15px;min-height:48px;padding:13px 22px;border:1px solid var(--ink);background:var(--ink);color:var(--paper);cursor:pointer;letter-spacing:.01em;display:inline-flex;align-items:center;justify-content:center;gap:10px;transition:background .3s,color .3s,border-color .3s}
.btn .arr{display:inline-block;transition:transform .35s cubic-bezier(.2,.7,.2,1)}
.btn:hover{background:var(--brand);border-color:var(--brand);color:var(--paper)}
.btn:hover .arr{transform:translate(3px,-2px)}
.btn.ghost{background:transparent;color:var(--ink)}
.btn.ghost:hover{background:var(--ink);color:var(--paper)}
.hero-note{font-family:var(--mono);font-size:11px;letter-spacing:.06em;color:var(--ink-3);margin-top:14px}
@media (min-width:640px){.cta-row{flex-direction:row}.cta-row .btn{flex:0 1 auto}}
@media (min-width:960px){
  .hero-grid{grid-template-columns:minmax(440px,1.1fr) minmax(420px,1fr);gap:56px;align-items:center;padding:76px var(--gutter) 68px}
}

/* record card (Fig.01) */
.record{border:1px solid var(--hairline);background:rgba(251,246,234,.75);backdrop-filter:blur(2px);padding:18px 16px 16px;position:relative}
.record .cap{display:flex;justify-content:space-between;gap:10px;font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-2);margin-bottom:12px;flex-wrap:wrap}
.record .cap .live{display:inline-flex;align-items:center;gap:7px}
.record .cap .live::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--brand);animation:pulse 2.2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(20,80,122,.5)}70%{box-shadow:0 0 0 9px rgba(20,80,122,0)}100%{box-shadow:0 0 0 0 rgba(20,80,122,0)}}
.record pre{font-family:var(--mono);font-size:clamp(10.5px,2.9vw,12.5px);line-height:1.75;color:var(--ink-2);background:var(--paper);border-left:2px solid var(--brand);padding:14px 12px;overflow-x:auto}
.record pre b{color:var(--ink);font-weight:500}
.record .foot{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3);margin-top:10px}

/* ───────── Stats band ───────── */
.strip{border-bottom:1px solid var(--hairline);padding:26px var(--gutter);display:grid;grid-template-columns:repeat(2,1fr);gap:22px 16px;background:var(--paper-2)}
.strip .cell .n{font-family:var(--serif);font-weight:500;font-size:clamp(24px,6.4vw,36px);line-height:1;letter-spacing:-.02em;margin-bottom:7px;color:var(--ink)}
.strip .cell .l{font-family:var(--mono);font-size:10px;letter-spacing:.13em;text-transform:uppercase;color:var(--ink-2);line-height:1.5}
@media (min-width:720px){.strip{grid-template-columns:repeat(3,1fr);padding:28px 40px}}
@media (min-width:1100px){.strip{grid-template-columns:repeat(6,1fr);padding:30px 60px}}

/* ───────── Generic section ───────── */
section.body{padding:60px var(--gutter);border-bottom:1px solid var(--hairline);max-width:1320px;margin:0 auto;position:relative;z-index:2}
.sec-head{display:flex;flex-direction:column;gap:14px;margin-bottom:34px}
.sec-eyebrow{font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--brand);margin-bottom:12px}
.sec-h{font-family:var(--serif);font-weight:500;font-size:clamp(26px,6.6vw,42px);letter-spacing:-.018em;line-height:1.08;max-width:24ch}
.sec-deck{font-size:15px;line-height:1.65;color:var(--ink-2);max-width:52ch}
@media (min-width:900px){
  section.body{padding:92px 60px}
  .sec-head{flex-direction:row;justify-content:space-between;align-items:end;gap:48px;margin-bottom:48px}
  .sec-deck{max-width:42ch;flex-shrink:0}
}

/* ───────── Fact cards ───────── */
.facts{display:grid;grid-template-columns:1fr;gap:14px}
.fact{border:1px solid var(--hairline);background:var(--paper-3);padding:22px 20px}
.fact .n{font-family:var(--serif);font-weight:500;font-size:clamp(30px,8vw,44px);letter-spacing:-.025em;line-height:1;color:var(--brand)}
.fact .n small{font-size:.55em;letter-spacing:0;color:var(--ink-3)}
.fact p{margin-top:10px;font-size:14px;line-height:1.6;color:var(--ink-2)}
.fact .src{margin-top:12px;font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3)}
@media (min-width:640px){.facts{grid-template-columns:1fr 1fr;gap:18px}}
@media (min-width:1024px){.facts{grid-template-columns:repeat(3,1fr);gap:22px}}

/* ───────── Report section ───────── */
.report-grid{display:grid;grid-template-columns:1fr;gap:30px}
@media (min-width:960px){.report-grid{grid-template-columns:5fr 7fr;gap:56px;align-items:start}}
.inc-list{list-style:none;margin-top:8px}
.inc-list li{font-size:14.5px;line-height:1.55;color:var(--ink-2);padding:11px 0;border-bottom:1px dotted var(--hairline);display:flex;gap:12px}
.inc-list li::before{content:"§";color:var(--brand);font-family:var(--serif);font-weight:600;flex-shrink:0;width:14px}
.shot{border:1px solid var(--hairline);background:var(--paper-3);padding:16px}
.shot .cap{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-2);margin-bottom:12px;display:flex;justify-content:space-between;gap:10px;flex-wrap:wrap}
.shot pre{font-family:var(--mono);font-size:clamp(10px,2.7vw,12px);line-height:1.7;color:var(--ink-2);background:var(--paper);border-left:2px solid var(--brand);padding:14px 12px;overflow-x:auto}
.shot pre b{color:var(--ink);font-weight:500}
.swipe-hint{display:block;font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3);margin-top:8px;text-align:right}
@media (min-width:760px){.swipe-hint{display:none}}

/* ───────── Pricing cards ───────── */
.price-grid{display:grid;grid-template-columns:1fr;gap:16px}
@media (min-width:680px){.price-grid{grid-template-columns:repeat(2,1fr);gap:18px}}
@media (min-width:1100px){.price-grid{grid-template-columns:repeat(3,1fr);gap:24px}}
.price-card{border:1px solid var(--hairline);padding:26px 22px;background:var(--paper-3);position:relative;display:flex;flex-direction:column;gap:15px;transition:border-color .3s,transform .3s cubic-bezier(.2,.7,.2,1)}
.price-card:hover{border-color:var(--ink);transform:translateY(-3px)}
.price-card .p-pop{position:absolute;top:-11px;left:20px;background:var(--brand);color:var(--paper);font-family:var(--mono);font-size:9px;letter-spacing:.18em;text-transform:uppercase;padding:5px 10px}
.price-card .p-tag{font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--brand)}
.price-card .p-name{font-family:var(--serif);font-weight:500;font-size:24px;letter-spacing:-.01em;line-height:1.1}
.price-card .p-price{font-family:var(--serif);font-weight:500;font-size:clamp(36px,9vw,44px);letter-spacing:-.025em;line-height:1;display:flex;align-items:baseline;gap:4px}
.price-card .p-price .p-suffix{font-family:var(--mono);font-size:13px;font-weight:500;opacity:.8;margin-left:4px;letter-spacing:.04em}
.price-card .p-deck{font-size:13.5px;line-height:1.55;color:var(--ink-2)}
.price-card .p-feat{list-style:none;font-size:13.5px;line-height:1.55;flex:1}
.price-card .p-feat li{display:flex;gap:10px;padding:8px 0;border-bottom:1px solid var(--hairline-2)}
.price-card .p-feat li:last-child{border-bottom:none}
.price-card .p-feat li::before{content:"·";color:var(--brand);font-weight:700;font-family:var(--serif);font-size:18px;line-height:1}
.price-card .p-cta{font-family:var(--sans);font-weight:500;font-size:14.5px;min-height:48px;padding:13px 18px;border:1px solid var(--ink);background:var(--ink);color:var(--paper);cursor:pointer;letter-spacing:.01em;text-align:center;display:inline-flex;align-items:center;justify-content:center;gap:8px;transition:background .3s,border-color .3s}
.price-card .p-cta:hover{background:var(--brand);border-color:var(--brand)}
.price-card.feat{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.price-card.feat .p-tag{color:var(--brand-3)}
.price-card.feat .p-deck{color:#e8ded0}
.price-card.feat .p-feat li{border-color:rgba(245,239,226,.18);color:#f5efe2}
.price-card.feat .p-feat li::before{color:var(--brand-3)}
.price-card.feat .p-cta{background:var(--brand);border-color:var(--brand)}
.price-card.feat .p-cta:hover{background:var(--brand-2);border-color:var(--brand-2)}
.price-foot{margin-top:22px;font-family:var(--mono);font-size:10.5px;color:var(--ink-3);letter-spacing:.06em;text-align:center;line-height:1.7;padding:0 8px}

/* ───────── Comparison table (pricing page) ───────── */
.tscroll{overflow-x:auto;-webkit-overflow-scrolling:touch;border:1px solid var(--hairline);background:var(--paper-3)}
table.cmp{width:100%;min-width:640px;border-collapse:collapse;font-size:13px}
table.cmp th{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-2);text-align:left;padding:14px 12px 10px;border-bottom:1px solid var(--ink);background:var(--paper-3);white-space:nowrap}
table.cmp td{padding:11px 12px;border-bottom:1px solid var(--hairline-2);color:var(--ink-2);vertical-align:top}
table.cmp td:first-child{font-weight:500;color:var(--ink);white-space:nowrap}
table.cmp td.y{color:var(--good);font-weight:600}
table.cmp td.n0{color:var(--ink-4)}

/* ───────── Methodology teaser + page ───────── */
.mprin{display:grid;grid-template-columns:1fr;gap:18px}
@media (min-width:680px){.mprin{grid-template-columns:1fr 1fr;gap:26px 40px}}
.mprin h3{font-family:var(--serif);font-weight:500;font-size:19px;letter-spacing:-.01em;margin-bottom:8px}
.mprin p{font-size:14px;line-height:1.65;color:var(--ink-2)}
.src-row{border-top:1px solid var(--hairline);padding:18px 0;display:grid;grid-template-columns:1fr;gap:8px}
@media (min-width:760px){.src-row{grid-template-columns:280px 1fr;gap:32px}}
.src-row .nm{font-family:var(--serif);font-weight:500;font-size:17px;line-height:1.3}
.src-row .vin{font-family:var(--mono);font-size:11px;color:var(--ink-3);letter-spacing:.06em;margin-top:5px}
.src-row p{font-size:14px;line-height:1.65;color:var(--ink-2)}

/* ───────── FAQ ───────── */
.faq{max-width:820px}
.faq details{border-bottom:1px solid var(--hairline)}
.faq summary{font-family:var(--serif);font-weight:500;font-size:17px;line-height:1.4;padding:17px 36px 17px 2px;min-height:48px;cursor:pointer;list-style:none;position:relative;display:flex;align-items:center}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";position:absolute;right:8px;font-family:var(--mono);font-size:19px;color:var(--brand);transition:transform .3s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details p{font-size:14.5px;line-height:1.7;color:var(--ink-2);padding:0 2px 20px;max-width:68ch}
.faq details a{color:var(--brand);text-decoration:underline;text-underline-offset:3px}

/* ───────── CTA band ───────── */
.cta-band{background:var(--ink);color:var(--paper);padding:60px var(--gutter);text-align:center;position:relative;z-index:2}
.cta-band h2{font-family:var(--serif);font-weight:500;font-size:clamp(26px,7vw,44px);letter-spacing:-.02em;line-height:1.1;max-width:24ch;margin:0 auto 14px}
.cta-band p{font-size:15px;color:#e8ded0;max-width:52ch;margin:0 auto 28px;line-height:1.6}
.cta-band .btn{background:var(--brand);border-color:var(--brand)}
.cta-band .btn:hover{background:var(--brand-2);border-color:var(--brand-2)}

/* ───────── Vignette ───────── */
.vignette{padding:56px 0;border-bottom:1px solid var(--hairline-2);position:relative;z-index:2}
.vignette .wrap{max-width:1080px;display:grid;grid-template-columns:1fr;gap:16px}
.vignette .v-tag{font-family:var(--mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--brand);padding-top:12px;border-top:1px solid var(--brand);max-width:180px}
.vignette p{font-family:var(--serif);font-style:italic;font-weight:400;font-size:clamp(18px,4.8vw,24px);line-height:1.45;color:var(--ink);max-width:54ch;letter-spacing:-.005em}
.vignette .v-att{font-family:var(--mono);font-size:11px;letter-spacing:.12em;color:var(--ink-2);margin-top:18px;text-transform:uppercase}
@media (min-width:860px){
  .vignette{padding:84px 0}
  .vignette .wrap{grid-template-columns:1fr 7fr;gap:48px;align-items:start}
}

/* ───────── Suites band ───────── */
.suites-band{padding:56px 0;background:var(--paper-2);border-bottom:1px solid var(--hairline-2);position:relative;z-index:2}
.suites-row{display:grid;grid-template-columns:1fr;gap:14px;margin-top:26px}
.suites-row a{display:block;padding:20px 18px;background:var(--paper);border:1px solid var(--hairline);color:var(--ink);transition:border-color .3s,transform .3s cubic-bezier(.2,.7,.2,1)}
.suites-row a:hover{border-color:var(--ink);transform:translateY(-2px)}
.suites-row .s-tag{font-family:var(--mono);font-size:9.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--brand);margin-bottom:8px}
.suites-row .s-name{font-family:var(--serif);font-weight:500;font-size:18px;line-height:1.25}
.suites-row .s-foot{font-family:var(--mono);font-size:10.5px;color:var(--ink-2);margin-top:12px}
@media (min-width:640px){.suites-row{grid-template-columns:1fr 1fr;gap:18px}}
@media (min-width:1024px){.suites-row{grid-template-columns:repeat(4,1fr)}}

/* ───────── Suite page ───────── */
.suite-hero{padding:48px 0 44px;border-bottom:1px solid var(--hairline);position:relative;z-index:2}
.suite-hero .wrap{display:grid;grid-template-columns:1fr;gap:30px}
@media (min-width:960px){.suite-hero{padding:88px 0 72px}.suite-hero .wrap{grid-template-columns:7fr 5fr;gap:72px;align-items:end}}
.suite-hero aside{border-top:1px solid var(--hairline);padding-top:22px}
@media (min-width:960px){.suite-hero aside{border-top:none;border-left:1px solid var(--hairline);padding-top:0;padding-left:36px}}
.suite-hero aside p{font-family:var(--serif);font-style:italic;font-size:clamp(16.5px,4.4vw,20px);line-height:1.5;color:var(--ink)}
.answers{list-style:none;margin-top:10px;max-width:820px}
.answers li{font-size:15px;line-height:1.6;color:var(--ink-2);padding:12px 0;border-bottom:1px dotted var(--hairline);display:flex;gap:12px}
.answers li::before{content:"→";color:var(--brand);font-family:var(--mono);flex-shrink:0}
.answers li b{color:var(--ink);font-weight:600}

/* ───────── Folio / breadcrumb ───────── */
.crumb{padding:10px 0;font-family:var(--mono);font-size:11px;letter-spacing:.08em;color:var(--ink-3);border-bottom:1px solid var(--hairline);position:relative;z-index:2}
.crumb a{color:var(--brand)}
.folio{border-bottom:1px solid var(--hairline);padding:9px 0;font-family:var(--mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-3);position:relative;z-index:2}
.folio .wrap{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap}

/* ───────── Footer ───────── */
.site-foot{background:var(--ink);color:var(--paper);padding:52px var(--gutter) 26px;position:relative;z-index:2}
.ft-grid{display:grid;grid-template-columns:1fr;gap:32px;margin-bottom:40px;padding-bottom:36px;border-bottom:1px solid rgba(245,239,226,.12);max-width:1240px;margin-left:auto;margin-right:auto}
@media (min-width:680px){.ft-grid{grid-template-columns:1fr 1fr}}
@media (min-width:1024px){.ft-grid{grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:48px}.site-foot{padding:72px 60px 30px}}
.ft-mark{font-family:var(--serif);font-weight:700;font-size:22px;margin-bottom:12px;display:flex;align-items:center;gap:8px}
.ft-mark .dot{width:6px;height:6px;background:var(--brand-2);border-radius:50%}
.ft-blurb{font-size:13px;line-height:1.65;color:rgba(245,239,226,.62);max-width:36ch}
.ft-h{font-family:var(--mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:rgba(245,239,226,.72);margin-bottom:12px}
.ft-col a{display:flex;align-items:center;color:var(--paper);font-size:14px;padding:9px 0;min-height:40px;border-bottom:1px solid transparent;transition:color .3s}
.ft-col a:hover{color:var(--brand-3)}
.ft-cite{font-size:11px;line-height:1.6;color:rgba(245,239,226,.7);background:rgba(245,239,226,.06);padding:14px 16px;border-left:2px solid var(--brand-2);font-family:var(--mono);margin-top:12px}
.ft-bot{display:flex;flex-direction:column;gap:8px;font-family:var(--mono);font-size:11px;color:#d8cfc0;letter-spacing:.06em;max-width:1240px;margin:0 auto;line-height:1.7}
.ft-bot a{color:#d8cfc0;border-bottom:1px solid rgba(245,239,226,.35)}
@media (min-width:680px){.ft-bot{flex-direction:row;justify-content:space-between}}
