/*
Theme Name: Techable News
Theme URI: https://news.techable.com/
Author: Techable, Inc.
Description: Google News–compliant editorial theme for news.techable.com with built-in ad slots for techable.com and sellmac.com. Self-hosted typography, dark mode, related posts, sticky mobile CTA.
Version: 3.2.5
License: GPL-2.0-or-later
Text Domain: techable-news
*/

:root{
  --bg:#fafaf7; --fg:#0e0e10; --muted:#5b5b66; --line:#e6e4dd;
  --accent:#d11f2f; --card:#fff; --rail:#fff;
  --serif:'Fraunces',Georgia,'Times New Roman',serif;
  --sans:'Inter Tight',-apple-system,BlinkMacSystemFont,system-ui,sans-serif;
}
html[data-theme="dark"]{
  --bg:#0e0e10; --fg:#f4f4f0; --muted:#9a9aa6; --line:#26262c;
  --card:#17171c; --rail:#17171c;
}
@media (prefers-color-scheme: dark){
  html:not([data-theme="light"]){
    --bg:#0e0e10; --fg:#f4f4f0; --muted:#9a9aa6; --line:#26262c;
    --card:#17171c; --rail:#17171c;
  }
}

*{box-sizing:border-box}
html,body{margin:0;background:var(--bg);color:var(--fg);font-family:var(--sans);line-height:1.5;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block;height:auto}
.skip{position:absolute;left:-9999px}
.skip:focus{left:8px;top:8px;background:var(--card);padding:8px;z-index:99}
.container{max-width:1240px;margin:0 auto;padding:0 20px}

/* Reading progress bar */
#reading-progress{position:fixed;top:0;left:0;height:3px;width:0;background:var(--accent);z-index:100;transition:width .1s}

/* Header */
.site-header{background:var(--card);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:50}
.bar{max-width:1240px;margin:0 auto;padding:14px 20px;display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap}
.brand{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.brand-logo{display:flex;align-items:center;gap:10px}
.brand-logo img{max-height:40px;width:auto}
.logo-text{font-family:var(--serif);font-weight:900;font-size:26px;letter-spacing:-.02em;line-height:1;color:var(--fg)}
.logo-text span{color:var(--accent)}
.tagline{color:var(--muted);font-size:13px}
.meta{display:flex;gap:14px;align-items:center;color:var(--muted);font-size:13px}
.cta{background:var(--fg);color:var(--bg);padding:8px 14px;border-radius:999px;font-weight:600;font-size:13px}
.theme-toggle{background:transparent;border:1px solid var(--line);color:var(--muted);width:34px;height:34px;border-radius:50%;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;font-size:14px}
.theme-toggle:hover{color:var(--fg);border-color:var(--fg)}
.search-form{display:flex;align-items:center;gap:6px}
.search-form input{padding:6px 10px;border:1px solid var(--line);border-radius:6px;background:var(--bg);color:var(--fg);font:inherit;font-size:13px;width:140px}

/* Nav */
.catnav{border-top:1px solid var(--line);background:var(--card)}
.catnav ul{max-width:1240px;margin:0 auto;padding:0 20px;display:flex;gap:22px;list-style:none;overflow-x:auto;flex-wrap:nowrap}
.catnav ul ul{display:none !important}
.catnav li{position:relative;flex:0 0 auto}
.catnav a{display:block;padding:12px 0;font-size:14px;font-weight:500;color:var(--muted);white-space:nowrap;border-bottom:2px solid transparent}
.catnav .current-menu-item a,.catnav .current-cat a,.catnav a:hover{color:var(--fg);border-color:var(--accent)}

/* Hero */
.hero{display:grid;grid-template-columns:2fr 1fr;gap:24px;margin:32px 0;align-items:start}
.hero-lead{grid-row:1 / span 2}
.hero .card{display:flex;flex-direction:column;background:var(--card);border:1px solid var(--line);border-radius:14px;overflow:hidden;height:100%;transition:transform .2s,box-shadow .2s}
.hero .card:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.06)}
.hero-lead .img{aspect-ratio:16/9;background-size:cover;background-position:center;width:100%;min-height:300px}
.hero-sec .img{aspect-ratio:16/9;background-size:cover;background-position:center;width:100%}
.hero-lead .body{padding:24px}
.hero-sec .body{padding:16px}
.hero-lead h1,.hero-lead h2{font-family:var(--serif);font-weight:900;font-size:36px;line-height:1.1;margin:8px 0 10px;letter-spacing:-.02em}
.hero-sec h2{font-family:var(--serif);font-weight:700;font-size:20px;line-height:1.2;margin:6px 0 8px;letter-spacing:-.01em}
.placeholder{background:linear-gradient(135deg,#1a1a1f 0%,#3a3a45 100%);position:relative;min-height:300px}
.placeholder::after{content:'TECHABLE NEWS';position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.25);font-family:var(--serif);font-weight:900;letter-spacing:.15em;font-size:18px}
.kicker{display:inline-block;font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);padding-left:1px}
.byline{color:var(--muted);font-size:13px;margin-top:8px}
.byline a,.byline .author-name{color:var(--fg);font-weight:500}

