/* ============================================================
   ZWIP · Blog — design system
   Diseño de referencia (Blog_Zwip) remapeado a la marca REAL de
   zwip: Space Grotesk + teal #82C0AB + slate #1E293B (home-v2.css).
   Autocontenido: las páginas del blog cargan SOLO este archivo
   (no home-v2.css) → sin conflicto con .reveal{opacity:0} del home.
   ============================================================ */

@import url("https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=Space+Mono:wght@400;700&display=swap");

:root {
  /* -------- Surfaces (slate-800, igual que home-v2) -------- */
  --bg-0:      #131A27;   /* footer / lo más profundo */
  --bg-1:      #1E293B;   /* page background          */
  --bg-2:      #172033;
  --surface:   #273245;   /* cards                    */
  --surface-2: #2F3B50;   /* raised chips / inner     */
  --surface-3: #3A475D;

  /* -------- Brand accent (teal real de zwip) -------- */
  --mint:        #82C0AB;
  --mint-bright: #9AD0BD;
  --mint-deep:   #5A9C85;
  --mint-glow:   rgba(130,192,171,0.30);
  --ink:         #0F1929;  /* texto sobre teal */

  /* -------- Text -------- */
  --t1: #E8ECF2;   /* headings / primary */
  --t2: #9FAAC0;   /* body               */
  --t3: #6F7C95;   /* meta / muted       */
  --t-mint: #82C0AB;

  /* -------- Lines -------- */
  --line:    rgba(255,255,255,0.07);
  --line-2:  rgba(255,255,255,0.12);
  --line-mint: rgba(130,192,171,0.42);

  /* -------- Category / badge hues (alineadas a status de zwip) -------- */
  --c-green:  #34D399;  --c-green-bg:  rgba(52,211,153,0.13);
  --c-purple: #A78BFA;  --c-purple-bg: rgba(167,139,250,0.15);
  --c-orange: #F59E0B;  --c-orange-bg: rgba(245,158,11,0.15);
  --c-blue:   #60A5FA;  --c-blue-bg:   rgba(96,165,250,0.15);
  --c-red:    #F87171;  --c-red-bg:    rgba(248,113,113,0.14);
  --c-gray:   #8593A2;  --c-gray-bg:   rgba(133,147,162,0.14);

  /* -------- Type -------- */
  --font-sans: "Space Grotesk", "Helvetica Neue", Arial, sans-serif;
  --font-mono: "Space Mono", ui-monospace, Menlo, monospace;

  --fs-display: clamp(40px, 6.2vw, 80px);
  --fs-h1:      clamp(34px, 4.6vw, 58px);
  --fs-h2:      clamp(26px, 3vw, 38px);
  --fs-h3:      22px;
  --fs-lead:    clamp(18px, 1.5vw, 22px);
  --fs-body:    17px;
  --fs-small:   15px;
  --fs-cap:     13px;
  --fs-micro:   12px;

  --lh-tight: 1.04;
  --lh-head:  1.12;
  --lh-body:  1.7;

  /* -------- Spacing -------- */
  --s1: 4px; --s2: 8px; --s3: 12px; --s4: 16px; --s5: 24px;
  --s6: 32px; --s7: 48px; --s8: 64px; --s9: 96px; --s10: 128px;

  /* -------- Radius -------- */
  --r-xs: 6px; --r-sm: 10px; --r-md: 16px; --r-lg: 22px; --r-pill: 999px;

  /* -------- Shadow -------- */
  --sh-1: 0 1px 0 rgba(0,0,0,0.2);
  --sh-2: 0 10px 30px rgba(0,0,0,0.32);
  --sh-3: 0 24px 60px rgba(0,0,0,0.45);
  --sh-mint: 0 12px 34px rgba(130,192,171,0.22);

  /* -------- Motion -------- */
  --ease: cubic-bezier(0.22,0.7,0.2,1);
  --ease-snap: cubic-bezier(0.2,0.9,0.1,1.25);
  --dur: 220ms;

  /* -------- Layout -------- */
  --maxw: 1280px;
  --maxw-prose: 720px;
  --gutter: clamp(20px, 4.5vw, 56px);
  --pad-pg-x: clamp(20px, 5vw, 80px);
  --nav-h: 64px;

  /* Aliases a los tokens del sitio (home-v2.css) — mismos valores, otro nombre —
     para reusar el NAV y FOOTER reales con su CSS exacto y que el blog quede
     idéntico al resto del sitio. */
  --p-teal: var(--mint); --p-teal-2: var(--mint-bright); --p-teal-ink: var(--ink);
  --p-fg: var(--t1); --p-fg-2: var(--t2); --p-fg-3: var(--t3); --p-fg-4: #4E5972;
  --p-bg-2: var(--bg-2); --p-surface: var(--surface);
  --p-border: var(--line); --p-border-2: var(--line-2); --p-border-hi: var(--line-mint);
  --radius-sm: var(--r-sm);
  --fs-sm: 14px; --fs-xs: 12px;
}

* { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  margin: 0;
  font-family: var(--font-sans);
  font-size: var(--fs-body);
  line-height: var(--lh-body);
  color: var(--t2);
  background:
    radial-gradient(1200px 700px at 80% -8%, rgba(130,192,171,0.08), transparent 60%),
    radial-gradient(900px 600px at -5% 8%, rgba(96,165,250,0.06), transparent 55%),
    var(--bg-1);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

img { max-width: 100%; display: block; }

::selection { background: var(--mint); color: var(--ink); }

/* ---------------- Layout helpers ---------------- */
.wrap {
  width: 100%;
  max-width: var(--maxw);
  margin: 0 auto;
  padding-left: var(--pad-pg-x);
  padding-right: var(--pad-pg-x);
}
/* Padding lateral para que el cuerpo NO se pegue a los bordes en mobile.
   El max-width suma el padding (box-sizing border-box) → la columna de lectura
   sigue siendo ~720px en desktop, pero en pantallas angostas hay aire a los lados. */
.prose-wrap {
  max-width: calc(var(--maxw-prose) + var(--gutter) * 2);
  margin: 0 auto;
  padding-left: var(--gutter);
  padding-right: var(--gutter);
}

/* ---------------- Type ---------------- */
h1, h2, h3, h4 { color: var(--t1); margin: 0; font-weight: 600; letter-spacing: -0.02em; }
h1 { font-size: var(--fs-h1); line-height: var(--lh-head); font-weight: 700; }
h2 { font-size: var(--fs-h2); line-height: var(--lh-head); }
h3 { font-size: var(--fs-h3); line-height: 1.25; }
p { margin: 0 0 var(--s5); text-wrap: pretty; }

.eyebrow {
  font-family: var(--font-mono);
  font-size: var(--fs-cap);
  font-weight: 700;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--mint);
  display: inline-flex; align-items: center; gap: 10px;
}
.eyebrow::before {
  content: ""; width: 22px; height: 1px; background: var(--mint);
  opacity: 0.7;
}
.eyebrow.no-rule::before { display: none; }

a { color: var(--mint); text-decoration: none; }
a:hover { color: var(--mint-bright); }

/* ---------------- Nav (idéntico al sitio: home-v2.css) ---------------- */
.nav {
  position: sticky; top: 0; z-index: 50;
  background: rgba(30,41,59,0.78);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--p-border);
}
.nav-inner { display: flex; align-items: center; gap: 24px; height: 64px; }
.logo { display: inline-flex; align-items: center; gap: 8px; font-weight: 700; letter-spacing: 0.04em; font-size: 15px; color: var(--p-fg); }
.logo img { display: block; }
.nav-links { display: flex; align-items: center; gap: 4px; margin: 0 0 0 24px; padding: 0; list-style: none; }
.nav-link { padding: 8px 12px; border-radius: 6px; color: var(--p-fg-2); font-family: var(--font-sans); font-size: var(--fs-sm); font-weight: 500; transition: color 140ms ease, background 140ms ease; }
.nav-link:hover { color: var(--p-fg); background: var(--p-surface); }
.nav-right { margin-left: auto; display: flex; align-items: center; gap: 8px; }

/* Botones del nav/drawer = estilo del sitio. Scoped para NO pisar los .btn--*
   del cuerpo del blog (CTA band, newsletter). */
.nav .btn, .nav-mobile .btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  height: 44px; padding: 0 18px; border-radius: var(--radius-sm);
  font-family: var(--font-sans); font-size: var(--fs-sm); font-weight: 600;
  border: 1px solid transparent; cursor: pointer; text-decoration: none; white-space: nowrap;
  box-shadow: none;
  transition: background 140ms ease, color 140ms ease, transform 80ms ease, border-color 140ms ease;
}
.nav .btn:active, .nav-mobile .btn:active { transform: translateY(1px); }
.nav .btn-sm { height: 34px; padding: 0 12px; font-size: var(--fs-xs); }
.nav .btn-primary, .nav-mobile .btn-primary { background: var(--p-teal); color: var(--p-teal-ink); }
.nav .btn-primary:hover, .nav-mobile .btn-primary:hover { background: var(--p-teal-2); }
.nav .btn-ghost, .nav-mobile .btn-ghost { background: transparent; color: var(--p-fg); border-color: var(--p-border-2); }
.nav .btn-ghost:hover, .nav-mobile .btn-ghost:hover { background: var(--p-surface); border-color: var(--p-border-hi); }

