/* ============================================================
   starguo — a British review (warm ivory broadsheet)
   Oxblood accent. Playfair Display (display) / Spectral (body) / DM Mono (labels)
   ============================================================ */
:root{
  --paper:#F7F4EC;
  --paper-2:#EFEAE0;
  --surface:#FFFDF8;
  --ink:#1C1A17;
  --ink-soft:#46423B;
  --mute:#8A8579;
  --mute-2:#A8A293;
  --line:#E2DBCD;
  --line-2:#D4CCBA;
  --accent:#8B2635;
  --accent-2:#A8323F;
  --accent-soft:#F1E3E1;
  --brass:#A9853F;
  --shadow:0 16px 44px rgba(40,28,20,.12);
  --shadow-sm:0 6px 20px rgba(40,28,20,.08);
  --max:1180px;
  --serif:"Playfair Display","Times New Roman",serif;
  --body:"Spectral",Georgia,"Times New Roman",serif;
  --mono:"DM Mono","Courier New",monospace;
}
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--body);font-size:17px;line-height:1.62;color:var(--ink);background:var(--paper);-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:var(--ink);text-decoration:none}
.wrap{max-width:var(--max);margin:0 auto;padding:0 26px}

/* ============ MASTHEAD ============ */
.masthead{background:var(--paper);border-bottom:2px solid var(--ink)}
.masthead-top{display:flex;align-items:center;justify-content:space-between;padding:9px 0;border-bottom:1px solid var(--line)}
.masthead-top .wrap{display:flex;align-items:center;justify-content:space-between;width:100%}
.edition{font-family:var(--mono);font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--mute)}
.util{display:flex;gap:18px}
.util a{font-family:var(--mono);font-size:11px;letter-spacing:.8px;text-transform:uppercase;color:var(--ink-soft)}
.util a:hover{color:var(--accent)}
.masthead-mid{display:flex;align-items:center;justify-content:space-between;padding:20px 0 18px}
.masthead-mid .wrap{display:flex;align-items:center;justify-content:space-between;width:100%}
.brand{font-family:var(--serif);font-weight:900;font-size:40px;letter-spacing:-1px;color:var(--ink);line-height:1}
.brand .accent{color:var(--accent);font-style:italic}
.head-actions{display:flex;align-items:center;gap:12px}
.icon-btn{width:40px;height:40px;border-radius:50%;border:1px solid var(--line-2);background:var(--surface);cursor:pointer;display:grid;place-items:center;color:var(--ink)}
.icon-btn:hover{border-color:var(--accent);color:var(--accent)}
.icon-btn svg{width:17px;height:17px;stroke:currentColor;fill:none;stroke-width:1.9}
.subscribe-btn{font-family:var(--mono);font-weight:500;font-size:12px;letter-spacing:1.2px;text-transform:uppercase;background:var(--accent);color:#fff;border:none;padding:12px 22px;cursor:pointer}
.subscribe-btn:hover{background:var(--accent-2)}
.mainnav{background:var(--ink);position:sticky;top:0;z-index:50}
.mainnav .wrap{display:flex;flex-wrap:wrap}
.mainnav a{font-family:var(--mono);font-weight:500;font-size:12.5px;letter-spacing:1.4px;text-transform:uppercase;color:#E9E2D4;padding:14px 18px}
.mainnav a:hover{background:var(--accent);color:#fff}
.mainnav a.active{color:#fff;box-shadow:inset 0 -3px 0 var(--accent)}

/* ============ BULLETIN ============ */
.bulletin{background:var(--accent);color:#fff}
.bulletin .wrap{display:flex;align-items:center;gap:16px;padding:9px 26px}
.b-label{font-family:var(--mono);font-size:10.5px;font-weight:500;letter-spacing:1.4px;text-transform:uppercase;background:#fff;color:var(--accent);padding:4px 10px;white-space:nowrap}
.b-headline{flex:1;min-width:0}
.b-headline-item{font-family:var(--body);font-weight:600;font-size:14.5px}
.b-headline-item a{color:#fff}
.b-headline-item a:hover{text-decoration:underline}
.b-arrows{display:flex;gap:6px}
.b-arrows button{width:28px;height:28px;border:1px solid rgba(255,255,255,.4);background:transparent;color:#fff;cursor:pointer;display:grid;place-items:center}
.b-arrows button:hover{background:#fff;color:var(--accent)}
.b-arrows svg{width:13px;height:13px;stroke:currentColor;fill:none;stroke-width:2.4}

/* ============ LEAD ============ */
.lead{display:grid;grid-template-columns:1.75fr 1fr;gap:36px;padding:34px 0 0}
.lead-main .lead-fig{display:block;overflow:hidden;aspect-ratio:16/10;margin-bottom:16px}
.lead-main .lead-fig img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.lead-main .lead-fig:hover img{transform:scale(1.03)}
.cat-pill{display:inline-block;font-family:var(--mono);font-size:10.5px;font-weight:500;letter-spacing:1.2px;text-transform:uppercase;color:var(--accent);border-top:2px solid var(--accent);padding-top:5px;margin-bottom:9px}
.lead-main h1{font-family:var(--serif);font-weight:800;font-size:42px;line-height:1.08;letter-spacing:-.6px;margin:0 0 12px}
.lead-main h1 a{color:var(--ink)}.lead-main h1 a:hover{color:var(--accent)}
.lead-main .standfirst{font-size:19px;line-height:1.5;color:var(--ink-soft);margin:0 0 14px;font-style:italic}
.byline-row{font-family:var(--mono);font-size:11.5px;letter-spacing:.4px;text-transform:uppercase;color:var(--mute)}
.byline-row .author{color:var(--accent)}
.lead-side{display:flex;flex-direction:column;border-top:2px solid var(--ink);padding-top:6px}
.side-item{padding:16px 0;border-bottom:1px solid var(--line)}
.side-item:last-child{border-bottom:none}
.side-item h3{font-family:var(--serif);font-weight:700;font-size:20px;line-height:1.18;margin:7px 0 6px}
.side-item h3 a{color:var(--ink)}.side-item h3 a:hover{color:var(--accent)}
.side-item p{font-size:14.5px;color:var(--mute);margin:0;line-height:1.5}

/* ============ SECTION HEAD + GRID ============ */
.sec-head{display:flex;align-items:center;gap:14px;margin:40px 0 20px;border-bottom:2px solid var(--ink);padding-bottom:8px}
.sec-head h2{font-family:var(--serif);font-weight:800;font-size:25px;letter-spacing:-.3px;margin:0}
.sec-head::before{content:"";width:22px;height:22px;background:var(--accent)}
.story-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.story{display:flex;flex-direction:column}
.story-fig{display:block;overflow:hidden;aspect-ratio:3/2;margin-bottom:13px}
.story-fig img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.story:hover .story-fig img{transform:scale(1.04)}
.story h3{font-family:var(--serif);font-weight:700;font-size:21px;line-height:1.2;margin:8px 0 8px}
.story h3 a{color:var(--ink)}.story h3 a:hover{color:var(--accent)}
.story p{font-size:15px;color:var(--ink-soft);margin:0 0 10px;line-height:1.5}
.story-meta{font-family:var(--mono);font-size:10.5px;letter-spacing:.4px;text-transform:uppercase;color:var(--mute);margin-top:auto}
.story-meta .author{color:var(--accent)}
.more-row{display:flex;justify-content:center;margin:34px 0 0}
.more-btn{font-family:var(--mono);font-weight:500;font-size:12px;letter-spacing:1.2px;text-transform:uppercase;border:1px solid var(--ink);background:transparent;color:var(--ink);padding:13px 30px;cursor:pointer}
.more-btn:hover{background:var(--ink);color:var(--paper)}

/* ============ CATEGORY HEADER ============ */
.cat-header{padding:40px 0 8px;border-bottom:2px solid var(--ink);margin-bottom:26px}
.cat-header .eyebrow{font-family:var(--mono);font-size:11px;letter-spacing:1.4px;text-transform:uppercase;color:var(--accent);margin-bottom:10px}
.cat-header h1{font-family:var(--serif);font-weight:900;font-size:46px;letter-spacing:-1px;margin:0;line-height:1}
.cat-header p{font-size:17px;color:var(--mute);margin:12px 0 0;max-width:560px;font-style:italic}

/* ============ ARTICLE ============ */
.article-shell{max-width:760px;margin:0 auto;padding:34px 26px 0}
.breadcrumb{font-family:var(--mono);font-size:11px;letter-spacing:.5px;text-transform:uppercase;color:var(--mute);margin-bottom:18px}
.breadcrumb a{color:var(--mute)}.breadcrumb a:hover{color:var(--accent)}
.article-cat{display:inline-block;font-family:var(--mono);font-size:11px;font-weight:500;letter-spacing:1.4px;text-transform:uppercase;color:var(--accent);border-top:2px solid var(--accent);padding-top:6px;margin-bottom:14px}
.article-shell h1{font-family:var(--serif);font-weight:800;font-size:44px;line-height:1.07;letter-spacing:-.8px;margin:0 0 18px}
.article-standfirst{font-size:21px;line-height:1.5;color:var(--ink-soft);margin:0 0 24px;font-style:italic}
.article-byline{display:flex;flex-wrap:wrap;gap:8px 16px;align-items:center;padding:15px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);margin-bottom:26px;font-family:var(--mono);font-size:11.5px;letter-spacing:.4px;text-transform:uppercase;color:var(--mute)}
.article-byline .author{color:var(--accent);font-weight:500}
.article-hero{margin:0 0 28px}
.article-hero img{width:100%;aspect-ratio:16/9;object-fit:cover}
.article-hero figcaption{font-family:var(--mono);font-size:11px;color:var(--mute);padding-top:10px;line-height:1.45}
.article-body{font-size:18.5px;line-height:1.75;color:var(--ink-soft)}
.article-body p{margin:0 0 1.25em}
.article-body > p:first-of-type::first-letter{float:left;font-family:var(--serif);font-weight:900;font-size:74px;line-height:.72;margin:8px 12px 0 0;color:var(--accent)}
.article-body h2{font-family:var(--serif);font-weight:800;font-size:28px;line-height:1.14;margin:38px 0 13px;color:var(--ink);letter-spacing:-.4px}
.article-body h3{font-family:var(--serif);font-weight:700;font-size:22px;margin:26px 0 10px;color:var(--ink)}
.article-body ul,.article-body ol{margin:0 0 1.25em;padding-left:1.3em}
.article-body li{margin-bottom:.5em}
.article-body a{color:var(--accent);text-decoration:underline;text-underline-offset:2px}
.article-body blockquote{font-family:var(--serif);font-weight:700;font-style:italic;font-size:26px;line-height:1.3;color:var(--ink);border-left:4px solid var(--accent);margin:30px 0;padding:4px 0 4px 24px}
.article-inline{margin:30px 0}
.article-inline img{width:100%;aspect-ratio:16/9;object-fit:cover}
.article-inline figcaption{font-family:var(--mono);font-size:11px;color:var(--mute);padding-top:9px}
.callout{background:var(--accent-soft);border-left:4px solid var(--accent);padding:20px 24px;margin:28px 0;font-size:16px;line-height:1.55;color:var(--ink-soft)}
.callout strong{display:block;font-family:var(--mono);font-size:11px;letter-spacing:.6px;text-transform:uppercase;color:var(--accent);margin-bottom:6px}
.callout p{margin:0}
.rank-card{background:var(--surface);border:1px solid var(--line);border-left:4px solid var(--accent);padding:20px 22px;margin:20px 0;box-shadow:var(--shadow-sm)}
.rank-card .rank-no{display:inline-grid;place-items:center;width:34px;height:34px;background:var(--accent);color:#fff;font-family:var(--serif);font-weight:800;font-size:16px;margin-bottom:11px}
.rank-card h3{font-family:var(--serif);font-weight:700;font-size:22px;margin:0 0 6px;color:var(--ink)}
.rank-card .rank-meta{font-family:var(--mono);font-size:10.5px;letter-spacing:.3px;text-transform:uppercase;color:var(--mute);margin-bottom:11px}
.rank-card .rank-meta .tag{background:var(--ink);color:var(--paper);padding:3px 8px;margin-right:8px}
.rank-card p{font-size:16.5px;line-height:1.6;color:var(--ink-soft);margin:0}
/* data table */
.data-table{width:100%;border-collapse:collapse;margin:28px 0;font-size:15px}
.data-table caption{font-family:var(--mono);font-size:11px;letter-spacing:.6px;text-transform:uppercase;color:var(--mute);text-align:left;padding-bottom:8px}
.data-table th,.data-table td{text-align:left;padding:11px 13px;border-bottom:1px solid var(--line)}
.data-table thead th{font-family:var(--mono);font-size:11px;letter-spacing:.5px;text-transform:uppercase;color:var(--paper);background:var(--ink)}
.data-table tbody tr:nth-child(even){background:var(--paper-2)}
.data-table td:first-child{font-weight:600;color:var(--ink)}
.data-table .num{font-family:var(--mono);color:var(--accent)}

/* paywall */
.paywall-fade{position:relative;height:120px;margin-top:-120px;background:linear-gradient(180deg,transparent,var(--paper) 90%);pointer-events:none}
.paywall-gate{background:var(--surface);border:2px solid var(--accent);padding:32px 28px;text-align:center;margin-top:16px;box-shadow:var(--shadow)}
.pg-eyebrow{font-family:var(--mono);font-size:11px;font-weight:500;letter-spacing:1.2px;text-transform:uppercase;color:var(--accent)}
.paywall-gate h3{font-family:var(--serif);font-weight:800;font-size:26px;margin:10px 0 8px;color:var(--ink)}
.paywall-gate p{font-size:16px;color:var(--ink-soft);margin:0 0 22px}
.paywall-tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:22px 0;text-align:center}
.paywall-tier{border:1px solid var(--line-2);background:var(--paper);padding:18px 10px;cursor:pointer;position:relative;transition:.15s}
.paywall-tier:hover{border-color:var(--accent);transform:translateY(-2px)}
.paywall-tier.popular{border:2px solid var(--accent)}
.paywall-tier.selected{border:2px solid var(--accent);background:var(--accent-soft)}
.paywall-tier .tier-badge{position:absolute;top:-10px;left:50%;transform:translateX(-50%);background:var(--accent);color:#fff;font-family:var(--mono);font-size:9px;letter-spacing:.4px;text-transform:uppercase;padding:3px 10px;white-space:nowrap}
.paywall-tier .tier-name{font-family:var(--mono);font-size:10.5px;letter-spacing:.5px;text-transform:uppercase;color:var(--mute)}
.paywall-tier .tier-price{font-family:var(--serif);font-weight:800;font-size:27px;color:var(--ink);margin:6px 0 0}
.paywall-tier .tier-period{font-family:var(--mono);font-size:10px;color:var(--mute)}
.paywall-cta{font-family:var(--mono);font-weight:500;font-size:12.5px;letter-spacing:1.2px;text-transform:uppercase;background:var(--accent);color:#fff;border:none;padding:15px 34px;cursor:pointer}
.paywall-cta:hover{background:var(--accent-2)}

/* share / author / related */
.share-bar{display:flex;align-items:center;gap:9px;flex-wrap:wrap;margin:26px 0;padding:16px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.share-bar .label{font-family:var(--mono);font-size:11px;letter-spacing:.6px;text-transform:uppercase;color:var(--mute);margin-right:4px}
.share-btn{font-family:var(--mono);font-weight:500;font-size:11.5px;letter-spacing:.4px;text-transform:uppercase;border:1px solid var(--line-2);background:var(--surface);color:var(--ink);padding:8px 14px;cursor:pointer}
.share-btn:hover{background:var(--accent);border-color:var(--accent);color:#fff}
.author-card{display:flex;gap:15px;align-items:flex-start;background:var(--paper-2);padding:18px 20px;margin:26px 0}
.author-card .avatar{width:52px;height:52px;border-radius:50%;background:var(--accent);color:#fff;display:grid;place-items:center;font-family:var(--serif);font-weight:800;font-size:19px;flex-shrink:0}
.author-card h4{font-family:var(--serif);font-weight:700;font-size:17px;margin:0 0 4px;color:var(--ink)}
.author-card p{font-size:14.5px;color:var(--ink-soft);margin:0;line-height:1.5}
.related{margin:32px 0 8px}
.related > h3{font-family:var(--serif);font-weight:800;font-size:22px;margin:0 0 16px;border-bottom:2px solid var(--ink);padding-bottom:8px}
.related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.related-card{display:block}
.related-card .r-fig{overflow:hidden;aspect-ratio:3/2;margin-bottom:10px}
.related-card .r-fig img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.related-card:hover .r-fig img{transform:scale(1.04)}
.related-card .cat-pill{margin-bottom:6px}
.related-card h4{font-family:var(--serif);font-weight:700;font-size:16px;line-height:1.22;margin:0}
.related-card h4 a{color:var(--ink)}.related-card h4 a:hover{color:var(--accent)}

/* ============ MODAL ============ */
#starguo-modal{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;animation:mf .18s ease}
@keyframes mf{from{opacity:0}to{opacity:1}}
#starguo-modal .modal-backdrop{position:absolute;inset:0;background:rgba(28,26,23,.6);cursor:pointer}
#starguo-modal .modal-dialog{position:relative;background:var(--surface);max-width:500px;width:100%;box-shadow:var(--shadow);border-top:4px solid var(--accent);animation:ms .22s ease}
@keyframes ms{from{transform:translateY(16px);opacity:0}to{transform:translateY(0);opacity:1}}
#starguo-modal .modal-close{position:absolute;top:8px;right:14px;background:none;border:none;font-size:28px;line-height:1;cursor:pointer;color:var(--mute)}
#starguo-modal .modal-close:hover{color:var(--accent)}
#starguo-modal .modal-body{padding:36px 36px 30px;text-align:center}
#starguo-modal .modal-icon{width:52px;height:52px;border-radius:50%;background:var(--accent-soft);color:var(--accent);margin:0 auto 14px;display:grid;place-items:center;font-size:23px}
#starguo-modal h3{font-family:var(--serif);font-weight:800;font-size:24px;margin:0 0 14px;color:var(--ink)}
#starguo-modal .subscribe-tier-label{font-size:14px;color:var(--ink-soft);margin:0 0 16px;padding:9px 12px;background:var(--accent-soft);text-align:left}
#starguo-modal label{display:block;font-family:var(--mono);font-size:10.5px;letter-spacing:.5px;text-transform:uppercase;color:var(--mute);margin-bottom:9px;text-align:left}
#starguo-modal .subscribe-row{display:flex;gap:8px}
#starguo-modal input[type=email]{flex:1;border:1px solid var(--line-2);padding:13px 14px;font-size:15px;font-family:var(--body);background:var(--paper);color:var(--ink);outline:none}
#starguo-modal input[type=email]:focus{border-color:var(--accent)}
#starguo-modal .subscribe-submit-btn{background:var(--accent);color:#fff;border:none;padding:0 22px;font-family:var(--mono);font-weight:500;font-size:12px;letter-spacing:.8px;text-transform:uppercase;cursor:pointer;white-space:nowrap}
#starguo-modal .subscribe-submit-btn:hover{background:var(--accent-2)}
#starguo-modal .subscribe-fineprint{font-family:var(--mono);font-size:10px;color:var(--mute);margin:13px 0 0;line-height:1.5}
#starguo-modal .modal-success .subscribe-success-icon{width:52px;height:52px;margin:0 auto 12px;background:var(--accent);color:#fff;border-radius:50%;display:grid;place-items:center;font-size:25px}
#starguo-modal .modal-success p{font-size:15px;color:var(--ink-soft);margin:0 0 10px}
#starguo-modal .subscribe-success-meta{font-family:var(--mono);font-size:10px;letter-spacing:.4px;text-transform:uppercase;color:var(--mute);margin:14px 0 18px}
#starguo-modal .modal-done-btn{font-family:var(--mono);font-weight:500;font-size:12px;letter-spacing:.8px;text-transform:uppercase;background:var(--ink);color:var(--paper);border:none;padding:12px 30px;cursor:pointer}
#starguo-modal .modal-done-btn:hover{background:var(--accent);color:#fff}

/* ============ GENERIC PAGE ============ */
.page-shell{max-width:760px;margin:0 auto;padding:34px 26px 0}
.page-shell h1{font-family:var(--serif);font-weight:800;font-size:42px;line-height:1.06;letter-spacing:-.6px;margin:0 0 8px}
.page-shell .page-sub{font-size:19px;color:var(--mute);margin:0 0 24px;font-style:italic}
.page-shell h2{font-family:var(--serif);font-weight:700;font-size:24px;margin:28px 0 12px;color:var(--ink)}
.page-shell p{font-size:17px;line-height:1.68;color:var(--ink-soft);margin:0 0 1.1em}
.page-shell ul,.page-shell ol{font-size:17px;line-height:1.68;color:var(--ink-soft)}
.page-shell a{color:var(--accent);text-decoration:underline}
.contact-form{display:grid;gap:14px;max-width:560px;margin-top:6px}
.contact-form label{font-family:var(--mono);font-size:10.5px;letter-spacing:.4px;text-transform:uppercase;color:var(--mute)}
.contact-form input,.contact-form textarea,.contact-form select{width:100%;border:1px solid var(--line-2);padding:12px 14px;font-family:var(--body);font-size:15px;background:var(--surface);color:var(--ink);outline:none}
.contact-form input:focus,.contact-form textarea:focus,.contact-form select:focus{border-color:var(--accent)}
.contact-form button{font-family:var(--mono);font-weight:500;font-size:12px;letter-spacing:1.2px;text-transform:uppercase;background:var(--accent);color:#fff;border:none;padding:13px 28px;cursor:pointer;width:fit-content}
.contact-form button:hover{background:var(--accent-2)}
.form-success{background:var(--accent-soft);padding:15px 18px;margin-top:16px;font-size:15.5px;color:var(--ink-soft);border-left:4px solid var(--accent)}
.signin-card{max-width:430px;margin:0 auto;background:var(--surface);border:1px solid var(--line);padding:32px 28px;box-shadow:var(--shadow-sm)}
.signin-card h1{font-size:30px;text-align:center;margin:0 0 18px}
.signin-help{text-align:center;font-family:var(--mono);font-size:11px;color:var(--mute);margin-top:14px}
.signin-help a{color:var(--accent)}
.plan-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin:24px 0;align-items:stretch}
.plan-card{background:var(--surface);border:2px solid var(--line-2);padding:28px 22px;text-align:center;cursor:pointer;display:flex;flex-direction:column;box-shadow:var(--shadow-sm);transition:.18s}
.plan-card:hover{border-color:var(--accent);transform:translateY(-2px)}
.plan-card.popular{border-color:var(--accent);position:relative}
.plan-card.popular::before{content:"Most popular";position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--accent);color:#fff;font-family:var(--mono);font-size:10px;letter-spacing:.4px;text-transform:uppercase;padding:4px 14px}
.plan-card h3{font-family:var(--serif);font-weight:800;font-size:23px;margin:0 0 6px;color:var(--ink)}
.plan-card .price{font-family:var(--serif);font-weight:800;font-size:42px;color:var(--accent);margin:8px 0 2px}
.plan-card .period{font-family:var(--mono);font-size:10.5px;letter-spacing:.4px;text-transform:uppercase;color:var(--mute)}
.plan-card ul{list-style:none;padding:0;margin:18px 0;text-align:left}
.plan-card li{font-size:14.5px;padding:8px 0;border-bottom:1px solid var(--line);color:var(--ink-soft)}
.plan-card li::before{content:"\2713";color:var(--accent);font-weight:700;margin-right:9px}
.plan-cta{font-family:var(--mono);font-weight:500;font-size:12px;letter-spacing:1px;text-transform:uppercase;background:var(--paper-2);color:var(--ink);border:1px solid var(--line-2);padding:12px 20px;cursor:pointer;width:100%}
.plan-card.popular .plan-cta{background:var(--accent);border-color:var(--accent);color:#fff}
.plan-cta:hover{background:var(--accent);border-color:var(--accent);color:#fff}

/* ============ FOOTER ============ */
.site-footer{background:var(--ink);color:#CFC9BD;margin-top:30px}
.site-footer .wrap{padding:44px 26px 26px}
.footer-top{display:grid;grid-template-columns:1.7fr 1fr 1fr 1fr;gap:30px;padding-bottom:28px;border-bottom:1px solid #383430}
.footer-brand .logo{font-family:var(--serif);font-weight:900;font-size:30px;color:#fff}
.footer-brand .logo .accent{color:var(--accent-2);font-style:italic}
.footer-brand p{font-size:14px;line-height:1.55;color:#9A948A;margin:12px 0 12px;max-width:300px}
.footer-brand address{font-family:var(--mono);font-size:11px;line-height:1.7;color:#9A948A;font-style:normal}
.footer-brand address strong{color:#CFC9BD}
.footer-brand address a{color:#9A948A}
.footer-col h5{font-family:var(--mono);font-size:11px;font-weight:500;letter-spacing:1px;text-transform:uppercase;color:#fff;margin:0 0 13px}
.footer-col ul{list-style:none;padding:0;margin:0}
.footer-col li{padding:5px 0;font-size:14px}
.footer-col a{color:#B6B0A4}.footer-col a:hover{color:var(--accent-2)}
.footer-bottom{padding-top:20px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;font-family:var(--mono);font-size:11px;color:#7E786E}
.footer-bottom a{color:#7E786E}.footer-bottom a:hover{color:var(--accent-2)}

#search-banner{position:fixed;top:0;left:0;right:0;background:var(--accent);color:#fff;padding:11px 16px;text-align:center;z-index:1100;font-family:var(--body);font-size:14px;box-shadow:var(--shadow)}
#search-banner a{color:#fff;text-decoration:underline;margin-left:12px;font-weight:600}

/* ============ RESPONSIVE ============ */
@media (max-width:900px){
  .lead{grid-template-columns:1fr}
  .story-grid,.related-grid{grid-template-columns:1fr 1fr}
  .footer-top{grid-template-columns:1fr 1fr}
  .brand{font-size:32px}
}
@media (max-width:600px){
  .wrap{padding:0 18px}
  .masthead-top{display:none}
  .mainnav .wrap{overflow-x:auto;flex-wrap:nowrap}
  .mainnav a{white-space:nowrap}
  .lead-main h1{font-size:31px}
  .article-shell h1{font-size:31px}
  .article-body{font-size:17px}
  .story-grid,.related-grid,.paywall-tiers,.plan-grid,.footer-top{grid-template-columns:1fr}
  .bulletin .b-label{display:none}
}
