/* =========================================================
   Lex.com.mx — Editorial System v2
   Atlantic + Wired hybrid · NOT minimalism · Editorial density with air
   File: assets/css/editorial.css
   ========================================================= */

/* ---------- CSS variables (LIGHT — default) ---------- */

:root {

  /* Backgrounds */
  --color-bg:           #FFFFFF;   /* blanco puro de papel digital — NO crema, NO marfil */
  --color-bg-elev:      #FAFAFA;   /* fondo elevado / sección alterna */

  /* Foregrounds */
  --color-fg:           #0A0A0A;
  --color-fg-secondary: #525252;
  --color-fg-tertiary:  #737373;

  /* Lines */
  --color-line:         #E5E5E5;
  --color-line-strong:  #D4D4D4;

  /* Accent — Verde Digital */
  --color-accent:       #1F8A5B;
  --color-accent-hover: #176A45;

  /* Kicker box */
  --color-kicker-bg:    #0A0A0A;
  --color-kicker-fg:    #FFFFFF;

  /* Newsletter (siempre oscuro, contrasta con resto del sitio) */
  --color-newsletter-bg:    #0A0A0A;
  --color-newsletter-fg:    #FAFAFA;
  --color-newsletter-muted: #A3A3A3;
  --color-newsletter-line:  #404040;
  --color-newsletter-btn:   #2BAA75;
  --color-newsletter-btn-h: #3EC18C;

  /* Footer (siempre oscuro) */
  --color-footer-bg:        #0A0A0A;
  --color-footer-fg:        #A3A3A3;
  --color-footer-fg-strong: #FAFAFA;
  --color-footer-line:      #262626;
  --color-footer-muted:     #737373;

  /* Typography */
  --font-display: 'Fraunces', Georgia, 'Times New Roman', serif;
  --font-sans:    'Inter Tight', -apple-system, BlinkMacSystemFont, system-ui, sans-serif;
  --font-mono:    'IBM Plex Mono', 'Menlo', 'Consolas', monospace;

  --fs-display-1: clamp(40px, 5vw, 64px);
  --fs-display-2: clamp(32px, 4vw, 48px);
  --fs-display-3: clamp(24px, 3vw, 36px);
  --fs-h2:        28px;
  --fs-h3:        22px;
  --fs-body:      18px;
  --fs-body-sm:   16px;
  --fs-kicker:    12px;
  --fs-meta:      13px;

  --lh-display: 1.1;
  --lh-body:    1.65;
  --lh-meta:    1.3;

  --ls-kicker:  0.12em;
  --ls-meta:    0.08em;
  --ls-display: -0.015em;

  /* Spacing (CRÍTICO para densidad baja con aire) */
  --space-section: clamp(80px, 10vw, 128px);
  --space-block:   clamp(48px, 6vw, 72px);
  --space-element: 24px;
  --space-tight:   12px;

  /* Containers */
  --container-max:  1600px;
  --container-text: 720px;

  /* Edges */
  --edge-x: 32px;
}

/* ---------- CSS variables (DARK) ---------- */

[data-theme="dark"] {
  --color-bg:           #0A0A0A;
  --color-bg-elev:      #1A1A1A;
  --color-fg:           #FAFAFA;
  --color-fg-secondary: #A3A3A3;
  --color-fg-tertiary:  #737373;
  --color-line:         #262626;
  --color-line-strong:  #404040;
  --color-accent:       #2BAA75;
  --color-accent-hover: #3EC18C;
  --color-kicker-bg:    #FFFFFF;
  --color-kicker-fg:    #0A0A0A;
}

/* ---------- Mobile padding ---------- */

@media (max-width: 768px) {
  :root { --edge-x: 20px; }
}

/* ---------- Body ---------- */

html {
  background: var(--color-bg);
  overflow-x: hidden;
}

body {
  background: var(--color-bg);
  color: var(--color-fg);
  font-family: var(--font-sans);
  font-size: var(--fs-body);
  line-height: var(--lh-body);
  transition: background 0.2s ease, color 0.2s ease;
  overflow-x: hidden;
  max-width: 100vw;
}

