/* ============================================================
   INTERNAMENTE HABLANDO — Design System: "The Intellectual Curator"
   Tipografía: Newsreader (serif) + Inter (sans-serif)
   Fuente de verdad: guidelines/DESIGN.md
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Newsreader:ital,wght@0,400;0,600;0,700;1,400;1,600&family=Inter:wght@400;500;600&display=swap');

/* ── Tokens del design system ── */
:root {
  /* Colores principales */
  /* Acento cyan */
  --color-accent: #00e8c4;

  --color-primary:           #1b4a42;
  --color-primary-container: #1B2B4B;
  --color-secondary:         #c43b73;
  --color-olive:             #807d6b;

  /* Superficies (tonal layering, sin líneas) */
  --color-surface:         #FAF9F6;
  --color-surface-low:     #F4F3F1;
  --color-surface-high:    #E3E2E0;
  --color-surface-lowest:  #FFFFFF;

  /* Texto */
  --color-on-surface:  #1A1C1A;
  --color-on-primary:  #FAF9F6;
  --color-metadata:    #6B7280;

  /* Borde fantasma (solo accesibilidad) */
  --color-outline-variant: rgba(26, 28, 26, 0.15);

  /* Gradiente signature */
  --gradient-signature: linear-gradient(135deg, #1b4a42, #1B2B4B);

  /* ── Aliases de compatibilidad (para inline styles en HTML) ── */
  --color-bg:          var(--color-surface);
  --color-bg-alt:      var(--color-surface-low);
  --color-text:        var(--color-on-surface);
  --color-text-muted:  var(--color-metadata);
  --color-text-light:  #9A9890;
  --color-nav:         var(--color-primary);
  --color-nav-text:    var(--color-on-primary);
  --color-border:      var(--color-outline-variant);
  --color-border-dark: rgba(26, 28, 26, 0.25);
  --color-verde:       var(--color-primary);
  --color-verde-claro: rgba(27, 74, 66, 0.08);
  --color-verde-dark:  var(--color-primary);
  --color-mostaza:     var(--color-olive);
  --color-mostaza-claro: rgba(128, 125, 107, 0.1);
  --color-mostaza-dark:  #5a5845;
  --color-rosa:        var(--color-secondary);
  --color-rosa-claro:  rgba(196, 59, 115, 0.08);
  --color-rosa-dark:   #922D55;

  /* Tipografía */
  --font-serif:  'Newsreader', Georgia, serif;
  --font-sans:   'Inter', system-ui, sans-serif;
  --font-titulo: var(--font-serif);   /* alias legacy */
  --font-cuerpo: var(--font-sans);    /* alias legacy */

  /* Escala tipográfica */
  --text-xs:   0.75rem;    /* 12px */
  --text-sm:   0.875rem;   /* 14px */
  --text-base: 1rem;       /* 16px */
  --text-md:   1.125rem;   /* 18px */
  --text-lg:   1.25rem;    /* 20px */
  --text-xl:   1.5rem;     /* 24px */
  --text-2xl:  2rem;       /* 32px */
  --text-3xl:  2.5rem;     /* 40px */
  --text-4xl:  3.25rem;    /* 52px */

  /* Espaciado */
  --space-xs:  0.5rem;
  --space-sm:  0.75rem;
  --space-md:  1rem;
  --space-lg:  1.5rem;
  --space-xl:  2rem;
  --space-2xl: 3rem;
  --space-3xl: 4rem;
  --space-4xl: 6rem;

  /* Layout */
  --max-width:       1160px;
  --max-width-texto: 720px;

  /* Border-radius — máximo sm según design system */
  --radius-sm:   0.125rem;
  --radius-md:   0.125rem;  /* alias → sm */
  --radius-lg:   0.125rem;  /* alias → sm */
  --radius-pill: 999px;     /* solo para inputs de formulario */

  /* Sombra ambiental */
  --shadow-ambient: 0px 20px 40px rgba(26, 28, 26, 0.04);

  /* Transiciones */
  --transition: 0.2s ease;
}

/* ── Reset base ── */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  font-size: 16px;
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
  overflow-x: hidden;
}

body {
  font-family: var(--font-sans);
  font-size: var(--text-base);
  font-weight: 400;
  line-height: 1.6;
  color: var(--color-on-surface);
  background-color: var(--color-surface);
  -webkit-font-smoothing: antialiased;
}

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

a {
  color: inherit;
  text-decoration: none;
}

ul, ol { list-style: none; }

button {
  font-family: inherit;
  cursor: pointer;
  border: none;
  background: none;
}

/* ── Tipografía base ── */
h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-serif);
  font-weight: 400;
  line-height: 1.2;
  letter-spacing: -0.02em;
  color: var(--color-on-surface);
}

h1 { font-size: clamp(var(--text-2xl), 5vw, var(--text-4xl)); }
h2 { font-size: clamp(var(--text-xl), 3vw, var(--text-3xl)); }
h3 { font-size: var(--text-xl); }
h4 { font-size: var(--text-lg); }
h5 { font-size: var(--text-md); }
h6 { font-size: var(--text-base); }

p {
  font-size: var(--text-base);
  line-height: 1.75;
  color: var(--color-on-surface);
}

p + p { margin-top: var(--space-md); }

strong { font-weight: 600; }
em     { font-style: italic; }

/* ── Pull Quote — "The Pull Quote" del design system ── */
blockquote {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 400;
  font-size: clamp(var(--text-lg), 2vw, var(--text-xl));
  line-height: 1.55;
  color: var(--color-on-surface);
  border-left: 4px solid var(--color-secondary);
  background: linear-gradient(135deg, rgba(27, 74, 66, 0.05), rgba(27, 43, 75, 0.05));
  padding: var(--space-xl) var(--space-2xl);
  margin: var(--space-xl) -2rem;
}

/* ── Layout ── */
.container {
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 0 var(--space-xl);
}

.container--texto {
  max-width: var(--max-width-texto);
  margin: 0 auto;
  padding: 0 var(--space-xl);
}

/* ── Navegación — glassmorphism ── */
.nav {
  background: rgba(250, 249, 246, 0.82);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  padding: var(--space-md) 0;
  position: sticky;
  top: 0;
  z-index: 100;
  transition: box-shadow 0.3s ease, background 0.3s ease;
}

