/* ============================================================
   LA WEB DEL CHEF — Sistema de Diseño Base
   Estilo: Natural / Mediterráneo
   Versión: 1.1 — Ronda 3
   ============================================================ */

/* ────────────────────────────────────────────────────────────
   1. GOOGLE FONTS IMPORT
   Nota: las fuentes se cargan vía <link> en cabecera.php
   para aprovechar preconnect. Este @import se mantiene
   como fallback pero no es necesario en producción.
   ──────────────────────────────────────────────────────────── */
/* @import eliminado: las fuentes se cargan desde cabecera.php */

/* ────────────────────────────────────────────────────────────
   2. VARIABLES CSS — TOKENS DE DISEÑO
   ──────────────────────────────────────────────────────────── */
:root {
  /* Colores principales */
  --color-primary:       #7A9E7E;   /* Verde salvia */
  --color-primary-dark:  #5E8262;   /* Verde salvia oscuro (hover) */
  --color-primary-light: #A8C4AB;   /* Verde salvia claro (tints) */
  --color-primary-bg:    #EFF5F0;   /* Verde salvia muy suave (fondos) */

  --color-secondary:      #C97B5A;  /* Terracota / salmón */
  --color-secondary-dark: #A8604A;  /* Terracota oscuro (hover) */
  --color-secondary-light:#E4A98E;  /* Terracota claro */
  --color-secondary-bg:   #FAF0EB;  /* Terracota muy suave (fondos) */

  /* Neutrales */
  --color-bg:       #F7F4EF;  /* Crema papel — fondo general */
  --color-surface:  #FFFFFF;  /* Blanco puro — tarjetas, formularios */
  --color-text:     #2D2D2D;  /* Casi negro suave — texto principal */
  --color-text-soft:#8A8478;  /* Gris arena — metadatos, secundario */
  --color-border:   #E3DDD5;  /* Beige claro — separadores, bordes */
  --color-border-dark: #CEC7BB; /* Borde más visible */

  /* Alias de conveniencia — usados en admin y páginas legales */
  --color-bg-alt:      var(--color-bg);        /* #F7F4EF — crema papel */
  --color-text-muted:  var(--color-text-soft); /* #8A8478 — gris arena  */

  /* Semánticos */
  --color-success: #5A9E6A;
  --color-error:   #C9605A;
  --color-warning: #D4A04A;

  /* Tipografías */
  --font-heading: 'DM Serif Display', Georgia, serif;
  --font-body:    'DM Sans', system-ui, sans-serif;

  /* Escalas tipográficas */
  --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:  1.875rem;  /* 30px */
  --text-3xl:  2.25rem;   /* 36px */
  --text-4xl:  3rem;      /* 48px */
  --text-5xl:  3.75rem;   /* 60px */

  /* Espaciado */
  --space-1:   0.25rem;   /* 4px */
  --space-2:   0.5rem;    /* 8px */
  --space-3:   0.75rem;   /* 12px */
  --space-4:   1rem;      /* 16px */
  --space-5:   1.25rem;   /* 20px */
  --space-6:   1.5rem;    /* 24px */
  --space-8:   2rem;      /* 32px */
  --space-10:  2.5rem;    /* 40px */
  --space-12:  3rem;      /* 48px */
  --space-16:  4rem;      /* 64px */
  --space-20:  5rem;      /* 80px */
  --space-24:  6rem;      /* 96px */

  /* Bordes */
  --radius-sm:   4px;
  --radius-md:   8px;
  --radius-lg:   12px;
  --radius-xl:   20px;
  --radius-full: 9999px;

  /* Sombras */
  --shadow-xs: 0 1px 2px rgba(45, 45, 45, 0.06);
  --shadow-sm: 0 2px 6px rgba(45, 45, 45, 0.08);
  --shadow-md: 0 4px 16px rgba(45, 45, 45, 0.10);
  --shadow-lg: 0 8px 32px rgba(45, 45, 45, 0.12);
  --shadow-xl: 0 16px 48px rgba(45, 45, 45, 0.15);

  /* Transiciones */
  --transition-fast:   150ms ease;
  --transition-base:   250ms ease;
  --transition-slow:   400ms ease;

  /* Layout */
  --container-max: 1200px;
  --container-padding: var(--space-6);
  --header-height: 72px;
}

/* ────────────────────────────────────────────────────────────
   3. RESET Y BASE
   ──────────────────────────────────────────────────────────── */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

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

body {
  font-family: var(--font-body);
  font-size: var(--text-base);
  font-weight: 400;
  line-height: 1.65;
  color: var(--color-text);
  background-color: var(--color-bg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

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

a {
  color: var(--color-primary-dark);
  text-decoration: none;
  transition: color var(--transition-fast);
}

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

ul, ol {
  list-style: none;
}

button, input, select, textarea {
  font-family: inherit;
  font-size: inherit;
}

h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-heading);
  font-weight: 400;
  line-height: 1.2;
  color: var(--color-text);
  letter-spacing: -0.01em;
}

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

p { margin-bottom: var(--space-4); }
p:last-child { margin-bottom: 0; }

/* ────────────────────────────────────────────────────────────
   4. UTILIDADES
   ──────────────────────────────────────────────────────────── */
.container {
  max-width: var(--container-max);
  margin: 0 auto;
  padding-inline: var(--container-padding);
}

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

.section {
  padding-block: var(--space-16);
}

.section-sm {
  padding-block: var(--space-10);
}

.section-title {
  font-family: var(--font-heading);
  font-size: var(--text-3xl);
  color: var(--color-text);
  margin-bottom: var(--space-2);
}

.section-subtitle {
  font-size: var(--text-md);
  color: var(--color-text-soft);
  margin-bottom: var(--space-10);
  font-weight: 300;
}

.section-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  margin-bottom: var(--space-8);
  gap: var(--space-4);
  flex-wrap: wrap;
}

.divider {
  display: inline-block;
  width: 48px;
  height: 2px;
  background: var(--color-secondary);
  margin-bottom: var(--space-6);
  border-radius: var(--radius-full);
}

/* ────────────────────────────────────────────────────────────
   5. LOGO — LA WEB DEL CHEF
   ──────────────────────────────────────────────────────────── */
.logo {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  text-decoration: none;
  line-height: 1;
}

.logo__icon {
  width: 36px;
  height: 36px;
  background: var(--color-secondary);
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-heading);
  font-size: 1.2rem;
  color: #fff;
  flex-shrink: 0;
  transition: background var(--transition-fast);
}

.logo:hover .logo__icon {
  background: var(--color-secondary-dark);
}

.logo__text {
  display: flex;
  flex-direction: column;
  line-height: 1.1;
}

.logo__pre {
  font-family: var(--font-body);
  font-size: 0.6rem;
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-text-soft);
}

.logo__name {
  font-family: var(--font-heading);
  font-size: 1.15rem;
  color: var(--color-text);
  letter-spacing: -0.01em;
}

/* Logo compacto (favicon / móvil) */
.logo--compact .logo__text { display: none; }
.logo--compact .logo__icon { width: 40px; height: 40px; font-size: 1.4rem; }

/* ────────────────────────────────────────────────────────────
   6. HEADER
   ──────────────────────────────────────────────────────────── */
.site-header {
  position: sticky;
  top: 0;
  z-index: 100;
  background: var(--color-surface);
  border-bottom: 1px solid var(--color-border);
  height: var(--header-height);
  box-shadow: var(--shadow-xs);
}

.site-header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 100%;
  gap: var(--space-6);
  position: relative;
}

/* Navegación principal */
.site-nav {
  display: flex;
  align-items: center;
  gap: var(--space-1);
}

.site-nav__link {
  font-family: var(--font-body);
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--color-text);
  padding: var(--space-2) var(--space-4);
  border-radius: var(--radius-md);
  transition: all var(--transition-fast);
  letter-spacing: 0.01em;
}

.site-nav__link:hover,
.site-nav__link--active {
  color: var(--color-primary-dark);
  background: var(--color-primary-bg);
}

/* Buscador header */
.header-search {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.header-search__input {
  width: 220px;
  height: 38px;
  padding: 0 var(--space-4);
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-full);
  background: var(--color-bg);
  color: var(--color-text);
  font-size: var(--text-sm);
  transition: border-color var(--transition-fast), width var(--transition-base);
  outline: none;
}

.header-search__input::placeholder { color: var(--color-text-soft); }

.header-search__input:focus {
  border-color: var(--color-primary);
  width: 270px;
  background: var(--color-surface);
}

.header-search__btn {
  width: 38px;
  height: 38px;
  border: none;
  background: var(--color-primary);
  color: #fff;
  border-radius: var(--radius-full);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background var(--transition-fast);
  flex-shrink: 0;
}

.header-search__btn:hover { background: var(--color-primary-dark); }
.header-search__btn svg { width: 16px; height: 16px; }

/* Botón menú móvil */
.hamburger {
  display: none;
  flex-direction: column;
  gap: 5px;
  width: 40px;
  height: 40px;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  background: none;
  border: none;
  padding: var(--space-2);
}

.hamburger span {
  display: block;
  width: 22px;
  height: 2px;
  background: var(--color-text);
  border-radius: 2px;
  transition: transform .2s ease, opacity .2s ease;
  transform-origin: center;
}

.hamburger span:nth-child(2) { margin: 5px 0; }

/* ────────────────────────────────────────────────────────────
   7. FOOTER
   ──────────────────────────────────────────────────────────── */
.site-footer {
  background: var(--color-text);
  color: rgba(255,255,255,0.75);
  padding-block: var(--space-16) var(--space-8);
  margin-top: var(--space-24);
}

.site-footer__grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1.5fr;
  gap: var(--space-12);
  margin-bottom: var(--space-12);
}

.site-footer .logo__icon { background: var(--color-secondary); }
.site-footer .logo__pre  { color: rgba(255,255,255,0.45); }
.site-footer .logo__name { color: #fff; }

.footer-desc {
  font-size: var(--text-sm);
  line-height: 1.7;
  margin-top: var(--space-4);
  color: rgba(255,255,255,0.55);
}

.footer-col__title {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.45);
  margin-bottom: var(--space-4);
}

.footer-links {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.footer-links a {
  font-size: var(--text-sm);
  color: rgba(255,255,255,0.65);
  transition: color var(--transition-fast);
}

.footer-links a:hover { color: #fff; }

.footer-bottom {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: var(--space-6);
  border-top: 1px solid rgba(255,255,255,0.10);
  gap: var(--space-4);
  flex-wrap: wrap;
}

.footer-copy {
  font-size: var(--text-xs);
  color: rgba(255,255,255,0.35);
}

.footer-legal {
  display: flex;
  gap: var(--space-6);
}

.footer-legal a {
  font-size: var(--text-xs);
  color: rgba(255,255,255,0.35);
}

.footer-legal a:hover { color: rgba(255,255,255,0.7); }

/* ────────────────────────────────────────────────────────────
   8. BOTONES
   ──────────────────────────────────────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-6);
  font-family: var(--font-body);
  font-size: var(--text-sm);
  font-weight: 500;
  line-height: 1;
  border-radius: var(--radius-full);
  border: 1.5px solid transparent;
  cursor: pointer;
  transition: all var(--transition-fast);
  text-decoration: none;
  white-space: nowrap;
  letter-spacing: 0.01em;
}

.btn:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}

/* Botón primario */
.btn--primary {
  background: var(--color-primary);
  color: #fff;
  border-color: var(--color-primary);
}

.btn--primary:hover {
  background: var(--color-primary-dark);
  border-color: var(--color-primary-dark);
  color: #fff;
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(122, 158, 126, 0.35);
}

/* Botón secundario */
.btn--secondary {
  background: var(--color-secondary);
  color: #fff;
  border-color: var(--color-secondary);
}

.btn--secondary:hover {
  background: var(--color-secondary-dark);
  border-color: var(--color-secondary-dark);
  color: #fff;
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(201, 123, 90, 0.35);
}

/* Botón ghost (contorno verde) */
.btn--ghost {
  background: transparent;
  color: var(--color-primary-dark);
  border-color: var(--color-primary);
}

.btn--ghost:hover {
  background: var(--color-primary-bg);
  color: var(--color-primary-dark);
}

/* Botón ghost terracota */
.btn--ghost-secondary {
  background: transparent;
  color: var(--color-secondary);
  border-color: var(--color-secondary);
}

.btn--ghost-secondary:hover {
  background: var(--color-secondary-bg);
  color: var(--color-secondary-dark);
}

/* Botón texto */
.btn--text {
  background: transparent;
  color: var(--color-primary-dark);
  border-color: transparent;
  padding-inline: var(--space-2);
}

.btn--text:hover {
  color: var(--color-secondary);
}

/* Tamaños */
.btn--sm {
  padding: var(--space-2) var(--space-4);
  font-size: var(--text-xs);
}

.btn--lg {
  padding: var(--space-4) var(--space-8);
  font-size: var(--text-md);
}

.btn--icon {
  padding: var(--space-3);
  border-radius: var(--radius-full);
}

/* ────────────────────────────────────────────────────────────
   9. TARJETA DE RECETA
   ──────────────────────────────────────────────────────────── */
.recipe-card {
  background: var(--color-surface);
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
  border: 1px solid var(--color-border);
  transition: transform var(--transition-base), box-shadow var(--transition-base);
  display: flex;
  flex-direction: column;
}

.recipe-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg);
}

.recipe-card__image {
  position: relative;
  overflow: hidden;
  aspect-ratio: 4/3;
  background: var(--color-border);
}

.recipe-card__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transition-slow);
}

.recipe-card:hover .recipe-card__image img {
  transform: scale(1.05);
}

