/**
 * components.css — DJT Backyard 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}
  }

/* ===========================================================
   Single post — Medium-style article layout — v1.0.27
   Self-contained chrome for single.php. Source Serif 4 (serif)
   for title/body, Inter (sans) for UI. Brand navy/red used as
   accents on follow button + links. Pure black/white reading
   surface so the prose breathes.
   =========================================================== */

.med-body {
  background: #fff;
  color: #242424;
  font-family: 'Source Serif 4', Charter, Georgia, serif;
  -webkit-font-smoothing: antialiased;
  margin: 0;
  padding: 0;
  line-height: 1.6;
}
.med-body * { box-sizing: border-box; }
.med-body img { display: block; max-width: 100%; height: auto; }
.med-body a { color: inherit; text-decoration: none; }
.med-body button { font: inherit; cursor: pointer; background: none; border: 0; padding: 0; color: inherit; }

/* ===== Top bar ===== */
.med-topbar {
  position: sticky; top: 0; z-index: 100;
  background: #fff; border-bottom: 1px solid #f0f0f0;
}
.med-topbar-inner {
  max-width: 1192px; margin: 0 auto;
  display: flex; align-items: center; gap: 24px;
  padding: 0 24px; height: 57px;
  font-family: 'Inter', system-ui, -apple-system, 'Segoe UI', sans-serif;
}
.med-brand {
  display: flex; align-items: center; gap: 8px;
  color: var(--navy); flex-shrink: 0;
}
.med-brand-mark { width: 32px; height: 32px; }
.med-brand-name {
  font-family: 'Source Serif 4', Charter, Georgia, serif;
  font-size: 22px; font-weight: 700; letter-spacing: -0.01em;
}
.med-search {
  flex: 1; max-width: 240px;
  display: flex; align-items: center; gap: 10px;
  background: #f9f9f9; border-radius: 999px;
  padding: 8px 14px;
  border: 1px solid transparent;
  transition: border-color .15s ease, background .15s ease;
}
.med-search:focus-within { background: #fff; border-color: #ddd; }
.med-search-icon { width: 18px; height: 18px; color: #6b6b6b; flex-shrink: 0; }
.med-search-input {
  flex: 1; border: 0; background: transparent; outline: 0;
  font-size: 14px; font-family: inherit; color: #242424;
}
.med-search-input::placeholder { color: #6b6b6b; }
.med-actions { display: flex; align-items: center; gap: 18px; margin-left: auto; }
.med-write {
  display: flex; align-items: center; gap: 6px;
  color: #6b6b6b; font-size: 14px;
}
.med-write:hover { color: #242424; }
.med-write svg { width: 22px; height: 22px; }
.med-icon-btn {
  width: 24px; height: 24px;
  display: inline-flex; align-items: center; justify-content: center;
  color: #6b6b6b;
}
.med-icon-btn:hover { color: #242424; }
.med-icon-btn svg { width: 22px; height: 22px; }

/* ===== Avatars ===== */
.med-avatar {
  display: inline-flex; align-items: center; justify-content: center;
  border-radius: 999px; overflow: hidden; background: #f2f2f2;
  flex-shrink: 0;
}
.med-avatar img { width: 100%; height: 100%; object-fit: cover; }
.med-avatar-xs { width: 24px; height: 24px; }
.med-avatar-sm { width: 28px; height: 28px; }
.med-avatar-md { width: 44px; height: 44px; }
.med-avatar-lg { width: 60px; height: 60px; }
.med-avatar-placeholder { background: #e0e0e0; }

/* ===== Article column ===== */
.med-article {
  max-width: 728px;
  margin: 56px auto 0;
  padding: 0 24px 56px;
}
.med-article-body { all: initial; display: block; }
.med-article-body * { box-sizing: border-box; }

/* Title */
.med-title {
  font-family: 'Source Serif 4', Charter, Georgia, serif;
  font-weight: 700;
  font-size: 42px;
  line-height: 1.15;
  letter-spacing: -0.014em;
  color: #242424;
  margin: 0 0 24px;
}

/* Author row */
.med-author-row {
  display: flex; align-items: center; gap: 12px;
  margin-bottom: 24px;
  font-family: 'Inter', system-ui, sans-serif;
}
.med-author-meta { display: flex; flex-direction: column; gap: 2px; }
.med-author-name-row { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.med-author-name { font-size: 14px; font-weight: 500; color: #242424; }
.med-author-name:hover { color: var(--navy); }
.med-author-meta-row { display: flex; align-items: center; gap: 8px; font-size: 13px; color: #6b6b6b; }
.med-sep { color: #c0c0c0; }
.med-follow {
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 13px; font-weight: 500;
  color: var(--red); cursor: pointer;
  background: transparent; border: 0;
  padding: 0;
  transition: color .15s ease;
}
.med-follow:hover { color: var(--red-hover); }
.med-follow-lg {
  border: 1px solid var(--navy);
  background: var(--navy); color: #fff;
  padding: 7px 16px; border-radius: 999px;
  font-size: 13px; font-weight: 500;
}
.med-follow-lg:hover { background: var(--navy-deep); border-color: var(--navy-deep); }
.med-reading-time, .med-time-ago { font-size: 13px; color: #6b6b6b; }

/* Action bar */
.med-action-bar {
  display: flex; align-items: center; justify-content: space-between;
  border-top: 1px solid #f0f0f0; border-bottom: 1px solid #f0f0f0;
  padding: 8px 0; margin-bottom: 32px;
  font-family: 'Inter', system-ui, sans-serif;
}
.med-action-bar-bottom { margin: 56px 0 32px; }
.med-action-left, .med-action-right { display: flex; align-items: center; gap: 18px; }
.med-action {
  display: inline-flex; align-items: center; gap: 6px;
  color: #6b6b6b; font-size: 13px;
}
.med-action svg { width: 22px; height: 22px; }
.med-action:hover { color: #242424; }
.med-action-clap:hover { color: #1a8917; }

/* Featured image */
.med-feature {
  margin: 0 0 40px;
  text-align: center;
}
.med-feature .med-feature-img,
.med-feature img {
  max-width: 100%;
  margin: 0 auto;
}
.med-feature-caption {
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 13px; color: #6b6b6b;
  margin-top: 12px;
  font-style: italic;
}

/* ===== Body content typography ===== */
.med-content {
  font-family: 'Source Serif 4', Charter, Georgia, serif;
  font-size: 20px; line-height: 1.65;
  color: #242424;
  letter-spacing: -0.003em;
}
.med-content p { margin: 0 0 28px; }
.med-content a { color: var(--navy); text-decoration: underline; text-decoration-thickness: 1px; text-underline-offset: 3px; }
.med-content a:hover { color: var(--red); }
.med-content em, .med-content i { font-style: italic; }
.med-content strong { font-weight: 700; }
.med-content h2 {
  font-family: 'Source Serif 4', Charter, Georgia, serif;
  font-weight: 700; font-size: 30px; line-height: 1.2;
  letter-spacing: -0.01em;
  color: #242424;
  margin: 48px 0 16px;
}
.med-content h3 { font-size: 24px; font-weight: 700; margin: 36px 0 12px; }
.med-content blockquote {
  border-left: 3px solid #242424;
  padding: 4px 0 4px 22px;
  margin: 32px 0;
  font-style: italic;
  color: #6b6b6b;
}

/* In-body review elements */
.med-content .review-deck {
  font-family: 'Source Serif 4', Charter, Georgia, serif;
  font-size: 20px; line-height: 1.45;
  color: #6b6b6b;
  font-style: italic;
  margin: -8px 0 28px;
}
.med-content .review-deck em { font-style: italic; }

.med-content .retailer-links {
  list-style: none; padding: 0; margin: 4px 0 36px;
  display: flex; flex-wrap: wrap; gap: 8px;
  font-family: 'Inter', system-ui, sans-serif;
}
.med-content .retailer-links li { margin: 0; }
.med-content .retailer-links li a {
  display: inline-block;
  background: #fff;
  color: var(--navy);
  border: 1px solid var(--navy);
  padding: 8px 16px;
  border-radius: 999px;
  font-size: 13px; font-weight: 500;
  text-decoration: none;
  transition: background .15s ease, color .15s ease;
}
.med-content .retailer-links li a:hover { background: var(--navy); color: #fff; }

.med-content .bookmeta {
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 14px; color: #6b6b6b;
  border-top: 1px solid #f0f0f0; border-bottom: 1px solid #f0f0f0;
  padding: 16px 0; margin: 36px 0 28px;
  font-style: normal;
}
.med-content .byline {
  font-family: 'Source Serif 4', Charter, Georgia, serif;
  font-size: 17px; color: #6b6b6b;
  font-style: italic;
  margin: 0 0 8px;
}

/* Tags */
.med-tags {
  display: flex; flex-wrap: wrap; gap: 8px;
  margin: 48px 0 24px;
  font-family: 'Inter', system-ui, sans-serif;
}
.med-tag-pill {
  display: inline-block;
  background: #f2f2f2;
  color: #242424;
  padding: 6px 14px;
  border-radius: 999px;
  font-size: 13px;
  text-decoration: none;
  transition: background .15s ease;
}
.med-tag-pill:hover { background: #e6e6e6; }

/* Author card */
.med-author-card {
  border-top: 1px solid #f0f0f0;
  padding: 40px 0;
  font-family: 'Inter', system-ui, sans-serif;
}
.med-author-card-top { display: flex; align-items: center; gap: 16px; margin-bottom: 16px; }
.med-author-card-top .med-follow { margin-left: auto; }
.med-author-card-title {
  font-family: 'Source Serif 4', Charter, Georgia, serif;
  font-size: 24px; font-weight: 700; color: #242424;
  margin: 0 0 6px;
}
.med-author-card-title a { color: inherit; }
.med-author-card-title a:hover { color: var(--navy); }
.med-author-card-stats { font-size: 14px; color: #6b6b6b; margin: 0 0 16px; }
.med-author-card-bio { font-size: 16px; line-height: 1.55; color: #242424; margin: 0; }

/* Responses */
.med-responses {
  border-top: 1px solid #f0f0f0;
  padding: 32px 0;
  font-family: 'Inter', system-ui, sans-serif;
}
.med-responses-title { font-size: 22px; font-weight: 600; color: #242424; margin: 0 0 20px; font-family: inherit; }
.med-responses-input-row {
  display: flex; align-items: center; gap: 12px;
  border: 1px solid #e6e6e6; border-radius: 6px;
  padding: 12px 14px;
  background: #fff;
  margin-bottom: 20px;
}
.med-responses-input {
  flex: 1; border: 0; background: transparent; outline: 0;
  font-size: 15px; font-family: inherit; color: #242424;
}
.med-responses-input::placeholder { color: #6b6b6b; }
.med-responses-empty { color: #6b6b6b; font-size: 14px; margin: 0; }

/* More from / Recommended sections */
.med-more-from, .med-recommended {
  border-top: 1px solid #f0f0f0;
  padding: 40px 0;
  font-family: 'Inter', system-ui, sans-serif;
}
.med-section-heading {
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 16px; font-weight: 600; color: #242424;
  margin: 0 0 24px;
  letter-spacing: 0.01em;
}
.med-card-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 28px; }
.med-card { font-family: 'Inter', system-ui, sans-serif; }
.med-card-author { display: flex; align-items: center; gap: 8px; margin-bottom: 8px; }
.med-card-author-name { font-size: 13px; font-weight: 500; color: #242424; }
.med-card-title {
  font-family: 'Source Serif 4', Charter, Georgia, serif;
  font-size: 18px; font-weight: 700; line-height: 1.25;
  letter-spacing: -0.005em;
  margin: 0 0 6px;
}
.med-card-title a { color: #242424; }
.med-card-title a:hover { color: var(--navy); }
.med-card-excerpt {
  font-family: 'Source Serif 4', Charter, Georgia, serif;
  font-size: 14px; color: #6b6b6b; line-height: 1.5;
  margin: 0 0 8px;
}
.med-card-meta { font-size: 12px; color: #6b6b6b; }
.med-card-empty {
  grid-column: 1 / -1;
  background: #fafafa; border: 1px dashed #e0e0e0;
  border-radius: 6px;
  padding: 24px; color: #6b6b6b; font-size: 14px; line-height: 1.5;
}
.med-card-empty p { margin: 0 0 6px; }
.med-card-empty p:last-child { margin: 0; }
.med-card-empty strong { color: #242424; }
.med-see-all {
  display: inline-block; margin-top: 24px;
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 14px; color: var(--navy);
}
.med-see-all:hover { color: var(--red); text-decoration: underline; }

/* Footer */
.med-footer {
  border-top: 1px solid #f0f0f0;
  background: #fafafa;
  padding: 32px 24px;
  font-family: 'Inter', system-ui, sans-serif;
  margin-top: 48px;
}
.med-footer-inner {
  max-width: 728px; margin: 0 auto;
  display: flex; flex-wrap: wrap; gap: 8px 20px;
  font-size: 13px; color: #6b6b6b;
}
.med-footer-inner a { color: #6b6b6b; }
.med-footer-inner a:hover { color: #242424; text-decoration: underline; }
.med-footer-credit {
  max-width: 728px; margin: 16px auto 0;
  font-size: 12px; color: #9a9a9a;
}

/* Mobile */
@media (max-width: 728px) {
  .med-topbar-inner { gap: 12px; padding: 0 16px; height: 52px; }
  .med-search { display: none; }
  .med-write span { display: none; }
  .med-article { margin-top: 32px; padding: 0 16px 32px; }
  .med-title { font-size: 32px; line-height: 1.18; margin-bottom: 16px; }
  .med-content { font-size: 18px; line-height: 1.6; }
  .med-content p { margin-bottom: 24px; }
  .med-content h2 { font-size: 24px; margin: 36px 0 12px; }
  .med-action-bar { padding: 6px 0; }
  .med-action-left, .med-action-right { gap: 12px; }
  .med-card-grid { grid-template-columns: 1fr; gap: 24px; }
  .med-author-row { flex-wrap: wrap; }
  .med-author-card-top { flex-wrap: wrap; }
}

/* Hide djtbackyard topbar/footer if any plugin prepends/appends them on this template */
.med-body .topbar, .med-body .a250, .med-body .strip, .med-body .trend, .med-body .bottom-row,
.med-body .cta-grid, .med-body .mission, .med-body footer:not(.med-footer) { display: none !important; }

/* ===========================================================
   Latest from DJT (Truth Social) sidebar widget — v1.0.28
   Lives in front-page.php's <aside class="side"> column.
   =========================================================== */
.dj-truths {
  background: var(--bg-card);
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: 14px 16px 12px;
  margin: 0 0 18px;
  font-family: 'Lato', Arial, sans-serif;
}
.dj-truths-head {
  display: flex;
  align-items: baseline;
  gap: 6px;
  flex-wrap: wrap;
  border-bottom: 1px solid var(--line);
  padding-bottom: 10px;
  margin-bottom: 10px;
}
.dj-truths-head h2 {
  font-family: 'Lato', Arial, sans-serif;
  font-size: 16px;
  font-weight: 900;
  color: var(--navy);
  letter-spacing: 0.01em;
  margin: 0;
  flex: 1 1 auto;
}
.dj-truths-mark {
  display: inline-block;
  background: var(--red);
  color: #fff;
  font-size: 10px;
  font-weight: 900;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  padding: 3px 7px;
  border-radius: 3px;
  margin-right: 4px;
}
.dj-truths-source {
  font-size: 11px;
  font-weight: 700;
  color: var(--text-muted);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  text-decoration: none;
  white-space: nowrap;
}
.dj-truths-source:hover { color: var(--red); }
.dj-truths-list {
  list-style: none;
  padding: 0;
  margin: 0;
}
.dj-truth {
  border-bottom: 1px solid var(--line);
  padding: 0;
}
.dj-truth:last-child { border-bottom: 0; }
.dj-truth-link {
  display: flex;
  align-items: flex-start;
  padding: 10px 0;
  text-decoration: none;
  color: inherit;
  transition: background .12s ease;
}
.dj-truth-link:hover { background: rgba(191, 32, 38, 0.04); }
.dj-truth-body {
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 0;
}
.dj-truth-text {
  font-family: 'Georgia', serif;
  font-size: 13.5px;
  line-height: 1.42;
  color: var(--text);
  font-weight: 400;
}
.dj-truth-text-muted {
  color: var(--text-muted);
  font-style: italic;
  font-family: 'Lato', Arial, sans-serif;
  font-size: 12.5px;
}
.dj-truth-meta {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 11px;
  color: var(--text-muted);
  font-family: 'Lato', Arial, sans-serif;
  letter-spacing: 0.02em;
}
.dj-truth-meta time { font-weight: 700; }
.dj-truth-likes { color: var(--red); font-weight: 700; }

.dj-truth-media-icon {
  display: inline-block;
  font-size: 11px;
  color: var(--text-muted);
  line-height: 1;
  vertical-align: middle;
  opacity: 0.85;
}
.dj-truth-media-icon:hover { opacity: 1; }
[data-theme="dark"] .dj-truths { background: var(--bg-card); border-color: var(--line); }
[data-theme="dark"] .dj-truth-link:hover { background: rgba(217, 59, 65, 0.08); }

/* ===========================================================
   Homepage Truths card row + single Truth page — v1.0.30
   Surfaces djt_truth CPT posts as homepage cards (above the YT
   video grid) + single-post layout for /truth/<id>/.
   =========================================================== */

/* ----- Homepage row ----- */
.row-truths {
  border-bottom: 1px solid var(--line);
  padding: 0 0 22px;
  margin: 16px 0 24px;
}
.row-truths-head {
  display: flex; align-items: baseline; gap: 14px;
  margin: 0 0 12px;
  font-family: 'Lato', Arial, sans-serif;
}
.row-truths-title {
  font-family: 'Lato', Arial, sans-serif;
  font-size: 17px; font-weight: 900; color: var(--navy);
  margin: 0; letter-spacing: 0.01em;
  flex: 1 1 auto;
}
.row-truths-mark {
  display: inline-block;
  background: var(--red);
  color: #fff;
  font-size: 11px; font-weight: 900;
  padding: 3px 8px; border-radius: 3px;
  letter-spacing: 0.04em; text-transform: uppercase;
  vertical-align: 2px;
  margin-right: 6px;
}
.row-truths-all {
  font-size: 12px; font-weight: 700;
  color: var(--text-muted);
  letter-spacing: 0.04em; text-transform: uppercase;
  text-decoration: none;
}
.row-truths-all:hover { color: var(--red); }
.row-truths-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}
.truth-card {
  background: var(--bg-card);
  border: 1px solid var(--line);
  border-left: 3px solid var(--red);
  border-radius: 4px;
  transition: box-shadow 0.15s ease, transform 0.15s ease;
}
.truth-card:hover {
  box-shadow: 0 4px 14px rgba(0,0,0,0.08);
  transform: translateY(-1px);
}
.truth-card-link {
  display: block;
  padding: 12px 14px;
  text-decoration: none;
  color: inherit;
  font-family: 'Lato', Arial, sans-serif;
}
.truth-card-kicker {
  display: inline-block;
  font-size: 9px;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--red);
  margin-bottom: 4px;
}
.truth-card-title {
  font-family: 'Georgia', serif;
  font-size: 15.5px;
  line-height: 1.36;
  font-weight: 700;
  color: var(--headline);
  margin: 0 0 10px;
  /* Clamp to 4 lines */
  display: -webkit-box;
  -webkit-line-clamp: 4;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.truth-card-meta {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 11px;
  color: var(--text-muted);
  font-family: 'Lato', Arial, sans-serif;
}
.truth-card-meta time { font-weight: 700; }
.truth-card-likes,
.truth-card-replies { color: var(--red); font-weight: 700; }
.truth-card-mediaicon { opacity: 0.85; }
@media (max-width: 880px) {
  .row-truths-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px) {
  .row-truths-grid { grid-template-columns: 1fr; }
}

/* ----- Single Truth page (/truth/<id>/) ----- */
.single-djt-truth .truth-article {
  padding-bottom: 32px;
}
.single-djt-truth .truth-kicker {
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 13px;
  color: #6b6b6b;
  margin: 0 0 8px;
}
.single-djt-truth .truth-kicker-badge {
  display: inline-block;
  background: var(--red);
  color: #fff;
  font-weight: 600;
  font-size: 11px;
  padding: 3px 8px;
  border-radius: 3px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  margin-right: 4px;
}
.single-djt-truth .truth-kicker-source { font-style: italic; }
.single-djt-truth .truth-title {
  font-size: 36px;
  margin-bottom: 16px;
}
.single-djt-truth .truth-meta-counts {
  display: inline-flex;
  align-items: center;
  gap: 12px;
}
.single-djt-truth .truth-meta-counts span { font-weight: 600; }
.single-djt-truth .truth-archive-link a {
  font-size: 13px; color: var(--navy); text-decoration: none;
}
.single-djt-truth .truth-archive-link a:hover { color: var(--red); text-decoration: underline; }
.single-djt-truth .truth-content { font-size: 19px; line-height: 1.6; }
.single-djt-truth .truth-content p { margin: 0 0 22px; }

/* Media block — Rumble video embed wrapper */
.truth-media {
  margin: 24px 0;
}
.truth-rumble {
  position: relative;
  padding-bottom: 56.25%;
  height: 0;
  overflow: hidden;
  background: #000;
  border-radius: 4px;
}
.truth-rumble iframe {
  position: absolute;
  top: 0; left: 0;
  width: 100%; height: 100%;
  border: 0;
}
.truth-media-link {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 24px;
  background: #f9f9f9;
  border: 1px dashed #ccc;
  border-radius: 4px;
  color: #6b6b6b;
  text-decoration: none;
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 14px;
  transition: background 0.15s ease, color 0.15s ease;
}
.truth-media-link:hover { background: #f0f0f0; color: var(--red); }
.truth-media-icon { font-size: 22px; }

/* Link-preview card (inside body) */
.truth-card-preview {
  margin: 24px 0;
  padding: 14px 16px;
  background: #fafafa;
  border: 1px solid #e6e6e6;
  border-radius: 4px;
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 14px;
  line-height: 1.5;
}
.truth-card-preview a {
  color: var(--navy);
  text-decoration: none;
}
.truth-card-preview a:hover { color: var(--red); }
.truth-card-preview .truth-card-desc {
  display: inline-block;
  margin-top: 4px;
  color: #6b6b6b;
  font-weight: 400;
}

/* Outbound-to-truthsocial line */
.truth-source-line {
  margin: 36px 0 12px;
  font-family: 'Inter', system-ui, sans-serif;
}
.truth-source-out {
  display: inline-block;
  padding: 10px 18px;
  background: var(--navy);
  color: #fff;
  border-radius: 999px;
  font-size: 14px;
  font-weight: 600;
  text-decoration: none;
  transition: background 0.15s ease;
}
.truth-source-out:hover { background: var(--navy-deep); }
.truth-sync-meta {
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 11px;
  color: #9a9a9a;
  margin-top: 14px;
  font-style: italic;
}

/* ===========================================================
   Truth thumbnails — v1.0.31
   Featured-image thumbs on homepage card row + sidebar widget,
   sourced from Rumble (for video posts) since Truth Social CDN
   blocks hot-linking. Image-only posts still render text-only.
   =========================================================== */

/* ----- Homepage card row thumbnails ----- */
.truth-card-has-thumb .truth-card-link {
  display: flex;
  flex-direction: column;
  padding: 0;
  overflow: hidden;
}
.truth-card-thumb {
  display: block;
  aspect-ratio: 16 / 9;
  background: #000;
  overflow: hidden;
  position: relative;
}
.truth-card-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.3s ease;
}
.truth-card-thumb::after {
  content: "\25B6";  /* play triangle */
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  width: 44px; height: 44px;
  background: rgba(0,0,0,0.55);
  color: #fff;
  font-size: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  pointer-events: none;
  transition: background 0.15s ease;
}
.truth-card-has-thumb:hover .truth-card-thumb img { transform: scale(1.04); }
.truth-card-has-thumb:hover .truth-card-thumb::after { background: var(--red); }
.truth-card-has-thumb .truth-card-kicker,
.truth-card-has-thumb .truth-card-title,
.truth-card-has-thumb .truth-card-meta {
  padding-left: 14px; padding-right: 14px;
}
.truth-card-has-thumb .truth-card-kicker { padding-top: 12px; }
.truth-card-has-thumb .truth-card-meta   { padding-bottom: 12px; }

/* ----- Sidebar widget thumbnails ----- */
.dj-truth-has-thumb .dj-truth-link {
  display: flex;
  align-items: flex-start;
  gap: 10px;
}
.dj-truth-thumb {
  flex-shrink: 0;
  display: block;
  width: 64px;
  height: 64px;
  background: #000;
  border-radius: 4px;
  overflow: hidden;
  position: relative;
}
.dj-truth-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.dj-truth-thumb::after {
  content: "\25B6";
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  width: 22px; height: 22px;
  background: rgba(0,0,0,0.55);
  color: #fff;
  font-size: 9px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  pointer-events: none;
}
.dj-truth-body {
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 0;
}

/* ===========================================================
   Truth Social official embed iframe (image-only posts) — v1.0.32
   Fallback for Truth Social CDN's challenge wall: render the
   official /embed page in an iframe. The user's browser passes
   the JS challenge transparently, so the post (with its actual
   image) renders inside the iframe.
   =========================================================== */
.truth-media-iframe {
  margin: 24px 0;
  background: #f4f4f5;
  border: 1px solid var(--line);
  border-radius: 8px;
  overflow: hidden;
}
.truth-iframe-wrap {
  position: relative;
  width: 100%;
  min-height: 380px;
  background: #fff;
}
.truth-iframe-wrap iframe {
  display: block;
  width: 100%;
  min-height: 480px;
  border: 0;
  background: #fff;
}
@media (max-width: 640px) {
  .truth-iframe-wrap iframe { min-height: 560px; }
}

/* v1.0.32 — bump iframe min-height for typical image posts */
.truth-iframe-wrap, .truth-iframe-wrap iframe { min-height: 720px; }
@media (max-width: 640px) { .truth-iframe-wrap, .truth-iframe-wrap iframe { min-height: 820px; } }