/* Estado scrolled: sombra ambiental sutil */
.nav.scrolled {
  background: rgba(250, 249, 246, 0.95);
  box-shadow: 0px 4px 24px rgba(26, 28, 26, 0.06);
}

.nav__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 0 var(--space-xl);
  position: relative;
}

.nav__logo {
  display: inline-flex;
  align-items: center;
  transition: opacity var(--transition);
}

.nav__logo img {
  height: 96px;
  max-height: 40px;
  width: auto;
  display: block;
}

.nav__logo:hover { opacity: 0.6; }

.nav__links {
  display: flex;
  gap: var(--space-xl);
  list-style: none;
}

.nav__links a {
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--color-on-surface);
  opacity: 0.6;
  transition: opacity var(--transition);
  letter-spacing: 0.01em;
}

.nav__links a:hover,
.nav__links a.activo {
  opacity: 1;
  color: var(--color-primary);
}

.nav__cta {
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--color-on-primary);
  background: var(--gradient-signature);
  padding: var(--space-xs) var(--space-md);
  border-radius: var(--radius-sm);
  transition: opacity var(--transition);
}

.nav__cta:hover { opacity: 0.85; }

/* Nav toggle móvil */
.nav__toggle {
  display: none;
  flex-direction: column;
  gap: 5px;
  width: 28px;
  background: none;
  border: none;
  cursor: pointer;
  padding: var(--space-xs);
}

.nav__toggle span {
  display: block;
  height: 1.5px;
  background: var(--color-on-surface);
  transition: transform var(--transition), opacity var(--transition);
}

/* ── Hero estático (páginas interiores) ── */
.hero {
  padding: var(--space-4xl) 0 var(--space-3xl);
  background-color: var(--color-surface);
}

.hero__inner {
  max-width: var(--max-width-texto);
  margin: 0 auto;
  padding: 0 var(--space-xl);
}

.hero__etiqueta {
  display: inline-block;
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--color-secondary);
  background-color: rgba(196, 59, 115, 0.08);
  padding: 4px 12px;
  border-radius: var(--radius-sm);
  margin-bottom: var(--space-lg);
}

.hero__titulo {
  font-family: var(--font-serif);
  font-size: clamp(var(--text-2xl), 5vw, var(--text-4xl));
  font-weight: 400;
  line-height: 1.1;
  letter-spacing: -0.02em;
  color: var(--color-on-surface);
  margin-bottom: var(--space-lg);
}

.hero__titulo em { color: var(--color-secondary); }

.hero__subtitulo {
  font-family: var(--font-sans);
  font-size: var(--text-md);
  line-height: 1.75;
  color: var(--color-metadata);
  margin-bottom: var(--space-2xl);
  max-width: 560px;
}


/* ── Botones ── */
.btn {
  display: inline-flex;
  align-items: center;
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  font-weight: 500;
  padding: 0.7rem 1.5rem;
  border-radius: var(--radius-sm);
  border: none;
  cursor: pointer;
  transition: opacity var(--transition), transform var(--transition);
  text-decoration: none;
  letter-spacing: 0.01em;
}

/* Primary — signature gradient */
.btn--primario {
  background: var(--gradient-signature);
  color: var(--color-on-primary);
}

.btn--primario:hover {
  opacity: 0.88;
  transform: translateY(-1px);
}

/* Secondary — magenta, solo newsletter */
.btn--secundario {
  background-color: transparent;
  color: var(--color-primary);
  border: 1.5px solid var(--color-outline-variant);
  transition: background-color var(--transition), transform var(--transition);
}

.btn--secundario:hover {
  background-color: var(--color-surface-low);
  transform: translateY(-1px);
}

/* Mostaza → olive en nuevo sistema */
.btn--mostaza {
  background-color: var(--color-olive);
  color: var(--color-surface-lowest);
}

.btn--mostaza:hover {
  opacity: 0.85;
  transform: translateY(-1px);
}


/* ── Secciones generales — tonal layering, sin líneas ── */
.seccion {
  padding: var(--space-3xl) 0;
  background-color: var(--color-surface);
}

.seccion--alt {
  background-color: var(--color-surface-low);
}

.seccion--verde {
  background-color: rgba(27, 74, 66, 0.06);
}


/* ── Cards de artículos ── */
/* No border, no dividers — spacing as separator */
.posts-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: var(--space-3xl);
}

.post-card {
  background: var(--color-surface-lowest);
  border-radius: var(--radius-sm);
  overflow: hidden;
  box-shadow: var(--shadow-ambient);
  transition: box-shadow var(--transition), transform var(--transition);
}

.post-card:hover {
  transform: translateY(-2px);
  box-shadow: 0px 24px 48px rgba(26, 28, 26, 0.08);
}

.post-card__img {
  width: 100%;
  aspect-ratio: 16/9;
  object-fit: cover;
  display: block;
}

.post-card__img-placeholder {
  width: 100%;
  aspect-ratio: 16/9;
  background: linear-gradient(135deg, var(--color-surface-low) 0%, var(--color-surface-high) 100%);
}

.post-card__body {
  padding: var(--space-lg) var(--space-lg) var(--space-xl);
}

.post-card__categoria {
  display: inline-block;
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-secondary);
  background-color: rgba(196, 59, 115, 0.08);
  padding: 3px 10px;
  border-radius: var(--radius-sm);
  margin-bottom: var(--space-sm);
}

.post-card__titulo {
  font-family: var(--font-serif);
  font-size: var(--text-lg);
  font-weight: 400;
  line-height: 1.3;
  letter-spacing: -0.01em;
  color: var(--color-on-surface);
  margin-bottom: var(--space-sm);
  transition: color var(--transition);
}

.post-card:hover .post-card__titulo {
  color: var(--color-primary);
}

.post-card__extracto {
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--color-metadata);
  line-height: 1.65;
  margin-bottom: var(--space-md);
}

.post-card__meta {
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  color: var(--color-metadata);
  letter-spacing: 0.01em;
}

/* ── Filtros de categoría ── */
.categorias {
  display: flex;
  gap: var(--space-sm);
  flex-wrap: wrap;
}