/* Hamburger (mobile) */
.nav-burger { display: none; background: none; border: none; cursor: pointer; padding: 0; margin-left: auto; width: 40px; height: 40px; position: relative; color: var(--p-fg); }
.burger-bar { position: absolute; left: 8px; width: 24px; height: 2px; background: currentColor; border-radius: 999px; transition: transform 220ms cubic-bezier(0.2,0.8,0.2,1), opacity 200ms ease, top 220ms cubic-bezier(0.2,0.8,0.2,1); }
.bar-1 { top: 14px; } .bar-2 { top: 20px; } .bar-3 { top: 26px; }
.bar-1.open { top: 20px; transform: rotate(45deg); }
.bar-2.open { opacity: 0; }
.bar-3.open { top: 20px; transform: rotate(-45deg); }

/* Mobile drawer */
.nav-mobile { position: absolute; top: 100%; left: 0; right: 0; background: rgba(30,41,59,0.96); backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px); border-bottom: 1px solid var(--p-border); padding: 12px var(--pad-pg-x) 20px; display: flex; flex-direction: column; gap: 2px; box-shadow: 0 30px 60px rgba(0,0,0,0.5); }
.nav-mobile[hidden] { display: none; }
.nav-mobile-link { display: block; padding: 14px 16px; border-radius: 8px; color: var(--p-fg); font-family: var(--font-sans); font-size: var(--fs-body); font-weight: 500; text-decoration: none; transition: background 140ms ease, color 140ms ease; }
.nav-mobile-link:hover, .nav-mobile-link:active { background: var(--p-surface); color: var(--p-teal); }
.nav-mobile-cta { display: flex; flex-direction: column; gap: 8px; padding-top: 14px; margin-top: 10px; border-top: 1px solid var(--p-border); }
.nav-mobile-cta .btn { width: 100%; }

@media (max-width: 760px) {
  .nav-links { display: none; }
  .nav-burger { display: block; }
  .nav-right { display: none; }
}

/* ---------------- Buttons (cuerpo del blog) ---------------- */
.btn {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-sans); font-weight: 600; font-size: 15px;
  padding: 12px 20px; border-radius: var(--r-pill);
  border: 1px solid transparent; cursor: pointer;
  text-decoration: none; white-space: nowrap;
  transition: transform var(--dur) var(--ease), background var(--dur) var(--ease),
              color var(--dur) var(--ease), border-color var(--dur) var(--ease),
              box-shadow var(--dur) var(--ease);
}
.btn .arr { transition: transform var(--dur) var(--ease-snap); }
.btn:hover .arr { transform: translateX(3px); }
.btn--primary { background: var(--mint); color: var(--ink); box-shadow: var(--sh-mint); }
.btn--primary:hover { background: var(--mint-bright); color: var(--ink); transform: translateY(-2px); }
.btn--ghost { background: transparent; color: var(--t1); border-color: var(--line-2); }
.btn--ghost:hover { border-color: var(--mint); color: var(--mint); }
.btn--quiet { background: var(--surface-2); color: var(--t1); }
.btn--quiet:hover { background: var(--surface-3); }
.btn--sm { padding: 9px 16px; font-size: 13.5px; }

/* ---------------- Pills / badges ---------------- */
.pill {
  display: inline-flex; align-items: center; gap: 7px;
  font-family: var(--font-mono); font-size: 12px; font-weight: 700;
  letter-spacing: 0.04em;
  padding: 5px 11px 5px 10px; border-radius: var(--r-pill);
  background: var(--surface-2); color: var(--t2);
  border: 1px solid var(--line);
}
.pill .dot { width: 7px; height: 7px; border-radius: 50%; background: var(--mint); }

.cat {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: var(--font-mono); font-size: 11.5px; font-weight: 700;
  letter-spacing: 0.06em; text-transform: uppercase;
  padding: 4px 10px; border-radius: var(--r-pill);
}
.cat .dot { width: 6px; height: 6px; border-radius: 50%; background: currentColor; }
.cat--green  { color: var(--c-green);  background: var(--c-green-bg);  }
.cat--purple { color: var(--c-purple); background: var(--c-purple-bg); }
.cat--orange { color: var(--c-orange); background: var(--c-orange-bg); }
.cat--blue   { color: var(--c-blue);   background: var(--c-blue-bg);   }
.cat--red    { color: var(--c-red);    background: var(--c-red-bg);    }
.cat--gray   { color: var(--c-gray);   background: var(--c-gray-bg);   }

