/* FacturaOk Blog — estilos compartidos */
:root{
  --bg:#f4f7fb;
  --surface:#ffffff;
  --ink:#0f172a;
  --ink-2:#1e293b;
  --muted:#5b6475;
  --soft:#7c8699;
  --line:#e3eaf3;
  --line-strong:#cfdbeb;
  --accent:#0b4ba2;
  --accent-2:#0c68c8;
  --accent-soft:#e7f0ff;
  --green:#1d9a62;
  --green-soft:#e3f6ec;
  --warn:#f08a1f;
  --danger:#cf3542;
  --mono:"IBM Plex Mono",ui-monospace,monospace;
  --sans:"Plus Jakarta Sans",system-ui,sans-serif;
  --radius:14px;
  --radius-lg:20px;
  --shadow-sm:0 1px 2px rgba(15,23,42,.04), 0 1px 3px rgba(15,23,42,.05);
  --shadow:0 6px 24px -8px rgba(11,75,162,.18), 0 2px 6px rgba(15,23,42,.04);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:var(--sans);color:var(--ink);background:var(--bg);-webkit-font-smoothing:antialiased;line-height:1.65;font-feature-settings:"ss01","cv11"}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%;display:block}
.container{max-width:1180px;margin:0 auto;padding:0 24px}
.container-wide{max-width:1180px;margin:0 auto;padding:0 24px}