.categoria-tag {
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  font-weight: 500;
  padding: 6px 16px;
  border-radius: var(--radius-sm);
  border: 1.5px solid var(--color-outline-variant);
  color: var(--color-metadata);
  background: transparent;
  cursor: pointer;
  transition: background-color var(--transition), color var(--transition), border-color var(--transition);
}

.categoria-tag:hover,
.categoria-tag.activo {
  border-color: var(--color-primary);
  color: var(--color-primary);
  background-color: rgba(27, 74, 66, 0.06);
}

/* ── Página de artículo ── */
.articulo {
  padding: var(--space-3xl) 0 var(--space-4xl);
  background-color: var(--color-surface);
}

.articulo__header {
  max-width: var(--max-width-texto);
  margin: 0 auto var(--space-3xl);
  padding: 0 var(--space-xl);
}

.articulo__imagen {
  max-width: var(--max-width);
  margin: 0 auto var(--space-3xl);
  padding: 0 var(--space-xl);
}

.articulo__imagen img {
  width: 100%;
  height: auto;
  display: block;
  border-radius: 0.25rem;
  aspect-ratio: 16 / 9;
  object-fit: cover;
}

.articulo__titulo {
  font-family: var(--font-serif);
  font-size: clamp(var(--text-2xl), 4vw, var(--text-4xl));
  font-weight: 400;
  line-height: 1.15;
  letter-spacing: -0.02em;
  margin: var(--space-md) 0 var(--space-lg);
  color: var(--color-on-surface);
}

.articulo__meta {
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--color-metadata);
  display: flex;
  gap: var(--space-md);
  align-items: center;
}

.articulo__cuerpo {
  max-width: var(--max-width-texto);
  margin: 0 auto;
  padding: 0 var(--space-xl);
  font-family: var(--font-sans);
  font-size: var(--text-md);
  line-height: 1.8;
  counter-reset: seccion;
}

.articulo__cuerpo p {
  font-size: var(--text-md);
  line-height: 1.8;
  margin-bottom: var(--space-lg);
}

.articulo__cuerpo h2 {
  font-family: var(--font-serif);
  font-size: clamp(var(--text-xl), 3vw, var(--text-2xl));
  font-weight: 400;
  letter-spacing: -0.02em;
  margin: var(--space-3xl) 0 var(--space-lg);
  counter-increment: seccion;
}

.articulo__cuerpo h2::before {
  content: counter(seccion, decimal-leading-zero);
  display: block;
  font-family: var(--font-sans);
  font-size: 0.65rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-secondary);
  margin-bottom: var(--space-xs);
}

.articulo__cuerpo h3 {
  font-family: var(--font-serif);
  font-size: var(--text-xl);
  font-weight: 400;
  letter-spacing: -0.01em;
  margin: var(--space-2xl) 0 var(--space-sm);
}

/* ── Bloque acento — punto de énfasis con borde magenta ── */
.bloque-acento {
  border-left: 3px solid var(--color-secondary);
  background: rgba(196, 59, 115, 0.05);
  padding: var(--space-lg) var(--space-xl);
  margin: var(--space-xl) 0;
}

.bloque-acento strong {
  display: block;
  font-family: var(--font-sans);
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-secondary);
  margin-bottom: var(--space-xs);
}

/* ── Newsletter CTA ── */
.form-email {
  display: flex;
  gap: var(--space-sm);
  max-width: 420px;
  margin: 0 auto;
}

.form-email input[type="email"] {
  flex: 1;
  padding: 0.7rem 1.2rem;
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  border: 1.5px solid rgba(250, 249, 246, 0.20);
  background: rgba(250, 249, 246, 0.08);
  color: var(--color-on-primary);
  border-radius: var(--radius-sm);
  outline: none;
  transition: border-color var(--transition);
}

.form-email input[type="email"]::placeholder {
  color: rgba(250, 249, 246, 0.35);
}

.form-email input[type="email"]:focus {
  border-color: var(--color-secondary);
}

.form-email--claro input[type="email"] {
  border-color: var(--color-outline-variant);
  background: var(--color-surface-lowest);
  color: var(--color-on-surface);
}

.form-email--claro input[type="email"]::placeholder {
  color: var(--color-metadata);
}

.form-email--claro input[type="email"]:focus {
  border-color: var(--color-primary);
}

.newsletter-nota {
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  color: rgba(250, 249, 246, 0.40);
  margin-top: var(--space-sm);
}


/* ── Sobre mí ── */
.sobre-mi__foto-placeholder {
  width: 100%;
  max-width: 360px;
  aspect-ratio: 3/4;
  background-color: var(--color-surface-low);
  border-radius: var(--radius-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: var(--space-xl);
}

/* ── Colaboraciones ── */
.colaboracion-item {
  padding: var(--space-2xl) 0;
  background-color: var(--color-surface-low);
}

.colaboracion-item + .colaboracion-item {
  background-color: var(--color-surface);
}


.colaboracion-item__tipo {
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--color-secondary);
  padding-top: 6px;
}

.colaboracion-item__titulo {
  font-family: var(--font-serif);
  font-size: var(--text-xl);
  font-weight: 400;
  letter-spacing: -0.01em;
  margin-bottom: var(--space-md);
}

.colaboracion-item__temas {
  list-style: none;
  margin-top: var(--space-md);
}

.colaboracion-item__temas li {
  position: relative;
  padding-left: var(--space-lg);
  font-family: var(--font-sans);
  font-size: var(--text-base);
  color: var(--color-metadata);
  margin-bottom: var(--space-xs);
}

.colaboracion-item__temas li::before {
  content: '—';
  position: absolute;
  left: 0;
  color: var(--color-outline-variant);
}

/* ── Footer ── */
.footer {
  background: var(--gradient-signature);
  padding: var(--space-3xl) 0 var(--space-xl);
  color: var(--color-on-primary);
}

.footer__inner {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: var(--space-2xl);
  align-items: start;
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 0 var(--space-xl);
}

.footer__logo {
  font-family: var(--font-serif);
  font-size: var(--text-lg);
  font-weight: 400;
  letter-spacing: -0.01em;
  color: var(--color-on-primary);
  margin-bottom: var(--space-sm);
  display: block;
  transition: opacity var(--transition);
}