/* ---------- Selection ---------- */

::selection {
  background: var(--color-accent);
  color: #FFFFFF;
}

/* ---------- Links genéricos ---------- */

a {
  color: var(--color-accent);
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 0.18em;
  transition: color 0.2s ease;
}

a:hover { color: var(--color-accent-hover); }

/* ============================================================
   A. SITE HEADER
   ============================================================ */

.site-header {
  position: sticky;
  top: 0;
  z-index: 100;
  background: var(--color-bg);
  border-bottom: 1px solid var(--color-line);
  height: 80px;
  width: 100%;
}

.site-header__container {
  max-width: var(--container-max);
  margin: 0 auto;
  padding: 0 var(--edge-x);
  height: 100%;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: 40px;
}

.site-header .masthead {
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  line-height: 1;
  flex-shrink: 0;
  min-width: 130px;
}

.site-header .masthead .lex-mark {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 400;
  font-size: 36px;          /* ⚠️ MEDIO — entre 32–40px */
  letter-spacing: -0.02em;
  color: var(--color-fg);
  line-height: 1;
}

/* Logo PNG en masthead — alterna entre light/dark según data-theme */
.masthead__logo {
  display: block;
  height: 56px;
  width: auto;
  max-width: 100%;
  flex-shrink: 0;
  object-fit: contain;
}

.masthead__logo--dark { display: none; }
[data-theme="dark"] .masthead__logo--light { display: none; }
[data-theme="dark"] .masthead__logo--dark  { display: block; }

@media (max-width: 768px) {
  .masthead__logo { height: 44px; }
}

.primary-nav {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 24px;
  flex-wrap: nowrap;
  min-width: 0;
}

.primary-nav a {
  font-family: var(--font-sans);
  font-size: 13px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--color-fg);
  text-decoration: none;
  transition: color 0.2s ease;
  white-space: nowrap;
}

.primary-nav a:hover { color: var(--color-accent); }

/* "+ Más" dropdown — usa <details>/<summary>, CSS-only, sin JS */
.primary-nav__more {
  position: relative;
}

.primary-nav__more > summary {
  list-style: none;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--font-sans);
  font-size: 13px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--color-fg);
  white-space: nowrap;
  padding: 4px 8px;
  border: 1px solid var(--color-line);
  border-radius: 999px;
  transition: border-color 0.2s ease, color 0.2s ease;
}

.primary-nav__more > summary::-webkit-details-marker { display: none; }
.primary-nav__more > summary::marker { content: ""; }

.primary-nav__more > summary:hover {
  color: var(--color-accent);
  border-color: var(--color-accent);
}

.primary-nav__more-plus {
  font-size: 14px;
  font-weight: 400;
  line-height: 1;
  display: inline-block;
  margin-right: 1px;
  color: var(--color-accent);
}

.primary-nav__more-chevron {
  width: 10px;
  height: 7px;
  margin-left: 2px;
  transition: transform 0.2s ease;
}

.primary-nav__more[open] > summary .primary-nav__more-chevron {
  transform: rotate(180deg);
}

.primary-nav__more[open] > summary {
  border-color: var(--color-accent);
  color: var(--color-accent);
}

.primary-nav__more-panel {
  position: absolute;
  top: calc(100% + 12px);
  right: 0;
  min-width: 220px;
  background: var(--color-bg);
  border: 1px solid var(--color-line);
  border-radius: 4px;
  padding: 8px 0;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.08);
  display: flex;
  flex-direction: column;
  z-index: 110;
  animation: lex-fade-in 0.18s ease;
}

[data-theme="dark"] .primary-nav__more-panel {
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.4);
}

@keyframes lex-fade-in {
  from { opacity: 0; transform: translateY(-4px); }
  to   { opacity: 1; transform: translateY(0); }
}

.primary-nav__more-panel a {
  padding: 10px 18px;
  white-space: nowrap;
  text-transform: none;
  letter-spacing: 0;
  font-size: 14px;
  font-weight: 400;
  color: var(--color-fg);
}