.recipe-card__category {
  position: absolute;
  top: var(--space-3);
  left: var(--space-3);
  background: rgba(247, 244, 239, 0.92);
  backdrop-filter: blur(4px);
  color: var(--color-text);
  font-size: var(--text-xs);
  font-weight: 500;
  letter-spacing: 0.05em;
  padding: var(--space-1) var(--space-3);
  border-radius: var(--radius-full);
  text-transform: uppercase;
  border: 1px solid var(--color-border);
}

.recipe-card__body {
  padding: var(--space-5) var(--space-6);
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.recipe-card__title {
  font-family: var(--font-heading);
  font-size: var(--text-xl);
  line-height: 1.25;
  color: var(--color-text);
  transition: color var(--transition-fast);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.recipe-card:hover .recipe-card__title { color: var(--color-primary-dark); }

.recipe-card__excerpt {
  font-size: var(--text-sm);
  color: var(--color-text-soft);
  line-height: 1.6;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  flex: 1;
}
.recipe-card__author {
  font-size: var(--text-xs);
  color: var(--color-text-soft);
  font-style: italic;
  margin-bottom: var(--space-2);
}

.recipe-card__meta {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  padding-top: var(--space-3);
  border-top: 1px solid var(--color-border);
}

.recipe-card__meta-item {
  display: flex;
  align-items: center;
  gap: var(--space-1);
  font-size: var(--text-xs);
  color: var(--color-text-soft);
}

.recipe-card__meta-item svg {
  width: 14px;
  height: 14px;
  color: var(--color-primary);
}

/* Variante horizontal */
.recipe-card--horizontal {
  flex-direction: row;
  max-height: 180px;
}

.recipe-card--horizontal .recipe-card__image {
  width: 200px;
  min-width: 200px;
  aspect-ratio: unset;
}

.recipe-card--horizontal .recipe-card__body {
  padding: var(--space-4) var(--space-5);
}

/* ────────────────────────────────────────────────────────────
   10. TARJETA DE CATEGORÍA
   ──────────────────────────────────────────────────────────── */
.category-card {
  position: relative;
  border-radius: var(--radius-xl);
  overflow: hidden;
  aspect-ratio: 4/3;
  cursor: pointer;
  display: block;
  text-decoration: none;
}

.category-card__image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transition-slow);
}

.category-card:hover .category-card__image { transform: scale(1.08); }

.category-card__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to top,
    rgba(45, 45, 45, 0.72) 0%,
    rgba(45, 45, 45, 0.15) 60%,
    transparent 100%
  );
  transition: background var(--transition-base);
}

.category-card:hover .category-card__overlay {
  background: linear-gradient(
    to top,
    rgba(122, 158, 126, 0.8) 0%,
    rgba(122, 158, 126, 0.25) 60%,
    transparent 100%
  );
}

.category-card__label {
  position: absolute;
  bottom: var(--space-4);
  left: var(--space-4);
  right: var(--space-4);
  font-family: var(--font-heading);
  font-size: var(--text-xl);
  color: #fff;
  text-shadow: 0 1px 4px rgba(0,0,0,0.3);
}

/* ────────────────────────────────────────────────────────────
   11. PAGINACIÓN
   ──────────────────────────────────────────────────────────── */
.pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding-block: var(--space-8);
}

.pagination__item {
  display: flex;
}

.pagination__link {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--color-text-soft);
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-md);
  transition: all var(--transition-fast);
  text-decoration: none;
}

.pagination__link:hover {
  color: var(--color-primary-dark);
  border-color: var(--color-primary);
  background: var(--color-primary-bg);
}

.pagination__link--active {
  background: var(--color-primary);
  color: #fff;
  border-color: var(--color-primary);
}

.pagination__link--active:hover {
  background: var(--color-primary-dark);
  color: #fff;
}

.pagination__link--prev,
.pagination__link--next {
  width: auto;
  padding-inline: var(--space-4);
  gap: var(--space-2);
}

.pagination__ellipsis {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  font-size: var(--text-sm);
  color: var(--color-text-soft);
}

/* ────────────────────────────────────────────────────────────
   12. BREADCRUMB
   ──────────────────────────────────────────────────────────── */
.breadcrumb {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-2);
  padding-block: var(--space-4);
  font-size: var(--text-sm);
}

.breadcrumb__item {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  color: var(--color-text-soft);
}

.breadcrumb__item:not(:last-child)::after {
  content: '/';
  color: var(--color-border-dark);
}

.breadcrumb__link {
  color: var(--color-text-soft);
  transition: color var(--transition-fast);
}

.breadcrumb__link:hover { color: var(--color-primary-dark); }

.breadcrumb__current {
  color: var(--color-text);
  font-weight: 500;
}

/* Variante semántica (sin BEM explícito — páginas legales R10) */
.breadcrumb a {
  color: var(--color-text-soft);
  text-decoration: none;
  transition: color var(--transition-fast);
}

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

.breadcrumb [aria-current="page"] {
  color: var(--color-text);
  font-weight: 500;
}

/* ────────────────────────────────────────────────────────────
   13. BUSCADOR HERO
   ──────────────────────────────────────────────────────────── */
.search-bar {
  display: flex;
  align-items: center;
  background: var(--color-surface);
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-full);
  padding: var(--space-2) var(--space-2) var(--space-2) var(--space-6);
  gap: var(--space-2);
  box-shadow: var(--shadow-md);
  max-width: 620px;
  width: 100%;
}

.search-bar:focus-within {
  border-color: var(--color-primary);
  box-shadow: var(--shadow-md), 0 0 0 3px rgba(122, 158, 126, 0.15);
}

.search-bar__input {
  flex: 1;
  border: none;
  background: transparent;
  font-size: var(--text-base);
  color: var(--color-text);
  outline: none;
  min-width: 0;
}

.search-bar__input::placeholder { color: var(--color-text-soft); }

.search-bar__btn {
  flex-shrink: 0;
  padding: var(--space-3) var(--space-6);
  background: var(--color-secondary);
  color: #fff;
  border: none;
  border-radius: var(--radius-full);
  font-family: var(--font-body);
  font-size: var(--text-sm);
  font-weight: 500;
  cursor: pointer;
  transition: background var(--transition-fast);
}

.search-bar__btn:hover { background: var(--color-secondary-dark); }

/* ────────────────────────────────────────────────────────────
   14. HERO SECTION
   ──────────────────────────────────────────────────────────── */
.hero {
  position: relative;
  padding-block: var(--space-24);
  overflow: hidden;
  background: linear-gradient(
    135deg,
    #EFF5F0 0%,
    #F7F4EF 40%,
    #FAF0EB 100%
  );
}

.hero::before {
  content: '';
  position: absolute;
  top: -40px;
  right: -60px;
  width: 500px;
  height: 500px;
  background: radial-gradient(
    circle,
    rgba(122, 158, 126, 0.12) 0%,
    transparent 70%
  );
  pointer-events: none;
}

.hero::after {
  content: '';
  position: absolute;
  bottom: -40px;
  left: -60px;
  width: 400px;
  height: 400px;
  background: radial-gradient(
    circle,
    rgba(201, 123, 90, 0.10) 0%,
    transparent 70%
  );
  pointer-events: none;
}

.hero__inner {
  position: relative;
  z-index: 1;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-8);
}

.hero__tag {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-xs);
  font-weight: 500;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-secondary);
  background: var(--color-secondary-bg);
  border: 1px solid rgba(201, 123, 90, 0.2);
  padding: var(--space-2) var(--space-4);
  border-radius: var(--radius-full);
}

.hero__title {
  font-family: var(--font-heading);
  font-size: clamp(2.5rem, 6vw, 4rem);
  line-height: 1.1;
  color: var(--color-text);
  max-width: 700px;
}

.hero__title em {
  font-style: italic;
  color: var(--color-secondary);
}

.hero__subtitle {
  font-size: var(--text-md);
  color: var(--color-text-soft);
  max-width: 500px;
  line-height: 1.7;
  font-weight: 300;
  margin-bottom: 0;
}

.hero__tags {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  justify-content: center;
  margin-top: var(--space-2);
}

.hero__pill {
  font-size: var(--text-xs);
  color: var(--color-text-soft);
  background: rgba(255,255,255,0.7);
  border: 1px solid var(--color-border);
  padding: var(--space-1) var(--space-3);
  border-radius: var(--radius-full);
  cursor: pointer;
  transition: all var(--transition-fast);
}

.hero__pill:hover {
  background: var(--color-primary-bg);
  color: var(--color-primary-dark);
  border-color: var(--color-primary-light);
}

/* ────────────────────────────────────────────────────────────
   15. GRIDS
   ──────────────────────────────────────────────────────────── */
.grid-recipes {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-6);
}

.grid-categories {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-4);
}

/* ────────────────────────────────────────────────────────────
   16. BADGE / ETIQUETA
   ──────────────────────────────────────────────────────────── */
.badge {
  display: inline-flex;
  align-items: center;
  padding: var(--space-1) var(--space-3);
  font-size: var(--text-xs);
  font-weight: 500;
  border-radius: var(--radius-full);
  line-height: 1;
}

.badge--primary {
  background: var(--color-primary-bg);
  color: var(--color-primary-dark);
}

.badge--secondary {
  background: var(--color-secondary-bg);
  color: var(--color-secondary-dark);
}

.badge--neutral {
  background: var(--color-border);
  color: var(--color-text-soft);
}

/* ────────────────────────────────────────────────────────────
   17. FORMULARIO / INPUTS
   ──────────────────────────────────────────────────────────── */
.form-group {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  margin-bottom: var(--space-5);
}

.form-label {
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--color-text);
}

.form-input,
.form-select,
.form-textarea {
  width: 100%;
  padding: var(--space-3) var(--space-4);
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-surface);
  color: var(--color-text);
  font-size: var(--text-sm);
  font-family: var(--font-body);
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
  outline: none;
}

.form-input::placeholder,
.form-textarea::placeholder { color: var(--color-text-soft); }

.form-input:focus,
.form-select:focus,
.form-textarea:focus {
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(122, 158, 126, 0.15);
}

.form-textarea { resize: vertical; min-height: 120px; }

/* ────────────────────────────────────────────────────────────
   18. RESPONSIVE — TABLET (≤ 900px)
   ──────────────────────────────────────────────────────────── */
@media (max-width: 900px) {
  :root {
    --container-padding: var(--space-5);
  }

  .grid-recipes    { grid-template-columns: repeat(2, 1fr); gap: var(--space-5); }
  .grid-categories { grid-template-columns: repeat(2, 1fr); gap: var(--space-4); }

  .site-footer__grid { grid-template-columns: 1fr 1fr; gap: var(--space-8); }

  .hero { padding-block: var(--space-16); }
  .hero__title { font-size: clamp(2rem, 6vw, 3rem); }

  .header-search__input { width: 160px; }
  .header-search__input:focus { width: 200px; }

  .recipe-card--horizontal { flex-direction: column; max-height: unset; }
  .recipe-card--horizontal .recipe-card__image { width: 100%; aspect-ratio: 4/3; }
}

/* ────────────────────────────────────────────────────────────
   19. RESPONSIVE — MÓVIL (≤ 640px)
   ──────────────────────────────────────────────────────────── */
@media (max-width: 640px) {
  :root {
    --container-padding: var(--space-4);
    --header-height: 64px;
  }

  h1 { font-size: var(--text-3xl); }
  h2 { font-size: var(--text-2xl); }

  .grid-recipes    { grid-template-columns: 1fr; }
  .grid-categories { grid-template-columns: repeat(2, 1fr); gap: var(--space-3); }

  .site-nav { display: none; }
  .site-nav.is-open { display: flex; }   /* hamburger abierto: mostrar nav */
  .header-search { display: none; }
  .hamburger { display: flex; }

  .site-footer__grid { grid-template-columns: 1fr; gap: var(--space-8); }
  .footer-bottom { flex-direction: column; align-items: flex-start; }

  .hero { padding-block: var(--space-12); }

  .search-bar { padding: var(--space-2) var(--space-2) var(--space-2) var(--space-4); }
  .search-bar__btn { padding: var(--space-3) var(--space-4); font-size: var(--text-xs); }

  .section { padding-block: var(--space-10); }
  .section-header { flex-direction: column; align-items: flex-start; }
}

/* ────────────────────────────────────────────────────────────
   20. ACCESIBILIDAD
   ──────────────────────────────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    transition-duration: 0.01ms !important;
  }
}

:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}

/* ════════════════════════════════════════════════════════════
   RONDA 3 — NUEVOS COMPONENTES
   ════════════════════════════════════════════════════════════ */

/* ────────────────────────────────────────────────────────────
   21. MENÚ MÓVIL — Panel desplegable
   ──────────────────────────────────────────────────────────── */
.mobile-menu {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 200;
  pointer-events: none;
}
.mobile-menu.is-open { pointer-events: all; }

.mobile-menu__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(45, 45, 45, 0.45);
  backdrop-filter: blur(2px);
  opacity: 0;
  transition: opacity var(--transition-base);
}
.mobile-menu.is-open .mobile-menu__backdrop { opacity: 1; }

.mobile-menu__panel {
  position: absolute;
  top: 0; right: 0;
  width: min(320px, 85vw);
  height: 100%;
  background: var(--color-surface);
  padding: var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
  transform: translateX(100%);
  transition: transform var(--transition-base);
  overflow-y: auto;
  box-shadow: var(--shadow-xl);
}
.mobile-menu.is-open .mobile-menu__panel { transform: translateX(0); }

.mobile-menu__header {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.mobile-menu__close {
  width: 40px; height: 40px;
  border: none;
  background: var(--color-bg);
  border-radius: var(--radius-full);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-text);
  transition: background var(--transition-fast);
}
.mobile-menu__close:hover { background: var(--color-border); }
.mobile-menu__close svg { width: 18px; height: 18px; }