.footer__logo:hover { opacity: 0.70; }

/* ── Estado vacío ── */
.estado-vacio {
  padding: var(--space-4xl) 0;
  text-align: center;
}

.estado-vacio__titulo {
  font-family: var(--font-serif);
  font-size: var(--text-xl);
  font-weight: 400;
  margin-bottom: var(--space-md);
}

.estado-vacio__texto {
  font-family: var(--font-sans);
  font-size: var(--text-base);
  color: var(--color-metadata);
  max-width: 42ch;
  margin: 0 auto var(--space-xl);
}

/* ── Utilidades ── */
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  border: 0;
}

.text-centro { text-align: center; }

/* ── Responsive ── */
@media (max-width: 768px) {
  h1 { font-size: var(--text-2xl); }
  h2 { font-size: var(--text-xl); }
  h3 { font-size: var(--text-lg); }

  .container,
  .container--texto { padding: 0 var(--space-md); }

  .hero { padding: var(--space-2xl) 0; }

  /* Nav móvil */
  .nav__links {
    display: none;
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: rgba(250, 249, 246, 0.97);
    backdrop-filter: blur(24px);
    -webkit-backdrop-filter: blur(24px);
    flex-direction: column;
    gap: 0;
    padding: var(--space-sm) 0;
  }

  .nav__links.is-open { display: flex; }

  .nav__links li {
    border-bottom: 1px solid var(--color-outline-variant);
  }

  .nav__links a {
    display: block;
    padding: var(--space-sm) var(--space-xl);
    font-size: var(--text-base);
  }

  .nav__cta { display: none; }
  .nav__toggle { display: flex; }

  .posts-grid { grid-template-columns: 1fr; gap: var(--space-xl); }

  .mini-bio {
    grid-template-columns: 1fr;
    text-align: left;
  }

  .colaboracion-item__inner {
    grid-template-columns: 1fr;
    gap: var(--space-sm);
  }

  .footer__inner { grid-template-columns: 1fr; }

  .form-email {
    flex-direction: column;
    padding: 0 var(--space-md);
  }

  .seccion { padding: var(--space-xl) 0; }

  blockquote {
    margin-left: 0;
    margin-right: 0;
    padding: var(--space-lg);
  }
}

/* ============================================================
   COMPONENTES HOME — The Intellectual Curator
   ============================================================ */

/* ── Highlight — marca de texto con acento cyan ── */
.highlight {
  background: #00e8c4;
  color: #0a0a0a;
  padding: 0 0.12em;
  display: inline;
  line-height: inherit;
}

/* ── Highlight magenta — tensión, conflicto, problema ── */
.highlight--magenta {
  background: #c43b73;
  color: #FAF9F6;
  padding: 0 0.12em;
  display: inline;
  line-height: inherit;
}

.highlight-sm {
  background: var(--color-accent);
  color: #0a0a0a;
  padding: 0 0.1em;
  display: inline;
}

/* ── Tags / Pills ── */
.tag {
  display: inline-block;
  font-family: var(--font-sans);
  font-size: 0.75rem;
  font-weight: 500;
  letter-spacing: 0.02em;
  color: var(--color-on-surface);
  border: 1px solid rgba(26, 28, 26, 0.20);
  border-radius: 999px;
  padding: 4px 14px;
  background: transparent;
}

.tag--accent {
  background: rgba(196, 59, 115, 0.10);
  color: var(--color-secondary);
  border: none;
}

.tag--sm {
  font-size: 0.7rem;
  padding: 3px 10px;
}

/* ── Botón flecha — texto plano con arrow ── */
.btn-arrow {
  display: inline-flex;
  align-items: center;
  gap: 0.4em;
  font-family: var(--font-sans);
  font-size: 0.95rem;
  font-weight: 500;
  color: var(--color-on-surface);
  text-decoration: none;
  transition: text-decoration var(--transition), opacity var(--transition);
}

.btn-arrow:hover { text-decoration: underline; opacity: 0.75; }
.btn-arrow .arrow { transition: transform 0.2s ease; }
.btn-arrow:hover .arrow { transform: translate(2px, -2px); }

/* ── Placeholder de imagen ── */
.img-placeholder {
  width: 100%;
  aspect-ratio: 4/3;
  background: var(--color-surface-high);
}

.img-placeholder--tall {
  aspect-ratio: 3/4;
}

.img-placeholder--portrait {
  aspect-ratio: 3/4;
  width: 100%;
}

/* ── HERO — tipográfico, sin imagen ── */
.hero {
  padding: clamp(5rem, 12vh, 9rem) 0 clamp(4rem, 8vh, 7rem);
  background: var(--color-surface);
}

/* ── Hero home — background-image, gana cascada sobre .hero ── */
.hero--img {
  width: 100%;
  min-height: 100vh;
  padding: 0;
  background-color: var(--color-primary);
  background-image: url('../assets/img/hero.png');
  background-size: cover;
  background-position: right center;
  background-repeat: no-repeat;
  display: flex;
  align-items: center;
  position: relative;
}

.hero--img::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to right,
    rgba(27, 74, 66, 0.82) 0%,
    rgba(27, 74, 66, 0.60) 45%,
    rgba(27, 74, 66, 0.15) 70%,
    transparent 85%
  );
  z-index: 0;
}

.hero--img .hero__inner {
  max-width: 680px;
  margin-left: clamp(2rem, 6vw, 7rem);
  margin-right: auto;
  padding: 6rem 2rem 4rem;
  gap: var(--space-lg);
  position: relative;
  z-index: 1;
}

.hero--img .hero__headline {
  color: var(--color-on-primary);
}

.hero--img .tag {
  border-color: rgba(250, 249, 246, 0.4);
  color: var(--color-on-primary);
}

.hero__inner {
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 0 var(--space-xl);
  display: flex;
  flex-direction: column;
  gap: var(--space-2xl);
}

.hero__inner .btn {
  align-self: flex-start;
}

.hero__headline {
  font-family: var(--font-serif);
  font-size: clamp(2.5rem, 5.5vw, 4rem);
  font-weight: 400;
  line-height: 1.05;
  letter-spacing: -0.02em;
  color: var(--color-on-surface);
  max-width: 26ch;
}