.primary-nav__more-panel a:hover {
  color: var(--color-accent);
  background: var(--color-bg-alt, rgba(0, 0, 0, 0.03));
}

[data-theme="dark"] .primary-nav__more-panel a:hover {
  background: rgba(255, 255, 255, 0.04);
}

.header-actions {
  display: flex;
  align-items: center;
  gap: 20px;
  flex-shrink: 0;
}

.link-newsletter {
  font-family: var(--font-sans);
  font-size: 13px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: var(--ls-meta);
  color: var(--color-accent);
  text-decoration: none;
  transition: color 0.2s ease;
}

.link-newsletter:hover { color: var(--color-accent-hover); }

.theme-toggle {
  width: 36px;
  height: 36px;
  border: 1px solid var(--color-line);
  background: transparent;
  border-radius: 50%;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--color-fg);
  padding: 0;
  transition: border-color 0.2s ease, color 0.2s ease;
}

.theme-toggle:hover { border-color: var(--color-accent); color: var(--color-accent); }

.theme-toggle svg { width: 18px; height: 18px; }
.theme-toggle .icon-moon { display: none; }
[data-theme="dark"] .theme-toggle .icon-sun  { display: none; }
[data-theme="dark"] .theme-toggle .icon-moon { display: inline; }

.mobile-menu-trigger { display: none; }

@media (max-width: 1024px) {
  .primary-nav { display: none; }
  .site-header__container { grid-template-columns: auto minmax(0, 1fr) auto; }
  .mobile-menu-trigger {
    display: inline-flex;
    width: 36px; height: 36px;
    border: 1px solid var(--color-line);
    background: transparent;
    border-radius: 50%;
    align-items: center; justify-content: center;
    color: var(--color-fg);
    cursor: pointer;
    padding: 0;
  }
}

@media (max-width: 768px) {
  .site-header { height: 64px; }
  .site-header .masthead .lex-mark { font-size: 30px; }
  .link-newsletter { display: none; }
}

/* Mobile drawer (toggled by JS) */
.mobile-nav {
  display: none;
  border-top: 1px solid var(--color-line);
  background: var(--color-bg);
}
.mobile-nav.is-open { display: block; }
.mobile-nav ul {
  list-style: none; padding: 16px var(--edge-x); margin: 0;
}
.mobile-nav li { padding: 14px 0; border-bottom: 1px solid var(--color-line); }
.mobile-nav li:last-child { border-bottom: none; }
.mobile-nav a {
  font-family: var(--font-sans);
  font-size: 14px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: var(--ls-meta);
  color: var(--color-fg);
  text-decoration: none;
}

/* ============================================================
   B. HERO — HOME (1 historia dominante)
   ============================================================ */

.hero-home {
  max-width: var(--container-max);
  margin: 0 auto;
  padding: var(--space-section) var(--edge-x) var(--space-block);
  border-bottom: 1px solid var(--color-line);
}

.hero-home__grid {
  display: grid;
  grid-template-columns: 5fr 7fr;   /* texto izq 40 / imagen der 60 */
  gap: 64px;
  align-items: center;
}

.hero-home__title {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-display-1);
  line-height: var(--lh-display);
  letter-spacing: var(--ls-display);
  color: var(--color-fg);
  margin: 0 0 24px;
}

.hero-home__title a { color: inherit; text-decoration: none; transition: color 0.2s ease; }
.hero-home__title a:hover { color: var(--color-accent); }

.hero-home__dek {
  font-family: var(--font-sans);
  font-size: 20px;
  line-height: 1.5;
  color: var(--color-fg-secondary);
  margin: 0 0 32px;
}

.hero-home__meta {
  font-family: var(--font-mono);
  font-size: var(--fs-meta);
  text-transform: uppercase;
  letter-spacing: var(--ls-meta);
  color: var(--color-fg-secondary);
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}

.hero-home__figure { margin: 0; }
.hero-home__figure img {
  width: 100%;
  height: auto;
  aspect-ratio: 4 / 3;
  object-fit: cover;
}

