/**
 * components.css — Romanian GOP brand layer
 *
 * Forked from roiban-tw. Brand-named CSS variables (--navy, --red, --gold, etc.)
 * defined alongside DaisyUI HSL tokens (--p, --s, --a, etc.) for any DaisyUI
 * components that get used. AF1 palette: navy / red / gold / white.
 *
 * Per R22 (no Tailwind utilities on themed surfaces): all brand colors come
 * through CSS variables, no Tailwind utility classes for color/bg.
 * Per R23 (DaisyUI HSL theming, no !important): tokens are raw HSL triples.
 */

/* ========================================
   Section 1: DaisyUI HSL token map
   For any DaisyUI components (.btn, .card, .navbar, etc.) that get used.
   ======================================== */

[data-theme="light"] {
  /* Primary — navy #002F6C */
  --p:  212 100% 21%;
  --pc: 0 0% 100%;
  /* Secondary — red #BF2026 */
  --s:  358 71% 44%;
  --sc: 0 0% 100%;
  /* Accent — gold #D4AF37 */
  --a:  46 65% 52%;
  --ac: 220 13% 10%;
  /* Neutral */
  --n:  220 13% 14%;
  --nc: 0 0% 100%;
  /* Base surfaces */
  --b1: 0 0% 100%;
  --b2: 0 0% 95%;
  --b3: 0 0% 90%;
  --bc: 220 13% 10%;
  /* Status */
  --in: 200 92% 46%;
  --su: 142 72% 38%;
  --wa: 38 95% 50%;
  --er: 358 71% 44%;
}

[data-theme="dark"] {
  --p:  212 70% 35%;
  --pc: 0 0% 100%;
  --s:  358 65% 50%;
  --sc: 0 0% 100%;
  --a:  46 65% 56%;
  --ac: 220 53% 9%;
  --n:  220 13% 90%;
  --nc: 220 53% 9%;
  --b1: 220 53% 9%;
  --b2: 220 25% 14%;
  --b3: 220 25% 18%;
  --bc: 220 18% 95%;
  --in: 200 90% 65%;
  --su: 142 65% 58%;
  --wa: 40 92% 62%;
  --er: 358 70% 60%;
}

/* ========================================
   Section 2: Brand mockup CSS (ported verbatim from mockup.html)
   ======================================== */