.hero__headline em {
  font-style: italic;
  font-weight: 400;
}

.hero__tags {
  display: flex;
  gap: var(--space-sm);
  flex-wrap: wrap;
}

/* ── Hero con imagen de fondo — home ── */
/* ── Hero dark — páginas interiores ── */
.hero--dark {
  background: var(--gradient-signature);
  height: calc(100vh - 64px);
  display: flex;
  align-items: center;
}
.hero--dark .hero__inner {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: var(--space-md);
  margin-left: clamp(2rem, 6vw, 7rem);
  margin-right: auto;
  max-width: 680px;
}
@media (max-width: 640px) {
  .hero--dark { height: calc(100svh - 60px); }
}
.hero--dark .hero__etiqueta {
  color: var(--color-accent);
  background-color: rgba(0, 232, 196, 0.12);
}
.hero--dark .hero__titulo,
.hero--dark h1 {
  color: #FAF9F6;
}
.hero--dark .hero__titulo em {
  color: var(--color-accent);
}
.hero--dark .hero__subtitulo {
  color: rgba(250, 249, 246, 0.72);
}

/* ═══════════════════════════════════════════════════════════
   PROPUESTA DE VALOR — el bloque más importante de la home
   ═══════════════════════════════════════════════════════════ */
.propuesta {
  background: var(--color-surface);
  padding: clamp(5rem, 10vh, 8rem) 0;
}

.propuesta__inner {
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 0 var(--space-xl);
}

/* ── Cabecera en dos columnas: marca | statement ── */
.propuesta__head {
  display: grid;
  grid-template-columns: 1fr 1.75fr;
  gap: var(--space-4xl);
  align-items: center;
  padding-bottom: var(--space-3xl);
  margin-bottom: var(--space-3xl);
  border-bottom: 1px solid var(--color-border);
}

/* Columna izquierda — logo + tagline */
.propuesta__marca {
  display: flex;
  flex-direction: column;
  gap: var(--space-xl);
}

.propuesta__logo {
  height: 64px;
  width: auto;
  display: block;
}

.propuesta__tagline {
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--color-metadata);
  line-height: 1.7;
  max-width: 26ch;
  margin: 0;
  padding-top: var(--space-xl);
  border-top: 1px solid var(--color-border);
}

/* Columna derecha — statement grande */
.propuesta__titulo {
  font-family: var(--font-serif);
  font-size: clamp(var(--text-2xl), 4.5vw, 4rem);
  font-weight: 400;
  line-height: 1.08;
  letter-spacing: -0.025em;
  color: var(--color-on-surface);
  margin: 0;
}

/* ── Cuerpo persuasivo ── */
.propuesta__cuerpo {
  margin-bottom: var(--space-3xl);
  padding-bottom: var(--space-3xl);
  border-bottom: 1px solid var(--color-border);
}

.propuesta__intro {
  font-family: var(--font-serif);
  font-size: clamp(var(--text-lg), 2vw, var(--text-2xl));
  font-weight: 300;
  font-style: italic;
  line-height: 1.65;
  color: var(--color-on-surface);
  max-width: 72ch;
  margin: 0 0 var(--space-lg);
  letter-spacing: -0.01em;
}

.propuesta__intro--sm {
  font-size: clamp(var(--text-base), 1.5vw, var(--text-lg));
  color: var(--color-metadata);
  margin-bottom: 0;
}

.propuesta__intro strong {
  font-style: normal;
  font-weight: 500;
  color: var(--color-on-surface);
}

/* ── Tres pilares ── */
.propuesta__pilares {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-xl) var(--space-3xl);
  margin-bottom: var(--space-3xl);
}

.propuesta__num {
  display: block;
  font-family: var(--font-sans);
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-accent);
  margin-bottom: var(--space-sm);
}

.propuesta__pilar {
  padding-top: var(--space-md);
  border-top: 2px solid var(--color-border);
  transition: border-color 0.25s ease;
}

.propuesta__pilar:hover {
  border-top-color: var(--color-accent);
}

.propuesta__pilar-titulo {
  font-family: var(--font-serif);
  font-size: var(--text-xl);
  font-weight: 400;
  line-height: 1.2;
  letter-spacing: -0.01em;
  color: var(--color-on-surface);
  margin: 0 0 var(--space-md);
}

.propuesta__pilar p {
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  line-height: 1.8;
  color: var(--color-metadata);
  margin: 0;
}

/* ── CTA ── */
.propuesta__cta {
  display: flex;
  align-items: center;
  gap: var(--space-xl);
  flex-wrap: wrap;
}

/* ── Responsive ── */
@media (max-width: 1024px) {
  .propuesta__head {
    grid-template-columns: 1fr 1.4fr;
    gap: var(--space-3xl);
  }
}

@media (max-width: 768px) {
  .propuesta__head {
    grid-template-columns: 1fr;
    gap: var(--space-2xl);
  }

  .propuesta__logo { height: 48px; }

  .propuesta__pilares {
    grid-template-columns: 1fr;
    gap: var(--space-xl);
  }

  .propuesta__cta {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--space-lg);
  }
}

/* ── FEATURED — artículo destacado horizontal ── */
.featured {
  background: var(--color-surface-low);
  padding: clamp(4rem, 8vh, 6rem) 0;
}

.featured__inner {
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 0 var(--space-xl);
  display: grid;
  grid-template-columns: 40% 1fr;
  gap: 4rem;
  align-items: center;
}

.featured__image img,
.featured__image .img-placeholder {
  width: 100%;
  aspect-ratio: 4/3;
  object-fit: cover;
  border-radius: 0;
  display: block;
}

.featured__content {
  display: flex;
  flex-direction: column;
  gap: var(--space-lg);
}

.featured__title {
  font-family: var(--font-serif);
  font-size: clamp(2.5rem, 4vw, 3.5rem);
  font-weight: 400;
  line-height: 1.1;
  letter-spacing: -0.02em;
  color: var(--color-on-surface);
}

.featured__excerpt {
  font-family: var(--font-sans);
  font-size: var(--text-md);
  line-height: 1.7;
  color: var(--color-metadata);
  max-width: 52ch;
}