.hero-home__caption {
  font-family: var(--font-mono);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: var(--ls-meta);
  color: var(--color-fg-tertiary);
  margin-top: 12px;
}

@media (max-width: 1024px) {
  .hero-home__grid { grid-template-columns: 1fr; gap: 32px; }
  .hero-home__figure { order: -1; }
}

/* ============================================================
   Kicker box (categoría en cajita)
   ============================================================ */

.kicker {
  display: inline-block;
  background: var(--color-kicker-bg);
  color: var(--color-kicker-fg);
  font-family: var(--font-sans);
  font-size: var(--fs-kicker);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: var(--ls-kicker);
  padding: 6px 12px;
  margin-bottom: 24px;
  text-decoration: none;
  line-height: 1.4;
}

a.kicker:hover { background: var(--color-accent); color: #FFFFFF; }

/* WP block style: paragraph "lex-kicker" */
.is-style-lex-kicker {
  display: inline-block;
  background: var(--color-kicker-bg) !important;
  color: var(--color-kicker-fg) !important;
  font-family: var(--font-sans) !important;
  font-size: var(--fs-kicker) !important;
  font-weight: 600 !important;
  text-transform: uppercase;
  letter-spacing: var(--ls-kicker);
  padding: 6px 12px !important;
  margin: 0 0 24px !important;
}

/* WP block style: paragraph "lex-meta" */
.is-style-lex-meta {
  font-family: var(--font-mono) !important;
  font-size: var(--fs-meta) !important;
  text-transform: uppercase;
  letter-spacing: var(--ls-meta);
  color: var(--color-fg-secondary) !important;
  line-height: var(--lh-meta);
}

/* WP block style: paragraph "lex-dek" */
.is-style-lex-dek {
  font-family: var(--font-sans) !important;
  font-size: 20px !important;
  line-height: 1.5 !important;
  color: var(--color-fg-secondary) !important;
}

/* ============================================================
   C. SECONDARY STORIES (2 historias bajo el hero)
   ============================================================ */

.secondary-stories {
  max-width: var(--container-max);
  margin: 0 auto;
  padding: var(--space-block) var(--edge-x);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  border-bottom: 1px solid var(--color-line);
  position: relative;
}

.secondary-stories::before {
  content: "";
  position: absolute;
  top: var(--space-block);
  bottom: var(--space-block);
  left: 50%;
  width: 1px;
  background: var(--color-line);
}

.secondary-stories .story { display: flex; flex-direction: column; }

.secondary-stories .story-title {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 28px;
  line-height: 1.2;
  color: var(--color-fg);
  margin: 16px 0 16px;
  letter-spacing: -0.01em;
}

.secondary-stories .story-title a { color: inherit; text-decoration: none; transition: color 0.2s ease; }
.secondary-stories .story-title a:hover { color: var(--color-accent); }

.secondary-stories .story-meta {
  font-family: var(--font-mono);
  font-size: var(--fs-meta);
  text-transform: uppercase;
  letter-spacing: var(--ls-meta);
  color: var(--color-fg-secondary);
  display: flex;
  gap: 8px;
  margin-top: auto;
  padding-top: 16px;
}

@media (max-width: 768px) {
  .secondary-stories { grid-template-columns: 1fr; gap: 48px; }
  .secondary-stories::before { display: none; }
}

/* ============================================================
   D. CATEGORY SECTION (3-column modular grid)
   ============================================================ */

.category-section {
  padding: var(--space-section) var(--edge-x);
  border-bottom: 1px solid var(--color-line);
  background: var(--color-bg);
}

.category-section.is-style-lex-section-alt,
.is-style-lex-section-alt {
  background: var(--color-bg-elev);
}

.category-section__header {
  max-width: var(--container-max);
  margin: 0 auto var(--space-block);
  text-align: center;
}

.category-section__title {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-display-2);
  line-height: 1.15;
  color: var(--color-fg);
  margin: 0 0 24px;
  letter-spacing: var(--ls-display);
}

.category-section__rule {
  width: 60px;
  height: 2px;
  background: var(--color-accent);
  margin: 0 auto;
  border: none;
}