/* Layout */
.layout{display:grid;grid-template-columns:1fr 320px;gap:40px;margin-bottom:48px}
.section-head{display:flex;justify-content:space-between;align-items:baseline;border-bottom:2px solid var(--fg);padding-bottom:8px;margin:8px 0 20px}
.section-head h2{font-family:var(--serif);font-size:24px;margin:0}
.section-head a{font-size:13px;color:var(--muted)}
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:24px}
.card.sm{background:var(--card);border:1px solid var(--line);border-radius:12px;overflow:hidden;display:flex;flex-direction:column}
.card.sm .img{aspect-ratio:16/9;background-size:cover;background-position:center}
.card.sm .body{padding:14px}
.card.sm h3{font-family:var(--serif);font-size:17px;line-height:1.25;margin:6px 0 8px;font-weight:700}
.loadmore{display:inline-block;margin:24px auto;padding:12px 28px;background:var(--card);color:var(--fg);border:1px solid var(--fg);border-radius:999px;font-weight:600;cursor:pointer}
.more{text-align:center}

/* Sidebar */
.rail{display:flex;flex-direction:column;gap:24px}
.rail-card{background:var(--rail);border:1px solid var(--line);border-radius:12px;padding:18px}
.rail-card h3{font-family:var(--serif);margin:0 0 12px;font-size:18px}
.rail-card ol{margin:0;padding-left:20px}
.rail-card ol li{padding:8px 0;border-bottom:1px solid var(--line);font-size:14px}
.rail-card ol li:last-child{border:none}
.rail-card form{display:flex;gap:6px;margin-top:8px;flex-wrap:wrap}
.rail-card input[type=email]{flex:1;min-width:140px;padding:9px;border:1px solid var(--line);border-radius:6px;font:inherit;background:var(--bg);color:var(--fg)}
.rail-card button{padding:9px 14px;background:var(--fg);color:var(--bg);border:none;border-radius:6px;cursor:pointer;font-weight:600}