/* ── GRID RECIENTES — fondo acento + tarjetas overlay ── */
.grid-recientes {
  background: var(--color-verde-dark);
  padding: clamp(4rem, 8vh, 6rem) 0;
}

/* Cabecera introductoria */
.grid-recientes__cabecera {
  max-width: var(--max-width);
  margin: 0 auto var(--space-3xl);
  padding: 0 var(--space-xl);
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}

.grid-recientes__titulo {
  font-family: var(--font-serif);
  font-size: clamp(var(--text-2xl), 4vw, var(--text-4xl));
  font-weight: 400;
  line-height: 1.1;
  letter-spacing: -0.02em;
  color: var(--color-surface);
  margin: 0;
}

.grid-recientes__subtitulo {
  font-family: var(--font-sans);
  font-size: var(--text-md);
  color: rgba(250, 249, 246, 0.65);
  max-width: 52ch;
  line-height: 1.65;
  margin: 0;
}

/* Grid de 3 columnas */
.grid-recientes__inner {
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 0 var(--space-xl);
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
}

/* CTA al pie del bloque */
.grid-recientes__cta {
  max-width: var(--max-width);
  margin: var(--space-3xl) auto 0;
  padding: 0 var(--space-xl);
  text-align: center;
}

/* ── post-mini base (sin modificador) ── */
.post-mini { }

/* ── post-mini--overlay — tarjeta con texto superpuesto ── */
.post-mini--overlay .post-mini__card {
  display: block;
  position: relative;
  overflow: hidden;
  border-radius: 0.25rem;
  text-decoration: none;
}

.post-mini--overlay .post-mini__card img,
.post-mini--overlay .post-mini__card .img-placeholder {
  width: 100%;
  aspect-ratio: 3/4;
  object-fit: cover;
  display: block;
  transition: transform 0.4s ease;
}

.post-mini--overlay .post-mini__card:hover img,
.post-mini--overlay .post-mini__card:hover .img-placeholder {
  transform: scale(1.04);
}

/* Gradiente y texto superpuesto */
.post-mini__overlay {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: var(--space-2xl) var(--space-lg) var(--space-lg);
  background: linear-gradient(
    to top,
    rgba(0, 0, 0, 0.80) 0%,
    rgba(0, 0, 0, 0.45) 50%,
    transparent 100%
  );
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
  transition: background 0.3s ease;
}

.post-mini--overlay .post-mini__card:hover .post-mini__overlay {
  background: linear-gradient(
    to top,
    rgba(0, 0, 0, 0.90) 0%,
    rgba(0, 0, 0, 0.55) 50%,
    transparent 100%
  );
}

.post-mini__titulo {
  font-family: var(--font-serif);
  font-size: clamp(var(--text-base), 1.4vw, var(--text-lg));
  font-weight: 400;
  line-height: 1.3;
  letter-spacing: -0.01em;
  color: var(--color-surface);
  margin: 0;
}

/* "Leer artículo ↗" — aparece en hover */
.post-mini__leer {
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--color-accent);
  letter-spacing: 0.01em;
  opacity: 0;
  transform: translateY(5px);
  transition: opacity 0.25s ease, transform 0.25s ease;
}

.post-mini--overlay .post-mini__card:hover .post-mini__leer {
  opacity: 1;
  transform: translateY(0);
}

/* Tag claro para usar sobre fondo oscuro / overlay */
.tag--light {
  color: rgba(250, 249, 246, 0.90);
  border-color: rgba(250, 249, 246, 0.30);
  background: transparent;
}

/* Botón outline para fondos oscuros */
.btn--outline-light {
  background-color: transparent;
  color: var(--color-surface);
  border: 1.5px solid rgba(250, 249, 246, 0.35);
  transition: background-color 0.2s ease, border-color 0.2s ease, transform var(--transition);
}

.btn--outline-light:hover {
  background-color: rgba(250, 249, 246, 0.10);
  border-color: rgba(250, 249, 246, 0.65);
  transform: translateY(-1px);
}

/* ── TICKER — banda horizontal animada ── */
.ticker {
  background: var(--color-on-surface);
  padding: 1rem 0;
  overflow: hidden;
  white-space: nowrap;
}

.ticker__track {
  display: inline-flex;
  gap: 2rem;
  animation: ticker-scroll 22s linear infinite;
}

.ticker__track span {
  font-family: var(--font-sans);
  font-size: 0.9rem;
  font-weight: 500;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--color-surface);
}

.ticker__track .dot {
  color: var(--color-secondary);
  letter-spacing: 0;
}

@keyframes ticker-scroll {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

/* ── SOBRE — sección de la autora ── */
.sobre {
  background: var(--color-surface-low);
  padding: clamp(5rem, 10vh, 8rem) 0;
}

.sobre__inner {
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 0 var(--space-xl);
  display: grid;
  grid-template-columns: 40% 1fr;
  gap: 4rem;
  align-items: center;
}

.sobre__imagen img,
.sobre__imagen .img-placeholder {
  width: 100%;
  aspect-ratio: 3/4;
  object-fit: cover;
  display: block;
  border-radius: 0;
}

.sobre__texto {
  display: flex;
  flex-direction: column;
  gap: var(--space-lg);
}

.sobre__hey {
  font-family: var(--font-sans);
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--color-metadata);
  margin: 0;
  line-height: 1;
}

.sobre__titulo {
  font-family: var(--font-sans);
  font-size: clamp(2.5rem, 5vw, 4rem);
  font-weight: 700;
  line-height: 1;
  letter-spacing: -0.03em;
  color: var(--color-on-surface);
  margin: 0;
}

.sobre__bio {
  font-family: var(--font-sans);
  font-size: var(--text-md);
  line-height: 1.75;
  color: var(--color-metadata);
  max-width: 52ch;
  margin: 0;
}

/* ── NEWSLETTER — nueva sección home ── */
.newsletter {
  background: var(--gradient-signature);
  padding: clamp(5rem, 10vh, 8rem) 0;
}

.newsletter__inner {
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 0 var(--space-xl);
  display: grid;
  grid-template-columns: 55% 1fr;
  gap: 4rem;
  align-items: center;
}