.mobile-menu__search {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-4);
  background: var(--color-bg);
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-full);
}
.mobile-menu__search input {
  flex: 1; border: none; background: transparent;
  font-size: var(--text-sm); color: var(--color-text);
  outline: none; font-family: var(--font-body);
}
.mobile-menu__search input::placeholder { color: var(--color-text-soft); }

.mobile-nav { display: flex; flex-direction: column; gap: var(--space-1); }

.mobile-nav__link {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-4);
  font-size: var(--text-md);
  font-weight: 500;
  color: var(--color-text);
  border-radius: var(--radius-lg);
  transition: all var(--transition-fast);
  text-decoration: none;
}
.mobile-nav__link:hover,
.mobile-nav__link--active {
  background: var(--color-primary-bg);
  color: var(--color-primary-dark);
}
.mobile-nav__link svg { width: 20px; height: 20px; color: var(--color-text-soft); }
.mobile-nav__link--active svg { color: var(--color-primary); }

.mobile-menu__cats { border-top: 1px solid var(--color-border); padding-top: var(--space-5); }
.mobile-menu__cats-title {
  font-size: 0.65rem; font-weight: 600;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--color-text-soft); margin-bottom: var(--space-3);
}
.mobile-cats-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-2); }

.mobile-cat-chip {
  display: flex; align-items: center; justify-content: center;
  padding: var(--space-3);
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  font-size: var(--text-sm);
  color: var(--color-text);
  text-decoration: none;
  transition: all var(--transition-fast);
  text-align: center;
}
.mobile-cat-chip:hover {
  background: var(--color-primary-bg);
  border-color: var(--color-primary-light);
  color: var(--color-primary-dark);
}

.hamburger.is-open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.hamburger.is-open span:nth-child(2) { opacity: 0; }
.hamburger.is-open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

@media (max-width: 640px) { .mobile-menu { display: block; } }

/* ────────────────────────────────────────────────────────────
   22. FICHA DE RECETA
   ──────────────────────────────────────────────────────────── */
.recipe-hero { padding-block: var(--space-8) 0; }

.recipe-hero__image {
  width: 100%;
  aspect-ratio: 3/2;
  overflow: hidden;
  border-radius: var(--radius-xl);
  margin-top: var(--space-8);
  box-shadow: var(--shadow-lg);
}
.recipe-hero__image img { width: 100%; height: 100%; object-fit: cover; }

.recipe-header { display: flex; flex-direction: column; gap: var(--space-5); max-width: 760px; }
.recipe-header__tags { display: flex; gap: var(--space-2); flex-wrap: wrap; }
.recipe-header__title {
  font-family: var(--font-heading);
  font-size: clamp(var(--text-3xl), 4vw, var(--text-5xl));
  line-height: 1.1; color: var(--color-text);
}
.recipe-header__intro {
  font-size: var(--text-md); color: var(--color-text-soft);
  line-height: 1.7; font-weight: 300; margin-bottom: 0;
}

.recipe-stats {
  display: flex; gap: var(--space-2); flex-wrap: wrap;
  padding: var(--space-5) var(--space-6);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-xs);
}
.recipe-stat {
  flex: 1; min-width: 100px;
  display: flex; flex-direction: column;
  align-items: center; gap: var(--space-1);
  padding: var(--space-3) var(--space-4);
  border-radius: var(--radius-lg); text-align: center;
}
.recipe-stat + .recipe-stat { border-left: 1px solid var(--color-border); }
.recipe-stat__icon { font-size: 1.4rem; line-height: 1; }
.recipe-stat__value { font-family: var(--font-heading); font-size: var(--text-xl); color: var(--color-text); line-height: 1; }
.recipe-stat__label { font-size: var(--text-xs); color: var(--color-text-soft); text-transform: uppercase; letter-spacing: 0.06em; font-weight: 500; }

.recipe-layout {
  display: grid; grid-template-columns: 1fr 2fr;
  gap: var(--space-12); align-items: start;
  padding-block: var(--space-12);
}

.recipe-ingredients { position: sticky; top: calc(var(--header-height) + var(--space-6)); }
.recipe-ingredients__card {
  background: var(--color-surface); border: 1px solid var(--color-border);
  border-radius: var(--radius-xl); overflow: hidden; box-shadow: var(--shadow-sm);
}
.recipe-ingredients__header {
  padding: var(--space-5) var(--space-6);
  background: var(--color-primary-bg);
  border-bottom: 1px solid var(--color-border);
  display: flex; justify-content: space-between; align-items: center;
}
.recipe-ingredients__title { font-family: var(--font-heading); font-size: var(--text-xl); color: var(--color-primary-dark); }

.portions-control { display: flex; align-items: center; gap: var(--space-2); }
.portions-btn {
  width: 28px; height: 28px;
  border: 1.5px solid var(--color-primary-light); border-radius: var(--radius-full);
  background: var(--color-surface); color: var(--color-primary-dark);
  font-size: var(--text-base); font-weight: 600; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: all var(--transition-fast); line-height: 1;
}
.portions-btn:hover { background: var(--color-primary); color: #fff; border-color: var(--color-primary); }
.portions-count { font-size: var(--text-sm); font-weight: 500; min-width: 28px; text-align: center; color: var(--color-text); }

.recipe-ingredients__list { padding: var(--space-4) var(--space-6) var(--space-6); }
.ingredient-item {
  display: flex; align-items: center; gap: var(--space-3);
  padding-block: var(--space-3);
  border-bottom: 1px solid var(--color-border);
  font-size: var(--text-sm);
}
.ingredient-item:last-child { border-bottom: none; }
.ingredient-item__amount { font-weight: 600; color: var(--color-secondary); min-width: 60px; font-size: var(--text-sm); }
.ingredient-item__name { color: var(--color-text); flex: 1; }
.ingredient-item__check {
  width: 18px; height: 18px;
  border: 1.5px solid var(--color-border-dark); border-radius: 4px;
  flex-shrink: 0; cursor: pointer; transition: all var(--transition-fast);
  appearance: none; -webkit-appearance: none; position: relative;
}
.ingredient-item__check:checked { background: var(--color-primary); border-color: var(--color-primary); }
.ingredient-item__check:checked::after {
  content: ''; position: absolute;
  left: 3px; top: 1px; width: 9px; height: 6px;
  border-left: 2px solid #fff; border-bottom: 2px solid #fff;
  transform: rotate(-45deg);
}

.recipe-steps__title {
  font-family: var(--font-heading); font-size: var(--text-2xl);
  color: var(--color-text); margin-bottom: var(--space-8);
  padding-bottom: var(--space-4); border-bottom: 2px solid var(--color-border);
}
.recipe-step {
  display: flex; gap: var(--space-6);
  margin-bottom: var(--space-8); padding-bottom: var(--space-8);
  border-bottom: 1px solid var(--color-border);
}
.recipe-step:last-child { border-bottom: none; margin-bottom: 0; }
.recipe-step__number {
  flex-shrink: 0; width: 40px; height: 40px;
  background: var(--color-secondary); color: #fff;
  border-radius: var(--radius-full);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-heading); font-size: var(--text-lg); margin-top: 2px;
}
.recipe-step__content { flex: 1; }
.recipe-step__text { font-size: var(--text-md); line-height: 1.75; color: var(--color-text); margin-bottom: 0; }
.recipe-step__tip {
  margin-top: var(--space-3); padding: var(--space-3) var(--space-4);
  background: var(--color-secondary-bg);
  border-left: 3px solid var(--color-secondary);
  border-radius: 0 var(--radius-md) var(--radius-md) 0;
  font-size: var(--text-sm); color: var(--color-secondary-dark);
}

.chef-notes {
  background: linear-gradient(135deg, var(--color-primary-bg) 0%, #fff 100%);
  border: 1px solid var(--color-primary-light);
  border-radius: var(--radius-xl);
  padding: var(--space-8); margin-block: var(--space-10);
  position: relative; overflow: hidden;
}
.chef-notes::before {
  content: '"'; position: absolute; top: -10px; left: var(--space-6);
  font-family: var(--font-heading); font-size: 8rem; color: var(--color-primary-light);
  line-height: 1; pointer-events: none; opacity: 0.5;
}
.chef-notes__header { display: flex; align-items: center; gap: var(--space-3); margin-bottom: var(--space-4); position: relative; z-index: 1; }
.chef-notes__icon { font-size: 1.5rem; }
.chef-notes__title { font-family: var(--font-heading); font-size: var(--text-xl); color: var(--color-primary-dark); }
.chef-notes__body { font-size: var(--text-md); line-height: 1.7; color: var(--color-text); position: relative; z-index: 1; margin-bottom: 0; }

.recipe-nav {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: var(--space-4); margin-block: var(--space-12);
  padding-top: var(--space-8); border-top: 1px solid var(--color-border);
}
.recipe-nav__item {
  display: flex; flex-direction: column; gap: var(--space-2);
  padding: var(--space-5) var(--space-6);
  background: var(--color-surface); border: 1.5px solid var(--color-border);
  border-radius: var(--radius-xl); text-decoration: none;
  transition: all var(--transition-base);
}
.recipe-nav__item:hover {
  border-color: var(--color-primary-light);
  box-shadow: var(--shadow-md); transform: translateY(-2px);
}
.recipe-nav__item--next { text-align: right; }
.recipe-nav__label {
  font-size: var(--text-xs); font-weight: 600;
  letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--color-text-soft);
  display: flex; align-items: center; gap: var(--space-2);
}
.recipe-nav__item--next .recipe-nav__label { justify-content: flex-end; }
.recipe-nav__title {
  font-family: var(--font-heading); font-size: var(--text-lg);
  color: var(--color-text); line-height: 1.3; transition: color var(--transition-fast);
}
.recipe-nav__item:hover .recipe-nav__title { color: var(--color-primary-dark); }

/* ────────────────────────────────────────────────────────────
   23. ADMIN — Layout y componentes
   ──────────────────────────────────────────────────────────── */
:root {
  --admin-sidebar-width: 240px;
  --admin-header-height: 60px;
}