/* Ads */
.ad-slot{position:relative;background:#fbf6ec;border:1px solid #ead9b8;border-radius:10px;margin:18px auto;padding:14px 16px;text-align:center}
html[data-theme="dark"] .ad-slot{background:#1f1c14;border-color:#3a321e}
.ad-label{display:inline-block;font-size:10px;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:#8a6d00;background:var(--card);padding:2px 8px;border-radius:4px;border:1px solid #d4a017;margin-bottom:8px}
.ad-leaderboard{max-width:1240px;margin:14px auto;padding:14px 20px}
.ad-leaderboard .ad-creative{font-size:15px;font-family:var(--sans);font-weight:500;color:var(--fg)}
.ad-leaderboard .ad-creative strong{font-family:var(--serif);font-size:17px}
.ad-creative{display:block;font-family:var(--serif);font-size:18px;color:var(--fg)}
.ad-creative strong{color:var(--accent);margin-right:6px}
.ad-creative.tall{display:flex;flex-direction:column;gap:10px;padding:8px 0;font-size:16px}
.ad-creative .btn,.cta-creative .btn{display:inline-block;background:var(--fg);color:var(--bg);padding:8px 16px;border-radius:999px;font-family:var(--sans);font-size:13px;font-weight:600;margin-top:6px;text-decoration:none}
.ad-native{padding:0;background:var(--card);border:1px dashed #d4a017;text-align:left;overflow:hidden}
.ad-native .ad-label{position:absolute;top:8px;left:10px;margin:0;z-index:2}
.native-creative{display:grid;grid-template-columns:1fr 2fr;gap:0;align-items:stretch}
.native-img{background:linear-gradient(135deg,#0f3460,#16537e);min-height:160px}
.native-body{padding:18px}
.native-body h3{font-family:var(--serif);font-size:20px;margin:6px 0 6px;color:var(--fg)}
.native-body p{color:var(--muted);margin:0 0 10px;font-size:14px}
.ad-sticky{position:sticky;top:120px}
.ad-cta{padding:30px 20px;background:linear-gradient(135deg,#fff8e6,#ffe9b3);border:1px solid #d4a017}
html[data-theme="dark"] .ad-cta{background:linear-gradient(135deg,#2a2412,#3a3018)}
.cta-creative h2{font-family:var(--serif);font-size:26px;margin:6px 0 8px;color:var(--fg)}
.cta-creative p{color:var(--muted);margin:0 0 12px}
.btn.lg{padding:12px 22px;font-size:15px}

/* Sticky mobile CTA */
.mobile-cta{display:none;position:fixed;bottom:0;left:0;right:0;background:var(--card);border-top:1px solid var(--line);padding:10px 14px;z-index:60;box-shadow:0 -4px 12px rgba(0,0,0,.08);align-items:center;justify-content:space-between;gap:10px}
.mobile-cta .label{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.1em}
.mobile-cta .text{font-family:var(--serif);font-weight:700;font-size:14px;color:var(--fg);line-height:1.2}
.mobile-cta a.btn{flex:0 0 auto;background:var(--accent);color:#fff;padding:10px 14px;border-radius:999px;font-weight:600;font-size:13px;text-decoration:none;white-space:nowrap}
.mobile-cta button.close{background:none;border:none;color:var(--muted);font-size:18px;cursor:pointer;padding:4px 8px}

/* Single article — editorial NYT-style */
.article-wrap{max-width:1080px}
.crumbs{font-size:13px;color:var(--muted);margin:24px 0 12px;text-align:center}
.crumbs a{color:var(--muted)}
.crumbs a:hover{color:var(--fg)}
.article-head{max-width:760px;margin:24px auto 0;text-align:center}
.article-head .kicker{margin-bottom:14px}
.article-head h1{font-family:var(--serif);font-weight:900;font-size:48px;line-height:1.08;letter-spacing:-.025em;margin:8px 0 18px;color:var(--fg)}
.dek{font-family:var(--serif);font-size:21px;color:var(--muted);margin:0 auto 22px;line-height:1.45;max-width:680px;font-weight:400;font-style:italic}
.article-meta{font-size:13px;color:var(--muted);display:flex;flex-wrap:wrap;gap:10px;align-items:center;justify-content:center;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:14px 0;margin:0 auto 32px;max-width:680px}
.article-meta .author a{color:var(--fg);font-weight:600}
.updated-pill{display:inline-block;background:var(--accent);color:#fff;padding:2px 8px;border-radius:999px;font-size:11px;font-weight:600;letter-spacing:.05em}
.lead-image{margin:0 auto 32px;max-width:1080px}
.lead-image img{border-radius:10px;width:100%}
.lead-image figcaption{font-size:13px;color:var(--muted);margin-top:10px;text-align:center;font-style:italic;max-width:680px;margin-inline:auto}
.article-body{font-family:Georgia,'Times New Roman',serif;font-size:19px;line-height:1.75;color:var(--fg);max-width:680px;margin:0 auto}
.article-body p{margin:0 0 1.3em}
.article-body > p:first-of-type::first-letter{font-family:var(--serif);font-weight:900;font-size:64px;line-height:.9;float:left;margin:6px 10px 0 0;color:var(--accent)}
.article-body li::first-letter,.article-body li p::first-letter,.article-body ul::first-letter,.article-body ol::first-letter,.article-body blockquote::first-letter,.article-body blockquote p::first-letter,.article-body figure::first-letter,.article-body figcaption::first-letter,.article-body h2::first-letter,.article-body h3::first-letter{all:unset}
.article-body h2,.article-body h3{font-family:var(--serif);letter-spacing:-.01em;margin-top:1.8em;font-weight:900}
.article-body h2{font-size:28px;line-height:1.2}
.article-body h3{font-size:22px;line-height:1.25}
.article-body a{color:var(--accent);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:3px}
.article-body img{border-radius:8px;margin:1.4em 0}
.article-body blockquote{border-left:4px solid var(--accent);margin:1.6em 0;padding:8px 0 8px 22px;font-family:var(--serif);font-size:24px;line-height:1.4;color:var(--fg);font-style:italic}
.affiliate-disclosure{background:var(--card);border-left:3px solid var(--accent);padding:12px 16px;font-size:14px;color:var(--muted);margin:18px auto;border-radius:4px;max-width:680px;font-family:var(--sans)}
.toc{background:var(--card);border:1px solid var(--line);border-radius:8px;padding:16px 20px;margin:0 auto 28px;font-family:var(--sans);max-width:680px}
.toc h4{margin:0 0 10px;font-size:12px;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);font-weight:700}
.toc ol{margin:0;padding-left:20px}
.toc li{padding:4px 0;font-size:14px}
.toc a{color:var(--fg)}
.toc a:hover{color:var(--accent)}
.share-rail{display:flex;gap:8px;justify-content:center;margin:0 auto 24px;max-width:680px;padding-bottom:20px;border-bottom:1px solid var(--line)}
.share-rail a{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;background:var(--card);border:1px solid var(--line);color:var(--muted);font-size:13px;font-weight:700;transition:all .15s;text-decoration:none}
.share-rail a:hover{background:var(--fg);color:var(--bg);border-color:var(--fg)}
.article-foot{margin:48px auto 0;padding-top:28px;border-top:1px solid var(--line);max-width:680px}
.author-bio{display:flex;gap:16px;align-items:flex-start;background:var(--card);border:1px solid var(--line);border-radius:12px;padding:20px}
.author-bio img{border-radius:50%}
.author-bio strong{font-family:var(--serif);font-size:20px;display:block;margin-bottom:4px}
.author-bio p{margin:0;color:var(--muted);font-size:14px;line-height:1.5}
.tags{margin-top:18px;font-size:13px;color:var(--muted)}
.tags a{color:var(--accent);margin-right:6px}

.related{margin-top:48px}
.related h2{font-family:var(--serif);font-size:24px;margin:0 0 18px;border-bottom:2px solid var(--fg);padding-bottom:8px}
.related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}

/* Archive */
.archive-head{margin:32px 0 24px;padding-bottom:16px;border-bottom:2px solid var(--fg)}
.archive-head h1{font-family:var(--serif);font-size:36px;margin:0;letter-spacing:-.02em}
.archive-head p{color:var(--muted);margin:8px 0 0}
.pagination-nav{display:flex;justify-content:center;gap:8px;margin:32px 0}
.pagination-nav a,.pagination-nav span{padding:8px 14px;border:1px solid var(--line);border-radius:6px;color:var(--fg);font-size:14px}
.pagination-nav .current{background:var(--fg);color:var(--bg);border-color:var(--fg)}

/* Author archive */
.author-header{display:flex;gap:20px;align-items:center;background:var(--card);border:1px solid var(--line);border-radius:14px;padding:24px;margin:32px 0}
.author-header img{border-radius:50%;width:96px;height:96px}
.author-header h1{font-family:var(--serif);margin:0 0 6px;font-size:28px}
.author-header p{color:var(--muted);margin:0}

/* Search */
.search-page{max-width:780px;margin:0 auto}
.search-page .result{padding:18px 0;border-bottom:1px solid var(--line)}
.search-page h2{font-family:var(--serif);font-size:22px;margin:0 0 6px}

/* Footer */
.site-footer{background:#0e0e10;color:#cfcfd6;margin-top:48px;padding:40px 0 80px}
.foot{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:30px}
.foot strong{color:#fff;font-family:var(--serif);font-size:20px;display:block;margin-bottom:6px}
.foot p{color:#9a9aa6;font-size:14px}
.foot nav{display:flex;flex-direction:column;gap:6px;font-size:14px}
.foot h4{margin:0 0 6px;color:#fff;font-size:13px;text-transform:uppercase;letter-spacing:.1em}
.foot a{color:#cfcfd6}
.foot a:hover{color:#fff}
.subfoot{border-top:1px solid #2a2a30;margin-top:24px;padding-top:16px;font-size:12px;color:#777}

@media (max-width:900px){
  .hero{grid-template-columns:1fr}
  .hero-lead{grid-row:auto}
  .hero-lead h1,.hero-lead h2{font-size:28px}
  .layout{grid-template-columns:1fr}
  .grid3,.related-grid{grid-template-columns:1fr 1fr}
  .foot{grid-template-columns:1fr 1fr}
  .ad-sticky{position:static}
  .native-creative{grid-template-columns:1fr}
  .native-img{min-height:140px}
  .article-head h1{font-size:32px}
  .dek{font-size:18px}
  .article-body{font-size:18px}
  .article-body > p:first-of-type::first-letter{font-size:52px}
  .mobile-cta{display:flex}
  .search-form input{width:120px}
}
@media (max-width:560px){
  .grid3,.related-grid{grid-template-columns:1fr}
  .foot{grid-template-columns:1fr}
  .tagline{display:none}
  .meta .search-form{display:none}
}

/* v3.1.0 additions */
.lead-image img{max-height:560px;object-fit:cover}
.article-body > p:first-of-type::first-letter{font-weight:900 !important;color:var(--accent) !important;font-family:var(--serif) !important}
.reviewed-by{font-size:13px;color:var(--muted);margin:8px 0 0;font-style:italic;text-align:center}
.reviewed-by strong{color:var(--fg);font-style:normal}
.ai-disclosure{font-size:12px;color:var(--muted);margin:24px auto 0;max-width:680px;padding:10px 14px;background:var(--card);border:1px dashed var(--line);border-radius:6px;text-align:center;font-family:var(--sans)}
.inline-newsletter{max-width:680px;margin:28px auto;padding:22px 24px;background:linear-gradient(135deg,var(--card),var(--bg));border:1px solid var(--line);border-radius:12px;display:flex;flex-wrap:wrap;align-items:center;gap:14px;justify-content:space-between;font-family:var(--sans)}
.inline-newsletter .pitch{flex:1 1 220px;min-width:0}
.inline-newsletter .pitch strong{font-family:var(--serif);font-size:20px;display:block;color:var(--fg);margin-bottom:2px}
.inline-newsletter .pitch span{font-size:13px;color:var(--muted)}
.inline-newsletter form{display:flex;gap:6px;flex:1 1 280px}
.inline-newsletter input[type=email]{flex:1;min-width:0;padding:10px 12px;border:1px solid var(--line);border-radius:6px;background:var(--bg);color:var(--fg);font:inherit;font-size:14px}
.inline-newsletter button{padding:10px 16px;background:var(--accent);color:#fff;border:none;border-radius:6px;font-weight:600;cursor:pointer;white-space:nowrap}
.inline-related{max-width:680px;margin:28px auto;padding:16px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.inline-related .label{font-size:11px;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);font-weight:700;margin-bottom:10px;font-family:var(--sans)}
.inline-related-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.inline-related a{display:flex;gap:10px;align-items:flex-start}
.inline-related .thumb{width:80px;height:60px;background-size:cover;background-position:center;border-radius:6px;flex:0 0 80px}
.inline-related h4{font-family:var(--serif);font-size:15px;line-height:1.3;margin:0;font-weight:700;color:var(--fg)}
.inline-related a:hover h4{color:var(--accent)}

/* Sticky desktop TOC */
@media (min-width:1180px){
  .article-with-toc{display:grid;grid-template-columns:240px 1fr;gap:48px;max-width:1080px;margin:0 auto;align-items:start}
  .article-with-toc .toc{position:sticky;top:100px;margin:0;max-width:none}
  .article-with-toc .article-body,
  .article-with-toc .inline-newsletter,
  .article-with-toc .inline-related,
  .article-with-toc .article-foot,
  .article-with-toc .affiliate-disclosure{margin-left:0;margin-right:0;max-width:680px}
}
@media (max-width:560px){
  .inline-related-grid{grid-template-columns:1fr}
  .inline-newsletter{padding:18px}
}

/* v3.1.3 — mobile header & alignment fixes */
@media (max-width:900px){
  .bar{padding:10px 16px;gap:10px;flex-wrap:nowrap}
  .brand{gap:10px;min-width:0;flex:1 1 auto}
  .brand-logo img{max-height:32px}
  .logo-text{font-size:22px}
  .meta{gap:8px;flex:0 0 auto}
  .cta{padding:7px 12px;font-size:12px}
  .theme-toggle{width:32px;height:32px;font-size:13px}
  .catnav ul{padding:0 16px;gap:18px;-webkit-overflow-scrolling:touch;scrollbar-width:none}
  .catnav ul::-webkit-scrollbar{display:none}
  .catnav a{padding:11px 0;font-size:13px}
  .hero{margin:18px 0;gap:16px}
  .hero-lead .body{padding:18px}
  .hero-sec .body{padding:14px}
  .hero-lead h1,.hero-lead h2{font-size:26px;line-height:1.15}
  .container{padding:0 16px}
  body{padding-bottom:72px}
  #reading-progress{height:2px}
}
@media (max-width:560px){
  .bar{padding:10px 14px}
  .brand-logo img{max-height:28px}
  .logo-text{font-size:20px}
  .cta{padding:6px 10px;font-size:11px}
  .meta{gap:6px}
  .hero-lead h1,.hero-lead h2{font-size:24px}
  .hero-lead .body,.hero-sec .body{padding:14px}
  .ad-leaderboard{padding:10px 14px;margin:10px auto}
  .article-head h1{font-size:28px;line-height:1.12}
  .dek{font-size:17px}
  .article-body{font-size:17px}
  .crumbs{margin:16px 0 8px;font-size:12px}
  .container{padding:0 14px}
}

/* ============ v3.2.0 — Header & nav system ============ */
html,body{overflow-x:hidden;max-width:100vw}

.nav-toggle{display:none;background:transparent;border:none;color:var(--fg);width:44px;height:44px;align-items:center;justify-content:center;cursor:pointer;padding:0;margin-right:-4px;border-radius:8px}
.nav-toggle:hover{background:var(--bg)}

.search-toggle{display:none;background:transparent;border:1px solid var(--line);color:var(--fg);width:40px;height:40px;border-radius:50%;cursor:pointer;align-items:center;justify-content:center}
.search-toggle:hover{border-color:var(--fg)}

/* SVG theme toggle icons */
.theme-toggle{width:40px;height:40px;display:inline-flex;align-items:center;justify-content:center}
.theme-toggle svg{display:none}
.theme-toggle .i-sun{display:block}
html[data-theme="dark"] .theme-toggle .i-sun{display:none}
html[data-theme="dark"] .theme-toggle .i-moon{display:block}
@media (prefers-color-scheme: dark){
  html:not([data-theme="light"]) .theme-toggle .i-sun{display:none}
  html:not([data-theme="light"]) .theme-toggle .i-moon{display:block}
}

/* Per-category kicker accent via --kicker var */
.kicker{color:var(--kicker, var(--accent))}

/* Byline avatar */
.byline-avatar{width:22px;height:22px;border-radius:50%;vertical-align:middle;margin-right:6px;display:inline-block}
.byline{display:flex;align-items:center;flex-wrap:wrap;gap:4px 8px}
.byline > *{display:inline-flex;align-items:center}

/* Mobile nav drawer */
.mobile-nav{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:80;display:none;opacity:0;transition:opacity .2s}
.mobile-nav.open{display:block;opacity:1}
.mobile-nav::after{content:'';position:absolute;inset:0;left:auto;width:min(86vw,340px);background:var(--card);box-shadow:-8px 0 32px rgba(0,0,0,.2);z-index:-1}
.mobile-nav-head{position:absolute;top:0;right:0;width:min(86vw,340px);display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--line);font-family:var(--serif);font-weight:800;font-size:18px;color:var(--fg)}
.mobile-nav-head button{background:none;border:none;color:var(--muted);font-size:28px;line-height:1;cursor:pointer;padding:0 8px}
.mobile-nav-list{position:absolute;top:64px;right:0;width:min(86vw,340px);height:calc(100% - 64px);overflow-y:auto;list-style:none;margin:0;padding:8px 0}
.mobile-nav-list li{padding:0}
.mobile-nav-list a{display:block;padding:14px 24px;color:var(--fg);font-size:16px;font-weight:500;border-bottom:1px solid var(--line)}
.mobile-nav-list a:hover{background:var(--bg);color:var(--accent)}

/* Search overlay */
.search-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:90;display:none;align-items:flex-start;justify-content:center;padding:80px 20px 20px}
.search-overlay.open{display:flex}
.search-overlay form{display:flex;width:100%;max-width:600px;background:var(--card);border-radius:12px;padding:6px;box-shadow:0 20px 60px rgba(0,0,0,.3)}
.search-overlay input{flex:1;padding:14px 18px;border:none;background:transparent;color:var(--fg);font:inherit;font-size:17px;outline:none}
.search-overlay button{background:none;border:none;color:var(--muted);font-size:28px;cursor:pointer;padding:0 16px}

/* Mobile header rules */
@media (max-width:900px){
  .nav-toggle{display:inline-flex}
  .search-toggle{display:inline-flex}
  .meta .search-form{display:none}
  .tagline{display:none}
  .bar{padding:8px 14px;gap:8px;flex-wrap:nowrap}
  .brand{flex:1 1 auto;min-width:0;justify-content:flex-start}
  .brand-logo img{max-height:28px}
  .meta{gap:6px;flex:0 0 auto}
  .cta{padding:8px 12px;font-size:12px;min-height:36px;display:inline-flex;align-items:center}
  .theme-toggle,.search-toggle{width:38px;height:38px}
}

/* Hide reading progress on small screens (reclaim pixels) */
@media (max-width:700px){
  #reading-progress{display:none}
}

/* Tap target safety */
button,a.cta,.theme-toggle,.search-toggle,.nav-toggle{min-height:36px}

/* ============ v3.2.5 — Mobile overflow fix ============
   Bug: .hero-lead .img and .placeholder set min-height:300px while also using
   aspect-ratio:16/9. On narrow viewports the aspect-ratio tries to honor the
   min-height, forcing a min width of ~533px and pushing the hero, layout, and
   ads past the viewport edge. Drop min-height on small screens. */
@media (max-width:900px){
  .hero-lead .img,
  .hero-sec .img,
  .placeholder{min-height:0}
  .hero-lead .img{aspect-ratio:16/10}
  /* Make sure nothing inside the container can exceed it */
  .hero,.hero-lead,.hero-sec,.hero .card,
  .layout,.feed,.rail,.grid3,.card.sm,
  .ad-leaderboard,.ad-slot,.native-creative,
  main{min-width:0;max-width:100%}
  .hero-lead h1,.hero-lead h2,.hero-sec h2,.card.sm h3{overflow-wrap:break-word;word-wrap:break-word;hyphens:auto}
}