.category-section__grid {
  max-width: var(--container-max);
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 48px;
}

.card { display: flex; flex-direction: column; }
.card-link { display: block; text-decoration: none; color: inherit; }

.card-image {
  margin-bottom: 20px;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  background: var(--color-bg-elev);
}
.card-image img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform 0.4s ease;
}
.card-link:hover .card-image img { transform: scale(1.03); }

.card-title {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 22px;
  line-height: 1.25;
  color: var(--color-fg);
  margin: 12px 0;
  letter-spacing: -0.005em;
}

.card-link:hover .card-title { color: var(--color-accent); }

.card-meta {
  font-family: var(--font-mono);
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: var(--ls-meta);
  color: var(--color-fg-secondary);
}

@media (max-width: 1024px) { .category-section__grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 640px)  { .category-section__grid { grid-template-columns: 1fr; gap: 40px; } }

/* ============================================================
   E. NEWSLETTER CTA
   ============================================================ */

.newsletter-cta {
  background: var(--color-newsletter-bg);
  color: var(--color-newsletter-fg);
  padding: 96px var(--edge-x);
}

.newsletter-cta__container {
  max-width: 720px;
  margin: 0 auto;
  text-align: center;
}

.newsletter-cta__title {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: clamp(32px, 4vw, 48px);
  line-height: 1.15;
  color: #FFFFFF;
  margin: 0 0 24px;
  letter-spacing: var(--ls-display);
}

.newsletter-cta__dek {
  font-family: var(--font-sans);
  font-size: 18px;
  line-height: 1.6;
  color: var(--color-newsletter-muted);
  margin: 0 0 40px;
}

.newsletter-cta__form {
  display: flex;
  gap: 8px;
  margin-bottom: 24px;
}

.newsletter-cta__form input[type="email"] {
  flex: 1;
  background: transparent;
  border: 1px solid var(--color-newsletter-line);
  color: #FFFFFF;
  font-family: var(--font-sans);
  font-size: 16px;
  padding: 16px 20px;
  outline: none;
  transition: border-color 0.2s ease;
}

.newsletter-cta__form input[type="email"]::placeholder {
  color: var(--color-newsletter-muted);
}

.newsletter-cta__form input[type="email"]:focus {
  border-color: var(--color-newsletter-btn);
}

.newsletter-cta__form button {
  background: var(--color-newsletter-btn);
  color: #FFFFFF;
  font-family: var(--font-sans);
  font-size: 14px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: var(--ls-meta);
  padding: 16px 28px;
  border: none;
  cursor: pointer;
  transition: background 0.2s ease;
  white-space: nowrap;
}

.newsletter-cta__form button:hover { background: var(--color-newsletter-btn-h); }

.newsletter-cta__fineprint {
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--color-footer-muted);
  text-transform: uppercase;
  letter-spacing: var(--ls-meta);
  margin: 0;
}

.newsletter-cta__fineprint a {
  color: var(--color-newsletter-btn);
  text-decoration: underline;
}

@media (max-width: 640px) {
  .newsletter-cta { padding: 72px var(--edge-x); }
  .newsletter-cta__form { flex-direction: column; }
}

/* ============================================================
   F. SITE FOOTER
   ============================================================ */

.site-footer {
  background: var(--color-footer-bg);
  color: var(--color-footer-fg);
  padding: 96px var(--edge-x) 48px;
}

.site-footer__container {
  max-width: var(--container-max);
  margin: 0 auto;
}

.site-footer__brand {
  text-align: center;
  margin-bottom: 64px;
}

.site-footer__mark {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 32px;
  color: #FFFFFF;
  text-decoration: none;
  display: inline-block;
  margin-bottom: 24px;
  line-height: 1;
}

.site-footer__logo {
  display: inline-block;
  height: 56px;
  width: auto;
  margin-bottom: 24px;
}

.site-footer__manifest {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 400;
  font-size: 17px;
  line-height: 1.55;
  color: var(--color-footer-fg);
  max-width: 720px;
  margin: 0 auto;
}

.site-footer__rule {
  height: 1px;
  background: var(--color-footer-line);
  margin: 64px 0;
  border: none;
}