.admin-layout { display: flex; min-height: 100vh; background: #F2F0EC; font-family: var(--font-body); }

.admin-sidebar {
  width: var(--admin-sidebar-width); min-height: 100vh;
  background: var(--color-text);
  display: flex; flex-direction: column;
  position: fixed; top: 0; left: 0; z-index: 50; overflow-y: auto;
}
.admin-sidebar__brand { padding: var(--space-6); border-bottom: 1px solid rgba(255,255,255,0.07); }
.admin-sidebar__brand .logo__icon { background: var(--color-secondary); }
.admin-sidebar__brand .logo__pre  { color: rgba(255,255,255,0.4); }
.admin-sidebar__brand .logo__name { color: #fff; }

.admin-sidebar__section-title {
  font-size: 0.65rem; font-weight: 600;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: rgba(255,255,255,0.3);
  padding: var(--space-5) var(--space-6) var(--space-2);
}

.admin-nav { flex: 1; padding: var(--space-3); display: flex; flex-direction: column; gap: var(--space-1); }
.admin-nav__link {
  display: flex; align-items: center; gap: var(--space-3);
  padding: var(--space-3) var(--space-4);
  font-size: var(--text-sm); font-weight: 400;
  color: rgba(255,255,255,0.62);
  border-radius: var(--radius-lg); transition: all var(--transition-fast); text-decoration: none;
}
.admin-nav__link svg { width: 18px; height: 18px; flex-shrink: 0; }
.admin-nav__link:hover { background: rgba(255,255,255,0.07); color: rgba(255,255,255,0.9); }
.admin-nav__link--active { background: var(--color-primary); color: #fff; }
.admin-nav__link--active:hover { background: var(--color-primary-dark); color: #fff; }
.admin-nav__divider { height: 1px; background: rgba(255,255,255,0.07); margin-block: var(--space-2); }
.admin-nav__link--danger { color: rgba(201,96,90,0.75); }
.admin-nav__link--danger:hover { background: rgba(201,96,90,0.12); color: #e07070; }

.admin-main { margin-left: var(--admin-sidebar-width); flex: 1; display: flex; flex-direction: column; min-height: 100vh; }

.admin-topbar {
  height: var(--admin-header-height);
  background: var(--color-surface); border-bottom: 1px solid var(--color-border);
  display: flex; align-items: center; justify-content: space-between;
  padding-inline: var(--space-8);
  position: sticky; top: 0; z-index: 40; box-shadow: var(--shadow-xs);
}
.admin-topbar__breadcrumb { display: flex; align-items: center; gap: var(--space-2); font-size: var(--text-sm); color: var(--color-text-soft); }
.admin-topbar__breadcrumb span { color: var(--color-text); font-weight: 500; }
.admin-topbar__actions { display: flex; align-items: center; gap: var(--space-3); }

.admin-user-chip {
  display: flex; align-items: center; gap: var(--space-2);
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-full);
  background: var(--color-bg); border: 1px solid var(--color-border);
  font-size: var(--text-sm); color: var(--color-text);
  cursor: pointer; transition: background var(--transition-fast);
}
.admin-user-chip:hover { background: var(--color-border); }
.admin-avatar {
  width: 28px; height: 28px; background: var(--color-primary);
  border-radius: var(--radius-full);
  display: flex; align-items: center; justify-content: center;
  font-size: var(--text-xs); font-weight: 600; color: #fff;
}

.admin-content { padding: var(--space-8); flex: 1; }
.admin-page-header {
  display: flex; justify-content: space-between; align-items: flex-start;
  margin-bottom: var(--space-8); gap: var(--space-4); flex-wrap: wrap;
}
.admin-page-title { font-family: var(--font-heading); font-size: var(--text-2xl); color: var(--color-text); font-weight: 400; }
.admin-page-subtitle { font-size: var(--text-sm); color: var(--color-text-soft); margin-top: var(--space-1); }

.admin-stats { display: grid; grid-template-columns: repeat(4,1fr); gap: var(--space-4); margin-bottom: var(--space-8); }
.admin-stat-card {
  background: var(--color-surface); border: 1px solid var(--color-border);
  border-radius: var(--radius-xl); padding: var(--space-5) var(--space-6);
  display: flex; align-items: center; gap: var(--space-4);
}
.admin-stat-card__icon {
  width: 44px; height: 44px; border-radius: var(--radius-lg);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.3rem; flex-shrink: 0;
}
.admin-stat-card__icon--green  { background: var(--color-primary-bg); }
.admin-stat-card__icon--orange { background: var(--color-secondary-bg); }
.admin-stat-card__icon--blue   { background: #EBF3FA; }
.admin-stat-card__icon--purple { background: #F0EBFA; }
.admin-stat-card__value { font-family: var(--font-heading); font-size: var(--text-2xl); color: var(--color-text); line-height: 1; }
.admin-stat-card__label { font-size: var(--text-xs); color: var(--color-text-soft); text-transform: uppercase; letter-spacing: 0.06em; font-weight: 500; margin-top: var(--space-1); }

.admin-card { background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-xl); overflow: hidden; box-shadow: var(--shadow-xs); }
.admin-card__header {
  padding: var(--space-5) var(--space-6); border-bottom: 1px solid var(--color-border);
  display: flex; align-items: center; justify-content: space-between; gap: var(--space-4); flex-wrap: wrap;
}
.admin-card__title { font-size: var(--text-base); font-weight: 600; color: var(--color-text); }

.admin-search { display: flex; gap: var(--space-3); flex-wrap: wrap; }
.admin-search__input {
  padding: var(--space-2) var(--space-4);
  border: 1.5px solid var(--color-border); border-radius: var(--radius-md);
  background: var(--color-bg); font-size: var(--text-sm); color: var(--color-text);
  outline: none; font-family: var(--font-body); width: 260px;
  transition: border-color var(--transition-fast);
}
.admin-search__input:focus { border-color: var(--color-primary); }
.admin-search__input::placeholder { color: var(--color-text-soft); }
.admin-search__select {
  padding: var(--space-2) var(--space-4);
  border: 1.5px solid var(--color-border); border-radius: var(--radius-md);
  background: var(--color-bg); font-size: var(--text-sm); color: var(--color-text);
  outline: none; font-family: var(--font-body); cursor: pointer;
}

.admin-table { width: 100%; border-collapse: collapse; }
.admin-table th {
  padding: var(--space-3) var(--space-5); text-align: left;
  font-size: var(--text-xs); font-weight: 600;
  letter-spacing: 0.06em; text-transform: uppercase;
  color: var(--color-text-soft); background: var(--color-bg);
  border-bottom: 1px solid var(--color-border); white-space: nowrap;
}
.admin-table td {
  padding: var(--space-4) var(--space-5); font-size: var(--text-sm);
  color: var(--color-text); border-bottom: 1px solid var(--color-border); vertical-align: middle;
}
.admin-table tr:last-child td { border-bottom: none; }
.admin-table tr:hover td { background: rgba(122,158,126,0.04); }
.admin-table__thumb { width: 48px; height: 36px; border-radius: var(--radius-sm); object-fit: cover; display: block; }
.admin-table__title { font-weight: 500; color: var(--color-text); max-width: 280px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.admin-table__actions { display: flex; align-items: center; gap: var(--space-2); }

.admin-action-btn {
  width: 32px; height: 32px;
  border: 1.5px solid var(--color-border); border-radius: var(--radius-md);
  background: var(--color-surface); cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: all var(--transition-fast); color: var(--color-text-soft);
  text-decoration: none;
}
.admin-action-btn svg { width: 14px; height: 14px; }
.admin-action-btn:hover { background: var(--color-bg); color: var(--color-text); border-color: var(--color-border-dark); }
.admin-action-btn--edit:hover  { color: var(--color-primary-dark); border-color: var(--color-primary-light); background: var(--color-primary-bg); }
.admin-action-btn--delete:hover { color: var(--color-error); border-color: #f5c0bc; background: #fdf2f1; }

.admin-table-footer {
  padding: var(--space-4) var(--space-6); border-top: 1px solid var(--color-border);
  display: flex; justify-content: space-between; align-items: center;
  gap: var(--space-4); flex-wrap: wrap; background: var(--color-bg);
}
.admin-table-count { font-size: var(--text-sm); color: var(--color-text-soft); }

.admin-login-page {
  min-height: 100vh;
  background: linear-gradient(135deg, #2D2D2D 0%, #3D3530 100%);
  display: flex; align-items: center; justify-content: center;
  padding: var(--space-6); position: relative; overflow: hidden;
}
.admin-login-page::before {
  content: ''; position: absolute; top: -100px; right: -100px;
  width: 500px; height: 500px;
  background: radial-gradient(circle, rgba(122,158,126,0.12) 0%, transparent 70%);
  pointer-events: none;
}
.admin-login-page::after {
  content: ''; position: absolute; bottom: -80px; left: -80px;
  width: 400px; height: 400px;
  background: radial-gradient(circle, rgba(201,123,90,0.10) 0%, transparent 70%);
  pointer-events: none;
}
.admin-login-card {
  background: var(--color-surface); border-radius: var(--radius-xl);
  padding: var(--space-10); width: 100%; max-width: 420px;
  box-shadow: var(--shadow-xl); position: relative; z-index: 1;
}
.admin-login-card__brand {
  text-align: center; margin-bottom: var(--space-8);
  display: flex; flex-direction: column; align-items: center; gap: var(--space-3);
}
.admin-login-card__logo {
  width: 56px; height: 56px; background: var(--color-secondary);
  border-radius: var(--radius-lg);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-heading); font-size: 1.8rem; color: #fff;
}
.admin-login-card__title { font-family: var(--font-heading); font-size: var(--text-2xl); color: var(--color-text); }
.admin-login-card__subtitle { font-size: var(--text-sm); color: var(--color-text-soft); margin-bottom: 0; }
.admin-login-error {
  background: #fdf2f1; border: 1px solid #f5c0bc; border-radius: var(--radius-md);
  padding: var(--space-3) var(--space-4); font-size: var(--text-sm); color: var(--color-error);
  margin-bottom: var(--space-5); display: flex; align-items: center; gap: var(--space-2);
}

/* Responsive admin */
@media (max-width: 900px) {
  .admin-stats { grid-template-columns: repeat(2, 1fr); }
  .admin-search__input { width: 200px; }
}
@media (max-width: 640px) {
  :root { --admin-sidebar-width: 0px; }
  .admin-sidebar { transform: translateX(-100%); }
  .admin-main { margin-left: 0; }
  .admin-stats { grid-template-columns: 1fr 1fr; }
  .admin-content { padding: var(--space-4); }
  .admin-topbar { padding-inline: var(--space-4); }
}

/* ────────────────────────────────────────────────────────────
   24. RESPONSIVE FICHA RECETA
   ──────────────────────────────────────────────────────────── */
@media (max-width: 900px) {
  .recipe-layout { grid-template-columns: 1fr; gap: var(--space-8); }
  .recipe-ingredients { position: static; }
  .recipe-stat + .recipe-stat { border-left: none; border-top: 1px solid var(--color-border); }
  .recipe-stats { flex-direction: column; }
  .recipe-stat { flex-direction: row; align-items: center; justify-content: space-between; }
}
@media (max-width: 640px) {
  .recipe-nav { grid-template-columns: 1fr; }
  .recipe-stats { flex-direction: row; flex-wrap: wrap; }
  .recipe-stat { flex: 1 1 40%; border: none !important; }
}

/* ════════════════════════════════════════════════════════════
   RONDA 4 — NUEVOS COMPONENTES
   ════════════════════════════════════════════════════════════ */

/* ────────────────────────────────────────────────────────────
   25. ADMIN SIDEBAR RESPONSIVE (overlay móvil)
   ──────────────────────────────────────────────────────────── */
.admin-sidebar-toggle {
  display: none;
  width: 40px; height: 40px;
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  cursor: pointer;
  align-items: center;
  justify-content: center;
  color: var(--color-text);
  transition: background var(--transition-fast);
  flex-shrink: 0;
}
.admin-sidebar-toggle:hover { background: var(--color-border); }
.admin-sidebar-toggle svg { width: 18px; height: 18px; }

.admin-sidebar-backdrop {
  display: none;
  position: fixed; inset: 0; z-index: 49;
  background: rgba(45,45,45,0.5);
  backdrop-filter: blur(2px);
  opacity: 0;
  transition: opacity var(--transition-base);
}
.admin-sidebar-backdrop.is-visible { opacity: 1; }

@media (max-width: 900px) {
  :root { --admin-sidebar-width: 240px; }

  .admin-sidebar-toggle { display: flex; }
  .admin-sidebar-backdrop { display: block; }

  .admin-sidebar {
    transform: translateX(-100%);
    transition: transform var(--transition-base);
    z-index: 50;
  }
  .admin-sidebar.is-open { transform: translateX(0); }

  .admin-main { margin-left: 0; }
  .admin-topbar { padding-inline: var(--space-4); gap: var(--space-3); }
  .admin-content { padding: var(--space-5); }
  .admin-stats { grid-template-columns: 1fr 1fr; }
  .admin-page-header { flex-direction: column; align-items: flex-start; }
}

@media (max-width: 560px) {
  .admin-stats { grid-template-columns: 1fr; }
  .admin-search { flex-direction: column; }
  .admin-search__input { width: 100%; }
}

/* ────────────────────────────────────────────────────────────
   26. FORMULARIO ADMIN — Componentes de alta/edición
   ──────────────────────────────────────────────────────────── */

/* Layout de formulario de dos columnas */
.admin-form-layout {
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: var(--space-6);
  align-items: start;
}

.admin-form-main  { display: flex; flex-direction: column; gap: var(--space-5); }
.admin-form-aside { display: flex; flex-direction: column; gap: var(--space-5); position: sticky; top: calc(var(--admin-header-height) + var(--space-4)); }

/* Tarjeta de sección del formulario */
.admin-form-card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  overflow: hidden;
}

.admin-form-card__header {
  padding: var(--space-4) var(--space-6);
  border-bottom: 1px solid var(--color-border);
  background: var(--color-bg);
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

.admin-form-card__icon {
  width: 32px; height: 32px;
  background: var(--color-primary-bg);
  border-radius: var(--radius-md);
  display: flex; align-items: center; justify-content: center;
  font-size: 1rem; flex-shrink: 0;
}

.admin-form-card__title {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-text);
}

.admin-form-card__body { padding: var(--space-6); }

/* Grid de campos */
.form-grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-4); }
.form-grid-3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: var(--space-4); }
.form-grid-4 { display: grid; grid-template-columns: repeat(4,1fr); gap: var(--space-4); }
.form-col-full { grid-column: 1 / -1; }

.form-group { display: flex; flex-direction: column; gap: var(--space-2); }
.form-label {
  font-size: var(--text-sm); font-weight: 500; color: var(--color-text);
  display: flex; align-items: center; gap: var(--space-2);
}
.form-label--required::after {
  content: '*'; color: var(--color-secondary); font-size: var(--text-sm);
}
.form-hint { font-size: var(--text-xs); color: var(--color-text-soft); }

/* Slug field */
.slug-field {
  display: flex;
  align-items: center;
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-bg);
  overflow: hidden;
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}
.slug-field:focus-within {
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(122,158,126,0.15);
  background: var(--color-surface);
}
.slug-field__prefix {
  padding: var(--space-3) var(--space-3) var(--space-3) var(--space-4);
  font-size: var(--text-sm); color: var(--color-text-soft);
  white-space: nowrap; user-select: none;
  border-right: 1px solid var(--color-border);
  background: var(--color-bg);
}
.slug-field__input {
  flex: 1; border: none; background: transparent;
  padding: var(--space-3) var(--space-4);
  font-size: var(--text-sm); color: var(--color-text);
  outline: none; font-family: var(--font-body);
  font-family: 'Courier New', monospace;
}

/* Dificultad — radio visual */
.difficulty-selector { display: flex; gap: var(--space-2); }
.difficulty-option { flex: 1; }
.difficulty-option input[type="radio"] { position: absolute; opacity: 0; width: 0; }
.difficulty-option label {
  display: flex; align-items: center; justify-content: center;
  padding: var(--space-3);
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-md);
  font-size: var(--text-sm); font-weight: 500;
  color: var(--color-text-soft);
  cursor: pointer;
  transition: all var(--transition-fast);
  text-align: center; gap: var(--space-2);
}
.difficulty-option input:checked + label {
  border-color: var(--color-primary);
  background: var(--color-primary-bg);
  color: var(--color-primary-dark);
}
.difficulty-option label:hover { border-color: var(--color-primary-light); }

/* Uploader de imagen */
.image-uploader {
  border: 2px dashed var(--color-border);
  border-radius: var(--radius-xl);
  padding: var(--space-8);
  text-align: center;
  cursor: pointer;
  transition: all var(--transition-base);
  position: relative;
  background: var(--color-bg);
}
.image-uploader:hover, .image-uploader.drag-over {
  border-color: var(--color-primary);
  background: var(--color-primary-bg);
}
.image-uploader__icon { font-size: 2.5rem; margin-bottom: var(--space-3); }
.image-uploader__text { font-size: var(--text-sm); color: var(--color-text-soft); line-height: 1.6; }
.image-uploader__text strong { color: var(--color-primary-dark); }
.image-uploader__hint { font-size: var(--text-xs); color: var(--color-text-soft); margin-top: var(--space-2); }
.image-uploader input[type="file"] { position: absolute; inset: 0; opacity: 0; cursor: pointer; width: 100%; height: 100%; }

.image-preview {
  position: relative;
  border-radius: var(--radius-xl);
  overflow: hidden;
  aspect-ratio: 3/2;
  border: 1px solid var(--color-border);
}
.image-preview img { width: 100%; height: 100%; object-fit: cover; }
.image-preview__replace {
  position: absolute; inset: 0;
  background: rgba(45,45,45,0.6);
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  gap: var(--space-2);
  opacity: 0;
  transition: opacity var(--transition-base);
  cursor: pointer;
}
.image-preview:hover .image-preview__replace { opacity: 1; }
.image-preview__replace-text {
  color: #fff; font-size: var(--text-sm); font-weight: 500;
}
.image-preview__replace input { position: absolute; inset: 0; opacity: 0; cursor: pointer; }

/* Editor WYSIWYG placeholder */
.wysiwyg-wrapper {
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-md);
  overflow: hidden;
  transition: border-color var(--transition-fast);
}
.wysiwyg-wrapper:focus-within { border-color: var(--color-primary); }