:root, [data-theme="light"]{
    --navy:#002F6C;
    --navy-deep:#001E47;
    --navy-bar:#0E1A2A;
    --red:#BF2026;
    --red-hover:#9C1A1F;
    --gold:#D4AF37;
    --bg:#FFFFFF;
    --bg-muted:#F2F2F2;
    --bg-card:#FFFFFF;
    --line:#D9D9D9;
    --text:#1A1A1A;
    --text-muted:#5A5A5A;
    --headline:#002F6C;
  }
  [data-theme="dark"]{
    --navy:#0a3f86;
    --navy-deep:#001E47;
    --navy-bar:#070D1A;
    --red:#D93B41;
    --red-hover:#BF2026;
    --gold:#E0BF4D;
    --bg:#0B1525;
    --bg-muted:#142238;
    --bg-card:#142238;
    --line:#22344F;
    --text:#F0F4FA;
    --text-muted:#A8B5C8;
    --headline:#F0F4FA;
  }
  [data-theme="dark"] footer{background:var(--bg-muted)}
  /* Light/dark surface overrides driven by CSS vars */
  body{background:var(--bg);color:var(--text)}
  .trend{background:var(--bg);border-bottom-color:var(--line)}
  .trend .label{color:var(--text-muted)}
  .lead-story .copy h1, .tile h3{color:var(--headline)}
  .tile .meta, .tile .dek, .lead-story .copy .dek{color:var(--text-muted)}
  .row{border-bottom-color:var(--line)}
  .lead-story{border-bottom-color:var(--line)}
  .side .stream-list{background:var(--bg-card);border-color:var(--line)}
  .side .stream-list a{color:var(--text);border-top-color:var(--line)}
  .side .stream-list a:hover{background:var(--bg-muted)}
  .side .stream-list .name small{color:var(--text-muted)}
  .side .ad{background:var(--bg-muted)}
  .side .ad .ad-title{color:var(--headline)}
  .side .ad .ad-tag, .side .ad .ad-source{color:var(--text-muted)}
  .ad-slot{background:var(--bg-muted);color:var(--text-muted);border-color:var(--line)}
  .promo{background:var(--bg-card);border-color:var(--line)}
  .promo .title{color:var(--headline)}
  .promo .title small{color:var(--text-muted)}
  .bottom-row{border-top-color:var(--line)}
  [data-theme="dark"] .topbar{background:var(--navy-deep)}
  [data-theme="dark"] .strip{background:#000;border-bottom-color:#181818}
  [data-theme="dark"] .promo .img .ph svg{color:#fff;opacity:0.45}
  *,*:before,*:after{box-sizing:border-box;margin:0;padding:0}
  html,body{background:var(--bg);color:var(--text);font-family:'Lato',Arial,sans-serif;font-size:16px;line-height:1.4;-webkit-font-smoothing:antialiased}
  a{color:inherit;text-decoration:none}
  img{display:block;max-width:100%;height:auto}
  ul{list-style:none}
  .container{width:min(100%,1200px);margin:0 auto;padding:0 16px}

  /* ===== Top utility strip — Fox property links row ===== */
  .strip{background:#000;color:#fff;font-size:12px;font-weight:900;letter-spacing:0.04em;text-transform:uppercase;border-bottom:1px solid #1a1a1a}
  .strip-inner{display:flex;align-items:center;gap:0;padding:0 4px;height:34px;width:min(100%,1400px);margin:0 auto;overflow:hidden}
  .strip-link{display:flex;align-items:center;gap:6px;padding:0 14px;height:100%;border-right:1px solid #1a1a1a;color:#fff;white-space:nowrap}
  .strip-link:first-child{border-left:1px solid #1a1a1a}
  .strip-link.active{background:#1a1a1a}
  .strip-mark{font-family:Georgia,serif;font-style:italic;font-weight:900;font-size:11px;letter-spacing:-0.02em;color:#bcbcbc}
  .strip-mark .b{color:#fff;background:#fff;color:#000;padding:1px 4px;display:inline-block;font-style:normal}
  .strip-mark.red .b{background:var(--red);color:#fff}
  .strip-play{display:inline-flex;align-items:center;justify-content:center;width:14px;height:14px;background:#fff;color:#000;border-radius:1px;font-size:8px;line-height:1}
  .strip-tag{font-size:9px;font-weight:900;text-transform:uppercase;color:#9b9b9b;letter-spacing:0.06em}
  .strip-tagline-row{justify-content:center}
  .strip-tagline{font-family:Georgia,serif;font-style:italic;font-weight:400;font-size:13px;color:var(--gold);letter-spacing:0.02em;text-transform:none}

  /* America 250 countdown bar */
  .a250{background:linear-gradient(180deg,#0a142a 0%,#050b1c 100%);color:#fff;border-bottom:2px solid var(--red);position:relative;overflow:hidden}
  .a250:before{content:"";position:absolute;left:0;right:0;top:0;height:2px;background:linear-gradient(90deg,var(--red) 0%,var(--gold) 50%,var(--red) 100%)}
  .a250-inner{display:flex;align-items:center;justify-content:center;gap:24px;min-height:54px;width:min(100%,1400px);margin:0 auto;padding:8px 24px;flex-wrap:wrap}
  .a250 .label{display:inline-flex;align-items:center;gap:10px;font-family:'Lato',Arial,sans-serif;font-size:18px;font-weight:900;letter-spacing:0.14em;text-transform:uppercase;color:#fff;line-height:1}
  .a250 .label .flag{display:inline-block;width:32px;height:19px;flex-shrink:0}
  .a250 .label .yr{color:var(--gold);font-style:italic;font-family:Georgia,serif;font-weight:400;font-size:22px;letter-spacing:0.02em;text-transform:none;margin-left:2px;line-height:1}
  .a250 .clock-row{display:inline-flex;align-items:baseline;gap:10px;flex-wrap:wrap}
  .a250 .unit{display:inline-flex;align-items:baseline;gap:6px;font-family:'Lato',Arial,sans-serif}
  .a250 .unit .v{font-weight:900;font-size:22px;color:#fff;font-variant-numeric:tabular-nums;line-height:1;letter-spacing:-0.01em}
  .a250 .unit .v.gold{color:var(--gold)}
  .a250 .unit .u{font-size:10px;font-weight:900;letter-spacing:0.16em;color:#9aa3b5;text-transform:uppercase;line-height:1}
  .a250 .colon{color:#3a4868;font-size:18px;font-weight:900;line-height:1}
  .a250 .target{font-family:Georgia,serif;font-style:italic;font-size:22px;color:#fff;letter-spacing:0.02em;line-height:1;white-space:nowrap;display:inline-flex;align-items:baseline;gap:10px;font-weight:400}
  .a250 .target b{color:var(--gold);font-style:normal;font-family:'Lato',Arial,sans-serif;font-weight:900;font-size:13px;letter-spacing:0.14em;text-transform:uppercase}
  @media (max-width:760px){
    .a250-inner{min-height:0;padding:8px 12px;gap:12px}
    .a250 .label{font-size:14px}
    .a250 .label .yr{font-size:18px}
    .a250 .unit .v{font-size:18px}
    .a250 .colon{font-size:14px}
    .a250 .target{display:none}
  }

  /* ===== Main navy header ===== */
  .topbar{background:var(--navy);color:#fff;border-top:3px solid var(--red);border-bottom:3px solid var(--red)}
  .topbar-inner{display:flex;align-items:center;gap:0;height:64px;width:min(100%,1400px);margin:0 auto;padding:0 16px}
  .brand{display:flex;align-items:stretch;gap:10px;color:#fff;padding:6px 14px 6px 0;border-right:1px solid rgba(255,255,255,0.18);height:100%;align-items:center}
  .brand-mark{width:54px;height:54px;border-radius:50%;background:#fff;display:grid;place-items:center;flex-shrink:0;overflow:hidden}
  .brand-mark img{width:100%;height:100%;object-fit:cover}
  .brand-text{display:flex;flex-direction:column;line-height:1;gap:6px;align-items:center;color:#fff;padding:0 4px}
  .brand-text .l1{display:inline-flex;align-items:center;font-family:Georgia,serif;font-weight:400;font-size:20px;letter-spacing:0.16em;line-height:1;text-transform:uppercase;white-space:nowrap}
  .brand-text .l1:before,.brand-text .l1:after{content:"";display:inline-block;width:18px;height:1px;background:currentColor;margin:0 10px;opacity:0.55}
  .brand-text .l2{font-family:'Lato',Arial,sans-serif;font-weight:700;font-size:10px;letter-spacing:0.32em;text-transform:uppercase;line-height:1;opacity:0.85}
  .topnav{display:flex;align-items:center;gap:0;flex:1;padding:0 14px;height:100%}
  .topnav a{display:inline-flex;align-items:center;gap:5px;padding:0 11px;font-size:14px;font-weight:700;letter-spacing:0.02em;height:100%;color:#fff;border-bottom:3px solid transparent;margin-bottom:-3px}
  .topnav a:hover{border-bottom-color:var(--red)}
  .topnav a .caret{font-size:9px;opacity:0.8}
  .topnav .more{font-size:18px;letter-spacing:1px}
  .actions{display:flex;align-items:center;gap:14px;padding-left:14px;border-left:1px solid rgba(255,255,255,0.18);height:100%;margin-left:auto}
  .actions .icon{width:18px;height:18px;color:#fff;display:grid;place-items:center;cursor:pointer;background:none;border:0;padding:0}
  .actions .theme-toggle{width:32px;height:32px;border-radius:50%;border:1px solid rgba(255,255,255,0.25);display:grid;place-items:center;background:transparent;color:#fff;cursor:pointer;padding:0;transition:background .18s ease,border-color .18s ease}
  .actions .theme-toggle:hover{background:rgba(255,255,255,0.1);border-color:rgba(255,255,255,0.5)}
  .actions .theme-toggle svg{width:15px;height:15px}
  [data-theme="dark"] .actions .theme-toggle{border-color:rgba(255,255,255,0.3)}
  .actions .login{font-size:13px;font-weight:700;color:#fff}
  .actions .watchtv{background:var(--red);color:#fff;font-size:13px;font-weight:900;letter-spacing:0.02em;padding:8px 14px;text-transform:uppercase;display:inline-flex;align-items:center;gap:6px}
  .actions .watchtv:before{content:"▶";font-size:9px}

  /* ===== Trending bar ===== */
  .trend{background:var(--bg);border-bottom:1px solid var(--line)}
  .trend-inner{display:flex;align-items:center;gap:0;height:46px;width:min(100%,1400px);margin:0 auto;padding:0 16px}
  .trend .label{font-weight:900;font-size:12px;letter-spacing:0.06em;color:var(--text-muted);text-transform:uppercase;padding-right:16px}
  .trend ul{display:flex;align-items:center;gap:0;flex:1}
  .trend li{position:relative}
  .trend li + li{padding-left:18px;margin-left:18px}
  .trend li + li:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:1px;height:14px;background:var(--line)}
  .trend li a{color:var(--red);font-weight:900;font-size:13px;letter-spacing:0.04em;text-transform:uppercase}
  .trend li a:hover{color:var(--red-hover);text-decoration:underline}
  .trend .meta{margin-left:auto;display:flex;align-items:center;gap:10px;color:var(--text-muted);font-size:13px;font-weight:700}
  .trend .meta .temp{font-weight:900;color:var(--text)}

  /* ===== Trending bar — vertical title rotator (3s tick) ===== */
  .trend .trend-rotator{flex:1;height:46px;overflow:hidden;position:relative;min-width:0;padding-right:18px}
  .trend .trend-rotator ul{display:block;flex:initial;align-items:initial;gap:initial;list-style:none;margin:0;padding:0;will-change:transform}
  .trend .trend-rotator li{position:relative;height:46px;display:flex;align-items:center;padding-left:0;margin-left:0;list-style:none}
  .trend .trend-rotator li:before{display:none}
  .trend .trend-rotator li + li{padding-left:0;margin-left:0}
  .trend .trend-rotator li a{display:block;width:100%;color:var(--red);font-weight:900;font-size:13px;letter-spacing:0.04em;text-transform:uppercase;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:46px}
  .trend .trend-rotator li a:hover{color:var(--red-hover);text-decoration:underline}

  /* ===== Main layout ===== */
  .main{padding:24px 0 32px;width:min(100%,1400px);margin:0 auto}
  .main-grid{display:grid;grid-template-columns:1fr 320px;gap:24px;padding:0 16px}

  /* ===== Hero feature ===== */
  .lead-story{display:grid;grid-template-columns:1.1fr 0.9fr;gap:24px;align-items:start;padding-bottom:18px;border-bottom:1px solid var(--line);margin-bottom:24px}
  .lead-story .img-wrap{position:relative;aspect-ratio:16/10;overflow:hidden;background:#1B2A4E;display:block}
  .lead-story .img-wrap img{width:100%;height:100%;object-fit:cover;display:block;filter:saturate(0.9) contrast(1.04)}
  .lead-story .img-wrap:before{content:"";position:absolute;inset:0;background:rgba(0,47,108,0.14);mix-blend-mode:multiply;pointer-events:none;z-index:1}
  .lead-story .img-wrap:after{content:"";position:absolute;left:0;right:0;bottom:0;height:55%;background:linear-gradient(180deg,transparent 0%,rgba(0,0,0,0.55) 100%);pointer-events:none;z-index:2}
  .lead-story .img-wrap .kicker{z-index:3}
  .lead-story .kicker{position:absolute;left:0;bottom:14px;background:var(--navy);color:#fff;font-weight:900;letter-spacing:0.04em;text-transform:uppercase;font-size:13px;padding:7px 12px 7px 16px}
  .lead-story .kicker.red{background:var(--red)}
  .lead-story .copy h1{color:var(--headline);font-size:42px;line-height:1.05;font-weight:900;letter-spacing:-0.01em;font-family:'Lato',Arial,sans-serif}
  .lead-story .copy h1{color:var(--headline)}
  .lead-story .copy h1 a{color:inherit}
  .lead-story .copy h1 a:hover{color:var(--red)}
  .lead-story .copy .dek{margin-top:14px;color:var(--text-muted);font-size:15px;line-height:1.45;font-weight:400}

  /* ===== Story grid ===== */
  .row{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;padding-bottom:24px;border-bottom:1px solid var(--line);margin-bottom:24px}
  .row:last-child{border-bottom:0;margin-bottom:0}
  .tile .img-wrap{position:relative;aspect-ratio:4/3;overflow:hidden;background:#1B2A4E;display:block}
  .tile .img-wrap img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .35s ease,filter .35s ease;filter:saturate(0.88) contrast(1.05)}
  .tile:hover .img-wrap img{transform:scale(1.04);filter:saturate(1) contrast(1)}
  .tile .img-wrap:before{content:"";position:absolute;inset:0;background:rgba(0,47,108,0.18);mix-blend-mode:multiply;pointer-events:none;z-index:1;transition:opacity .35s ease}
  .tile:hover .img-wrap:before{opacity:0}
  .tile .img-wrap:after{content:"";position:absolute;left:0;right:0;bottom:0;height:55%;background:linear-gradient(180deg,transparent 0%,rgba(0,0,0,0.5) 100%);pointer-events:none;z-index:2}

  /* ===== Play-button overlay for video tiles ===== */
  .tile .img-wrap .play-btn,
  .lead-story .img-wrap .play-btn{position:absolute;inset:0;margin:auto;width:64px;height:64px;border-radius:50%;background:rgba(0,0,0,0.55);border:2px solid #fff;display:flex;align-items:center;justify-content:center;z-index:3;pointer-events:none;transition:transform .25s ease,background .25s ease,border-color .25s ease}
  .tile .img-wrap .play-btn:before,
  .lead-story .img-wrap .play-btn:before{content:"";width:0;height:0;border-style:solid;border-width:10px 0 10px 16px;border-color:transparent transparent transparent #fff;margin-left:4px;transition:border-left-color .25s ease}
  .tile:hover .img-wrap .play-btn,
  .lead-story:hover .img-wrap .play-btn{background:var(--red);transform:scale(1.08);border-color:#fff}
  .lead-story .img-wrap .play-btn{width:96px;height:96px}
  .lead-story .img-wrap .play-btn:before{border-width:14px 0 14px 22px;margin-left:6px}
  .tile .duration,
  .lead-story .duration{display:inline-flex;align-items:center;gap:5px;font-weight:900}
  .tile .duration:before,
  .lead-story .duration:before{content:"\25B6";font-size:9px;color:var(--red)}
  .tile .img-wrap .kicker{z-index:3}
  /* tile color variants */
  .ph-navy{background:linear-gradient(135deg,#0a3f86,#001E47)}
  .ph-deep{background:linear-gradient(135deg,#002F6C,#0E1A2A)}
  .ph-red{background:linear-gradient(135deg,#7C1418,#BF2026)}
  .ph-gold{background:linear-gradient(135deg,#7C5A0E,#D4AF37)}
  .ph-mix{background:linear-gradient(135deg,#001E47 0%,#002F6C 50%,#7C1418 100%)}
  .ph-papers{background:linear-gradient(160deg,#cdc7b5 0%,#9d9479 60%,#5b5337 100%)}
  .ph-bw{background:linear-gradient(135deg,#1a1a1a,#3a3a3a)}
  .ph-cream{background:linear-gradient(135deg,#F2EAD3,#C9B97E)}

  .tile .kicker{position:absolute;left:0;bottom:10px;background:var(--navy);color:#fff;font-weight:900;letter-spacing:0.04em;text-transform:uppercase;font-size:11px;padding:5px 10px 5px 12px}
  .tile .kicker.red{background:var(--red)}
  .tile .kicker.live:before{content:"";width:7px;height:7px;background:#fff;border-radius:50%;display:inline-block;margin-right:6px;vertical-align:middle;animation:pulse 1.4s infinite}
  @keyframes pulse{0%,100%{opacity:1}50%{opacity:0.45}}
  .tile h3{margin-top:14px;color:var(--headline);font-size:21px;line-height:1.18;font-weight:900;letter-spacing:-0.005em}
  .tile h3 a:hover{color:var(--red)}
  .tile .dek{margin-top:8px;font-size:13px;color:var(--text-muted)}
  .tile .meta, .lead-story .copy .meta{margin-top:10px;display:flex;align-items:center;gap:14px;font-size:12px;color:var(--text-muted);font-weight:700}
  .tile .meta .item, .lead-story .copy .meta .item{display:inline-flex;align-items:center;gap:5px}
  .tile .meta .item:before, .lead-story .copy .meta .item:before{display:inline-block;width:13px;height:13px;line-height:13px;text-align:center}
  .tile .meta .read:before, .lead-story .copy .meta .read:before{content:"⏱"}
  .tile .meta .comments:before, .lead-story .copy .meta .comments:before{content:"💬"}
  .tile .bullets{margin-top:10px;font-size:13px;color:var(--red);font-weight:700;line-height:1.45}
  .tile .bullets li{padding-left:14px;position:relative}
  .tile .bullets li:before{content:"•";color:var(--red);position:absolute;left:0;top:-1px;font-size:18px;line-height:1}

  /* ===== Sidebar ===== */
  .side > * + *{margin-top:14px}
  .side .onair{position:relative;background:var(--navy);color:#fff;overflow:hidden}
  .side .onair .stage{aspect-ratio:16/9;position:relative;background:linear-gradient(135deg,#0a3f86,#002F6C);display:grid;place-items:center;overflow:hidden}
  .side .onair .stage:before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at top,rgba(212,175,55,0.25),transparent 50%)}
  .side .onair .label{position:absolute;left:14px;top:14px;font-size:10px;font-weight:900;letter-spacing:0.12em;color:var(--gold);text-transform:uppercase}
  .side .onair .show{position:absolute;left:14px;bottom:36px;font-family:Georgia,serif;font-style:italic;font-size:30px;font-weight:900;line-height:0.95;color:#fff;text-shadow:0 2px 8px rgba(0,0,0,0.5);max-width:240px}
  .side .onair .show small{display:block;font-family:'Lato',sans-serif;font-style:normal;font-size:12px;font-weight:900;letter-spacing:0.1em;color:var(--gold);margin-top:8px;text-transform:uppercase}
  .side .onair .live{position:absolute;right:14px;bottom:14px;background:var(--red);color:#fff;font-size:10px;font-weight:900;letter-spacing:0.1em;padding:4px 8px;text-transform:uppercase;display:inline-flex;align-items:center;gap:5px}
  .side .onair .live:before{content:"";width:5px;height:5px;background:#fff;border-radius:50%;animation:pulse 1.4s infinite}
  .side .watch-cta{display:flex;align-items:center;justify-content:center;gap:8px;background:var(--red);color:#fff;font-weight:900;letter-spacing:0.04em;font-size:14px;padding:14px;text-transform:uppercase;transition:background .2s ease}
  .side .watch-cta:hover{background:var(--red-hover)}
  .side .watch-cta:after{content:"→";font-size:14px;font-weight:900}
  .side .stream24{display:flex;align-items:center;gap:10px;background:#000;color:#fff;padding:12px 14px}
  .side .stream24 .badge{background:#fff;color:#000;font-size:9px;font-weight:900;letter-spacing:0.05em;padding:4px 6px;line-height:1;font-family:Georgia,serif;font-style:italic}
  .side .stream24 .t{font-weight:900;font-size:13px;letter-spacing:0.02em}
  .side .stream24 .t small{display:block;font-weight:400;font-size:11px;color:#bbb;margin-top:2px;letter-spacing:0;text-transform:none}
  .side .stream-list{background:var(--bg-card);border:1px solid var(--line)}
  .side .stream-list a{display:flex;align-items:center;gap:10px;padding:11px 12px;border-top:1px solid var(--line);font-size:13px;font-weight:700;color:var(--text)}
  .side .stream-list a:first-child{border-top:0}
  .side .stream-list a:hover{background:var(--bg-muted)}
  .side .stream-list .badge{display:inline-grid;place-items:center;background:var(--navy);color:#fff;font-family:Georgia,serif;font-style:italic;font-size:9px;font-weight:900;padding:6px 7px;letter-spacing:0;line-height:1;width:48px;text-align:center;flex-shrink:0}
  .side .stream-list .badge.red{background:var(--red)}
  .side .stream-list .badge.gold{background:var(--gold);color:var(--navy)}
  .side .stream-list .badge.dark{background:#1a1a1a}
  .side .stream-list .name small{display:block;color:var(--text-muted);font-weight:400;font-size:11px;margin-top:2px}
  .side .stream-list .lock{margin-left:auto;color:var(--text-muted);font-size:13px}

  .side .ad{background:var(--bg-muted);padding:14px}
  .side .ad img{aspect-ratio:5/3;width:100%;background:linear-gradient(135deg,#a3b8d0,#5a7a98);object-fit:cover}
  .side .ad .ad-tag{display:flex;justify-content:space-between;align-items:center;margin-top:8px;font-size:11px;color:var(--text-muted)}
  .side .ad .ad-title{margin-top:6px;font-size:14px;font-weight:900;color:var(--headline);line-height:1.3}
  .side .ad .ad-source{font-size:12px;color:var(--text-muted);margin-top:4px}

  /* ===== Bottom row: 4 promos ===== */
  .bottom-row{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;padding:18px 16px 28px;width:min(100%,1400px);margin:0 auto;border-top:1px solid var(--line)}
  .wxbox{background:var(--navy);color:#fff;padding:18px;display:flex;flex-direction:column;gap:8px}
  .wxbox .head{display:flex;align-items:center;gap:8px;font-weight:900;font-size:11px;letter-spacing:0.08em;text-transform:uppercase}
  .wxbox .head .mark{background:#fff;color:var(--navy);font-weight:900;font-size:9px;padding:2px 5px;letter-spacing:0.04em}
  .wxbox .loc{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:700;opacity:0.9}
  .wxbox .now{display:flex;align-items:center;gap:14px;margin-top:4px}
  .wxbox .now .icon{font-size:32px}
  .wxbox .now .deg{font-size:48px;font-weight:900;letter-spacing:-0.02em;line-height:1}
  .wxbox .week{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-top:10px;padding-top:10px;border-top:1px solid rgba(255,255,255,0.15);font-size:12px;text-align:center}
  .wxbox .week .d{font-weight:900;text-transform:uppercase;font-size:11px;letter-spacing:0.04em}
  .wxbox .week .high{font-weight:900;font-size:14px;margin-top:4px}
  .wxbox .week .low{color:#bbcfe6;font-size:12px}

  .promo{background:var(--bg-card);border:1px solid var(--line);overflow:hidden;display:flex;flex-direction:column;text-decoration:none;color:inherit;transition:transform .2s ease,box-shadow .2s ease}
  .promo:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,47,108,0.12)}
  .promo .img{aspect-ratio:5/3;width:100%;position:relative;overflow:hidden;background:var(--navy)}
  .promo .img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .35s ease}
  .promo:hover .img img{transform:scale(1.04)}
  .promo .img:after{content:"";position:absolute;left:0;right:0;bottom:0;height:50%;background:linear-gradient(180deg,transparent 0%,rgba(0,30,71,0.55) 100%);pointer-events:none}
  .promo .body{padding:12px 14px}
  .promo .badge{display:inline-block;font-size:10px;font-weight:900;letter-spacing:0.08em;color:var(--red);text-transform:uppercase}
  .promo .title{margin-top:6px;font-weight:900;font-size:13px;color:var(--headline);line-height:1.3}
  .promo .title small{display:block;color:var(--text-muted);font-weight:400;margin-top:4px;font-size:12px;line-height:1.4}

  /* ===== CTA action grid ===== */
  .cta-grid{display:flex;flex-wrap:wrap;gap:12px 14px;justify-content:center;padding:36px 16px;width:min(100%,1400px);margin:0 auto;background:var(--bg)}
  .cta-grid .cta-btn{background:var(--navy);color:#fff;border:2px solid var(--red);padding:14px 22px;font-family:Georgia,serif;font-weight:700;font-size:15px;letter-spacing:0.03em;text-transform:uppercase;line-height:1;display:inline-flex;align-items:center;justify-content:center;text-align:center;transition:background .2s ease,border-color .2s ease,transform .15s ease;min-height:48px;white-space:nowrap}
  .cta-grid .cta-btn:hover{background:var(--navy-deep);border-color:var(--red-hover);transform:translateY(-1px)}
  [data-theme="dark"] .cta-grid{background:var(--bg)}
  [data-theme="dark"] .cta-grid .cta-btn{background:var(--navy-deep);border-color:var(--red)}
  @media (max-width:760px){
    .cta-grid{padding:24px 12px;gap:10px}
    .cta-grid .cta-btn{font-size:13px;padding:12px 16px;white-space:normal}
  }

  /* ===== Campaign ad (shared) ===== */
  .ad-campaign{position:relative;color:#fff;border:1px solid color-mix(in srgb,var(--gold) 28%,transparent);overflow:hidden;display:grid;grid-template-columns:1fr 110px;gap:10px;align-items:stretch;padding:24px 14px 16px}
  .ad-campaign:before{content:"PAID POLITICAL ADVERTISEMENT";position:absolute;top:0;left:0;right:0;background:rgba(0,0,0,0.35);color:#fff;font-family:'Lato',Arial,sans-serif;font-size:8px;font-weight:900;letter-spacing:0.18em;padding:4px 10px;text-align:center;line-height:1.4}
  .ad-campaign:after{content:"";position:absolute;left:-20%;right:-20%;bottom:-20%;height:55%;background:radial-gradient(ellipse at center,rgba(212,175,55,0.16) 0%,transparent 70%);pointer-events:none}
  .ad-campaign .ad-copy{position:relative;z-index:1;display:flex;flex-direction:column}
  .ad-campaign .name{font-family:Georgia,serif;font-size:22px;font-weight:400;line-height:1.05;color:#fff;margin:0;letter-spacing:0.005em}
  .ad-campaign .role{display:block;font-family:'Lato',Arial,sans-serif;font-size:9px;font-weight:900;letter-spacing:0.22em;color:var(--gold);margin-top:6px;text-transform:uppercase}
  .ad-campaign .pitch{font-family:Georgia,serif;font-style:italic;font-size:12px;line-height:1.4;margin:10px 0 12px;color:rgba(255,255,255,0.92)}
  .ad-campaign .cta{display:inline-flex;align-items:center;gap:6px;background:var(--red);color:#fff;font-weight:900;font-size:11px;letter-spacing:0.08em;padding:9px 14px;border-radius:9999px;text-transform:uppercase;width:max-content;font-family:'Lato',Arial,sans-serif;line-height:1}
  .ad-campaign .cta:after{content:"→"}
  .ad-campaign .cta:hover{background:#9C1A1F}
  .ad-campaign .small{font-size:9px;color:rgba(255,255,255,0.55);margin-top:auto;padding-top:10px;letter-spacing:0.02em;line-height:1.3}
  .ad-campaign .photo{position:relative;align-self:end;margin:0 -14px -16px 0;height:170px;width:110px;overflow:hidden}
  .ad-campaign .photo img{height:100%;width:100%;object-fit:cover;object-position:center top;display:block}
  /* George variant — red lean */
  .ad-george{background:linear-gradient(135deg,#0a3f86 0%,#002F6C 55%,#7C1418 130%)}
  .ad-george .photo img{object-fit:contain;object-position:bottom right;width:auto;position:absolute;right:0;bottom:0;max-width:none;height:100%}
  /* Singer variant — navy lean */
  .ad-singer{background:linear-gradient(135deg,#7C1418 0%,#A8181D 25%,#002F6C 100%)}

  /* ===== George Moraitis ad (legacy class — keeps existing instance) ===== */
  .ad-george{position:relative;background:linear-gradient(135deg,#0a3f86 0%,#002F6C 55%,#7C1418 130%);color:#fff;border:1px solid color-mix(in srgb,var(--gold) 28%,transparent);overflow:hidden;display:grid;grid-template-columns:1fr 110px;gap:10px;align-items:stretch;padding:24px 14px 16px}
  .ad-george:before{content:"PAID POLITICAL ADVERTISEMENT";position:absolute;top:0;left:0;right:0;background:rgba(0,0,0,0.35);color:#fff;font-family:'Lato',Arial,sans-serif;font-size:8px;font-weight:900;letter-spacing:0.18em;padding:4px 10px;text-align:center;line-height:1.4}
  .ad-george:after{content:"";position:absolute;left:-20%;right:-20%;bottom:-20%;height:55%;background:radial-gradient(ellipse at center,rgba(212,175,55,0.16) 0%,transparent 70%);pointer-events:none}
  .ad-george .ad-copy{position:relative;z-index:1;display:flex;flex-direction:column}
  .ad-george .name{font-family:Georgia,serif;font-size:22px;font-weight:400;line-height:1.05;color:#fff;margin:0;letter-spacing:0.005em}
  .ad-george .role{display:block;font-family:'Lato',Arial,sans-serif;font-size:9px;font-weight:900;letter-spacing:0.22em;color:var(--gold);margin-top:6px;text-transform:uppercase}
  .ad-george .pitch{font-family:Georgia,serif;font-style:italic;font-size:12px;line-height:1.4;margin:10px 0 12px;color:rgba(255,255,255,0.92)}
  .ad-george .cta{display:inline-flex;align-items:center;gap:6px;background:var(--red);color:#fff;font-weight:900;font-size:11px;letter-spacing:0.08em;padding:9px 14px;border-radius:9999px;text-transform:uppercase;width:max-content;font-family:'Lato',Arial,sans-serif;line-height:1}
  .ad-george .cta:after{content:"→"}
  .ad-george .cta:hover{background:#9C1A1F}
  .ad-george .small{font-size:9px;color:rgba(255,255,255,0.55);margin-top:auto;padding-top:10px;letter-spacing:0.02em;line-height:1.3}
  .ad-george .photo{position:relative;align-self:end;margin:0 -14px -16px 0;height:160px;width:110px;overflow:hidden}
  .ad-george .photo img{height:100%;width:auto;object-fit:contain;object-position:bottom right;display:block;position:absolute;right:0;bottom:0;max-width:none}

  /* ===== American Spirit box ===== */
  .spirit-box{background:var(--bg-card);border:1px solid var(--line);padding:22px 18px 20px;text-align:center}
  .spirit-box .l1{display:block;font-family:Georgia,serif;font-weight:400;color:#7C1418;font-size:18px;line-height:1.1;letter-spacing:0.005em}
  [data-theme="dark"] .spirit-box .l1{color:#E8A0A4}
  .spirit-box .of{display:block;font-family:Georgia,serif;font-style:italic;color:#7C1418;font-size:11px;margin:1px 0 -4px}
  [data-theme="dark"] .spirit-box .of{color:#E8A0A4}
  .spirit-box .l2{display:block;font-family:'Great Vibes',cursive;color:var(--red);font-size:54px;line-height:0.95;margin:0 0 12px;font-weight:400;letter-spacing:0.005em}
  .spirit-box .body{font-family:Georgia,serif;font-size:13px;color:var(--text);line-height:1.55;margin:0;text-align:left}
  .spirit-box .body em{color:var(--red);font-style:italic;display:block;padding:8px 0;border-top:1px solid color-mix(in srgb,var(--red) 25%,transparent);border-bottom:1px solid color-mix(in srgb,var(--red) 25%,transparent);margin:10px 0}

  /* ===== Sidebar civic widgets ===== */
  .side .widget-head{font-family:'Lato',Arial,sans-serif;font-size:11px;font-weight:900;letter-spacing:0.14em;color:var(--red);text-transform:uppercase;margin:0 0 10px;line-height:1}
  .side .widget-head small{display:inline-block;color:var(--text-muted);font-weight:700;margin-left:8px;letter-spacing:0.06em}

  .side .stat-trio{background:var(--bg-card);border:1px solid var(--line);padding:14px 16px;display:grid;grid-template-columns:repeat(3,1fr);gap:10px;text-align:center}
  .side .stat-trio .stat{display:flex;flex-direction:column;gap:4px;border-right:1px solid var(--line);padding-right:6px}
  .side .stat-trio .stat:last-child{border-right:0;padding-right:0}
  .side .stat-trio .stat b{font-family:'Lato',Arial,sans-serif;font-weight:900;font-size:22px;color:var(--headline);line-height:1;letter-spacing:-0.02em}
  .side .stat-trio .stat small{font-size:10px;font-weight:900;letter-spacing:0.1em;color:var(--text-muted);text-transform:uppercase;line-height:1.1}

  .side .roster{background:var(--bg-card);border:1px solid var(--line);padding:16px}
  .side .roster ul{list-style:none;padding:0;margin:0}
  .side .roster li{display:flex;flex-direction:column;gap:3px;padding:9px 0;border-top:1px solid var(--line)}
  .side .roster li:first-child{border-top:0;padding-top:0}
  .side .roster li span{font-size:10px;font-weight:900;letter-spacing:0.1em;color:var(--text-muted);text-transform:uppercase;line-height:1}
  .side .roster li strong{font-size:13px;font-weight:700;color:var(--headline);line-height:1.35}
  .side .roster .pty{display:inline-block;font-family:'Lato',sans-serif;font-style:normal;background:var(--red);color:#fff;font-size:9px;font-weight:900;padding:2px 5px;margin-left:6px;letter-spacing:0.06em;line-height:1;vertical-align:1px}

  .side .demo-chart{background:var(--bg-card);border:1px solid var(--line);padding:16px}
  .side .demo-chart .row{display:grid;grid-template-columns:64px 1fr 44px;align-items:center;gap:8px;padding:5px 0;font-size:12px}
  .side .demo-chart .row span{color:var(--text-muted);font-weight:700;font-size:11px;letter-spacing:0.04em;text-transform:uppercase}
  .side .demo-chart .row b{color:var(--headline);font-weight:900;font-size:12px;text-align:right;font-variant-numeric:tabular-nums}
  .side .demo-chart .bar{height:8px;background:color-mix(in srgb,var(--navy) 14%,transparent);border-radius:9999px;overflow:hidden;position:relative}
  .side .demo-chart .bar:after{content:"";position:absolute;left:0;top:0;bottom:0;width:var(--w);background:linear-gradient(90deg,var(--navy),var(--red));border-radius:9999px}
  .side .demo-chart .src{font-size:10px;font-weight:700;letter-spacing:0.04em;color:var(--text-muted);margin-top:8px;padding-top:8px;border-top:1px solid var(--line);text-transform:uppercase}

  .side .pullquote{background:var(--navy);color:#fff;padding:20px 18px 18px;position:relative;overflow:hidden;border:1px solid color-mix(in srgb,var(--gold) 30%,transparent)}
  .side .pullquote .mark{display:inline-block;width:24px;height:24px;border-radius:50%;background:var(--gold);color:var(--navy);font-family:Georgia,serif;font-weight:900;font-size:14px;text-align:center;line-height:24px;margin-bottom:10px}
  .side .pullquote q{display:block;font-family:Georgia,serif;font-style:italic;font-size:18px;line-height:1.25;color:#fff;quotes:"\201C" "\201D"}
  .side .pullquote q:before{content:open-quote;color:var(--gold);font-family:Georgia,serif;font-style:normal;font-size:24px;line-height:0;vertical-align:-6px;margin-right:2px}
  .side .pullquote q:after{content:close-quote;color:var(--gold);font-family:Georgia,serif;font-style:normal;font-size:24px;line-height:0;vertical-align:-12px;margin-left:1px}
  .side .pullquote cite{display:block;margin-top:10px;font-size:11px;font-weight:900;letter-spacing:0.12em;color:var(--gold);text-transform:uppercase;font-style:normal}

  /* ===== Join box (sidebar) ===== */
  .joinbox{position:relative;background:linear-gradient(180deg,#C42229 0%,#A8181D 100%);border:1px solid #7C1418;padding:30px 18px 22px;text-align:center;overflow:hidden;color:#fff}
  .joinbox:before{content:"";position:absolute;left:0;right:0;top:0;height:4px;background:var(--navy)}
  .joinbox:after{content:"";position:absolute;inset:auto -40% -50% -40%;height:80%;background:radial-gradient(ellipse at center,rgba(212,175,55,0.18) 0%,transparent 60%);pointer-events:none}
  .joinbox > *{position:relative;z-index:1}
  .joinbox .crest{width:120px;height:120px;margin:0 auto 14px;border-radius:50%;overflow:hidden;background:#fff;box-shadow:0 4px 14px rgba(0,47,108,0.2)}
  .joinbox .crest img{width:100%;height:100%;object-fit:cover}
  .joinbox .wm{font-family:Georgia,serif;color:#fff;text-align:center;margin-bottom:16px;line-height:1}
  .joinbox .wm .l1{display:block;font-size:14px;letter-spacing:0.16em;font-weight:400;line-height:1}
  .joinbox .wm .l1:before,.joinbox .wm .l1:after{content:"";display:inline-block;width:18px;height:1px;background:currentColor;vertical-align:middle;margin:0 8px;opacity:0.5}
  .joinbox .wm .l2{display:block;font-family:'Lato',Arial,sans-serif;font-weight:700;font-size:9px;letter-spacing:0.28em;margin-top:6px;line-height:1;opacity:0.85}
  .joinbox h2{font-family:Georgia,serif;font-weight:400;color:#fff;font-size:24px;line-height:1.05;letter-spacing:-0.005em;margin:0 0 10px;text-transform:uppercase}
  .joinbox .dek{font-family:'Lato',Arial,sans-serif;color:rgba(255,255,255,0.92);font-size:13px;line-height:1.42;font-weight:400;margin:0 0 14px}
  /* Form layout: 2-col grid; firstname+lastname share top row */
  .joinbox form{display:grid;grid-template-columns:1fr 1fr;gap:8px}
  .joinbox form > input[type="email"],
  .joinbox form > input[type="tel"],
  .joinbox form > button{grid-column:1 / -1}
  .joinbox form > input[type="hidden"]{display:none}
  /* Field styling — pill, slightly larger, with brand-gold focus ring */
  .joinbox input[type="text"],
  .joinbox input[type="email"],
  .joinbox input[type="tel"]{
    appearance:none;-webkit-appearance:none;
    background:#fff;color:#1A1A1A;
    border:1px solid rgba(0,0,0,0.14);
    border-radius:0;
    padding:12px 16px 12px 38px;
    font-size:14px;font-family:'Lato',Arial,sans-serif;font-weight:500;line-height:1.2;
    width:100%;outline:none;
    box-shadow:inset 0 1px 0 rgba(0,0,0,0.04);
    transition:border-color .18s ease,box-shadow .18s ease,transform .18s ease;
    background-repeat:no-repeat;background-position:14px center;background-size:14px 14px;
  }
  /* Inline icons (SVG data URIs, navy stroke) per field type */
  .joinbox input[name="mauticform[firstname]"],
  .joinbox input[name="mauticform[lastname]"]{
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23002F6C' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 21v-2a4 4 0 0 0-4-4H8a4 4 0 0 0-4 4v2'/%3E%3Ccircle cx='12' cy='7' r='4'/%3E%3C/svg%3E");
  }
  .joinbox input[type="email"]{
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23002F6C' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M4 4h16c1.1 0 2 .9 2 2v12c0 1.1-.9 2-2 2H4c-1.1 0-2-.9-2-2V6c0-1.1.9-2 2-2z'/%3E%3Cpolyline points='22,6 12,13 2,6'/%3E%3C/svg%3E");
  }
  .joinbox input[type="tel"]{
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23002F6C' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M22 16.92v3a2 2 0 0 1-2.18 2 19.79 19.79 0 0 1-8.63-3.07 19.5 19.5 0 0 1-6-6 19.79 19.79 0 0 1-3.07-8.67A2 2 0 0 1 4.11 2h3a2 2 0 0 1 2 1.72 12.84 12.84 0 0 0 .7 2.81 2 2 0 0 1-.45 2.11L8.09 9.91a16 16 0 0 0 6 6l1.27-1.27a2 2 0 0 1 2.11-.45 12.84 12.84 0 0 0 2.81.7A2 2 0 0 1 22 16.92z'/%3E%3C/svg%3E");
  }
  .joinbox input[type="text"]::placeholder,
  .joinbox input[type="email"]::placeholder,
  .joinbox input[type="tel"]::placeholder{color:#8A8A8A;font-weight:400}
  .joinbox input[type="text"]:hover,
  .joinbox input[type="email"]:hover,
  .joinbox input[type="tel"]:hover{border-color:rgba(0,0,0,0.28)}
  .joinbox input[type="text"]:focus,
  .joinbox input[type="email"]:focus,
  .joinbox input[type="tel"]:focus{
    border-color:var(--gold);
    box-shadow:0 0 0 3px rgba(212,175,55,0.55), inset 0 1px 0 rgba(0,0,0,0.04);
  }
  /* Submit button — pill, navy, separated by margin from the inputs above */
  .joinbox button{
    appearance:none;-webkit-appearance:none;
    background:var(--navy);color:#fff;border:0;border-radius:0;
    padding:13px 16px;margin-top:6px;
    font-family:Georgia,serif;font-weight:700;font-size:14px;letter-spacing:0.08em;text-transform:uppercase;
    cursor:pointer;line-height:1;
    box-shadow:0 2px 8px rgba(0,0,0,0.2);
    transition:background .2s ease,transform .15s ease,box-shadow .2s ease;
  }
  .joinbox button:hover{background:#001E47;transform:translateY(-1px);box-shadow:0 4px 12px rgba(0,0,0,0.25)}
  .joinbox button:active{transform:translateY(0)}
  .joinbox button:disabled{background:var(--navy-deep);opacity:0.85;cursor:default;transform:none;box-shadow:none}

  /* ===== Mission statement band ===== */
  .mission{background:var(--bg-muted);border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:48px 16px}
  .mission-inner{width:min(100%,920px);margin:0 auto;text-align:center}
  .mission-eyebrow{font-family:'Lato',Arial,sans-serif;font-weight:900;font-size:12px;letter-spacing:0.2em;color:var(--red);text-transform:uppercase;margin:0 0 18px;line-height:1}
  .mission-body{font-family:Georgia,serif;font-style:italic;font-weight:400;font-size:16px;line-height:1.5;color:var(--headline);letter-spacing:0.005em;margin:0}
  .mission-body strong{font-style:normal;font-weight:700;letter-spacing:0.02em;font-family:'Lato',Arial,sans-serif;font-size:0.92em}
  @media (max-width:760px){
    .mission{padding:36px 14px}
    .mission-body{font-size:14px}
  }

  /* ===== Big ad slot ===== */
  .ad-slot{height:280px;background:var(--bg-muted);border-top:1px solid var(--line);border-bottom:1px solid var(--line);display:grid;place-items:center;color:var(--text-muted);font-size:11px;letter-spacing:0.1em;text-transform:uppercase;font-weight:900}

  /* ===== Footer ===== */
  footer{background:var(--navy);color:#fff;padding:36px 0 24px;margin-top:0}
  .foot-inner{width:min(100%,1400px);margin:0 auto;padding:0 16px;display:flex;flex-direction:column;align-items:center;gap:18px}
  .socials{display:flex;align-items:center;gap:14px}
  .socials a{display:grid;place-items:center;width:32px;height:32px;border-radius:50%;background:rgba(255,255,255,0.08);color:#fff;font-size:14px;font-weight:900}
  .socials a:hover{background:rgba(255,255,255,0.18)}
  .foot-links{display:flex;flex-wrap:wrap;justify-content:center;gap:0 22px;font-size:13px;font-weight:700}
  .foot-links a{color:#fff;opacity:0.9;border-right:1px solid rgba(255,255,255,0.2);padding-right:22px}
  .foot-links a:last-child{border-right:0}
  .foot-legal{display:flex;align-items:flex-start;gap:14px;font-size:11px;color:#bbcfe6;line-height:1.5;max-width:1100px}
  .foot-mark{flex-shrink:0;width:60px;height:60px;background:#fff;border-radius:50%;overflow:hidden}
  .foot-mark img{width:100%;height:100%;object-fit:cover}

  /* REC dossier section */
  .rec{padding:clamp(2rem,5vw,3rem) 0;border-top:1px solid var(--line)}
  .rec .lead .eyebrow{display:inline-block;font-size:11px;font-weight:900;letter-spacing:0.12em;color:var(--red);text-transform:uppercase;margin-bottom:8px}
  .rec .lead h2{font-family:'Lato',Arial,sans-serif;font-weight:900;font-size:34px;line-height:1.1;color:var(--headline);letter-spacing:-0.01em;margin-bottom:14px}
  .rec .lead .dek{color:var(--text-muted);font-size:15px;line-height:1.55;max-width:64ch;margin-bottom:24px}
  .rec-grid{display:block}
  .rec-main h3{color:var(--headline);font-family:'Lato',Arial,sans-serif;font-weight:900;font-size:18px;letter-spacing:-0.005em;margin-top:20px;margin-bottom:8px;line-height:1.2}
  .rec-main h3:first-child{margin-top:0}
  .rec-main p{color:var(--text-muted);font-size:15px;line-height:1.55;margin-bottom:14px}
  .rec-list{margin:8px 0 18px;padding:0;list-style:none}
  .rec-list li{padding:6px 0 6px 22px;position:relative;font-size:14px;color:var(--text);line-height:1.45}
  .rec-list li:before{content:"";position:absolute;left:4px;top:13px;width:8px;height:2px;background:var(--red)}
  .rec-side{display:flex;flex-direction:column;gap:14px}
  .rec-card{background:var(--bg-card);border:1px solid var(--line);padding:18px}
  .rec-card .card-eyebrow{display:block;font-size:11px;font-weight:900;letter-spacing:0.12em;color:var(--red);text-transform:uppercase;margin-bottom:12px}
  .rec-card .kv{list-style:none;padding:0;margin:0}
  .rec-card .kv li{display:flex;flex-direction:column;gap:2px;padding:9px 0;border-top:1px solid var(--line)}
  .rec-card .kv li:first-child{border-top:0;padding-top:0}
  .rec-card .kv li span{color:var(--text-muted);font-size:11px;text-transform:uppercase;letter-spacing:0.06em;font-weight:700}
  .rec-card .kv li strong{color:var(--headline);font-weight:700;font-size:13px;line-height:1.4}
  .rec-card .rec-cta{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;background:var(--red);color:#fff;font-weight:900;font-size:13px;letter-spacing:0.04em;text-transform:uppercase;padding:12px 14px;margin-top:14px;transition:background .2s ease}
  .rec-card .rec-cta:hover{background:var(--red-hover)}
  .rec-card.alt{background:var(--navy);color:#fff;border-color:var(--navy)}
  .rec-card.alt .card-eyebrow{color:var(--gold)}
  .rec-card.alt p{color:rgba(255,255,255,0.9);font-size:14px;line-height:1.55;margin-bottom:0}
  .rec-card.alt .rec-link{display:inline-block;margin-top:12px;color:var(--gold);font-weight:900;font-size:12px;letter-spacing:0.04em;text-transform:uppercase}
  .rec-card.alt .rec-link:hover{color:#fff}

  /* ===== Mobile hamburger menu ===== */
  .nav-toggle{display:none;background:transparent;border:0;color:inherit;padding:8px;cursor:pointer;align-items:center;justify-content:center;margin-left:4px}
  .nav-toggle svg{width:26px;height:26px;display:block}
  .nav-toggle:hover{color:var(--red)}
  .topbar .nav-toggle{color:#fff}
  .mobile-menu{display:none;background:var(--bg);border-bottom:1px solid var(--line)}
  .mobile-menu a{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 20px;color:var(--text);font-weight:900;text-transform:uppercase;letter-spacing:0.04em;font-size:14px;border-top:1px solid var(--line);transition:background .15s ease,color .15s ease}
  .mobile-menu a:after{content:"\2192";color:var(--red);font-size:22px;font-weight:400;line-height:1;flex-shrink:0;transition:transform .15s ease}
  .mobile-menu a:hover{background:var(--bg-muted);color:var(--red)}
  .mobile-menu a:hover:after{transform:translateX(4px)}
  .mobile-menu.open{display:block}

  @media (max-width:1080px){
    .main-grid{grid-template-columns:1fr}
    .lead-story{grid-template-columns:1fr}
    .row{grid-template-columns:repeat(2,1fr)}
    .row .tile:nth-child(3n){grid-column:1 / -1}
    .rec-grid{grid-template-columns:1fr}
    .bottom-row{grid-template-columns:1fr 1fr}
    .topnav{display:none}
    .nav-toggle{display:inline-flex}
  }

  @media (max-width:640px){
    .row{grid-template-columns:1fr}
    .row .tile:nth-child(3n){grid-column:auto}
    .bottom-row{grid-template-columns:1fr}
  }

  /* ===== Single-page (page.php) typography ===== */
  .site-main{padding:56px 24px 80px;max-width:880px;margin:0 auto}
  .site-main article{display:block}
  .entry-header{margin-bottom:36px;padding-bottom:24px;border-bottom:2px solid var(--line)}
  .entry-title{font-family:'Lato',Arial,sans-serif;font-size:44px;line-height:1.08;font-weight:900;letter-spacing:-0.012em;color:var(--headline);margin:0}
  .entry-content{font-size:17px;line-height:1.7;color:var(--text);max-width:65ch}
  .entry-content .lead{font-family:Georgia,serif;font-style:italic;font-weight:400;font-size:22px;line-height:1.45;color:var(--text);margin:0 0 28px;padding-bottom:8px}
  .entry-content h2{font-family:'Lato',Arial,sans-serif;font-size:26px;line-height:1.22;font-weight:900;letter-spacing:-0.006em;color:var(--headline);margin:44px 0 14px;position:relative;padding-left:14px}
  .entry-content h2:before{content:"";position:absolute;left:0;top:6px;bottom:6px;width:4px;background:var(--red)}
  .entry-content h3{font-family:'Lato',Arial,sans-serif;font-size:19px;line-height:1.3;font-weight:900;color:var(--headline);margin:30px 0 10px}
  .entry-content p{margin:0 0 18px}
  .entry-content p:last-child{margin-bottom:0}
  .entry-content ul,.entry-content ol{margin:0 0 22px;padding-left:24px}
  .entry-content li{margin-bottom:10px;line-height:1.6}
  .entry-content li > strong:first-child{color:var(--headline);font-weight:900}
  .entry-content a{color:var(--red);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:3px;transition:color .15s ease,text-decoration-thickness .15s ease}
  .entry-content a:hover{color:var(--red-hover);text-decoration-thickness:2px}
  .entry-content dl{margin:0 0 24px}
  .entry-content dt{font-family:'Lato',Arial,sans-serif;font-weight:900;color:var(--headline);margin-top:18px;font-size:15px;letter-spacing:0.01em;text-transform:uppercase}
  .entry-content dt:first-child{margin-top:0}
  .entry-content dd{margin:4px 0 0 0;padding-left:14px;border-left:3px solid var(--line)}
  .entry-content dd a{font-weight:600}
  .entry-content code{font-family:'SFMono-Regular',Consolas,'Roboto Mono',monospace;font-size:0.88em;background:var(--bg-muted);color:var(--text);padding:2px 6px;border-radius:3px}
  .entry-content strong{font-weight:900;color:var(--text)}
  .entry-content blockquote{border-left:4px solid var(--red);margin:28px 0;padding:8px 0 8px 22px;font-family:Georgia,serif;font-style:italic;color:var(--text-muted);font-size:19px;line-height:1.55}
  .entry-content hr{border:0;border-top:1px solid var(--line);margin:32px 0}

  /* Dark-mode tweaks for page typography */
  [data-theme="dark"] .entry-content code{background:var(--bg-muted);color:var(--text)}
  [data-theme="dark"] .entry-header{border-bottom-color:var(--line)}

  @media (max-width:640px){
    .site-main{padding:32px 16px 56px}
    .entry-title{font-size:32px;line-height:1.12}
    .entry-content{font-size:16px}
    .entry-content .lead{font-size:19px}
    .entry-content h2{font-size:22px;margin:36px 0 12px}
    .entry-content h3{font-size:17px}
  }

  /* ===== "Tap to text us" CTA — touch devices only ===== */
  .entry-content .text-cta-wrap{display:none;text-align:center;margin:24px 0}
  .entry-content .text-cta{display:inline-block;background:var(--red);color:#fff;padding:14px 32px;font-family:'Lato',Arial,sans-serif;font-weight:900;font-size:14px;letter-spacing:0.06em;text-transform:uppercase;text-decoration:none;box-shadow:0 2px 8px rgba(0,0,0,0.2);transition:background .2s ease,transform .15s ease,box-shadow .2s ease}
  .entry-content .text-cta:before{content:"\1F4F1";margin-right:10px;font-size:16px}
  .entry-content .text-cta:hover{background:var(--red-hover);color:#fff;text-decoration:none;transform:translateY(-1px);box-shadow:0 4px 12px rgba(0,0,0,0.25)}
  .entry-content .text-cta:active{transform:translateY(0)}
  /* Show only on touch / coarse pointer, OR narrow viewport */
  @media (hover:none) and (pointer:coarse){
    .entry-content .text-cta-wrap{display:block}
    .entry-content .qr-desktop-only{display:none}
  }
  @media (max-width:640px){
    .entry-content .text-cta-wrap{display:block}
    .entry-content .qr-desktop-only{display:none}
  }