.site-footer__cols {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 64px;
  margin-bottom: 64px;
}

.site-footer__col h3 {
  font-family: var(--font-sans);
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: var(--ls-kicker);
  color: var(--color-footer-fg-strong);
  margin: 0 0 24px;
  line-height: 1.3;
}

.site-footer__col ul { list-style: none; padding: 0; margin: 0; }
.site-footer__col li { margin-bottom: 12px; }

.site-footer__col a {
  font-family: var(--font-sans);
  font-size: 14px;
  color: var(--color-footer-fg);
  text-decoration: none;
  transition: color 0.2s ease;
}

.site-footer__col a:hover { color: var(--color-footer-fg-strong); }

.site-footer__bottom {
  display: flex;
  justify-content: center;
  font-family: var(--font-mono);
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: var(--ls-meta);
  color: var(--color-footer-muted);
}

@media (max-width: 768px) {
  .site-footer__cols { grid-template-columns: 1fr; gap: 48px; }
  .site-footer__bottom { flex-direction: column; gap: 12px; text-align: center; }
}

/* ============================================================
   G. SINGLE ARTICLE (article-hero + prose)
   ============================================================ */

.single-article { background: var(--color-bg); }

.article-hero {
  max-width: var(--container-max);
  margin: 0 auto;
  padding: var(--space-section) var(--edge-x) var(--space-block);
  border-bottom: 1px solid var(--color-line);
}

.article-hero__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: center;
}

.article-hero__title {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: clamp(36px, 4.5vw, 56px);
  line-height: 1.1;
  letter-spacing: var(--ls-display);
  margin: 24px 0;
  color: var(--color-fg);
}

.article-hero__dek {
  font-family: var(--font-sans);
  font-size: 22px;
  line-height: 1.5;
  color: var(--color-fg-secondary);
  margin: 0 0 32px;
}

.article-hero__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  align-items: center;
}

.byline-box {
  background: var(--color-kicker-bg);
  color: var(--color-kicker-fg);
  font-family: var(--font-sans);
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: var(--ls-kicker);
  padding: 6px 12px;
  line-height: 1.4;
}

.meta-item {
  font-family: var(--font-mono);
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: var(--ls-meta);
  color: var(--color-fg-secondary);
}

.article-hero__figure { margin: 0; }
.article-hero__figure img {
  width: 100%;
  aspect-ratio: 4 / 5;
  object-fit: cover;
}

.article-hero__caption {
  font-family: var(--font-mono);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: var(--ls-meta);
  color: var(--color-fg-tertiary);
  margin-top: 16px;
  text-align: center;
}

.article-prose {
  max-width: 720px;
  margin: 0 auto;
  padding: var(--space-section) var(--edge-x);
  font-family: var(--font-sans);
  font-size: 19px;
  line-height: 1.7;
  color: var(--color-fg);
}

.article-prose p { margin: 0 0 1.5em; }

.article-prose h2 {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 32px;
  line-height: 1.2;
  margin: 2.5em 0 0.75em;
  letter-spacing: -0.01em;
  color: var(--color-fg);
}

.article-prose h3 {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 24px;
  line-height: 1.25;
  margin: 2em 0 0.5em;
  color: var(--color-fg);
}

.article-prose h4 {
  font-family: var(--font-sans);
  font-size: 14px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: var(--ls-kicker);
  color: var(--color-fg-secondary);
  margin: 2em 0 0.5em;
}

.article-prose a {
  color: var(--color-accent);
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 0.2em;
}

.article-prose a:hover { color: var(--color-accent-hover); }

.article-prose .dropcap,
.article-prose .lead-paragraph::first-letter {
  font-family: var(--font-display);
  font-size: 72px;
  line-height: 0.85;
  color: var(--color-accent);
}

.article-prose .dropcap {
  float: left;
  margin: 8px 12px 0 0;
}

.article-prose blockquote {
  border-left: 3px solid var(--color-accent);
  padding-left: 32px;
  margin: 2em 0;
  font-family: var(--font-display);
  font-style: italic;
  font-size: 28px;
  line-height: 1.35;
  color: var(--color-fg);
}