.wysiwyg-toolbar {
  display: flex;
  align-items: center;
  gap: var(--space-1);
  flex-wrap: wrap;
  padding: var(--space-2) var(--space-3);
  background: var(--color-bg);
  border-bottom: 1px solid var(--color-border);
}

.wysiwyg-btn {
  width: 30px; height: 30px;
  background: none; border: none;
  border-radius: var(--radius-sm);
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  color: var(--color-text-soft);
  font-size: var(--text-sm); font-weight: 600;
  transition: all var(--transition-fast);
}
.wysiwyg-btn:hover { background: var(--color-border); color: var(--color-text); }
.wysiwyg-btn.is-active { background: var(--color-primary-bg); color: var(--color-primary-dark); }

.wysiwyg-divider { width: 1px; height: 20px; background: var(--color-border); margin-inline: var(--space-1); }

.wysiwyg-area {
  min-height: 180px;
  padding: var(--space-4);
  background: var(--color-surface);
  outline: none;
  font-size: var(--text-sm);
  line-height: 1.7;
  color: var(--color-text);
  font-family: var(--font-body);
}
.wysiwyg-area:empty::before {
  content: attr(data-placeholder);
  color: var(--color-text-soft);
  pointer-events: none;
}
.wysiwyg-area ul { list-style: disc; padding-left: 1.5em; }
.wysiwyg-area ol { list-style: decimal; padding-left: 1.5em; }
.wysiwyg-area li { margin-bottom: var(--space-1); }
.wysiwyg-area strong { font-weight: 600; }
.wysiwyg-area em { font-style: italic; }

/* Selector de recetas relacionadas */
.related-search {
  position: relative;
}
.related-search__input-wrap {
  display: flex; align-items: center; gap: var(--space-2);
  padding: var(--space-3) var(--space-4);
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-surface);
  transition: border-color var(--transition-fast);
}
.related-search__input-wrap:focus-within { border-color: var(--color-primary); }
.related-search__input-wrap svg { width: 16px; height: 16px; color: var(--color-text-soft); flex-shrink: 0; }
.related-search__input {
  flex: 1; border: none; background: transparent;
  font-size: var(--text-sm); color: var(--color-text);
  outline: none; font-family: var(--font-body);
}
.related-search__input::placeholder { color: var(--color-text-soft); }

.related-dropdown {
  position: absolute; top: calc(100% + 4px); left: 0; right: 0;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
  z-index: 20;
  max-height: 240px;
  overflow-y: auto;
  display: none;
}
.related-dropdown.is-open { display: block; }

.related-option {
  display: flex; align-items: center; gap: var(--space-3);
  padding: var(--space-3) var(--space-4);
  cursor: pointer;
  transition: background var(--transition-fast);
  border-bottom: 1px solid var(--color-border);
}
.related-option:last-child { border-bottom: none; }
.related-option:hover { background: var(--color-primary-bg); }
.related-option img { width: 44px; height: 33px; border-radius: var(--radius-sm); object-fit: cover; flex-shrink: 0; }
.related-option__info { flex: 1; min-width: 0; }
.related-option__title { font-size: var(--text-sm); font-weight: 500; color: var(--color-text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.related-option__cat { font-size: var(--text-xs); color: var(--color-text-soft); }

.related-chips {
  display: flex; flex-wrap: wrap; gap: var(--space-2); margin-top: var(--space-3);
}
.related-chip {
  display: flex; align-items: center; gap: var(--space-2);
  padding: var(--space-2) var(--space-3);
  background: var(--color-primary-bg);
  border: 1px solid var(--color-primary-light);
  border-radius: var(--radius-full);
  font-size: var(--text-xs); font-weight: 500; color: var(--color-primary-dark);
}
.related-chip__remove {
  width: 16px; height: 16px; background: var(--color-primary-light);
  border-radius: var(--radius-full); border: none; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  color: var(--color-primary-dark); font-size: 0.7rem; line-height: 1;
  transition: background var(--transition-fast);
}
.related-chip__remove:hover { background: var(--color-primary); color: #fff; }

/* SEO colapsable */
.collapsible { overflow: hidden; transition: max-height var(--transition-slow); }
.collapsible[aria-hidden="true"] { max-height: 0; }
.collapsible[aria-hidden="false"] { max-height: 600px; }

.collapsible-trigger {
  display: flex; align-items: center; justify-content: space-between;
  width: 100%; background: none; border: none;
  padding: var(--space-4) var(--space-6);
  cursor: pointer; font-family: var(--font-body);
  border-bottom: 1px solid var(--color-border);
}
.collapsible-trigger:hover { background: var(--color-bg); }
.collapsible-trigger__label {
  display: flex; align-items: center; gap: var(--space-3);
  font-size: var(--text-sm); font-weight: 600; color: var(--color-text);
}
.collapsible-trigger__icon {
  width: 20px; height: 20px;
  transition: transform var(--transition-base);
  color: var(--color-text-soft);
}
.collapsible-trigger[aria-expanded="true"] .collapsible-trigger__icon { transform: rotate(180deg); }

/* Char counter */
.char-counter {
  font-size: var(--text-xs); color: var(--color-text-soft);
  text-align: right; margin-top: var(--space-1);
}
.char-counter.over { color: var(--color-error); }

/* Acciones sticky de formulario */
.admin-form-actions {
  position: sticky; bottom: 0;
  background: var(--color-surface);
  border-top: 1px solid var(--color-border);
  padding: var(--space-4) var(--space-8);
  display: flex; align-items: center; justify-content: space-between; gap: var(--space-4);
  box-shadow: 0 -4px 16px rgba(45,45,45,0.06);
  z-index: 30; margin-inline: calc(-1 * var(--space-8));
}

/* Responsive formulario */
@media (max-width: 900px) {
  .admin-form-layout { grid-template-columns: 1fr; }
  .admin-form-aside { position: static; }
  .form-grid-2, .form-grid-3, .form-grid-4 { grid-template-columns: 1fr; }
}

/* ────────────────────────────────────────────────────────────
   27. PÁGINA PÚBLICA: LISTADO RECETAS
   ──────────────────────────────────────────────────────────── */
.recipes-page-hero {
  background: linear-gradient(135deg, #EFF5F0 0%, #F7F4EF 60%, #FAF0EB 100%);
  padding-block: var(--space-12);
  text-align: center;
}

.recipes-filter-bar {
  background: var(--color-surface);
  border-bottom: 1px solid var(--color-border);
  padding-block: var(--space-5);
  position: sticky;
  top: var(--header-height);
  z-index: 10;
  box-shadow: var(--shadow-xs);
}

.recipes-filter-bar__inner {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  flex-wrap: wrap;
}

.filter-select {
  padding: var(--space-2) var(--space-4);
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-full);
  background: var(--color-surface);
  font-size: var(--text-sm);
  color: var(--color-text);
  font-family: var(--font-body);
  cursor: pointer;
  outline: none;
  transition: border-color var(--transition-fast);
  -webkit-appearance: none;
  padding-right: var(--space-8);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%238A8478' stroke-width='2.5'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
}
.filter-select:focus { border-color: var(--color-primary); }

.filter-divider { width: 1px; height: 20px; background: var(--color-border); flex-shrink: 0; }

.filter-count {
  font-size: var(--text-sm);
  color: var(--color-text-soft);
  margin-left: auto;
  white-space: nowrap;
}

.filter-search-inline {
  display: flex; align-items: center; gap: var(--space-2);
  padding: var(--space-2) var(--space-4) var(--space-2) var(--space-3);
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-full);
  background: var(--color-surface);
  transition: border-color var(--transition-fast);
  flex: 1; max-width: 320px;
}
.filter-search-inline:focus-within { border-color: var(--color-primary); }
.filter-search-inline svg { width: 16px; height: 16px; color: var(--color-text-soft); flex-shrink: 0; }
.filter-search-inline input {
  flex: 1; border: none; background: transparent;
  font-size: var(--text-sm); color: var(--color-text);
  outline: none; font-family: var(--font-body);
}

.recipes-empty {
  text-align: center; padding: var(--space-20) var(--space-6);
  display: none;
}
.recipes-empty__icon { font-size: 3rem; margin-bottom: var(--space-4); }
.recipes-empty__title { font-family: var(--font-heading); font-size: var(--text-2xl); margin-bottom: var(--space-3); }
.recipes-empty__text { color: var(--color-text-soft); font-size: var(--text-md); }

/* ────────────────────────────────────────────────────────────
   28. PÁGINA PÚBLICA: ARTÍCULO
   ──────────────────────────────────────────────────────────── */
.article-hero {
  padding-block: var(--space-10) 0;
}

.article-header { max-width: 760px; }

.article-header__tag {
  display: inline-flex; align-items: center; gap: var(--space-2);
  font-size: var(--text-xs); font-weight: 500; letter-spacing: 0.08em;
  text-transform: uppercase; color: var(--color-primary-dark);
  background: var(--color-primary-bg);
  border: 1px solid rgba(122,158,126,0.25);
  padding: var(--space-2) var(--space-4); border-radius: var(--radius-full);
  margin-bottom: var(--space-5);
}

.article-header__title {
  font-family: var(--font-heading);
  font-size: clamp(var(--text-3xl), 4vw, var(--text-4xl));
  line-height: 1.1; color: var(--color-text);
  margin-bottom: var(--space-5);
}

.article-meta {
  display: flex; align-items: center; gap: var(--space-5);
  flex-wrap: wrap; margin-bottom: var(--space-8);
}

.article-meta__item {
  display: flex; align-items: center; gap: var(--space-2);
  font-size: var(--text-sm); color: var(--color-text-soft);
}
.article-meta__item svg { width: 14px; height: 14px; }

.article-hero__image {
  width: 100%; aspect-ratio: 16/9;
  overflow: hidden; border-radius: var(--radius-xl);
  margin-top: var(--space-8); box-shadow: var(--shadow-lg);
}
.article-hero__image img { width: 100%; height: 100%; object-fit: cover; }

/* Cuerpo del artículo */
.article-layout {
  display: grid;
  grid-template-columns: 1fr 280px;
  gap: var(--space-16);
  align-items: start;
  padding-block: var(--space-12);
}

.article-body {
  font-size: var(--text-md);
  line-height: 1.85;
  color: var(--color-text);
}
.article-body h2 {
  font-family: var(--font-heading);
  font-size: var(--text-2xl);
  margin-top: var(--space-10); margin-bottom: var(--space-4);
  padding-bottom: var(--space-3);
  border-bottom: 2px solid var(--color-border);
}
.article-body h3 {
  font-family: var(--font-heading);
  font-size: var(--text-xl);
  margin-top: var(--space-8); margin-bottom: var(--space-3);
  color: var(--color-primary-dark);
}
.article-body p { margin-bottom: var(--space-5); }
.article-body ul, .article-body ol {
  padding-left: var(--space-6);
  margin-bottom: var(--space-5);
}
.article-body ul { list-style: disc; }
.article-body ol { list-style: decimal; }
.article-body li { margin-bottom: var(--space-2); }
.article-body strong { font-weight: 600; color: var(--color-text); }
.article-body em { font-style: italic; color: var(--color-text-soft); }

.article-body blockquote {
  margin: var(--space-8) 0;
  padding: var(--space-5) var(--space-6);
  background: var(--color-primary-bg);
  border-left: 4px solid var(--color-primary);
  border-radius: 0 var(--radius-lg) var(--radius-lg) 0;
  font-style: italic;
  color: var(--color-primary-dark);
}

.article-body .article-tip {
  margin: var(--space-8) 0;
  padding: var(--space-5) var(--space-6);
  background: var(--color-secondary-bg);
  border-left: 4px solid var(--color-secondary);
  border-radius: 0 var(--radius-lg) var(--radius-lg) 0;
}
.article-body .article-tip strong { color: var(--color-secondary-dark); }

/* Sidebar del artículo */
.article-sidebar {
  position: sticky;
  top: calc(var(--header-height) + var(--space-6));
  display: flex; flex-direction: column; gap: var(--space-5);
}

.article-sidebar-card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  overflow: hidden;
}

.article-sidebar-card__title {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  font-weight: 600; letter-spacing: 0.1em;
  text-transform: uppercase; color: var(--color-text-soft);
  padding: var(--space-4) var(--space-5);
  border-bottom: 1px solid var(--color-border);
  background: var(--color-bg);
}

.article-sidebar-card__body { padding: var(--space-5); }

/* Índice de contenidos */
.article-toc { display: flex; flex-direction: column; gap: var(--space-1); }
.article-toc a {
  font-size: var(--text-sm); color: var(--color-text-soft);
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-md);
  transition: all var(--transition-fast);
  display: block;
}
.article-toc a:hover { background: var(--color-primary-bg); color: var(--color-primary-dark); }
.article-toc a.active { background: var(--color-primary-bg); color: var(--color-primary-dark); font-weight: 500; }
.article-toc a.toc-h3 { padding-left: var(--space-6); font-size: var(--text-xs); }