/* ---------------- Cover placeholders (branded) ---------------- */
.cover {
  position: relative; overflow: hidden;
  background: var(--bg-2);
  border-radius: var(--r-md);
}
.cover .cover-art { position: absolute; inset: 0; }
.cover::before {
  content: ""; position: absolute; left: 18px; top: 16px; width: 26px; height: 21px; z-index: 2;
  background: no-repeat center/contain
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 40 32'%3E%3Cpath d='M2 3 L38 14 L15 17 Z' fill='%2382C0AB'/%3E%3Cpath d='M2 29 L38 14 L15 17 Z' fill='%233A6E8F'/%3E%3C/svg%3E");
  opacity: 0.85;
}
.cover .cover-glyph {
  position: absolute; right: -2%; bottom: -26%;
  font-family: var(--font-sans); font-weight: 700;
  font-size: 62%; line-height: 0.8; letter-spacing: -0.05em;
  color: rgba(255,255,255,0.13);
  text-shadow: 0 2px 30px rgba(0,0,0,0.3);
  pointer-events: none; user-select: none; z-index: 1;
}
/* per-category gradient washes — saturated brand corner glow */
.art-green  { background: radial-gradient(90% 120% at 12% 0%, #2a6f53 0%, #1c4536 38%, #16202e 78%); }
.art-purple { background: radial-gradient(90% 120% at 12% 0%, #574391 0%, #322a55 40%, #17202e 78%); }
.art-orange { background: radial-gradient(90% 120% at 12% 0%, #8a5a26 0%, #543921 40%, #18212e 78%); }
.art-blue   { background: radial-gradient(90% 120% at 12% 0%, #2e5a8e 0%, #233f63 40%, #16212e 78%); }
.art-red    { background: radial-gradient(90% 120% at 12% 0%, #8a4040 0%, #532e2e 40%, #18202e 78%); }
.art-grid::after {
  content: ""; position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,0.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.06) 1px, transparent 1px);
  background-size: 30px 30px;
  mask-image: radial-gradient(120% 110% at 85% 100%, #000, transparent 72%);
  -webkit-mask-image: radial-gradient(120% 110% at 85% 100%, #000, transparent 72%);
}

/* ---------------- Footer (idéntico al sitio: home-v2.css) ---------------- */
.home-footer {
  border-top: 1px solid var(--p-border);
  background: var(--p-bg-2);
  padding: 72px 0 32px;
  margin-top: var(--s10);
  color: var(--p-fg-3);
  font-size: var(--fs-sm);
}
.foot-grid {
  display: grid; grid-template-columns: 1.5fr 1fr 1fr 1fr; gap: 40px;
  margin-bottom: 56px;
}
@media (max-width: 880px) { .foot-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 520px) { .foot-grid { grid-template-columns: 1fr; } }
.foot-col h4 {
  font-family: var(--font-mono); font-size: var(--fs-xs); font-weight: 700;
  letter-spacing: 0.16em; text-transform: uppercase; color: var(--p-fg-4);
  margin: 0 0 16px;
}
.foot-col ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 10px; }
.foot-col a { color: var(--p-fg-2); }
.foot-col a:hover { color: var(--p-teal); }
.foot-bottom {
  display: flex; justify-content: space-between; align-items: center; gap: 16px;
  padding-top: 28px; border-top: 1px solid var(--p-border);
  font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--p-fg-4);
}

/* ---------------- Reveal ---------------- */
.reveal { opacity: 0; transform: translateY(20px); transition: opacity .7s var(--ease), transform .7s var(--ease); }
.reveal.in { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) {
  .reveal { opacity: 1; transform: none; transition: none; }
  html { scroll-behavior: auto; }
}

/* =================================================================
   BLOG LISTING
   ================================================================= */
.blog-hero { padding: clamp(48px,8vw,104px) var(--gutter) var(--s7); }
.blog-title {
  font-size: var(--fs-display); line-height: 1.0; letter-spacing: -0.03em;
  font-weight: 700; max-width: 14ch; margin: var(--s4) 0 var(--s5);
}
.blog-title .hl { color: var(--mint); }
.blog-lead { font-size: var(--fs-lead); color: var(--t2); max-width: 60ch; line-height: 1.55; }

.featured-wrap { padding-bottom: var(--s7); }
.featured {
  display: flex; gap: var(--s7);
  align-items: stretch; text-decoration: none;
  background: var(--surface); border: 1px solid var(--line);
  border-radius: var(--r-lg); overflow: hidden; padding: var(--s5);
  transition: border-color var(--dur) var(--ease), transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
.featured:hover { border-color: var(--line-mint); transform: translateY(-3px); box-shadow: var(--sh-2); }
.featured .cover { flex: 0 0 50%; min-width: 0; min-height: 340px; border-radius: var(--r-md); }
.featured-body { flex: 1 1 0; min-width: 0; display: flex; flex-direction: column; justify-content: center; gap: var(--s4); padding: var(--s4) var(--s4) var(--s4) var(--s2); }
.card-top { display: flex; align-items: center; justify-content: space-between; gap: var(--s3); }
.featured-title { font-size: clamp(26px,2.6vw,40px); line-height: 1.1; color: var(--t1); }
.featured:hover .featured-title { color: var(--mint-bright); }
.featured-dek { color: var(--t2); font-size: var(--fs-lead); margin: 0; }
@media (max-width: 860px) { .featured { flex-direction: column; } .featured .cover { flex-basis: auto; min-height: 220px; } }

/* controls */
.list-section { padding-bottom: var(--s8); }
.controls {
  display: flex; align-items: center; justify-content: space-between; gap: var(--s5);
  flex-wrap: wrap; padding: var(--s5) 0 var(--s4);
  border-top: 1px solid var(--line); margin-top: var(--s4);
  position: sticky; top: var(--nav-h); background: var(--bg-1); z-index: 20;
}
.filters { display: flex; gap: var(--s2); flex-wrap: wrap; }
.chip {
  font-family: var(--font-mono); font-size: 12.5px; font-weight: 700;
  letter-spacing: 0.02em; color: var(--t2);
  background: var(--surface-2); border: 1px solid var(--line);
  padding: 8px 14px; border-radius: var(--r-pill); cursor: pointer;
  transition: all var(--dur) var(--ease);
}
.chip:hover { color: var(--t1); border-color: var(--line-2); }
.chip.active { background: var(--mint); color: var(--ink); border-color: var(--mint); }
.search {
  display: flex; align-items: center; gap: 8px;
  background: var(--surface-2); border: 1px solid var(--line);
  border-radius: var(--r-pill); padding: 8px 16px; color: var(--t3);
  min-width: 230px; transition: border-color var(--dur) var(--ease);
}
.search:focus-within { border-color: var(--mint); color: var(--mint); }
.search input { background: none; border: 0; outline: 0; color: var(--t1); font-family: var(--font-sans); font-size: 14px; width: 100%; }
.search input::placeholder { color: var(--t3); }
.result-count { font-family: var(--font-mono); font-size: 12px; color: var(--t3); margin: 0 0 var(--s5); letter-spacing: 0.04em; }
.no-results { text-align: center; padding: var(--s8) 0; color: var(--t2); font-size: var(--fs-lead); }

/* post grid + cards */
.post-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--s5); }
@media (max-width: 920px) { .post-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .post-grid { grid-template-columns: 1fr; } }
.post-card > a {
  display: flex; flex-direction: column; height: 100%;
  background: var(--surface); border: 1px solid var(--line);
  border-radius: var(--r-md); overflow: hidden; text-decoration: none;
  transition: border-color var(--dur) var(--ease), transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
.post-card > a:hover { border-color: var(--line-mint); transform: translateY(-4px); box-shadow: var(--sh-2); }
.post-card .cover { aspect-ratio: 16/10; border-radius: 0; }
.post-card .cover-glyph { right: -2%; bottom: -28%; }
.card-body { padding: var(--s5); display: flex; flex-direction: column; gap: var(--s3); flex: 1; }
.card-top .read { font-family: var(--font-mono); font-size: 11.5px; color: var(--t3); }
.card-title { font-size: 20px; line-height: 1.25; color: var(--t1); margin: 0; }
.post-card > a:hover .card-title { color: var(--mint-bright); }
.card-dek { color: var(--t2); font-size: var(--fs-small); margin: 0; flex: 1; }
.card-meta { display: flex; align-items: center; justify-content: space-between; padding-top: var(--s3); border-top: 1px solid var(--line); }
.card-meta time { font-family: var(--font-mono); font-size: 12px; color: var(--t3); }
.card-meta .go { font-family: var(--font-mono); font-size: 12px; font-weight: 700; color: var(--mint); display: inline-flex; gap: 6px; }
.card-meta .go .arr { transition: transform var(--dur) var(--ease-snap); }
.post-card > a:hover .go .arr { transform: translateX(3px); }

/* newsletter strip */
.news-strip { margin-top: var(--s8); }
.news-inner {
  display: grid; grid-template-columns: 1.2fr 1fr; gap: var(--s7); align-items: center;
  background: linear-gradient(120deg, var(--surface) 0%, var(--bg-2) 100%);
  border: 1px solid var(--line); border-radius: var(--r-lg); padding: clamp(28px,4vw,52px);
}
@media (max-width: 760px) { .news-inner { grid-template-columns: 1fr; } }
.news-title { font-size: clamp(24px,2.4vw,34px); color: var(--t1); margin: var(--s3) 0; }
.news-sub { color: var(--t2); margin: 0; }
.news-form { display: flex; gap: var(--s3); flex-wrap: wrap; align-items: center; }
.news-form input {
  flex: 1; min-width: 200px; background: var(--bg-1); border: 1px solid var(--line-2);
  border-radius: var(--r-pill); padding: 13px 18px; color: var(--t1); font-family: var(--font-sans); font-size: 15px; outline: none;
}
.news-form input:focus { border-color: var(--mint); }
.news-ok { font-family: var(--font-mono); font-size: 13px; color: var(--mint); width: 100%; }
.news-err { font-family: var(--font-mono); font-size: 13px; color: var(--c-red); width: 100%; }

/* =================================================================
   ARTICLE
   ================================================================= */
.progress { position: fixed; top: 0; left: 0; height: 3px; width: 0; background: var(--mint); z-index: 80; box-shadow: 0 0 10px var(--mint-glow); }

.article-head { padding: clamp(36px,6vw,72px) var(--gutter) var(--s6); max-width: 860px; }
.breadcrumb { display: flex; gap: 10px; align-items: center; font-family: var(--font-mono); font-size: 12px; color: var(--t3); margin-bottom: var(--s5); }
.breadcrumb a { color: var(--t3); }
.breadcrumb a:hover { color: var(--mint); }
.article-title { font-size: var(--fs-h1); line-height: 1.08; margin: var(--s4) 0 var(--s4); max-width: 18ch; }
.article-dek { font-size: var(--fs-lead); color: var(--t2); line-height: 1.5; margin: 0 0 var(--s6); max-width: 52ch; }
.article-meta { display: flex; align-items: center; gap: var(--s4); flex-wrap: wrap; font-family: var(--font-mono); font-size: 13px; color: var(--t3); }
.article-meta.sm { font-size: 12px; gap: var(--s3); }
.meta-author { display: flex; align-items: center; gap: 10px; }
.avatar {
  width: 38px; height: 38px; border-radius: 50%; display: grid; place-items: center;
  background: linear-gradient(135deg, var(--mint) 0%, var(--mint-deep) 100%); color: var(--ink);
  font-family: var(--font-sans); font-weight: 700; font-size: 13px; letter-spacing: 0; flex: none;
}
.avatar--lg { width: 56px; height: 56px; font-size: 18px; }
.meta-author .who { display: flex; flex-direction: column; line-height: 1.3; }
.meta-author .who strong { color: var(--t1); font-family: var(--font-sans); font-weight: 600; font-size: 14px; }
.meta-author .who .role { color: var(--t3); font-size: 11.5px; }
.meta-dot { width: 4px; height: 4px; border-radius: 50%; background: var(--t3); opacity: 0.6; }

.article-cover { margin: 0 0 var(--s7); }
.cover--big { aspect-ratio: 21/9; min-height: 280px; }
.figcap { font-family: var(--font-mono); font-size: 11.5px; color: var(--t3); margin-top: var(--s3); text-align: right; }

.article-body { font-size: var(--fs-body); }
.article-body h2 { font-size: var(--fs-h2); margin: var(--s8) 0 var(--s4); scroll-margin-top: calc(var(--nav-h) + 16px); }
.article-body h2:first-of-type { margin-top: var(--s6); }
.article-body p { color: var(--t2); line-height: var(--lh-body); margin: 0 0 var(--s5); }
.article-body p strong, .rich-list strong { color: var(--t1); font-weight: 600; }
.article-body a { text-decoration: underline; text-underline-offset: 3px; text-decoration-color: var(--line-mint); }

/* TL;DR */
.tldr {
  background: var(--surface); border: 1px solid var(--line); border-left: 3px solid var(--mint);
  border-radius: var(--r-md); padding: var(--s5) var(--s6); margin: 0 0 var(--s7);
}
.tldr-h { font-family: var(--font-mono); font-size: 13px; letter-spacing: 0.18em; color: var(--mint); margin: 0 0 var(--s4); }
.tldr ul { margin: 0; padding-left: 0; list-style: none; display: grid; gap: var(--s3); }
.tldr li { position: relative; padding-left: 26px; color: var(--t2); line-height: 1.5; }
.tldr li::before { content: "→"; position: absolute; left: 0; top: 0; color: var(--mint); font-weight: 700; }

/* answer box (GEO) */
.answer-box {
  background: linear-gradient(120deg, rgba(130,192,171,0.09), rgba(130,192,171,0.02));
  border: 1px solid var(--line-mint); border-radius: var(--r-md);
  padding: var(--s5) var(--s6); margin: var(--s6) 0;
}
.answer-label { display: inline-flex; align-items: center; gap: 8px; font-family: var(--font-mono); font-size: 11px; font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase; color: var(--mint); margin-bottom: var(--s3); }
.answer-label .dot { width: 7px; height: 7px; border-radius: 50%; background: var(--mint); box-shadow: 0 0 8px var(--mint-glow); }
.answer-q { color: var(--t1) !important; font-weight: 600; font-size: 18px; margin: 0 0 var(--s2) !important; }
.answer-a { color: var(--t2) !important; margin: 0 !important; }

/* stats */
.stat-block { margin: var(--s7) 0; }
.stat-row { display: grid; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)); gap: var(--s5); }
.stat { border-top: 2px solid var(--mint); padding-top: var(--s3); }
.stat .n { font-family: var(--font-sans); font-weight: 700; font-size: clamp(32px,4vw,52px); color: var(--t1); line-height: 1; letter-spacing: -0.03em; }
.stat .l { color: var(--t3); font-size: 13.5px; margin-top: var(--s3); line-height: 1.4; }
.stat-note { font-family: var(--font-mono); font-size: 11.5px; color: var(--t3); margin: var(--s4) 0 0 !important; line-height: 1.5; }

/* pull quote */
.pullquote { margin: var(--s7) 0; border-left: 3px solid var(--mint); padding-left: var(--s6); }
.pullquote p { font-family: var(--font-sans); font-weight: 600; font-size: clamp(22px,2.4vw,30px); line-height: 1.3; color: var(--t1) !important; letter-spacing: -0.02em; margin: 0 0 var(--s3) !important; }
.pullquote cite { font-family: var(--font-mono); font-size: 12.5px; color: var(--t3); font-style: normal; }

/* rich list */
.rich-list { margin: 0 0 var(--s5); padding-left: 0; list-style: none; display: grid; gap: var(--s3); }
.rich-list li { position: relative; padding-left: 28px; color: var(--t2); line-height: 1.6; }
.rich-list li::before { content: ""; position: absolute; left: 4px; top: 11px; width: 7px; height: 7px; border-radius: 2px; background: var(--mint); }

/* FAQ */
.faq { margin: var(--s9) 0 var(--s7); padding-top: var(--s6); border-top: 1px solid var(--line); }
.faq h2 { margin: var(--s3) 0 var(--s5); }
.faq-item { border-bottom: 1px solid var(--line); }
.faq-item summary {
  list-style: none; cursor: pointer; padding: var(--s5) 0; color: var(--t1);
  font-weight: 600; font-size: 18px; display: flex; justify-content: space-between; gap: var(--s4); align-items: start;
  transition: color var(--dur) var(--ease);
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::after { content: "+"; color: var(--mint); font-weight: 400; font-size: 26px; line-height: 0.8; flex: none; transition: transform var(--dur) var(--ease); }
.faq-item[open] summary { color: var(--mint); }
.faq-item[open] summary::after { transform: rotate(45deg); }
.faq-item summary:hover { color: var(--mint); }
.faq-a { padding: 0 0 var(--s5); }
.faq-a p { margin: 0 !important; color: var(--t2); }

/* sources */
.sources { margin: var(--s7) 0; }
.sources-h { font-family: var(--font-mono); font-size: 13px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--mint); margin: 0 0 var(--s4); }
.sources ol { margin: 0; padding-left: 22px; display: grid; gap: var(--s3); }
.sources li { color: var(--t2); font-size: 14px; line-height: 1.5; }
.sources .src-t { display: block; }
.sources .src-d { font-family: var(--font-mono); font-size: 11.5px; color: var(--t3); }

/* share */
.share-row { display: flex; align-items: center; gap: var(--s3); margin: var(--s7) 0; padding: var(--s5) 0; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.share-label { font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.1em; color: var(--t3); margin-right: var(--s2); }
.share-btn {
  width: 40px; height: 40px; border-radius: 50%; display: inline-grid; place-items: center;
  background: var(--surface-2); border: 1px solid var(--line); color: var(--t2);
  font-family: var(--font-mono); font-size: 15px; cursor: pointer; text-decoration: none;
  transition: all var(--dur) var(--ease);
}
.share-btn:hover { background: var(--mint); color: var(--ink); border-color: var(--mint); transform: translateY(-2px); }
.share-btn.ok { background: var(--mint); color: var(--ink); border-color: var(--mint); }

/* author card */
.author-card { display: flex; gap: var(--s4); align-items: flex-start; background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-md); padding: var(--s5) var(--s6); margin: var(--s7) 0; }
.ac-name { color: var(--t1); font-weight: 600; font-size: 16px; }
.ac-role { color: var(--mint); font-family: var(--font-mono); font-size: 12px; margin-top: 2px; }
.ac-bio { color: var(--t2); font-size: 14px; margin: var(--s3) 0 0 !important; }

/* related */
.related { padding-top: var(--s8); }
.related-h { margin: var(--s3) 0 var(--s6); }

/* CTA band */
.cta-band { margin-top: var(--s9); border-top: 1px solid var(--line); background: linear-gradient(180deg, var(--bg-1), var(--bg-0)); padding: var(--s9) 0; }
.cta-inner { display: grid; grid-template-columns: 1.15fr 0.85fr; gap: var(--s8); align-items: center; }
@media (max-width: 820px) { .cta-inner { grid-template-columns: 1fr; } }
.cta-title { font-size: clamp(30px,3.6vw,52px); line-height: 1.08; color: var(--t1); margin: var(--s4) 0; letter-spacing: -0.02em; }
.cta-sub { color: var(--t2); font-size: var(--fs-lead); max-width: 44ch; margin: 0 0 var(--s6); }
.cta-actions { display: flex; gap: var(--s3); flex-wrap: wrap; }
.cta-card { background: var(--surface); border: 1px solid var(--line-2); border-radius: var(--r-md); padding: var(--s5); box-shadow: var(--sh-2); }
.cc-row { display: flex; align-items: center; justify-content: space-between; margin-bottom: var(--s4); }
.cc-time { font-family: var(--font-mono); font-size: 11px; color: var(--t3); }
.cc-line { color: var(--t2); font-size: 14px; margin-bottom: var(--s2); }
.cc-strong { color: var(--t1); font-weight: 600; }
.cc-agent { display: flex; align-items: center; gap: 10px; margin-top: var(--s4); padding-top: var(--s4); border-top: 1px solid var(--line); font-size: 13px; color: var(--mint); font-family: var(--font-mono); }
.cc-spark { width: 10px; height: 10px; border-radius: 50%; background: var(--mint); box-shadow: 0 0 0 0 var(--mint-glow); animation: spark 1.8s var(--ease) infinite; flex: none; }
@keyframes spark { 0%,100% { box-shadow: 0 0 0 0 rgba(130,192,171,0.5); } 50% { box-shadow: 0 0 0 7px rgba(130,192,171,0); } }

/* =================================================================
   TABLE OF CONTENTS (scroll-spy island)
   ================================================================= */
.toc {
  position: sticky; top: calc(var(--nav-h) + 24px);
  align-self: start;
  font-family: var(--font-mono);
}
.toc-label { font-size: 11px; font-weight: 700; letter-spacing: 0.16em; text-transform: uppercase; color: var(--t3); margin-bottom: var(--s4); }
.toc ul { list-style: none; margin: 0; padding: 0; display: grid; gap: 2px; }
.toc a {
  display: block; color: var(--t3); font-size: 12.5px; line-height: 1.4;
  padding: 7px 0 7px 16px; border-left: 2px solid var(--line);
  transition: color var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.toc a:hover { color: var(--t2); }
.toc a.active { color: var(--mint); border-left-color: var(--mint); }

/* Article layout with side TOC (desktop only) */
.article-shell { }
@media (min-width: 1080px) {
  .article-shell.has-toc {
    display: grid;
    grid-template-columns: 220px minmax(0, var(--maxw-prose));
    gap: var(--s8);
    justify-content: center;
    max-width: calc(var(--maxw-prose) + 220px + var(--s8) + var(--gutter) * 2);
    margin: 0 auto;
    padding: 0 var(--gutter);
  }
  .article-shell.has-toc .prose-wrap { margin: 0; padding: 0; max-width: none; }
}
.toc { display: none; }
@media (min-width: 1080px) { .toc { display: block; } }

/* ── Mobile hardening: ninguna nota desborda horizontalmente ── */
html, body { overflow-x: clip; }
.article-body, .prose-wrap { overflow-wrap: break-word; }

@media (max-width: 760px) {
  .controls { position: static; }
  .article-meta { gap: var(--s3); }
  /* el cover gigante (21/9 + min-height 280) en mobile era un bloque enorme */
  .cover--big { aspect-ratio: 16 / 9; min-height: 0; }
  /* 2 columnas fijas + números más chicos → no se pasan de la celda */
  .stat-row { grid-template-columns: 1fr 1fr; gap: var(--s4); }
  .stat .n { font-size: clamp(24px, 6.5vw, 36px); overflow-wrap: anywhere; }
  .stat .l { font-size: 12.5px; }
}