.article-prose blockquote p { margin: 0 0 0.5em; }
.article-prose blockquote cite {
  display: block;
  font-family: var(--font-mono);
  font-style: normal;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: var(--ls-meta);
  color: var(--color-fg-secondary);
  margin-top: 16px;
}

.article-prose hr {
  border: none;
  height: 1px;
  background: var(--color-line);
  margin: 3em 0;
}

.article-prose ul, .article-prose ol {
  padding-left: 1.5em;
  margin: 0 0 1.5em;
}

.article-prose li { margin-bottom: 0.5em; }

.article-prose figure { margin: 2em 0; }
.article-prose figcaption {
  font-family: var(--font-mono);
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: var(--ls-meta);
  color: var(--color-fg-tertiary);
  margin-top: 12px;
  text-align: center;
}

.article-prose code {
  font-family: var(--font-mono);
  font-size: 0.92em;
  background: var(--color-bg-elev);
  padding: 2px 6px;
  border-radius: 2px;
}

.article-prose pre {
  background: var(--color-bg-elev);
  padding: 24px;
  overflow-x: auto;
  font-family: var(--font-mono);
  font-size: 14px;
  line-height: 1.6;
  margin: 2em 0;
  border-left: 3px solid var(--color-accent);
}

.article-prose pre code { background: none; padding: 0; }

/* Article footer (tags + share) */
.article-footer {
  max-width: 720px;
  margin: 0 auto;
  padding: 0 var(--edge-x) var(--space-section);
  border-top: 1px solid var(--color-line);
  padding-top: 48px;
}

.article-tags {
  display: flex; flex-wrap: wrap; gap: 8px;
  margin-bottom: 24px;
}

.article-tags a {
  font-family: var(--font-mono);
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: var(--ls-meta);
  color: var(--color-fg-secondary);
  text-decoration: none;
  border: 1px solid var(--color-line);
  padding: 6px 12px;
}

.article-tags a:hover { color: var(--color-accent); border-color: var(--color-accent); }

@media (max-width: 1024px) {
  .article-hero__grid { grid-template-columns: 1fr; }
  .article-hero__figure { order: -1; }
}

@media (max-width: 640px) {
  .article-prose { font-size: 18px; line-height: 1.65; }
  .article-prose h2 { font-size: 26px; }
  .article-prose blockquote { font-size: 22px; padding-left: 20px; }
}

/* ============================================================
   H. ARCHIVE / CATEGORY PAGE
   ============================================================ */

.archive-header {
  max-width: var(--container-max);
  margin: 0 auto;
  padding: var(--space-section) var(--edge-x) var(--space-block);
  text-align: center;
  border-bottom: 1px solid var(--color-line);
}

.archive-header__title {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: clamp(48px, 7vw, 80px);
  line-height: 1.05;
  letter-spacing: var(--ls-display);
  color: var(--color-fg);
  margin: 0 0 24px;
}

.archive-header__dek {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 18px;
  line-height: 1.5;
  color: var(--color-fg-secondary);
  max-width: 640px;
  margin: 0 auto 32px;
}

.archive-header__rule {
  width: 60px;
  height: 2px;
  background: var(--color-accent);
  margin: 0 auto;
  border: none;
}

.archive-grid {
  max-width: var(--container-max);
  margin: 0 auto;
  padding: var(--space-block) var(--edge-x);
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: 64px;
  border-bottom: 1px solid var(--color-line);
}

.archive-grid__featured { /* artículo destacado */ }
.archive-grid__sidebar  { display: flex; flex-direction: column; gap: 32px; }

.archive-list {
  max-width: var(--container-max);
  margin: 0 auto;
  padding: var(--space-section) var(--edge-x);
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 48px 64px;
}