/* Nav (idéntico a la landing) */
.nav{background:rgba(255,255,255,.85);backdrop-filter:saturate(160%) blur(12px);border-bottom:1px solid var(--line)}
.nav .container{max-width:1180px}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:68px}
.logo{display:flex;align-items:center;gap:10px}
.logo:hover{text-decoration:none}
.logo img{height:24px}
.nav-links{display:flex;align-items:center;gap:34px}
.nav-links a{color:var(--ink-2);font-size:14px;font-weight:500}
.nav-links a:hover{color:var(--accent);text-decoration:none}
.nav-links a.active{color:var(--accent)}
.nav-cta{display:flex;align-items:center;gap:14px}
.nav-mobile-only{display:none !important}
.lang-switch{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:var(--soft);margin-right:6px}
.lang-switch button{background:none;border:0;font-family:inherit;font-size:13px;font-weight:600;color:var(--soft);cursor:pointer;padding:6px 8px;border-radius:6px;transition:color .15s ease}
.lang-switch button:hover{color:var(--accent)}
.lang-switch button.active{color:var(--accent)}
/* Backward compatibility if any page still has <a> in lang switch. */
.lang-switch a{color:var(--soft);padding:6px 8px;border-radius:6px;transition:color .15s ease;text-decoration:none}
.lang-switch a:hover,.lang-switch a.active{color:var(--accent)}
.lang-switch .sep{color:var(--line-strong)}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 18px;border-radius:10px;font-weight:600;font-size:14px;border:1px solid transparent;cursor:pointer;transition:all .15s ease;font-family:inherit;line-height:1}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover{background:var(--accent-2);box-shadow:0 6px 16px -6px rgba(11,75,162,.55);text-decoration:none}
.btn-ghost{background:transparent;color:var(--ink-2);border-color:var(--line-strong)}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent);text-decoration:none}
.nav-burger{display:none;background:none;border:0;cursor:pointer;padding:6px;position:relative;z-index:60}
.nav-burger svg{width:24px;height:24px;color:var(--ink-2)}
.nav-burger .ico-close{display:none}
body.nav-open .nav-burger .ico-open{display:none}
body.nav-open .nav-burger .ico-close{display:block}
.nav-drawer{position:fixed;top:0;right:0;bottom:0;width:min(86vw,340px);background:#fff;box-shadow:-24px 0 60px -20px rgba(11,23,45,.35),-2px 0 0 rgba(15,23,42,.04);padding:110px 22px 28px;display:none;flex-direction:column;gap:2px;z-index:55;transform:translateX(100%);transition:transform .28s cubic-bezier(.2,.8,.2,1);overflow-y:auto;visibility:hidden}
@media (max-width:920px){.nav-drawer{display:flex}}
body.nav-open .nav-drawer{transform:translateX(0);visibility:visible}
.nav-drawer a{display:flex;align-items:center;justify-content:space-between;font-size:16px;font-weight:600;color:#0F172A;padding:14px 14px;border-radius:10px;border-bottom:1px solid #F1F4F9;transition:background .15s ease,color .15s ease;text-decoration:none}
.nav-drawer a:hover,.nav-drawer a:active{background:#F4F8FE;color:var(--accent)}
.nav-drawer a::after{content:"›";color:#C9D2E0;font-weight:400;font-size:20px;line-height:1;transition:transform .15s ease,color .15s ease}
.nav-drawer a:hover::after{color:var(--accent);transform:translateX(2px)}
.nav-drawer a.nav-mobile-cta{margin-top:14px;padding:13px 22px;color:#fff;justify-content:center;border:0;border-radius:12px;background:var(--accent)}
.nav-drawer a.nav-mobile-cta::after{content:none}
.nav-drawer a.nav-mobile-cta:hover{background:#0a3f8c;color:#fff}
.nav-backdrop{position:fixed;inset:0;background:rgba(11,23,45,.45);backdrop-filter:blur(8px) saturate(1.1);-webkit-backdrop-filter:blur(8px) saturate(1.1);opacity:0;visibility:hidden;transition:opacity .25s ease, visibility .25s ease;z-index:54}
body.nav-open .nav-backdrop{opacity:1;visibility:visible}
body.nav-open{overflow:hidden}
@media (max-width:920px){
  .nav-links{display:none}
  .nav-burger{display:inline-flex}
  .nav-cta .btn-ghost,.nav-cta .btn-primary,.nav-cta .lang-switch{display:none}
}

/* Home blog (portada revista) */
.blog-home{padding:34px 0 96px}
.blog-hero{
  position:relative;
  border-radius:26px;
  overflow:hidden;
  margin:18px 0 24px;
  border:1px solid #d2e2f4;
  background:
    radial-gradient(1200px 420px at 12% 8%, rgba(12,104,200,.18) 0%, rgba(12,104,200,0) 60%),
    linear-gradient(145deg,#ffffff,#f7fbff 56%,#eef7ff);
  box-shadow:0 30px 80px -50px rgba(11,75,162,.35), 0 8px 24px -16px rgba(15,23,42,.25);
}
.blog-hero-grid{
  display:grid;
  grid-template-columns:1.1fr .95fr;
  gap:34px;
  align-items:center;
  padding:44px 46px;
}
.hero-kicker{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-family:var(--mono);
  font-size:12px;
  letter-spacing:.4px;
  text-transform:uppercase;
  color:var(--accent);
  background:#edf5ff;
  border:1px solid #c9ddfb;
  border-radius:999px;
  padding:7px 12px;
  margin-bottom:14px;
}
.hero-kicker .dot{width:8px;height:8px;border-radius:50%;background:var(--green)}
.blog-hero h1{font-size:50px;line-height:1.03;letter-spacing:-1.6px;margin:0 0 14px}
.blog-hero p{font-size:19px;color:var(--muted);max-width:640px;margin:0}
.hero-cta{display:flex;gap:12px;flex-wrap:wrap;margin-top:24px}
.hero-cta .btn{padding:12px 20px;border-radius:11px}
.hero-visual{
  border-radius:20px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.7);
  box-shadow:0 14px 36px -24px rgba(11,75,162,.5);
  animation:floaty 5.2s ease-in-out infinite;
}
.hero-visual img{width:100%;height:auto;display:block}

.news-strip{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:14px;
  margin:22px 0 32px;
}
.news-item{
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:14px;
  padding:14px 15px;
  color:inherit;
  transition:all .18s ease;
}
.news-item:hover{border-color:#bad4f6;transform:translateY(-1px);text-decoration:none;box-shadow:var(--shadow-sm)}
.news-item .label{display:block;font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.45px;color:var(--soft);margin-bottom:6px}
.news-item .title{display:block;font-weight:700;color:var(--ink);line-height:1.35}

.featured-grid{
  display:grid;
  grid-template-columns:1.3fr .92fr;
  gap:16px;
  margin:0 0 26px;
}
.featured-post,.mini-post{
  background:#fff;
  border:1px solid var(--line);
  border-radius:20px;
  overflow:hidden;
  color:inherit;
  transition:all .18s ease;
}
.featured-post:hover,.mini-post:hover{border-color:#b7d1f4;transform:translateY(-2px);box-shadow:var(--shadow);text-decoration:none}
.featured-post img,.mini-post img{width:100%;display:block}
.featured-body{padding:22px 24px 24px}
.stacked-mini{display:grid;grid-template-rows:1fr 1fr;gap:16px}
.mini-post .mini-body{padding:16px 18px 18px}

.meta{font-family:var(--mono);font-size:12px;color:var(--soft);letter-spacing:.4px;text-transform:uppercase;margin-bottom:10px}
.meta .tag{display:inline-block;background:var(--accent-soft);color:var(--accent);padding:2px 8px;border-radius:6px;font-weight:600;margin-right:8px}
.featured-body h2{font-size:33px;line-height:1.14;letter-spacing:-1px;margin:0 0 10px}
.mini-body h3{font-size:21px;line-height:1.22;letter-spacing:-.4px;margin:0 0 8px;color:var(--ink)}
.featured-body p,.mini-body p{margin:0;color:var(--muted)}

.topic-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:14px;
}
.topic-card{
  position:relative;
  border-radius:16px;
  overflow:hidden;
  min-height:178px;
  color:#fff;
  border:1px solid #c9d9ef;
}
.topic-card img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  filter:saturate(1.05) contrast(1.03);
}
.topic-card::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,rgba(8,18,44,.05) 10%,rgba(8,18,44,.72) 88%);
}
.topic-card .topic-body{position:relative;z-index:1;padding:16px 16px 17px;display:flex;height:100%;flex-direction:column;justify-content:flex-end}
.topic-card strong{font-size:19px;line-height:1.2;letter-spacing:-.3px}
.topic-card span{font-size:13px;opacity:.92;margin-top:4px}

.breaking-bar{
  display:grid;
  grid-template-columns:auto 1fr auto;
  gap:14px;
  align-items:center;
  margin:8px 0 16px;
  padding:12px 14px;
  border-radius:14px;
  border:1px solid #cbe0fb;
  background:#f1f7ff;
}
.breaking-pill{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.45px;
  text-transform:uppercase;
  color:#0a3f8f;
  background:#dbeafe;
  border:1px solid #b7d2fb;
  border-radius:999px;
  padding:6px 10px;
}
.breaking-pill .pulse{
  width:8px;
  height:8px;
  border-radius:50%;
  background:var(--green);
  box-shadow:0 0 0 0 rgba(29,154,98,.55);
  animation:pulseDot 1.8s infinite;
}
.breaking-copy{font-size:14px;color:#1e3a5f;font-weight:600}
.breaking-copy strong{color:#0b4ba2}
.breaking-meta{font-family:var(--mono);font-size:12px;color:#5d7190;white-space:nowrap}

.newsletter-band{
  margin:20px 0 18px;
  border-radius:20px;
  border:1px solid #d2e2f4;
  background:linear-gradient(145deg,#ffffff,#f4f9ff 60%,#ebf5ff);
  padding:26px 26px;
  display:grid;
  grid-template-columns:1.2fr 1fr;
  gap:20px;
  align-items:center;
}
.newsletter-band h3{margin:0 0 6px;font-size:29px;line-height:1.12;letter-spacing:-.8px}
.newsletter-band p{margin:0;color:var(--muted)}
.newsletter-band .newsletter-points{margin-top:12px;display:flex;flex-wrap:wrap;gap:8px}
.newsletter-band .newsletter-points span{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-family:var(--mono);padding:5px 9px;border-radius:999px;border:1px solid #c7dbf5;background:#edf5ff;color:#124887}
.newsletter-cta{display:flex;justify-content:flex-end;align-items:center;gap:10px;flex-wrap:wrap}
.newsletter-cta .btn{padding:12px 18px}

.timeline-panel{
  margin-top:16px;
  border-radius:20px;
  border:1px solid var(--line);
  background:#fff;
  padding:22px 22px 18px;
}
.timeline-head{display:flex;justify-content:space-between;align-items:flex-end;gap:12px;flex-wrap:wrap;margin-bottom:14px}
.timeline-head h3{margin:0;font-size:30px;line-height:1.1;letter-spacing:-.9px}
.timeline-head p{margin:0;color:var(--muted)}
.timeline-filters{display:flex;gap:8px;flex-wrap:wrap}
.timeline-filter{
  border:1px solid #d3e3f7;
  background:#f6faff;
  color:#29507d;
  border-radius:999px;
  padding:7px 11px;
  font-family:var(--mono);
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:.4px;
  cursor:pointer;
}
.timeline-filter.active{background:#0b4ba2;color:#fff;border-color:#0b4ba2}
.timeline-list{list-style:none;padding:0;margin:0;display:grid;gap:8px}
.timeline-item{display:grid;grid-template-columns:130px 1fr;gap:14px;align-items:flex-start;padding:11px 0;border-top:1px dashed #dbe6f4}
.timeline-item:first-child{border-top:0}
.timeline-item time{font-family:var(--mono);font-size:12px;color:#6d7d96;text-transform:uppercase;letter-spacing:.35px;padding-top:4px}
.timeline-item .item-card{border:1px solid #e1eaf6;background:#fafcff;border-radius:12px;padding:12px 13px}
.timeline-item .item-card strong{display:block;font-size:16px;line-height:1.25;color:var(--ink)}
.timeline-item .item-card p{margin:4px 0 0;font-size:14px;color:var(--muted)}

.post-grid{display:grid;grid-template-columns:1fr;gap:18px;padding:18px 0 0}
.post-card{display:block;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);padding:28px 30px;transition:all .15s ease;color:inherit}
.post-card:hover{border-color:var(--accent);box-shadow:var(--shadow);transform:translateY(-1px);text-decoration:none}
.post-card h2{font-size:24px;font-weight:700;letter-spacing:-.5px;margin:0 0 8px;line-height:1.25}
.post-card p{margin:0;color:var(--muted);font-size:16px}

/* ── Blog stats row ── */
.blog-stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin:16px 0 22px}
.blog-stat{background:#fff;border:1px solid var(--line);border-radius:16px;padding:20px 20px 16px;text-align:center;transition:transform .18s ease,box-shadow .18s ease;display:flex;flex-direction:column;align-items:center;justify-content:center}
.blog-stat:hover{transform:translateY(-2px);box-shadow:var(--shadow-sm)}
.stat-value{display:flex;align-items:baseline;justify-content:center;gap:3px}
.stat-num{font-size:44px;font-weight:800;letter-spacing:-1.8px;color:var(--accent);line-height:1;font-variant-numeric:tabular-nums}
.stat-suffix{font-size:26px;font-weight:800;letter-spacing:-1px;color:var(--accent);line-height:1}
.stat-label{font-size:13px;color:var(--muted);margin-top:6px;font-weight:500}

/* ── Carousel ── */
.carousel-wrap{position:relative;margin:0 0 26px;border-radius:22px;overflow:hidden;border:1px solid var(--line);background:#fff;box-shadow:var(--shadow-sm)}
.carousel-slide{display:none;text-decoration:none;color:inherit;min-height:260px}
.carousel-slide.active{display:flex;animation:slideIn .4s cubic-bezier(.2,.8,.2,1)}
.carousel-slide img{width:42%;object-fit:cover;flex-shrink:0;display:block}
.carousel-slide-body{padding:32px 36px;display:flex;flex-direction:column;justify-content:center;flex:1}
.carousel-slide-body h2{font-size:32px;line-height:1.1;letter-spacing:-1px;margin:0 0 10px;color:var(--ink)}
.carousel-slide:hover .carousel-slide-body h2{color:var(--accent)}
.carousel-slide-body p{margin:0;color:var(--muted);font-size:16px;line-height:1.55}
.carousel-dots{display:flex;justify-content:center;gap:8px;padding:12px 0 16px;background:#fff}
.carousel-dot{width:28px;height:6px;border-radius:3px;border:0;background:var(--line-strong);cursor:pointer;transition:background .2s ease,width .25s cubic-bezier(.2,.8,.2,1);padding:0}
.carousel-dot.active{background:var(--accent);width:46px}

/* ── Category page hero ── */
.cat-hero{border-radius:22px;overflow:hidden;margin:16px 0 28px;padding:44px 48px;border:1px solid var(--line);background:linear-gradient(145deg,#fff,#f4f9ff 60%,#ebf5ff);display:grid;grid-template-columns:1fr auto;gap:24px;align-items:center}
.cat-hero .cat-kicker{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:11px;letter-spacing:.4px;text-transform:uppercase;color:var(--accent);background:#edf5ff;border:1px solid #c9ddfb;border-radius:999px;padding:6px 12px;margin-bottom:12px}
.cat-hero h1{font-size:44px;line-height:1.05;letter-spacing:-1.5px;margin:0 0 12px}
.cat-hero p{font-size:18px;color:var(--muted);margin:0;max-width:560px}
.cat-hero-img{width:160px;height:160px;object-fit:cover;border-radius:16px;box-shadow:0 10px 30px -16px rgba(11,75,162,.35)}
.cat-articles{display:grid;gap:16px;margin-bottom:28px}
.cat-card{display:flex;gap:0;background:#fff;border:1px solid var(--line);border-radius:18px;overflow:hidden;text-decoration:none;color:inherit;transition:all .18s ease}
.cat-card:hover{border-color:#b7d1f4;transform:translateY(-2px);box-shadow:var(--shadow)}
.cat-card img{width:200px;object-fit:cover;flex-shrink:0}
.cat-card-body{padding:24px 28px;display:flex;flex-direction:column;justify-content:center}
.cat-card-body h2{font-size:26px;line-height:1.15;letter-spacing:-.7px;margin:0 0 10px}
.cat-card-body p{margin:0;color:var(--muted)}
.cat-related{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:56px}
.cat-related-card{background:#fff;border:1px solid var(--line);border-radius:16px;overflow:hidden;text-decoration:none;color:inherit;transition:all .18s ease;display:block}
.cat-related-card:hover{border-color:#b7d1f4;transform:translateY(-2px);box-shadow:var(--shadow-sm)}
.cat-related-card img{width:100%;display:block;height:110px;object-fit:cover}
.cat-related-card .cat-related-body{padding:14px 16px}
.cat-related-card strong{display:block;font-size:16px;margin-bottom:4px}
.cat-related-card span{font-size:13px;color:var(--muted)}

@keyframes slideIn{from{opacity:0;transform:translateX(14px)}to{opacity:1;transform:translateX(0)}}
@keyframes floaty{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-7px)}
}
@keyframes pulseDot{
  0%{box-shadow:0 0 0 0 rgba(29,154,98,.5)}
  70%{box-shadow:0 0 0 8px rgba(29,154,98,0)}
  100%{box-shadow:0 0 0 0 rgba(29,154,98,0)}
}
@media (prefers-reduced-motion: reduce){
  .hero-visual{animation:none}
  .breaking-pill .pulse{animation:none}
}

/* Artículo */
article.post{background:var(--surface);border-radius:var(--radius-lg);padding:64px 56px;margin:32px auto 96px;border:1px solid var(--line);box-shadow:var(--shadow-sm);max-width:800px}
article.post header{border-bottom:1px solid var(--line);padding-bottom:24px;margin-bottom:32px}
article.post header .meta{font-family:var(--mono);font-size:12px;color:var(--soft);letter-spacing:.4px;text-transform:uppercase;margin-bottom:14px}
article.post header .meta .tag{display:inline-block;background:var(--accent-soft);color:var(--accent);padding:2px 8px;border-radius:6px;font-weight:600;margin-right:8px}
article.post h1{font-size:40px;font-weight:800;letter-spacing:-1.2px;line-height:1.15;margin:0 0 14px}
article.post .lead{font-size:20px;color:var(--muted);margin:0;line-height:1.55}
article.post h2{font-size:28px;font-weight:700;letter-spacing:-.6px;margin:48px 0 14px;line-height:1.25}
article.post h3{font-size:20px;font-weight:700;margin:32px 0 10px}
article.post p{font-size:17px;color:var(--ink-2);margin:0 0 16px}
article.post ul,article.post ol{font-size:17px;color:var(--ink-2);padding-left:22px;margin:0 0 18px}
article.post li{margin:6px 0}
article.post code{font-family:var(--mono);font-size:14px;background:#f1f5fb;padding:2px 6px;border-radius:4px;color:var(--accent)}
article.post pre{font-family:var(--mono);font-size:13.5px;background:#0f172a;color:#e2e8f0;padding:18px 22px;border-radius:12px;overflow:auto;margin:18px 0}
article.post pre code{background:transparent;color:inherit;padding:0}
article.post blockquote{border-left:4px solid var(--accent);background:var(--accent-soft);padding:14px 20px;margin:18px 0;border-radius:0 10px 10px 0;color:var(--ink-2);font-size:16px}
article.post .callout{background:var(--green-soft);border:1px solid #b9e6cd;border-radius:12px;padding:16px 20px;margin:20px 0;font-size:15.5px}
article.post .callout strong{color:var(--green)}
article.post .warn{background:#fff5e8;border:1px solid #f8d4a3;color:#7a4514;border-radius:12px;padding:16px 20px;margin:20px 0;font-size:15.5px}
article.post .toc{background:#f7faff;border:1px solid var(--line);border-radius:12px;padding:18px 22px;margin:24px 0 36px}
article.post .toc-title{font-family:var(--mono);font-size:12px;color:var(--soft);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}
article.post .toc ul{list-style:none;padding:0;margin:0;font-size:15px}
article.post .toc li{margin:4px 0}
article.post hr{border:0;border-top:1px solid var(--line);margin:48px 0}
article.post .cta-box{background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;border-radius:16px;padding:28px 32px;margin:40px 0 0;text-align:center}
article.post .cta-box h3{color:#fff;margin:0 0 8px;font-size:22px}
article.post .cta-box p{color:rgba(255,255,255,.9);margin:0 0 16px;font-size:15px}
article.post .cta-box a.btn{display:inline-block;background:#fff;color:var(--accent);padding:11px 22px;border-radius:10px;font-weight:700;font-size:14px}
article.post .cta-box a.btn:hover{text-decoration:none;transform:translateY(-1px);box-shadow:0 6px 16px rgba(0,0,0,.18)}
article.post .back{font-size:14px;color:var(--soft);margin-bottom:28px;display:inline-block}

/* Footer */
footer.foot{background:#0a1530;color:#cfdbeb;padding:40px 0;font-size:14px;margin-top:60px}
footer.foot .container-wide{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:18px}
footer.foot a{color:#cfdbeb}
footer.foot .links a{margin-left:18px}

@media(max-width:680px){
  article.post{padding:40px 26px;margin:18px 12px 60px}
  article.post h1{font-size:30px}
  article.post h2{font-size:24px}
  .blog-home{padding-top:18px}
  .blog-hero{margin:8px 0 16px}
  .blog-hero-grid{padding:26px 18px;grid-template-columns:1fr;gap:18px}
  .blog-hero h1{font-size:34px}
  .blog-hero p{font-size:17px}
  .hero-kicker{font-size:11px}
  .news-strip{grid-template-columns:1fr;margin-top:12px}
  .featured-grid{grid-template-columns:1fr}
  .stacked-mini{grid-template-rows:auto;grid-template-columns:1fr}
  .featured-body h2{font-size:28px}
  .mini-body h3{font-size:20px}
  .topic-grid{grid-template-columns:1fr 1fr;gap:10px}
  .breaking-bar{grid-template-columns:1fr;gap:8px}
  .breaking-meta{white-space:normal}
  .newsletter-band{grid-template-columns:1fr;padding:20px 16px}
  .newsletter-band h3{font-size:24px}
  .newsletter-cta{justify-content:flex-start}
  .timeline-panel{padding:18px 14px}
  .timeline-head h3{font-size:24px}
  .timeline-item{grid-template-columns:1fr;gap:7px}
  .blog-stats-row{grid-template-columns:repeat(2,1fr);gap:10px}
  .carousel-slide{flex-direction:column}
  .carousel-slide img{width:100%;height:200px}
  .carousel-slide-body{padding:22px 20px}
  .carousel-slide-body h2{font-size:24px}
  .cat-hero{grid-template-columns:1fr;padding:28px 22px}
  .cat-hero-img{display:none}
  .cat-hero h1{font-size:32px}
  .cat-card{flex-direction:column}
  .cat-card img{width:100%;height:160px}
  .cat-related{grid-template-columns:1fr}
}
@media (max-width:980px){
  .blog-hero-grid{grid-template-columns:1fr;gap:20px}
  .news-strip{grid-template-columns:1fr 1fr}
  .featured-grid{grid-template-columns:1fr}
  .stacked-mini{grid-template-columns:1fr 1fr;grid-template-rows:auto}
  .topic-grid{grid-template-columns:1fr 1fr}
  .newsletter-band{grid-template-columns:1fr}
  .newsletter-cta{justify-content:flex-start}
  .blog-stats-row{grid-template-columns:repeat(2,1fr)}
  .carousel-slide{flex-direction:column}
  .carousel-slide img{width:100%;height:220px}
  .cat-hero{grid-template-columns:1fr}
  .cat-hero-img{display:none}
  .cat-related{grid-template-columns:1fr 1fr}
  .cat-card img{width:160px}
}