.newsletter__copy h2 {
  font-family: var(--font-serif);
  font-size: clamp(2.5rem, 4vw, 3.5rem);
  font-weight: 400;
  line-height: 1.15;
  letter-spacing: -0.02em;
  color: var(--color-on-primary);
  margin-bottom: var(--space-lg);
}

.newsletter__copy p {
  font-family: var(--font-sans);
  font-size: var(--text-base);
  color: rgba(250, 249, 246, 0.65);
  line-height: 1.6;
}

.newsletter__form {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}

.newsletter__form input[type="email"] {
  width: 100%;
  padding: 14px 18px;
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  background: transparent;
  border: 1px solid rgba(250, 249, 246, 0.30);
  border-radius: 0;
  color: var(--color-on-primary);
  outline: none;
  transition: border-color var(--transition);
}

.newsletter__form input[type="email"]::placeholder {
  color: rgba(250, 249, 246, 0.40);
}

.newsletter__form input[type="email"]:focus {
  border-color: var(--color-accent);
}

.newsletter__form button {
  width: 100%;
  padding: 14px 24px;
  font-family: var(--font-sans);
  font-size: 0.8rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  background: var(--color-on-primary);
  color: var(--color-primary);
  border: none;
  border-radius: 0;
  cursor: pointer;
  transition: opacity var(--transition);
}

.newsletter__form button:hover { opacity: 0.88; }

/* ── FOOTER — nuevo diseño ── */
.footer {
  background: #0f1f1c;
  padding: var(--space-2xl) 0 0;
  color: rgba(250, 249, 246, 0.75);
}

.footer__inner {
  display: grid;
  grid-template-columns: auto 1fr 1fr auto;
  gap: 4rem;
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 0 var(--space-xl) var(--space-3xl);
}

.footer__marca p {
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: rgba(250, 249, 246, 0.45);
  line-height: 1.6;
  max-width: 28ch;
  margin-top: var(--space-md);
}

.footer__logo {
  display: inline-flex;
  align-items: center;
  transition: opacity var(--transition);
}

.footer__logo img {
  height: 120px;
  width: auto;
  display: block;
}

.footer__logo:hover { opacity: 0.65; }

.footer__nav {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}

.footer__nav strong {
  font-family: var(--font-sans);
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(250, 249, 246, 0.40);
  display: block;
  margin-bottom: var(--space-sm);
}

.footer__nav a {
  font-family: var(--font-sans);
  font-size: 0.9rem;
  color: rgba(250, 249, 246, 0.65);
  transition: color var(--transition);
}

.footer__nav a:hover { color: var(--color-on-primary); }

.footer__bottom {
  border-top: 1px solid rgba(250, 249, 246, 0.08);
  padding: var(--space-lg) var(--space-xl);
  max-width: var(--max-width);
  margin: 0 auto;
}

.footer__bottom p {
  font-family: var(--font-sans);
  font-size: 0.75rem;
  letter-spacing: 0.05em;
  color: rgba(250, 249, 246, 0.25);
  margin: 0;
  line-height: 1;
}

/* ── ARTÍCULOS RELACIONADOS — nuevo layout horizontal ── */
.relacionados {
  padding: var(--space-3xl) 0 var(--space-xl);
  background: var(--color-surface-low);
}

.relacionados__label {
  font-family: var(--font-sans);
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-metadata);
  margin-bottom: var(--space-xl);
}

.relacionados__lista {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.rel-card {
  display: grid;
  grid-template-columns: 35% 1fr;
  gap: var(--space-2xl);
  align-items: start;
  padding: var(--space-2xl) 0;
  border-top: 1px solid var(--color-outline-variant);
  text-decoration: none;
  color: inherit;
  transition: opacity var(--transition);
}

.rel-card:hover { opacity: 0.75; }

.rel-card__img,
.rel-card__img-placeholder {
  width: 100%;
  aspect-ratio: 3/2;
  object-fit: cover;
  display: block;
  background: var(--color-surface-high);
}

.rel-card__body {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
  padding-top: var(--space-xs);
}

.rel-card__titulo {
  font-family: var(--font-serif);
  font-size: var(--text-xl);
  font-weight: 400;
  line-height: 1.25;
  letter-spacing: -0.01em;
}

.rel-card__extracto {
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--color-metadata);
  line-height: 1.65;
}

/* ── Responsive nuevos componentes ── */
@media (max-width: 768px) {
  .featured__inner,
  .sobre__inner,
  .newsletter__inner {
    grid-template-columns: 1fr;
    gap: var(--space-2xl);
  }

  .grid-recientes__inner {
    grid-template-columns: 1fr;
    gap: var(--space-xl);
  }

  /* En móvil las tarjetas overlay pasan a formato apaisado */
  .post-mini--overlay .post-mini__card img,
  .post-mini--overlay .post-mini__card .img-placeholder { aspect-ratio: 16/9; }

  /* Gradiente más corto en formato apaisado */
  .post-mini__overlay {
    padding: var(--space-xl) var(--space-md) var(--space-md);
  }

  /* En móvil "Leer artículo" siempre visible */
  .post-mini__leer {
    opacity: 1;
    transform: none;
  }

  .footer__inner {
    grid-template-columns: 1fr 1fr;
    gap: var(--space-2xl);
  }

  .footer__marca {
    grid-column: 1 / -1;
  }

  .sobre__titulo { font-size: 2.5rem; }

  .newsletter__copy h2 { font-size: 2.2rem; }

  .rel-card {
    grid-template-columns: 1fr;
    gap: var(--space-md);
  }
}

@media (max-width: 480px) {
  .footer__inner { grid-template-columns: 1fr; }
}

/* ============================================================
   BLOG INDEX — buscador, controles y hero
   ============================================================ */

/* ── Buscador ── */
.buscador {
  position: relative;
  max-width: 480px;
}
.buscador__icono {
  position: absolute;
  left: 14px;
  top: 50%;
  transform: translateY(-50%);
  width: 18px;
  height: 18px;
  color: var(--color-text-light);
  pointer-events: none;
}
.buscador__input {
  width: 100%;
  padding: 10px 16px 10px 42px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-pill);
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--color-text);
  background: #fff;
  outline: none;
  transition: border-color 0.2s;
}
.buscador__input:focus {
  border-color: var(--color-verde-dark);
}
.buscador__input::placeholder {
  color: var(--color-text-light);
}