@media (max-width: 1024px) {
  .archive-grid { grid-template-columns: 1fr; }
  .archive-list { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 640px) {
  .archive-list { grid-template-columns: 1fr; gap: 48px; }
}

/* ============================================================
   I. PAGINATION
   ============================================================ */

.pagination {
  max-width: var(--container-max);
  margin: 0 auto;
  padding: var(--space-block) var(--edge-x);
  display: flex;
  justify-content: center;
  gap: 8px;
  border-bottom: 1px solid var(--color-line);
}

.pagination a, .pagination span {
  font-family: var(--font-mono);
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: var(--ls-meta);
  padding: 12px 18px;
  border: 1px solid var(--color-line);
  text-decoration: none;
  color: var(--color-fg);
  transition: all 0.2s ease;
}

.pagination a:hover { border-color: var(--color-accent); color: var(--color-accent); }
.pagination .current { background: var(--color-fg); color: var(--color-bg); border-color: var(--color-fg); }

/* ============================================================
   J. 404 / SEARCH
   ============================================================ */

.error-404, .search-results-header {
  max-width: var(--container-text);
  margin: 0 auto;
  padding: var(--space-section) var(--edge-x);
  text-align: center;
}

.error-404__code {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: clamp(80px, 12vw, 160px);
  line-height: 1;
  color: var(--color-accent);
  margin: 0 0 16px;
  letter-spacing: var(--ls-display);
}

.error-404__title, .search-results-header__title {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: clamp(28px, 4vw, 40px);
  line-height: 1.15;
  color: var(--color-fg);
  margin: 0 0 16px;
  letter-spacing: var(--ls-display);
}

.error-404__dek, .search-results-header__dek {
  font-family: var(--font-sans);
  font-size: 18px;
  line-height: 1.6;
  color: var(--color-fg-secondary);
  margin: 0 0 32px;
}

.search-form {
  max-width: 480px;
  margin: 0 auto;
  display: flex;
  border-bottom: 1px solid var(--color-line-strong);
}

.search-form input[type="search"] {
  flex: 1;
  background: transparent;
  border: none;
  outline: none;
  font-family: var(--font-sans);
  font-size: 18px;
  padding: 14px 0;
  color: var(--color-fg);
}

.search-form button {
  background: transparent;
  border: none;
  color: var(--color-fg);
  cursor: pointer;
  padding: 14px 12px;
  font-family: var(--font-sans);
  font-size: 13px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: var(--ls-meta);
}

.search-form button:hover { color: var(--color-accent); }

/* ============================================================
   K. WordPress block alignment helpers (FSE compat)
   ============================================================ */

.wp-block-group.alignfull { width: 100%; max-width: none; }
.wp-block-group.alignwide { max-width: var(--container-max); margin-inline: auto; }

/* Limit prose width inside posts when WP renders content blocks */
.wp-block-post-content > * { max-width: 720px; margin-left: auto; margin-right: auto; }
.wp-block-post-content > .alignwide { max-width: var(--container-max); }
.wp-block-post-content > .alignfull { max-width: none; margin-left: 0; margin-right: 0; }

/* Image hover behavior consistency */
.wp-block-post-featured-image img { display: block; }

/* ============================================================
   L. Visually hidden (a11y)
   ============================================================ */

.screen-reader-text {
  position: absolute !important;
  clip: rect(1px, 1px, 1px, 1px);
  width: 1px; height: 1px; overflow: hidden;
}

.skip-link {
  position: absolute;
  top: -40px; left: 0;
  background: var(--color-fg);
  color: var(--color-bg);
  padding: 10px 16px;
  font-family: var(--font-sans);
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: var(--ls-meta);
  text-decoration: none;
  z-index: 200;
}
.skip-link:focus { top: 0; }

/* ============================================================
   M. Image rendering inside core blocks
   ============================================================ */

.wp-block-image img { width: 100%; height: auto; display: block; }
.wp-block-image figcaption {
  font-family: var(--font-mono);
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: var(--ls-meta);
  color: var(--color-fg-tertiary);
  text-align: center;
  margin-top: 12px;
}

/* ============================================================
   N. Reduce motion
   ============================================================ */

@media (prefers-reduced-motion: reduce) {
  * { transition: none !important; animation: none !important; }
  .card-link:hover .card-image img { transform: none; }
}