/* Tags artículo */
.article-tags {
  display: flex; flex-wrap: wrap; gap: var(--space-2);
  padding-block: var(--space-8);
  border-top: 1px solid var(--color-border);
  border-bottom: 1px solid var(--color-border);
  margin-block: var(--space-8);
}
.article-tag {
  padding: var(--space-2) var(--space-4);
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-full);
  font-size: var(--text-xs); color: var(--color-text-soft);
  transition: all var(--transition-fast);
  text-decoration: none;
}
.article-tag:hover { background: var(--color-primary-bg); border-color: var(--color-primary-light); color: var(--color-primary-dark); }

/* Responsive artículo */
@media (max-width: 900px) {
  .article-layout { grid-template-columns: 1fr; gap: var(--space-8); }
  .article-sidebar { position: static; }
}
@media (max-width: 640px) {
  .recipes-filter-bar__inner { gap: var(--space-2); }
  .filter-search-inline { max-width: 100%; flex: 1 1 100%; order: -1; }
  .filter-count { display: none; }
}

/* ================================================================
   STATS BAR — barra de estadísticas de portada
   ================================================================ */
.stats-bar {
  background: var(--color-surface);
  border-top: 1px solid var(--color-border);
  border-bottom: 1px solid var(--color-border);
  padding-block: var(--space-5);
}
.stats-bar__inner {
  display: flex;
  justify-content: center;
  gap: var(--space-16);
  flex-wrap: wrap;
}
.stat {
  text-align: center;
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}
.stat__number {
  font-family: var(--font-heading);
  font-size: var(--text-2xl);
  color: var(--color-secondary);
  line-height: 1;
}
.stat__label {
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-text-soft);
  font-weight: 500;
}
@media (max-width: 600px) {
  .stats-bar__inner { gap: var(--space-8); }
}

/* ================================================================
   PORTADA — Estilos específicos de index.php (migrados del modelo)
   ================================================================ */

/* Filtros de recetas */
.filter-tabs {
  display: flex;
  gap: var(--space-2);
  flex-wrap: wrap;
  margin-bottom: var(--space-8);
}
.filter-tab {
  padding: var(--space-2) var(--space-4);
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--color-text-soft);
  background: var(--color-surface);
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-full);
  cursor: pointer;
  transition: all var(--transition-fast);
  font-family: var(--font-body);
  text-decoration: none;
  display: inline-block;
}
.filter-tab:hover,
.filter-tab.active {
  color: var(--color-primary-dark);
  background: var(--color-primary-bg);
  border-color: var(--color-primary-light);
}

/* Tarjetas de artículo */
.article-card {
  display: flex;
  gap: var(--space-5);
  background: var(--color-surface);
  border-radius: var(--radius-xl);
  overflow: hidden;
  border: 1px solid var(--color-border);
  transition: transform var(--transition-base), box-shadow var(--transition-base);
}
.article-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-md);
}
.article-card__image {
  width: 180px;
  min-width: 180px;
  overflow: hidden;
}
.article-card__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transition-slow);
}
.article-card:hover .article-card__image img { transform: scale(1.05); }
.article-card__body {
  padding: var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  justify-content: center;
}
.article-card__tag {
  font-size: var(--text-xs);
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-primary-dark);
}
.article-card__title {
  font-family: var(--font-heading);
  font-size: var(--text-xl);
  line-height: 1.25;
  color: var(--color-text);
}
.article-card__excerpt {
  font-size: var(--text-sm);
  color: var(--color-text-soft);
  line-height: 1.6;
}
.article-card__date {
  font-size: var(--text-xs);
  color: var(--color-text-soft);
}
.article-card__byline {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  flex-wrap: wrap;
  margin-top: var(--space-2);
}
.article-card__author {
  font-size: var(--text-xs);
  color: var(--color-text-soft);
  font-style: italic;
}
.grid-articles {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-5);
}

/* Promo banner */
.promo-banner {
  background: linear-gradient(135deg, var(--color-primary) 0%, #5E8262 100%);
  border-radius: var(--radius-xl);
  padding: var(--space-12) var(--space-16);
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-8);
  overflow: hidden;
  position: relative;
}
.promo-banner::before {
  content: '🍳';
  position: absolute;
  right: var(--space-16);
  top: 50%;
  transform: translateY(-50%);
  font-size: 8rem;
  opacity: 0.12;
  pointer-events: none;
}
.promo-banner__title {
  font-family: var(--font-heading);
  font-size: var(--text-3xl);
  color: #fff;
  line-height: 1.2;
  max-width: 480px;
}
.promo-banner__title em { font-style: italic; color: rgba(255,255,255,0.85); }
.promo-banner__actions { display: flex; gap: var(--space-3); flex-shrink: 0; }
.btn--white { background: #fff; color: var(--color-primary-dark); border-color: #fff; }
.btn--white:hover { background: rgba(255,255,255,0.9); color: var(--color-primary-dark); }
.btn--outline-white { background: transparent; color: #fff; border-color: rgba(255,255,255,0.6); }
.btn--outline-white:hover { background: rgba(255,255,255,0.1); color: #fff; }

/* Footer nuevo */
.site-footer__grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1.5fr;
  gap: var(--space-12);
  padding-block: var(--space-12);
}
.footer-desc {
  font-size: var(--text-sm);
  color: rgba(255,255,255,0.5);
  margin-top: var(--space-4);
  line-height: 1.6;
}
.footer-col__title {
  font-size: var(--text-xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: rgba(255,255,255,0.4);
  margin-bottom: var(--space-4);
}
.footer-links {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}
.footer-links a {
  font-size: var(--text-sm);
  color: rgba(255,255,255,0.6);
  text-decoration: none;
  transition: color var(--transition-fast);
}
.footer-links a:hover { color: #fff; }
.footer-bottom {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-block: var(--space-5);
  border-top: 1px solid rgba(255,255,255,0.08);
  flex-wrap: wrap;
  gap: var(--space-4);
}
.footer-copy {
  font-size: var(--text-xs);
  color: rgba(255,255,255,0.35);
}
.footer-legal {
  display: flex;
  gap: var(--space-6);
}
.footer-legal a {
  font-size: var(--text-xs);
  color: rgba(255,255,255,0.35);
  text-decoration: none;
  transition: color var(--transition-fast);
}
.footer-legal a:hover { color: rgba(255,255,255,0.7); }

/* Responsive portada */
@media (max-width: 900px) {
  .grid-articles { grid-template-columns: 1fr; }
  .site-footer__grid { grid-template-columns: 1fr 1fr; gap: var(--space-8); }
}
@media (max-width: 640px) {
  /* Artículos: layout vertical con imagen arriba en lugar de lateral */
  .article-card { flex-direction: column; }
  .article-card__image {
    width: 100%;
    min-width: 0;
    height: 180px;
  }
  .promo-banner { padding: var(--space-8); flex-direction: column; text-align: center; }
  .promo-banner::before { display: none; }
  .promo-banner__actions { justify-content: center; }
  .site-footer__grid { grid-template-columns: 1fr; }
}

/* ── Fix: navegación principal ── */
.site-nav__list {
  display: flex;
  align-items: center;
  gap: var(--space-1);
  list-style: none;
  margin: 0;
  padding: 0;
}

.site-nav__toggle {
  display: none;
}

@media (max-width: 768px) {
  .site-nav__list {
    display: none;
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    flex-direction: column;
    align-items: flex-start;
    background: var(--color-surface);
    border-bottom: 1px solid var(--color-border);
    padding: var(--space-4) var(--space-6);
    gap: 0;
    box-shadow: var(--shadow-md);
    z-index: 100;
  }
  .site-nav__list.is-open {
    display: flex;
  }
  .site-nav__list li {
    width: 100%;
  }
  .site-nav__list .site-nav__link {
    display: block;
    padding: var(--space-3) var(--space-2);
  }
}

/* ════════════════════════════════════════════════════════════
   RONDA 7 — FICHA DE RECETA, WYSIWYG, RELACIONADAS,
              NAVEGACIÓN ANT/SIG, FICHA DE ARTÍCULO
   ════════════════════════════════════════════════════════════ */

/* ── Bloque 0: breadcrumb (fix selector faltante) ─────────── */
.breadcrumb__list {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-1);
  list-style: none;
  margin: 0;
  padding: 0;
}

/* ── Bloque 1: Ficha de receta ────────────────────────────── */
.receta-ficha {
  max-width: 900px;
  margin-inline: auto;
  padding-block: var(--space-10);
}

.receta-ficha__header {
  margin-bottom: var(--space-6);
}

.receta-ficha__meta-top {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  flex-wrap: wrap;
  margin-bottom: var(--space-4);
}

.receta-ficha__categoria-tag,
.receta-ficha__subcategoria-tag {
  display: inline-block;
  padding: var(--space-1) var(--space-3);
  font-size: var(--text-xs);
  font-weight: 500;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--color-primary-dark);
  background: var(--color-primary-bg);
  border: 1px solid var(--color-primary-light);
  border-radius: var(--radius-full);
  text-decoration: none;
  transition: background var(--transition-fast);
}
.receta-ficha__categoria-tag:hover,
.receta-ficha__subcategoria-tag:hover {
  background: var(--color-primary-light);
}

.receta-ficha__titulo {
  font-family: var(--font-heading);
  font-size: var(--text-4xl);
  line-height: 1.15;
  color: var(--color-text);
  margin-bottom: var(--space-4);
}

.receta-ficha__descripcion {
  font-size: var(--text-lg);
  color: var(--color-text-soft);
  line-height: 1.65;
  max-width: 65ch;
  margin-bottom: var(--space-6);
}

/* Barra de datos (preparación, cocción, total, porciones, dificultad) */
.receta-ficha__datos {
  display: flex;
  gap: 0;
  background: var(--color-surface);
  border-radius: var(--radius-xl);
  border: 1px solid var(--color-border);
  padding: var(--space-5) var(--space-6);
  flex-wrap: wrap;
  margin-bottom: var(--space-8);
}

.receta-dato {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-1);
  flex: 1;
  min-width: 90px;
  text-align: center;
  padding-inline: var(--space-3);
  position: relative;
}

@media (max-width: 640px) {
  .receta-ficha__datos {
    flex-wrap: nowrap;
    padding: var(--space-3) var(--space-2);
  }
  .receta-dato {
    min-width: 0;
    flex: 1 1 0;
    padding-inline: var(--space-1);
    gap: var(--space-1);
  }
  .receta-dato__label {
    display: none;
  }
  .receta-dato__icono {
    font-size: 1.4rem;
  }
  .receta-dato__valor {
    font-size: var(--text-sm);
    white-space: nowrap;
  }
}

/* Separador vertical entre datos */
.receta-dato + .receta-dato::before {
  content: '';
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  height: 60%;
  width: 1px;
  background: var(--color-border);
}

.receta-dato__icono {
  font-size: 1.4rem;
  line-height: 1;
}

.receta-dato__label {
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-text-soft);
  font-weight: 500;
}

.receta-dato__valor {
  font-family: var(--font-heading);
  font-size: var(--text-lg);
  color: var(--color-text);
  line-height: 1.1;
}

/* Colores de dificultad */
.receta-dato__valor--dificultad.dificultad-facil,
.dificultad-facil { color: var(--color-success); }
.receta-dato__valor--dificultad.dificultad-medio,
.dificultad-medio { color: var(--color-secondary); }
.receta-dato__valor--dificultad.dificultad-dificil,
.dificultad-dificil { color: var(--color-error, #c9605a); }

/* Imagen principal */
.receta-ficha__imagen-wrap {
  border-radius: var(--radius-xl);
  overflow: hidden;
  margin-bottom: var(--space-10);
  aspect-ratio: 16 / 7;
}

.receta-ficha__imagen {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transition-slow);
}

.receta-ficha__imagen-wrap:hover .receta-ficha__imagen {
  transform: scale(1.02);
}

/* Cuerpo: grid ingredientes | pasos */
.receta-ficha__cuerpo {
  display: grid;
  grid-template-columns: 1fr 2fr;
  gap: var(--space-10);
  align-items: start;
  margin-bottom: var(--space-10);
}

.receta-ficha__ingredientes,
.receta-ficha__pasos {
  position: sticky;
  top: 80px;
}

.receta-ficha__seccion-titulo {
  font-family: var(--font-heading);
  font-size: var(--text-2xl);
  color: var(--color-text);
  margin-bottom: var(--space-4);
  padding-bottom: var(--space-3);
  border-bottom: 2px solid var(--color-primary-light);
}

/* ── Bloque 2: Wysiwyg público ────────────────────────────── */
.wysiwyg {
  line-height: 1.75;
  font-size: var(--text-base);
  color: var(--color-text);
}

.wysiwyg h2 {
  font-family: var(--font-heading);
  font-size: var(--text-xl);
  color: var(--color-text);
  margin-top: var(--space-6);
  margin-bottom: var(--space-3);
  line-height: 1.3;
}

.wysiwyg h3 {
  font-family: var(--font-heading);
  font-size: var(--text-lg);
  color: var(--color-text);
  margin-top: var(--space-5);
  margin-bottom: var(--space-2);
}

.wysiwyg p {
  margin-bottom: var(--space-4);
}

.wysiwyg ul,
.wysiwyg ol {
  padding-left: 1.5em;
  margin-bottom: var(--space-4);
}

.wysiwyg li {
  margin-bottom: var(--space-2);
}

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

.wysiwyg blockquote {
  border-left: 3px solid var(--color-primary);
  padding-left: var(--space-4);
  margin-block: var(--space-5);
  color: var(--color-text-soft);
  font-style: italic;
}

.wysiwyg a {
  color: var(--color-primary-dark);
  text-decoration: underline;
  text-underline-offset: 2px;
}
.wysiwyg a:hover { color: var(--color-primary); }

.wysiwyg img {
  max-width: 100%;
  border-radius: var(--radius-lg);
  margin-block: var(--space-4);
}

/* ── Bloque 3: Recetas relacionadas ──────────────────────── */
.relacionadas {
  background: var(--color-surface);
  border-top: 1px solid var(--color-border);
  padding-block: var(--space-10);
  margin-top: var(--space-10);
}

/* Grid de tarjetas de receta (listado y relacionadas) */
.recetas-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-6);
  list-style: none;
  padding: 0;
  margin: 0;
}

