/* PhotoLib design system v1.0 — photolibsoftware.com */
:root{
  --blue:#14588F;--blue-hover:#0F4573;--navy:#0C2A44;--blue-tint:#EEF4F9;
  --amber:#E39A2D;--green:#2F7D51;--red:#B0402A;
  --ink:#16181D;--ink-2:#444B54;--muted:#6A727D;
  --bg:#F3F5F8;--border:#E3E6EA;
  --pros-bg:#EDF6F0;--pros-bd:#CBE5D4;--cons-bg:#F9EFEC;--cons-bd:#EBD2C9;
  --amber-bg:#FBF3E4;--amber-bd:#EBD9B4;--winner:#F0F8F3;
  --serif:'Source Serif 4',Georgia,serif;--sans:'Source Sans 3',system-ui,sans-serif;
  --maxw:1200px;--radius:10px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:84px}
@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}*,*::before,*::after{animation:none!important;transition:none!important}}
.visually-hidden{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}
.skip-link{position:absolute;left:-9999px;top:0;background:var(--navy);color:#fff;padding:12px 20px;border-radius:0 0 8px 0;font:600 15px var(--sans);z-index:100;text-decoration:none}
.skip-link:focus{left:0}
:focus-visible{outline:3px solid var(--blue);outline-offset:2px;border-radius:2px}
.site-header :focus-visible,.site-footer :focus-visible{outline-color:var(--amber)}
body{margin:0;background:var(--bg);color:var(--ink);font-family:var(--sans);font-size:17px;line-height:1.75;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto}
a{color:var(--blue)}
h1,h2,h3,h4{font-family:var(--serif);line-height:1.25;letter-spacing:-.02em;margin:0 0 .5em}
h1{font-size:42px;line-height:1.15;font-weight:700}
h2{font-size:28px;font-weight:700;margin-top:1.6em}
h3{font-size:20px;line-height:1.35;font-weight:700}
p{margin:0 0 1.1em;color:var(--ink-2)}
code{background:var(--blue-tint);border-radius:4px;padding:1px 6px;font-size:.9em;overflow-wrap:anywhere;word-break:break-word}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.kicker{display:inline-flex;align-items:center;gap:10px;font-size:12.5px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--blue);margin-bottom:10px}
.kicker::before{content:"";width:28px;height:4px;background:var(--amber);border-radius:2px;flex:none}