/* ── Barra de controles ── */
.blog-controles {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-lg);
  padding: var(--space-xl) 0;
  border-bottom: 1px solid var(--color-border);
}

/* ── Sin resultados ── */
.sin-resultados {
  display: none;
  grid-column: 1 / -1;
  text-align: center;
  padding: var(--space-3xl) 0;
  color: var(--color-text-muted);
  font-size: var(--text-sm);
}
.sin-resultados.visible {
  display: block;
}

/* ── Hero blog — encajado en el fold ── */
.hero--blog {
  height: calc(100vh - 68px);
  padding: 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
  position: relative;
}
.hero--blog::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to right,
    rgba(27, 74, 66, 0.82) 0%,
    rgba(27, 74, 66, 0.60) 45%,
    rgba(27, 74, 66, 0.15) 70%,
    transparent 85%
  );
  z-index: 0;
}
.hero--blog .hero__inner {
  padding: 0 var(--space-xl);
  margin-left: clamp(2rem, 6vw, 7rem);
  margin-right: auto;
  gap: var(--space-md);
  align-items: flex-start;
  position: relative;
  z-index: 1;
}
.hero--blog .hero__titulo {
  font-size: clamp(2rem, 4vw, 3rem);
  line-height: 1.1;
  margin: 0;
}
@media (max-width: 640px) {
  .hero--blog { height: calc(100svh - 60px); }
  .hero--blog .hero__inner { padding: 0 var(--space-md); }
}

/* ── Hero sobre-mi — overlay igual que blog ── */
.hero--sobre-mi {
  position: relative;
}
.hero--sobre-mi::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to right,
    rgba(27, 74, 66, 0.82) 0%,
    rgba(27, 74, 66, 0.60) 45%,
    rgba(27, 74, 66, 0.15) 70%,
    transparent 85%
  );
  z-index: 0;
}
.hero--sobre-mi .hero__inner {
  position: relative;
  z-index: 1;
}

/* ── Botón rosa ── */
.btn--rosa {
  background-color: var(--color-secondary);
  color: var(--color-on-primary);
  border: none;
}
.btn--rosa:hover {
  background-color: var(--color-rosa-dark);
  transform: translateY(-1px);
}

@media (max-width: 768px) {
  .hero--blog { min-height: 320px; }
}
@media (max-width: 600px) {
  .buscador { max-width: 100%; }
  .blog-controles { flex-direction: column; align-items: flex-start; }
}

/* ── sobre-mi — bloque autora dark ── */
.seccion--autora {
  background-color: var(--color-verde-dark);
  color: #FAF9F6;
}
.seccion--autora h2,
.seccion--autora p,
.seccion--autora strong {
  color: #FAF9F6;
}
.seccion--autora .autora__grid {
  display: grid;
  grid-template-columns: 160px 1fr;
  gap: var(--space-2xl);
  align-items: start;
}
.seccion--autora .sobre-mi__foto-placeholder {
  width: 160px;
  max-width: 160px;
  aspect-ratio: 1;
  border-radius: var(--radius-sm);
  background-color: rgba(250, 249, 246, 0.12);
}
@media (max-width: 640px) {
  .seccion--autora .autora__grid {
    grid-template-columns: 1fr;
  }
  .seccion--autora .sobre-mi__foto-placeholder {
    width: 120px;
    max-width: 120px;
    margin: 0 auto;
  }
}

/* ── nav-dropdown ── */
.nav__item--dropdown {
  position: relative;
}

.nav__dropdown-trigger {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  background: none;
  border: none;
  padding: 0;
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  font-weight: 400;
  color: var(--color-text-muted);
  cursor: pointer;
  transition: color 0.2s;
}
.nav__dropdown-trigger:hover { color: var(--color-primary); }

.nav__chevron {
  transition: transform 0.2s ease;
}
.nav__item--dropdown.is-open .nav__chevron,
.nav__item--dropdown:hover .nav__chevron {
  transform: rotate(180deg);
}

.nav__dropdown {
  display: none;
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
  padding-top: 12px;    /* puente invisible — el hover no se rompe al cruzar el gap */
  padding-bottom: var(--space-xs);
  min-width: 200px;
  background: transparent;
  z-index: 200;
  list-style: none;
  margin: 0;
}

/* Caja visual separada del área de hover */
.nav__dropdown::before {
  content: '';
  position: absolute;
  inset: 12px 0 0 0;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  box-shadow: 0 8px 24px rgba(26, 28, 26, 0.10);
  z-index: -1;
}

.nav__dropdown li {
  position: relative;
  z-index: 1;
}
.nav__item--dropdown:hover .nav__dropdown,
.nav__item--dropdown.is-open .nav__dropdown {
  display: block;
}
.nav__dropdown li a {
  display: block;
  padding: var(--space-xs) var(--space-lg);
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--color-text);
  transition: background 0.15s, color 0.15s;
}
.nav__dropdown li a:hover,
.nav__dropdown li a.activo {
  background: var(--color-verde-dark);
  color: #FAF9F6;
}

/* Mobile: dropdown dentro del menú hamburguesa */
@media (max-width: 768px) {
  .nav__item--dropdown { position: static; }

  .nav__dropdown-trigger {
    display: block;
    width: 100%;
    padding: var(--space-sm) var(--space-xl);
    font-size: inherit;
    border-bottom: 1px solid var(--color-outline-variant);
  }

  .nav__dropdown {
    position: static;
    transform: none;
    box-shadow: none;
    border: none;
    border-radius: 0;
    background: var(--color-surface-low);
    padding: 0;
  }
  .nav__item--dropdown.is-open .nav__dropdown { display: block; }
  .nav__item--dropdown:hover .nav__dropdown  { display: none; }
  .nav__item--dropdown.is-open:hover .nav__dropdown { display: block; }

  .nav__dropdown li a {
    padding-left: calc(var(--space-xl) + var(--space-md));
  }
}

/* ── colaboraciones — hereda estilos globales ── */