.recetas-grid--compacto {
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-4);
}

/* Tarjeta de receta (usada en relacionadas y listado) */
.receta-card {
  background: var(--color-surface);
  border-radius: var(--radius-xl);
  overflow: hidden;
  border: 1px solid var(--color-border);
  transition: transform var(--transition-base), box-shadow var(--transition-base);
  display: flex;
  flex-direction: column;
}

.receta-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-md);
}

.receta-card__img-link {
  display: block;
  overflow: hidden;
  aspect-ratio: 3 / 2;
}

.receta-card__img-wrap {
  width: 100%;
  height: 100%;
}

.receta-card__img-link img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transition-slow);
  display: block;
}

.receta-card:hover .receta-card__img-link img {
  transform: scale(1.05);
}

.receta-card__body {
  padding: var(--space-4);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  flex: 1;
}

.receta-card__titulo {
  font-family: var(--font-heading);
  font-size: var(--text-lg);
  line-height: 1.3;
  color: var(--color-text);
  margin: 0;
}

.receta-card__titulo a {
  color: inherit;
  text-decoration: none;
}
.receta-card__titulo a:hover { color: var(--color-primary-dark); }

.receta-card__tiempo {
  font-size: var(--text-sm);
  color: var(--color-text-soft);
  display: flex;
  align-items: center;
  gap: var(--space-1);
  margin-top: auto;
}

/* Variante compacta para relacionadas */
.receta-card--compacta .receta-card__titulo {
  font-size: var(--text-base);
}

/* ── Bloque 4: Navegación anterior / siguiente ────────────── */
.receta-nav {
  padding-block: var(--space-8);
  border-top: 1px solid var(--color-border);
  margin-top: var(--space-4);
}

.receta-nav__inner {
  display: flex;
  justify-content: space-between;
  gap: var(--space-4);
}

.receta-nav__item {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  text-decoration: none;
  max-width: 45%;
  transition: color var(--transition-fast);
}

.receta-nav__item--siguiente {
  align-items: flex-end;
  margin-left: auto;
}

.receta-nav__dir {
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-text-soft);
  font-weight: 500;
}

.receta-nav__titulo {
  font-family: var(--font-heading);
  font-size: var(--text-lg);
  color: var(--color-text);
  line-height: 1.3;
}

.receta-nav__item:hover .receta-nav__titulo {
  color: var(--color-primary-dark);
}

/* ── Bloque 5: Ficha de artículo ──────────────────────────── */
.articulo-ficha {
  max-width: 780px;
  margin-inline: auto;
  padding-block: var(--space-10);
}

.articulo-ficha__header {
  margin-bottom: var(--space-6);
}

.articulo-ficha__meta {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  flex-wrap: wrap;
  font-size: var(--text-sm);
  color: var(--color-text-soft);
  margin-bottom: var(--space-4);
}

.articulo-ficha__titulo {
  font-family: var(--font-heading);
  font-size: var(--text-4xl);
  line-height: 1.15;
  color: var(--color-text);
  margin-bottom: var(--space-4);
}

.articulo-ficha__extracto {
  font-size: var(--text-lg);
  color: var(--color-text-soft);
  line-height: 1.65;
  border-left: 3px solid var(--color-primary);
  padding-left: var(--space-5);
  margin-bottom: var(--space-8);
  font-style: italic;
}

.articulo-ficha__imagen-wrap {
  border-radius: var(--radius-xl);
  overflow: hidden;
  margin-bottom: var(--space-8);
  aspect-ratio: 16 / 9;
}

.articulo-ficha__imagen {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.articulo-ficha__contenido {
  /* Hereda estilos de .wysiwyg */
}

.articulo-ficha__autor {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-sm);
  color: var(--color-text-soft);
}

/* Separador visual entre fecha y autor */
.articulo-ficha__autor::before {
  content: '·';
  color: var(--color-border-dark);
}

/* ── Bloque 6: Responsivo ficha receta y artículo ─────────── */
@media (max-width: 900px) {
  .receta-ficha__cuerpo {
    grid-template-columns: 1fr;
    gap: var(--space-8);
  }
  .receta-ficha__ingredientes,
  .receta-ficha__pasos {
    position: static;
  }
  .receta-ficha__titulo,
  .articulo-ficha__titulo {
    font-size: var(--text-3xl);
  }
  .recetas-grid { grid-template-columns: repeat(2, 1fr); }
  .recetas-grid--compacto { grid-template-columns: repeat(2, 1fr); }
  .receta-nav__inner { flex-direction: column; gap: var(--space-3); }
  .receta-nav__item--siguiente { align-items: flex-start; margin-left: 0; }
}

@media (max-width: 640px) {
  .receta-ficha__titulo,
  .articulo-ficha__titulo { font-size: var(--text-2xl); }
  .receta-ficha__datos { gap: var(--space-4); padding: var(--space-4); }
  .receta-dato + .receta-dato::before { display: none; }
  .receta-dato {
    padding-inline: var(--space-2);
    padding-block: var(--space-2);
    border-top: 1px solid var(--color-border);
    width: 50%;
    flex: unset;
  }
  .recetas-grid { grid-template-columns: 1fr; }
  .recetas-grid--compacto { grid-template-columns: repeat(2, 1fr); gap: var(--space-3); }
}

/* ════════════════════════════════════════════════════════════
   RONDA 8 — LISTADO DE RECETAS, LISTADO DE ARTÍCULOS,
              BUSCADOR, PAGINACIÓN, TARJETA DE ARTÍCULO
   ════════════════════════════════════════════════════════════ */

/* ── Bloque 1: Cabecera de sección (recetas.php, articulos.php) */
.seccion-header {
  padding-block: var(--space-10) var(--space-6);
}

.seccion-header__titulo {
  font-family: var(--font-heading);
  font-size: var(--text-3xl);
  color: var(--color-text);
  line-height: 1.2;
  margin-bottom: var(--space-2);
}

.seccion-header__desc {
  font-size: var(--text-lg);
  color: var(--color-text-soft);
  max-width: 60ch;
  line-height: 1.6;
}

/* ── Bloque 2: Buscador de recetas ───────────────────────── */
.buscador-recetas {
  background: var(--color-surface);
  border-radius: var(--radius-xl);
  border: 1px solid var(--color-border);
  padding: var(--space-5) var(--space-6);
  margin-bottom: var(--space-8);
  box-shadow: var(--shadow-sm);
}

.buscador-recetas__form {
  width: 100%;
}

.buscador-recetas__fila {
  display: flex;
  gap: var(--space-3);
  flex-wrap: wrap;
  align-items: flex-end;
}

.buscador-recetas__campo {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  flex: 1;
  min-width: 180px;
}

.buscador-recetas__campo--q {
  flex: 2;
}

/* Inputs del buscador front */
.input-busqueda {
  height: 42px;
  padding: 0 var(--space-4);
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-full);
  font-family: var(--font-body);
  font-size: var(--text-sm);
  color: var(--color-text);
  background: #fff;
  width: 100%;
  transition: border-color var(--transition-fast);
  outline: none;
}

.input-busqueda:focus {
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px var(--color-primary-bg);
}

.input-select {
  height: 42px;
  padding: 0 var(--space-8) 0 var(--space-4);
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-full);
  font-family: var(--font-body);
  font-size: var(--text-sm);
  color: var(--color-text);
  background-color: #fff;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23888' stroke-width='2.5'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right var(--space-4) center;
  appearance: none;
  -webkit-appearance: none;
  width: 100%;
  cursor: pointer;
  transition: border-color var(--transition-fast);
  outline: none;
}

.input-select:focus {
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px var(--color-primary-bg);
}

/* Pills de subcategoría */
.buscador-recetas__subcats {
  display: flex;
  gap: var(--space-2);
  flex-wrap: wrap;
  margin-top: var(--space-4);
  padding-top: var(--space-4);
  border-top: 1px solid var(--color-border);
}

.subcat-tag {
  display: inline-block;
  padding: var(--space-1) var(--space-3);
  font-size: var(--text-sm);
  font-weight: 400;
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-full);
  color: var(--color-text-soft);
  text-decoration: none;
  background: #fff;
  transition: all var(--transition-fast);
  cursor: pointer;
}

.subcat-tag:hover,
.subcat-tag.is-active {
  background: var(--color-primary-bg);
  border-color: var(--color-primary-light);
  color: var(--color-primary-dark);
  font-weight: 500;
}

/* ── Bloque 3: Listado recetas y contador ────────────────── */
.listado-recetas {
  padding-bottom: var(--space-12);
}

.listado-recetas__contador {
  font-size: var(--text-sm);
  color: var(--color-text-soft);
  margin-bottom: var(--space-6);
}

/* Elementos adicionales de receta-card para el listado */
.receta-card__categoria {
  font-size: var(--text-xs);
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--color-primary-dark);
  text-decoration: none;
  transition: color var(--transition-fast);
}

.receta-card__categoria:hover {
  color: var(--color-primary);
}

.receta-card__autor {
  display: block;
  font-size: var(--text-xs);
  color: var(--color-text-soft);
  font-style: italic;
  margin-bottom: var(--space-2);
}

.receta-card__extracto {
  font-size: var(--text-sm);
  color: var(--color-text-soft);
  line-height: 1.55;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.receta-card__meta {
  display: flex;
  gap: var(--space-3);
  flex-wrap: wrap;
  margin-top: auto;
  padding-top: var(--space-3);
  border-top: 1px solid var(--color-border);
}

.receta-card__meta-item {
  display: flex;
  align-items: center;
  gap: var(--space-1);
  font-size: var(--text-xs);
  color: var(--color-text-soft);
}

.receta-card__meta-item svg {
  width: 13px;
  height: 13px;
  flex-shrink: 0;
}

/* ── Bloque 4: Paginación (recetas y artículos) ──────────── */
.paginacion {
  padding-block: var(--space-8);
  display: flex;
  justify-content: center;
}

.paginacion__lista {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  list-style: none;
  padding: 0;
  margin: 0;
}

.paginacion__btn,
.paginacion__num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-2) var(--space-4);
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-full);
  font-size: var(--text-sm);
  color: var(--color-text);
  text-decoration: none;
  background: #fff;
  transition: all var(--transition-fast);
  min-width: 38px;
  height: 38px;
  font-family: var(--font-body);
}

.paginacion__btn:hover,
.paginacion__num:hover {
  border-color: var(--color-primary);
  color: var(--color-primary-dark);
  background: var(--color-primary-bg);
}

.paginacion__num.is-active {
  background: var(--color-primary);
  color: #fff;
  border-color: var(--color-primary);
  font-weight: 600;
  pointer-events: none;
}

/* ── Bloque 5: Listado artículos y tarjeta ───────────────── */
.listado-articulos {
  padding-bottom: var(--space-12);
}

.articulos-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-6);
  list-style: none;
  padding: 0;
  margin: 0;
}

.articulo-card {
  background: var(--color-surface);
  border-radius: var(--radius-xl);
  overflow: hidden;
  border: 1px solid var(--color-border);
  display: flex;
  flex-direction: column;
  transition: transform var(--transition-base), box-shadow var(--transition-base);
}

.articulo-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-md);
}

.articulo-card__img-link {
  display: block;
  overflow: hidden;
  aspect-ratio: 16 / 9;
  flex-shrink: 0;
}

.articulo-card__img-wrap {
  width: 100%;
  height: 100%;
}

.articulo-card__img-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform var(--transition-slow);
}

.articulo-card:hover .articulo-card__img-wrap img {
  transform: scale(1.05);
}

.articulo-card__body {
  padding: var(--space-5);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  flex: 1;
}