/* ---------- header ---------- */
.site-header{position:sticky;top:0;z-index:50;background:#fff;border-bottom:1px solid var(--border);box-shadow:inset 0 4px 0 var(--blue);padding-top:4px}
.site-header .wrap{display:flex;align-items:center;gap:24px;height:64px}
.logo{display:flex;align-items:baseline;text-decoration:none;flex:none;font-family:var(--serif);font-weight:700;font-size:24px;letter-spacing:-.02em}
.logo b{color:var(--ink);font-weight:700}.logo span{color:var(--blue)}
.nav{display:flex;align-items:center;gap:2px;flex:1;min-width:0}
.nav>div{position:relative}
.nav a.top{display:block;text-decoration:none;font-size:15px;font-weight:600;color:var(--ink);padding:11px 12px;border-radius:6px;white-space:nowrap}
.nav a.top[aria-current]{color:var(--blue);background:var(--blue-tint)}
.nav a.top:hover{background:#F5F6F7}
.nav .caret{color:var(--muted);font-size:11px}
.dropdown{position:absolute;left:0;top:100%;background:#fff;border:1px solid var(--border);border-radius:10px;box-shadow:0 12px 32px rgba(12,42,68,.12);min-width:280px;padding:8px;display:none}
.nav>div:hover .dropdown,.nav>div:focus-within .dropdown{display:block}
.nav>div.dd-closed .dropdown{display:none}
.dropdown a{display:block;text-decoration:none;font-size:14.5px;font-weight:500;color:var(--ink-2);padding:11px 12px;border-radius:6px}
.dropdown a:hover{background:var(--blue-tint);color:var(--blue)}
.dropdown a[aria-current]{background:var(--blue-tint);color:var(--blue);font-weight:600}
.disclosure-link{font-size:12.5px;color:var(--muted);text-decoration:none;white-space:nowrap;border-bottom:1px dotted #B9BFC7;padding:12px 0}
.menu-btn{display:none;background:none;border:1px solid var(--border);border-radius:6px;padding:11px 14px;font:600 14px var(--sans);color:var(--ink);cursor:pointer}

/* ---------- article masthead (tinted band behind breadcrumb + title) ---------- */
.masthead{position:relative;overflow:hidden;border-bottom:1px solid var(--border);background:radial-gradient(circle at 1px 1px,rgba(20,88,143,.10) 1.2px,transparent 0) 0 0/24px 24px,linear-gradient(180deg,#E9F1F8 0%,#F7FAFC 100%)}
.masthead>.wrap{position:relative;z-index:1;padding-top:14px;padding-bottom:32px}
.masthead::before{content:"";position:absolute;right:-140px;top:-160px;width:420px;height:420px;border-radius:50%;border:58px solid rgba(20,88,143,.06);pointer-events:none}
.masthead .crumbs{padding:0 0 18px}
.masthead header{margin:0}

/* ---------- breadcrumbs ---------- */
.crumbs{font-size:13px;color:var(--muted);padding:14px 0}
.crumbs a{color:var(--muted);text-decoration:none}
.crumbs a:hover{color:var(--blue)}
.crumbs .sep{margin:0 6px;color:#B9BFC7}

/* ---------- buttons ---------- */
.btn{display:inline-block;text-decoration:none;font:600 15px var(--sans);border-radius:6px;padding:11px 20px;cursor:pointer;border:0}
.btn-primary{background:var(--blue);color:#fff}
.btn-primary:hover{background:var(--blue-hover)}
.btn-outline{background:#fff;color:var(--blue);border:1px solid #C7D7E5}
.btn-outline:hover{border-color:var(--blue)}
.btn-accent{background:var(--amber);color:#231a07}
.btn-accent:hover{filter:brightness(1.05)}
.btn-sm{padding:11px 16px;font-size:14px}
a.text-link{font-weight:600;text-decoration:none}
a.text-link:hover{text-decoration:underline}

/* ---------- badges & scores ---------- */
.score{display:inline-flex;align-items:center;justify-content:center;font:700 22px var(--sans);border-radius:8px;min-width:56px;padding:8px 10px}
.score-primary{background:var(--blue);color:#fff}
.score-tint{background:var(--blue-tint);color:var(--blue)}
.score-inline{display:inline-block;background:var(--blue-tint);color:var(--blue);font:700 14px var(--sans);border-radius:6px;padding:2px 8px}
.stars{color:var(--amber);letter-spacing:2px;font-size:15px}
.stars .off{color:#E0D5C2}
.ribbon{display:inline-block;background:var(--amber);color:#231a07;font:700 12.5px var(--sans);text-transform:uppercase;letter-spacing:.04em;border-radius:4px;padding:4px 10px}
.tag{display:inline-block;background:var(--blue-tint);color:var(--blue);font:600 13px var(--sans);border-radius:999px;padding:3px 12px}
.tier{font-weight:700;color:var(--green)}
.pill{display:inline-block;border:1px solid var(--border);background:#fff;border-radius:999px;padding:4px 14px;font-size:13.5px;color:var(--ink-2)}

/* ---------- cards ---------- */
.card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:24px}
.product-card{position:relative;background:#fff;border:1px solid var(--border);border-radius:12px;padding:28px;margin:40px 0}
.product-card.ec{border:2px solid var(--blue);background:linear-gradient(180deg,#F4F8FC 0%,#FFFFFF 120px)}
.product-card .ribbon{position:absolute;top:-14px;left:24px}
.pc-head{display:flex;align-items:flex-start;gap:16px;flex-wrap:wrap}
.pc-head .grow{flex:1;min-width:220px}
.rank-num{font:700 15px var(--sans);color:var(--muted)}
.logo-tile{flex:none;width:56px;height:56px;border-radius:10px;display:flex;align-items:center;justify-content:center;font:700 20px var(--serif);color:#fff}
.pc-score{text-align:center}
.pc-score .lbl{display:block;font-size:11.5px;color:var(--muted);margin-top:4px}
.spec-table{width:100%;border-collapse:collapse;font-size:14.5px;margin:16px 0}
.spec-table td{border:1px solid var(--border);padding:9px 13px}
.spec-table td:first-child{background:#F5F6F7;font-weight:600;width:38%}

/* ---------- pros / cons ---------- */
.pros-cons{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin:18px 0}
.pros,.cons{border-radius:8px;padding:16px 18px;font-size:15.5px}
.pros{background:var(--pros-bg);border:1px solid var(--pros-bd)}
.cons{background:var(--cons-bg);border:1px solid var(--cons-bd)}
.pros .pc-t,.cons .pc-t{font-family:var(--sans);font-size:14px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;margin:0 0 8px}
.pros .pc-t{color:var(--green)}.cons .pc-t{color:var(--red)}
.pros ul,.cons ul{margin:0;padding:0;list-style:none}
.pros li,.cons li{padding:4px 0 4px 22px;position:relative;color:var(--ink-2)}
.pros li::before{content:"+";position:absolute;left:0;font-weight:700;color:var(--green)}
.cons li::before{content:"−";position:absolute;left:0;font-weight:700;color:var(--red)}

/* ---------- comparison tables ---------- */
.table-scroll{overflow-x:auto;margin:20px 0}
.cmp caption{caption-side:top;text-align:left;font:700 13px var(--sans);text-transform:uppercase;letter-spacing:.05em;color:var(--muted);padding:0 0 8px}
.cmp{width:100%;border-collapse:collapse;background:#fff;font-size:15px;border:1px solid var(--border);border-radius:10px;overflow:hidden}
.cmp th{background:#F5F6F7;text-align:left;font-size:13.5px;text-transform:uppercase;letter-spacing:.04em;color:var(--ink-2);padding:11px 13px;border-bottom:1px solid var(--border)}
.cmp td{padding:13px;border-bottom:1px solid var(--border);vertical-align:top}
.cmp tr:last-child td{border-bottom:0}
.cmp tr.hl td{background:#F2F7FB}
.cmp td.win{background:var(--winner)}
.win-chip{display:inline-block;background:var(--green);color:#fff;font:700 11px var(--sans);text-transform:uppercase;border-radius:4px;padding:2px 7px;margin-left:8px;vertical-align:middle}
.tbl-note{font-size:13px;color:var(--muted);margin-top:8px}

/* ---------- callouts ---------- */
.callout{display:flex;gap:14px;border-radius:8px;padding:16px 18px;margin:22px 0;font-size:15.5px}
.callout .ico{flex:none;width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;color:#fff;font-size:14px}
.callout p{margin:0}
.callout-info{background:var(--blue-tint);border:1px solid #CBDDEC}.callout-info .ico{background:var(--blue)}
.callout-tip{background:var(--pros-bg);border:1px solid var(--pros-bd)}.callout-tip .ico{background:var(--green)}
.callout-warn{background:var(--amber-bg);border:1px solid var(--amber-bd)}.callout-warn .ico{background:var(--amber);color:#231a07}

/* ---------- author field notes (signed first-person reviewer insertions) ---------- */
.field-note{position:relative;background:#fff;border:1px solid var(--border);border-left:4px solid var(--amber);border-radius:10px;padding:18px 20px 18px 22px;margin:26px 0;box-shadow:0 1px 2px rgba(12,42,68,.05)}
.field-note .fn-head{display:flex;align-items:center;gap:11px;margin-bottom:10px}
.field-note .avatar{width:36px;height:36px;font-size:13px;background:var(--amber);color:#231a07}
.field-note .fn-who{font:700 14px var(--serif);color:var(--ink);line-height:1.25}
.field-note .fn-who span{display:block;font:700 11px var(--sans);text-transform:uppercase;letter-spacing:.07em;color:#8A5A0D;margin-top:1px}
.field-note .fn-body{font-size:15.5px}
.field-note .fn-body p{margin:0 0 .65em;color:var(--ink-2)}
.field-note .fn-body p:last-child{margin-bottom:0}
.field-note .fn-body em{font-style:italic;color:var(--ink)}

/* ---------- sources / references ---------- */
.sources{counter-reset:src;list-style:none;padding:0;margin:16px 0;font-size:14.5px}
.sources li{position:relative;counter-increment:src;padding:9px 0 9px 40px;border-bottom:1px solid var(--border);color:var(--ink-2)}
.sources li:last-child{border-bottom:0}
.sources li::before{content:counter(src);position:absolute;left:0;top:9px;width:26px;height:26px;border-radius:6px;background:var(--blue-tint);color:var(--blue);font:700 13px var(--sans);display:flex;align-items:center;justify-content:center}
.sources a{font-weight:600;text-decoration:none;overflow-wrap:anywhere}
.sources a:hover{text-decoration:underline}
.sources .src-note{color:var(--muted);font-size:13.5px}

/* ---------- verdict / navy panels ---------- */
.verdict{background:var(--navy);color:#fff;border-radius:14px;padding:32px;margin:32px 0}
.verdict h2,.verdict h3{color:#fff;margin-top:0}
.verdict p{color:#C9D6E2}
.verdict a{color:#8FC1E9}

/* ---------- CTA banner ---------- */
.cta-banner{display:flex;align-items:center;gap:16px;background:var(--navy);color:#fff;border-radius:12px;padding:18px 24px;margin:32px 0;flex-wrap:wrap}
.cta-banner .logo-tile{width:44px;height:44px;font-size:16px;background:#1B3C5C}
.cta-banner p{flex:1;margin:0;color:#C9D6E2;font-size:15.5px;min-width:200px}
.cta-banner p b{color:#fff}

/* ---------- layout with sidebar ---------- */
.layout{display:grid;grid-template-columns:1fr 264px;gap:40px;align-items:start}
.sidebar{position:sticky;top:88px}
@media(min-width:961px){.layout:has(>article>.box-30s:first-child) .sidebar,.layout:has(>article>.card:first-child) .sidebar{margin-top:26px}}
.toc{background:#fff;border:1px solid var(--border);border-radius:10px;padding:18px 20px;font-size:14.5px}
.toc strong{display:block;font-size:12.5px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin-bottom:8px}
.toc ol{margin:0;padding-left:18px}
.toc li{margin:5px 0}
.toc a{text-decoration:none;color:var(--ink-2)}
.toc a:hover{color:var(--blue)}
.side-cta{background:#fff;border:1px solid var(--border);border-radius:10px;padding:18px 20px;margin-top:16px;font-size:14.5px}
.side-cta .t{font:700 12.5px var(--sans);text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}

/* ---------- article meta / author ---------- */
.byline{display:flex;align-items:center;gap:12px;margin:18px 0 8px}
.avatar{width:44px;height:44px;border-radius:50%;background:var(--navy);color:#fff;display:flex;align-items:center;justify-content:center;font:700 15px var(--sans);flex:none}
.byline .who{font-size:14.5px;color:var(--ink-2)}
.byline .who b{color:var(--ink)}
.meta-line{font-size:13.5px;color:var(--muted)}
.author-box{display:flex;gap:16px;background:#fff;border:1px solid var(--border);border-radius:10px;padding:20px;margin:32px 0}
.author-box .avatar{width:56px;height:56px;font-size:18px}

/* ---------- FAQ ---------- */
.faq details{background:#fff;border:1px solid var(--border);border-radius:8px;margin:10px 0;padding:0}
.faq summary{cursor:pointer;list-style:none;font:600 16.5px var(--sans);padding:16px 44px 16px 18px;position:relative;color:var(--ink)}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";position:absolute;right:18px;top:12px;font-size:22px;color:var(--muted)}
.faq details[open] summary::after{content:"−"}
.faq .a{padding:0 18px 16px;font-size:15.5px;color:var(--ink-2)}
.faq .a p{margin:0 0 .6em}

/* ---------- figures / screenshots ---------- */
figure{margin:24px 0;background:#fff;border:1px solid var(--border);border-radius:10px;padding:10px}
figure img{display:block;width:100%;border-radius:6px;background:#E9EDF2}
figcaption{font-size:13px;color:var(--muted);padding:10px 6px 2px}

/* ---------- hero ---------- */
.hero{position:relative;overflow:hidden;padding:64px 0 52px;border-bottom:1px solid var(--border);background:radial-gradient(circle at 1px 1px,rgba(20,88,143,.12) 1.2px,transparent 0) 0 0/24px 24px,linear-gradient(180deg,#E9F1F8 0%,#F7FAFC 100%)}
.hero>.wrap{position:relative;z-index:1}
.hero::before{content:"";position:absolute;right:-120px;top:-140px;width:460px;height:460px;border-radius:50%;border:64px solid rgba(20,88,143,.07);pointer-events:none}
.hero::after{content:"";position:absolute;right:60px;top:150px;width:180px;height:180px;border-radius:50%;border:26px solid rgba(227,154,45,.16);pointer-events:none}
.hero .sub{font-size:19px;color:var(--ink-2);max-width:760px}
.trust-row{display:flex;gap:18px;flex-wrap:wrap;margin-top:22px;font-size:14.5px;color:var(--ink-2)}
.trust-row .ck{color:var(--green);font-weight:700}

/* ---------- home cards grid ---------- */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin:24px 0}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin:24px 0}
.mini-card{background:#fff;border:1px solid var(--border);border-radius:10px;padding:20px;text-decoration:none;display:block;color:var(--ink)}
.mini-card:hover{border-color:var(--blue)}
.mini-card .t{display:block;font:700 17px var(--serif)}
.mini-card .d{display:block;font-size:14.5px;color:var(--muted);margin-top:4px}
.vs-card{display:flex;align-items:center;gap:10px;background:#fff;border:1px solid var(--border);border-radius:10px;padding:16px 18px;text-decoration:none;color:var(--ink);font-weight:600;font-size:15.5px}
.vs-card:hover{border-color:var(--blue)}
.vs-card .vs{color:var(--muted);font-size:12px;font-weight:700}
.vs-card .arr{margin-left:auto;color:var(--blue)}

/* ---------- sections ---------- */
.section{padding:36px 0}
.section.band{background:#F5F6F7;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.section-head{display:flex;align-items:baseline;justify-content:space-between;gap:16px;flex-wrap:wrap}

/* ---------- verdict 30s box ---------- */
.box-30s{display:flex;gap:18px;background:#fff;border:1px solid var(--border);border-left:4px solid var(--blue);border-radius:10px;padding:22px;margin:26px 0}
.box-30s .badge30{flex:none;width:52px;height:52px;border-radius:50%;background:var(--blue-tint);color:var(--blue);display:flex;align-items:center;justify-content:center;font:700 15px var(--sans)}
.box-30s p{margin:0}

/* ---------- choose lists ---------- */
.choose{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin:22px 0}
.choose .col{background:#fff;border:1px solid var(--border);border-radius:10px;padding:20px}
.choose ul{margin:10px 0 16px;padding:0;list-style:none}
.choose li{padding:4px 0 4px 20px;position:relative;font-size:15.5px;color:var(--ink-2)}
.choose li::before{content:"▸";position:absolute;left:0;color:var(--blue)}

/* ---------- sub-scores ---------- */
.subscores{display:grid;grid-template-columns:1fr 1fr;gap:8px 24px;margin:14px 0;font-size:14.5px}
.subscores .row{display:flex;align-items:center;gap:10px}
.subscores .lbl{width:100px;color:var(--ink-2)}
.subscores .bar{flex:1;height:8px;background:#E9EDF2;border-radius:4px;overflow:hidden}
.subscores .bar i{display:block;height:100%;background:var(--blue);border-radius:4px}
.subscores .val{font-weight:700;width:32px;text-align:right}

/* ---------- footer ---------- */
.site-footer{background:var(--ink);color:#B9BFC7;margin-top:64px;padding:48px 0 24px;font-size:14.5px}
.site-footer .cols{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:32px}
.site-footer .fh{font-family:var(--sans);font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#fff;margin:0 0 12px}
.site-footer a{color:#B9BFC7;text-decoration:none;display:block;padding:3px 0}
.site-footer a:hover{color:#fff}
.site-footer .logo b{color:#fff}
.f-bottom{border-top:1px solid #2A2E35;margin-top:36px;padding-top:20px;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-size:13px;color:#8A9099}
.f-bottom a{display:inline;color:#8A9099;padding:0}

/* ---------- cookie ---------- */
.cookie{position:fixed;bottom:16px;left:16px;right:16px;max-width:520px;margin:0 auto;background:#fff;border:1px solid var(--border);border-radius:12px;box-shadow:0 12px 32px rgba(12,42,68,.18);padding:16px 18px;font-size:14px;z-index:60;display:none}
.cookie.show{display:block}
.cookie .row{display:flex;gap:10px;margin-top:10px}

/* ---------- forms ---------- */
.form{max-width:560px}
.field{margin:0 0 18px}
.field label{display:block;font:600 15px var(--sans);margin-bottom:6px}
.field label .req{color:var(--red)}
.field input,.field textarea,.field select{width:100%;font:400 16px var(--sans);color:var(--ink);background:#fff;border:1px solid var(--border);border-radius:8px;padding:12px 14px;min-height:48px}
.field textarea{min-height:140px;resize:vertical}
.field input:focus,.field textarea:focus{border-color:var(--blue);outline:2px solid var(--blue);outline-offset:0}
.field .hint{font-size:13px;color:var(--muted);margin-top:4px}
.field .err-msg{display:none;font-size:14px;color:var(--red);font-weight:600;margin-top:5px}
.field.invalid input,.field.invalid textarea{border-color:var(--red);outline-color:var(--red)}
.field.invalid .err-msg{display:block}
.char-count{font-size:13px;color:var(--muted);text-align:right;margin-top:4px}
.form-status{display:none;border-radius:8px;padding:14px 16px;margin:16px 0;font-size:15px}
.form-status.ok{display:block;background:var(--pros-bg);border:1px solid var(--pros-bd);color:var(--green)}
.form-status.fail{display:block;background:var(--cons-bg);border:1px solid var(--cons-bd);color:var(--red)}

/* ---------- print ---------- */
@media print{
  .site-header,.site-footer,.cookie,.cta-banner,.side-cta,.menu-btn,.skip-link,.btn{display:none!important}
  body{background:#fff;font-size:12pt}
  .layout{display:block}
  a{color:#000;text-decoration:none}
  main a[href^="http"]::after{content:" (" attr(href) ")";font-size:10pt;color:#444}
  .faq details{border:0}
  .faq details>.a{display:block}
}

/* ---------- responsive ---------- */
@media(max-width:960px){
  h1{font-size:32px}
  .layout{grid-template-columns:1fr}
  /* content first on tablet/mobile; sidebar (long TOC + CTA) moves below the article */
  .sidebar{position:static;order:2;margin-top:8px}
  .grid-3{grid-template-columns:1fr 1fr}
  .site-footer .cols{grid-template-columns:1fr 1fr}
}
@media(max-width:720px){
  body{font-size:16px}
  .nav{display:none;position:absolute;top:68px;left:0;right:0;background:#fff;border-bottom:1px solid var(--border);flex-direction:column;align-items:stretch;padding:10px 16px 16px;gap:0}
  .nav.open{display:flex}
  .nav .dropdown{position:static;display:block;border:0;box-shadow:none;padding:0 0 6px 14px;min-width:0}
  .menu-btn{display:block;margin-left:auto}
  .disclosure-link{display:none}
  .pros-cons,.choose,.grid-2,.subscores{grid-template-columns:1fr}
  .grid-3{grid-template-columns:1fr}
  .site-footer .cols{grid-template-columns:1fr}
  .hero{padding:28px 0}
  /* wide tables become labeled cards */
  .cmp.cards thead{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0)}
  .cmp.cards,.cmp.cards tbody{display:block;border:0}
  .cmp.cards tr{display:block;background:#fff;border:1px solid var(--border);border-radius:10px;margin:0 0 12px;padding:6px 0}
  .cmp.cards td{display:flex;justify-content:space-between;align-items:baseline;gap:12px;border:0;border-bottom:1px solid #F0F2F4;padding:10px 14px;text-align:right}
  .cmp.cards td:last-child{border-bottom:0}
  .cmp.cards td::before{content:attr(data-label);font:600 13px var(--sans);text-transform:uppercase;letter-spacing:.04em;color:var(--muted);text-align:left;flex:none}
  .cmp.cards td[data-label=""]::before{display:none}
  .pc-head{gap:12px}
  h1{font-size:28px}
}