.articulo-card__fecha {
  font-size: var(--text-xs);
  color: var(--color-text-soft);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.articulo-card__autor {
  display: block;
  font-size: var(--text-xs);
  color: var(--color-text-soft);
  font-style: italic;
  margin-top: var(--space-1);
}

.articulo-card__titulo {
  font-family: var(--font-heading);
  font-size: var(--text-xl);
  line-height: 1.3;
  color: var(--color-text);
  margin: 0;
}

.articulo-card__titulo a {
  color: inherit;
  text-decoration: none;
  transition: color var(--transition-fast);
}

.articulo-card__titulo a:hover {
  color: var(--color-primary-dark);
}

.articulo-card__extracto {
  font-size: var(--text-sm);
  color: var(--color-text-soft);
  line-height: 1.6;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.articulo-card__leer {
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--color-primary-dark);
  text-decoration: none;
  margin-top: auto;
  padding-top: var(--space-3);
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  transition: gap var(--transition-fast);
}

.articulo-card__leer::after {
  content: '→';
  transition: transform var(--transition-fast);
}

.articulo-card__leer:hover::after {
  transform: translateX(3px);
}

/* ── Bloque 6: Responsivo listados ──────────────────────── */
@media (max-width: 768px) {
  .buscador-recetas__fila {
    flex-direction: column;
    gap: var(--space-3);
  }
  .buscador-recetas__campo,
  .buscador-recetas__campo--q {
    min-width: 100%;
    flex: unset;
  }
  .articulos-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  .seccion-header__titulo { font-size: var(--text-2xl); }
  .articulo-card__img-link { aspect-ratio: 2 / 1; }
  /* Paginación móvil: solo activo + extremos */
  .paginacion__num:not(.is-active):not(:first-child):not(:last-child) {
    display: none;
  }
}


/* ════════════════════════════════════════════════════════
   PÁGINAS LEGALES / INFORMATIVAS — Ronda 9
   ════════════════════════════════════════════════════════ */

.pagina-legal {
    padding-top: var(--space-12);
    padding-bottom: var(--space-16);
    max-width: 780px;
}

.pagina-legal__header {
    margin-bottom: var(--space-8);
    padding-bottom: var(--space-6);
    border-bottom: 1px solid var(--color-border);
}

.pagina-legal__header h1 {
    font-family: var(--font-heading);
    font-size: clamp(1.8rem, 4vw, 2.5rem);
    color: var(--color-text);
    margin: 0;
}

.pagina-legal__content {
    line-height: 1.8;
    color: var(--color-text-muted);
}

.pagina-legal__content h2 {
    font-family: var(--font-heading);
    font-size: 1.35rem;
    color: var(--color-text);
    margin-top: var(--space-8);
    margin-bottom: var(--space-3);
}

.pagina-legal__content h3 {
    font-size: 1.1rem;
    font-weight: 600;
    color: var(--color-text);
    margin-top: var(--space-6);
    margin-bottom: var(--space-2);
}

.pagina-legal__content p {
    margin-bottom: var(--space-4);
}

.pagina-legal__content a {
    color: var(--color-primary);
    text-decoration: underline;
}

.pagina-legal__content ul,
.pagina-legal__content ol {
    padding-left: var(--space-6);
    margin-bottom: var(--space-4);
}

.pagina-legal__content li {
    margin-bottom: var(--space-2);
}

/* Formulario de contacto */
.contacto-form {
    display: flex;
    flex-direction: column;
    gap: var(--space-5);
    margin-top: var(--space-8);
}

.contacto-form label {
    display: block;
    font-size: var(--text-sm);
    font-weight: 500;
    color: var(--color-text);
    margin-bottom: var(--space-2);
}

.contacto-form input,
.contacto-form textarea {
    width: 100%;
    padding: var(--space-3) var(--space-4);
    border: 1.5px solid var(--color-border);
    border-radius: var(--radius-md);
    font-family: var(--font-body);
    font-size: var(--text-base);
    color: var(--color-text);
    background: #fff;
    transition: border-color .2s;
}

.contacto-form input:focus,
.contacto-form textarea:focus {
    outline: none;
    border-color: var(--color-primary);
}

.contacto-form textarea {
    min-height: 160px;
    resize: vertical;
}


/* ── Aliases: HTML generado por Desarrollo usa distinta nomenclatura ──────── */

/* pagina-legal: estilos directos sobre h2/p/a/ul/li (sin wrapper __content) */
.pagina-legal h2 {
    font-family: var(--font-heading);
    font-size: 1.35rem;
    color: var(--color-text);
    margin-top: var(--space-8);
    margin-bottom: var(--space-3);
}

.pagina-legal h3 {
    font-size: 1.1rem;
    font-weight: 600;
    color: var(--color-text);
    margin-top: var(--space-6);
    margin-bottom: var(--space-2);
}

.pagina-legal p {
    margin-bottom: var(--space-4);
    line-height: 1.8;
    color: var(--color-text-muted);
}

.pagina-legal a {
    color: var(--color-primary);
    text-decoration: underline;
}

.pagina-legal ul,
.pagina-legal ol {
    padding-left: var(--space-6);
    margin-bottom: var(--space-4);
}

.pagina-legal li {
    margin-bottom: var(--space-2);
    line-height: 1.7;
    color: var(--color-text-muted);
}

/* Formulario de contacto (clases de Desarrollo) */
.contacto__form {
    display: flex;
    flex-direction: column;
    gap: var(--space-5);
    margin-top: var(--space-8);
    max-width: 620px;
}

.contacto__field {
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
}

.contacto__field label {
    font-size: var(--text-sm);
    font-weight: 500;
    color: var(--color-text);
}

.input-text {
    width: 100%;
    padding: var(--space-3) var(--space-4);
    border: 1.5px solid var(--color-border);
    border-radius: var(--radius-md);
    font-family: var(--font-body);
    font-size: var(--text-base);
    color: var(--color-text);
    background: #fff;
    transition: border-color .2s;
}

.input-text:focus {
    outline: none;
    border-color: var(--color-primary);
}

textarea.input-text {
    min-height: 160px;
    resize: vertical;
}

.contacto__ok {
    padding: var(--space-6);
    background: #f0faf4;
    border: 1.5px solid #a8d8b9;
    border-radius: var(--radius-lg);
    color: var(--color-text);
    line-height: 1.6;
    margin-bottom: var(--space-6);
}

.pagina-legal__actualizado {
    font-size: var(--text-sm);
    color: var(--color-text-muted);
    margin-bottom: var(--space-6);
}


/* ────────────────────────────────────────────────────────────
   PÁGINA NOSOTROS
   ──────────────────────────────────────────────────────────── */

/* Layout de dos columnas */
.nosotros {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-16);
    padding-block: var(--space-12);
    align-items: start;
}

/* Columna historia */
.nosotros__texto {
    font-size: var(--text-md);
    line-height: 1.8;
    color: var(--color-text);
    margin-bottom: var(--space-6);
}

.nosotros__buen-provecho {
    font-size: var(--text-lg);
    margin-bottom: var(--space-10);
}

/* Imagen captura web antigua */
.nosotros__captura {
    margin: 0 0 var(--space-8) 0;
    text-align: center;
}

.nosotros__captura img {
    max-width: 100%;
    height: auto;
    border-radius: var(--radius-lg);
    border: 1px solid var(--color-border);
    box-shadow: var(--shadow-md);
}

.nosotros__captura figcaption {
    margin-top: var(--space-3);
    font-size: var(--text-sm);
    color: var(--color-text-soft);
    font-style: italic;
}

/* Logo centrado al pie de la columna */
.nosotros__logo-wrap {
    display: flex;
    justify-content: center;
    padding-top: var(--space-4);
}

.nosotros__logo-link {
    display: flex;
    align-items: center;
    gap: 10px;
    text-decoration: none;
}

.nosotros__logo-texto {
    display: flex;
    flex-direction: column;
    line-height: 1.2;
}

.nosotros__logo-pre {
    font-family: var(--font-body);
    font-size: 0.6rem;
    letter-spacing: 0.15em;
    font-weight: 600;
    color: var(--color-text-soft);
    text-transform: uppercase;
}

.nosotros__logo-name {
    font-family: var(--font-heading);
    font-size: 1.4rem;
    font-weight: 700;
    color: var(--color-text);
}

/* Columna formulario */
.nosotros__form-titulo {
    font-family: var(--font-heading);
    font-size: var(--text-xl);
    color: var(--color-text);
    margin-bottom: var(--space-2);
}

.nosotros__form-desc {
    font-size: var(--text-base);
    color: var(--color-text-soft);
    margin-bottom: var(--space-6);
}

/* Eliminar el margin-top que tiene .contacto__form por defecto */
.nosotros__form.contacto__form {
    margin-top: 0;
    max-width: 100%;
}

/* ── Responsive: una columna en móvil ──────────────────────── */
@media (max-width: 768px) {
    .nosotros {
        grid-template-columns: 1fr;
        gap: var(--space-10);
        padding-block: var(--space-8);
    }
}

/* ── Equipo (columna derecha Nosotros) ──────────────────────── */
.nosotros__equipo-titulo {
    font-family: var(--font-heading);
    font-size: var(--text-xl);
    color: var(--color-text);
    margin-bottom: var(--space-6);
}

.equipo-lista {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 0;                        /* la separación la gestiona el borde de cada card */
}

.equipo-card {
    display: flex;
    align-items: flex-start;
    gap: var(--space-5);
    padding-block: var(--space-8); /* más aire arriba y abajo */
    border-top: 1px solid var(--color-border);
}

.equipo-lista > li:first-child .equipo-card {
    border-top: none;
    padding-top: 0;
}

.equipo-card__foto-wrap {
    flex-shrink: 0;
}

.equipo-card__foto {
    width: 80px;
    height: 80px;
    border-radius: 50%;
    object-fit: cover;
    border: 2px solid var(--color-border);
    display: block;
}

.equipo-card__foto--inicial {
    width: 80px;
    height: 80px;
    border-radius: 50%;
    background: var(--color-primary);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.75rem;
    font-weight: 700;
    font-family: var(--font-heading);
}

.equipo-card__info {
    display: flex;
    flex-direction: column;
    gap: var(--space-2);           /* más espacio entre nombre / desc / link */
    padding-top: 6px;
}

.equipo-card__nombre {
    font-size: var(--text-base);
    font-weight: 700;
    color: var(--color-text);
}

.equipo-card__desc {
    font-size: var(--text-sm);
    color: var(--color-text-soft);
    line-height: 1.65;
    margin: 0;
}

.equipo-card__link {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: var(--text-sm);
    color: var(--color-primary);
    text-decoration: none;
    margin-top: var(--space-1);
    word-break: break-all;
}

.equipo-card__link:hover {
    text-decoration: underline;
}

/* ── Sección contacto (fila inferior Nosotros) ──────────────── */
.nosotros-contacto {
    border-top: 1px solid var(--color-border);
    padding-block: var(--space-12);
    margin-top: var(--space-4);
}

.nosotros-contacto__titulo {
    font-family: var(--font-heading);
    font-size: var(--text-xl);
    color: var(--color-text);
    margin-bottom: var(--space-2);
}

.nosotros-contacto__desc {
    font-size: var(--text-base);
    color: var(--color-text-soft);
    margin-bottom: var(--space-6);
}

.nosotros-contacto__grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-4);
    margin-bottom: var(--space-4);
}

.nosotros-contacto__field--full {
    grid-column: 1 / -1;
}

@media (max-width: 640px) {
    .nosotros-contacto__grid {
        grid-template-columns: 1fr;
    }
}


/* ============================================================
   BUSCADOR GLOBAL — /buscar/
   Ronda 6 — Resultados de búsqueda combinada
   ============================================================ */

/* Contenedor general de toda la página de resultados */
.buscar-resultados {
    display: flex;
    flex-direction: column;
    gap: var(--space-16);
    padding-top: var(--space-10);
    padding-bottom: var(--space-20);
}

/* Cada bloque (Recetas / Artículos) */
.buscar-seccion {
    /* separación visual garantizada por el gap del padre */
}

/* Cabecera de sección: título + contador + "ver más" */
.buscar-seccion__header {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: var(--space-4);
    margin-bottom: var(--space-6);
    padding-bottom: var(--space-4);
    border-bottom: 2px solid var(--color-border);
}

.buscar-seccion__titulo {
    font-family: var(--font-heading);
    font-size: var(--text-2xl);
    color: var(--color-text);
    margin: 0;
    line-height: 1.2;
}

.buscar-seccion__count {
    font-size: var(--text-sm);
    color: var(--color-text-muted);
    font-family: var(--font-body);
    white-space: nowrap;
}

.buscar-seccion__ver-mas {
    font-size: var(--text-sm);
    color: var(--color-primary);
    text-decoration: none;
    font-weight: 500;
    white-space: nowrap;
    transition: color var(--transition-fast);
}

.buscar-seccion__ver-mas:hover {
    color: var(--color-primary-dark);
    text-decoration: underline;
}

/* Botón "Ver todos los resultados" al pie de cada sección */
.buscar-seccion__footer {
    margin-top: var(--space-8);
    text-align: center;
}

/* Grid de recetas dentro del buscador — 4 columnas desktop */
.recetas-grid--buscar {
    grid-template-columns: repeat(4, 1fr);
    gap: var(--space-5);
}

/* Grid de artículos dentro del buscador — 4 columnas desktop */
.articulos-grid--buscar {
    grid-template-columns: repeat(4, 1fr);
    gap: var(--space-5);
}

/* Sin resultados */
.buscar-sin-resultados {
    text-align: center;
    padding: var(--space-16) 0;
}

.buscar-hint {
    font-size: var(--text-lg);
    color: var(--color-text-soft);
    margin-bottom: var(--space-8);
}

/* Sugerencias de búsqueda */
.buscar-sugerencias {
    display: flex;
    gap: var(--space-3);
    justify-content: center;
    flex-wrap: wrap;
    margin-top: var(--space-6);
}

.buscar-sugerencias a {
    display: inline-block;
    padding: var(--space-2) var(--space-4);
    background: var(--color-primary-bg);
    color: var(--color-primary-dark);
    border: 1px solid var(--color-primary-light);
    border-radius: var(--radius-full);
    font-size: var(--text-sm);
    font-weight: 500;
    text-decoration: none;
    transition: background var(--transition-fast), color var(--transition-fast);
}

.buscar-sugerencias a:hover {
    background: var(--color-primary);
    color: #fff;
}

/* ── Responsive ─────────────────────────────────────────────── */
@media (max-width: 1024px) {
    .recetas-grid--buscar,
    .articulos-grid--buscar {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 640px) {
    .buscar-resultados {
        gap: var(--space-12);
        padding-top: var(--space-6);
    }

    .recetas-grid--buscar,
    .articulos-grid--buscar {
        grid-template-columns: 1fr;
    }

    .buscar-seccion__header {
        flex-wrap: wrap;
        align-items: flex-start;
    }

    .buscar-seccion__titulo {
        font-size: var(--text-xl);
    }
}
