/* =============================================================
   componentes.css — AmedidaCuentos.com  (v09)
   Estilos de cabecera, menú, pie, hero, tarjetas, slider,
   tabs, accordion, botón volver arriba, aviso cookies.
   ============================================================= */

/* ═══════════════════════════════════════════════════════════
   1. BARRA DE NAVEGACIÓN
   ═══════════════════════════════════════════════════════════ */
.nav-principal {
  position:         fixed;
  top:              0;
  left:             0;
  width:            100%;
  z-index:          1000;
  background:       transparent;
  transition:       var(--transicion);
  padding:          16px 0;
}

/* Estado con scroll: fondo blanco y sombra */
.nav-principal.con-scroll {
  background: var(--color-nav-bg);
  box-shadow: var(--sombra-sm);
  padding:    10px 0;
}

.nav-principal__contenedor {
  display:         flex;
  align-items:     center;
  justify-content: space-between;
  gap:             24px;
}

/* Logo */
.nav-principal__logo {
  display:     flex;
  align-items: center;
  flex-shrink: 0;
}
.nav-principal__logo img {
  height:     48px;
  width:      auto;
  object-fit: contain;
  transition: var(--transicion);
}
.nav-principal.con-scroll .nav-principal__logo img { height: 40px; }

/* Lista de ítems */
.nav-principal__lista {
  display:     flex;
  align-items: center;
  gap:         4px;
  list-style:  none;
  margin:      0;
  padding:     0;
}

.nav-principal__item { position: relative; }

.nav-principal__enlace {
  display:       block;
  padding:       8px 14px;
  font-family:   var(--fuente-titulo);
  font-weight:   700;
  font-size:     0.95rem;
  color:         var(--color-texto-claro);
  border-radius: var(--radio-borde-sm);
  transition:    var(--transicion);
  white-space:   nowrap;
}

.nav-principal.con-scroll .nav-principal__enlace {
  color: var(--color-titulo);
}

.nav-principal__enlace:hover,
.nav-principal__item.activo > .nav-principal__enlace {
  background: var(--color-primario);
  color:      var(--color-texto-claro) !important;
}

/* Indicador de submenú */
.nav-principal__enlace--dropdown::after {
  content:   ' ▾';
  font-size: 0.75rem;
}

/* Dropdown — visible al hover/focus-within
   v09: el retardo de cierre se gestiona via JS (300ms setTimeout en mouseleave) */
.nav-principal__dropdown {
  display:       none;
  position:      absolute;
  top:           calc(100% + 8px);
  left:          0;
  min-width:     220px;
  background:    var(--color-nav-bg);
  border-radius: var(--radio-borde);
  box-shadow:    var(--sombra-lg);
  padding:       8px;
  list-style:    none;
  z-index:       1001;
}

.nav-principal__item:hover .nav-principal__dropdown,
.nav-principal__item:focus-within .nav-principal__dropdown {
  display: block;
}

/* Estado visible forzado por JS (retardo 300ms) */
.nav-principal__dropdown.visible { display: block; }

.nav-principal__dropdown li a {
  display:       block;
  padding:       10px 16px;
  font-family:   var(--fuente-titulo);
  font-weight:   600;
  font-size:     0.9rem;
  color:         var(--color-titulo);
  border-radius: var(--radio-borde-sm);
  transition:    var(--transicion);
}
.nav-principal__dropdown li a:hover,
.nav-principal__dropdown li.activo a {
  background: var(--color-fondo-1);
  color:      var(--color-primario);
}

/* Botón hamburguesa */
.nav-principal__hamburguesa {
  display:         none;
  flex-direction:  column;
  justify-content: center;
  gap:             5px;
  background:      none;
  border:          none;
  cursor:          pointer;
  padding:         8px;
  border-radius:   var(--radio-borde-sm);
  transition:      var(--transicion);
}
.nav-principal__hamburguesa:hover { background: rgba(255,255,255,0.2); }

.nav-principal__hamburguesa span {
  display:       block;
  width:         26px;
  height:        3px;
  background:    var(--color-texto-claro);
  border-radius: 3px;
  transition:    var(--transicion);
}
.nav-principal.con-scroll .nav-principal__hamburguesa span { background: var(--color-titulo); }

/* Hamburguesa abierta → X */
.nav-principal__hamburguesa.abierto span:nth-child(1) { transform: translateY(8px) rotate(45deg); }
.nav-principal__hamburguesa.abierto span:nth-child(2) { opacity: 0; }
.nav-principal__hamburguesa.abierto span:nth-child(3) { transform: translateY(-8px) rotate(-45deg); }

/* ── Responsive menú ────────────────────────────────────── */
@media (max-width: 991px) {
  .nav-principal__hamburguesa { display: flex; }

  .nav-principal__lista {
    display:        none;
    position:       absolute;
    top:            100%;
    left:           0;
    width:          100%;
    flex-direction: column;
    align-items:    stretch;
    background:     var(--color-nav-bg);
    box-shadow:     var(--sombra-lg);
    padding:        12px 16px 20px;
    gap:            2px;
  }

  .nav-principal__lista.abierto { display: flex; }

  .nav-principal__enlace { color: var(--color-titulo); }

  .nav-principal__dropdown {
    display:    block;
    position:   static;
    box-shadow: none;
    padding:    0 0 0 16px;
    background: transparent;
  }
}

/* ═══════════════════════════════════════════════════════════
   2. HERO / CABECERA
   ═══════════════════════════════════════════════════════════ */
.hero {
  position:            relative;
  min-height:          100vh;
  display:             flex;
  align-items:         center;
  justify-content:     flex-end;
  background-size:     cover;
  background-position: center center;
  background-repeat:   no-repeat;
  padding-top:         80px;
}

/* Overlay semitransparente para mejorar legibilidad */
.hero::before {
  content:    '';
  position:   absolute;
  inset:      0;
  background: linear-gradient(120deg, rgba(0,0,0,0.05) 0%, rgba(0,0,0,0.35) 100%);
  z-index:    1;
}

.hero__contenido {
  position:      relative;
  z-index:       2;
  max-width:     560px;
  padding:       48px 40px;
  background:    var(--color-overlay);
  border-radius: var(--radio-borde-xl) 0 0 var(--radio-borde-xl);
  text-align:    right;
  margin-right:  0;
}

.hero__titulo {
  font-size:     clamp(1.8rem, 4vw, 3rem);
  font-weight:   800;
  color:         var(--color-titulo);
  margin-bottom: 0.3em;
}

/* Subtítulo: fondo oscuro + texto blanco (contraste 16.7:1 ✓) */
.hero__subtitulo {
  display:       inline-block;
  font-size:     clamp(1rem, 2vw, 1.3rem);
  font-weight:   700;
  background:    var(--color-titulo);
  color:         var(--color-texto-claro);
  padding:       4px 16px;
  border-radius: 50px;
  margin-bottom: 0.8em;
}

.hero__texto {
  font-size:     1rem;
  color:         var(--color-texto);
  margin-bottom: 1.5em;
  line-height:   1.6;
}

@media (max-width: 768px) {
  .hero {
    justify-content: center;
    align-items:     flex-end;
    min-height:      85vh;
  }
  .hero__contenido {
    max-width:     100%;
    border-radius: var(--radio-borde-xl) var(--radio-borde-xl) 0 0;
    text-align:    center;
    padding:       32px 24px;
  }
}

/* ═══════════════════════════════════════════════════════════
   3. PIE DE PÁGINA
   ═══════════════════════════════════════════════════════════ */
.pie-pagina {
  background: var(--color-titulo);
  color:      rgba(255,255,255,0.85);
  padding:    64px 0 0;
}

.pie-pagina__grid {
  display:               grid;
  grid-template-columns: 1fr 2fr 1fr;
  gap:                   48px;
  padding-bottom:        48px;
}

/* Columna izquierda */
.pie-columna-logo img {
  height:        52px;
  width:         auto;
  margin-bottom: 16px;
  filter:        brightness(0) invert(1);
}
.pie-columna-logo p {
  font-size:   0.9rem;
  color:       rgba(255,255,255,0.75);
  line-height: 1.5;
}

/* Columna central */
.pie-columna-contacto { text-align: center; }
.pie-columna-contacto h3 {
  color:         var(--color-texto-claro);
  font-size:     1.3rem;
  margin-bottom: 4px;
}
.pie-columna-contacto .pie__email {
  /* Color naranja sobre fondo oscuro: contraste suficiente */
  color:         var(--color-primario);
  font-size:     1rem;
  font-weight:   700;
  display:       block;
  margin-bottom: 12px;
}
.pie-columna-contacto p {
  font-size:     0.9rem;
  color:         rgba(255,255,255,0.75);
  margin-bottom: 16px;
}

/* Columna derecha */
.pie-columna-redes { text-align: right; }
.pie-columna-redes p {
  font-size:     0.9rem;
  color:         rgba(255,255,255,0.75);
  margin-bottom: 12px;
}
.pie-columna-redes .redes-iconos {
  display:         flex;
  gap:             12px;
  justify-content: flex-end;
}
.redes-iconos a {
  display:         flex;
  align-items:     center;
  justify-content: center;
  width:           44px;
  height:          44px;
  background:      rgba(255,255,255,0.1);
  border-radius:   50%;
  transition:      var(--transicion);
}
.redes-iconos a:hover {
  background: var(--color-primario);
  transform:  scale(1.1);
}
.redes-iconos svg { width: 22px; height: 22px; fill: white; }

/* Línea de copyright */
.pie-copyright {
  border-top: 1px solid rgba(255,255,255,0.12);
  padding:    20px 0;
  text-align: center;
  font-size:  0.8rem;
  color:      rgba(255,255,255,0.5);
}
.pie-copyright a {
  color:  rgba(255,255,255,0.6);
  margin: 0 8px;
}
.pie-copyright a:hover { color: var(--color-primario); }

@media (max-width: 991px) {
  .pie-pagina__grid {
    grid-template-columns: 1fr;
    gap:                   32px;
    text-align:            center;
  }
  .pie-columna-redes             { text-align: center; }
  .pie-columna-redes .redes-iconos { justify-content: center; }
  .pie-columna-logo img          { margin: 0 auto 16px; }
}

/* ═══════════════════════════════════════════════════════════
   4. BOTÓN VOLVER ARRIBA
   ═══════════════════════════════════════════════════════════ */
.btn-arriba {
  position:        fixed;
  bottom:          100px;
  right:           24px;
  width:           50px;
  height:          50px;
  background:      var(--color-primario);
  color:           var(--color-texto-claro);
  border:          none;
  border-radius:   50%;
  cursor:          pointer;
  display:         flex;
  align-items:     center;
  justify-content: center;
  font-size:       1.3rem;
  box-shadow:      var(--sombra-md);
  z-index:         900;
  opacity:         0;
  transform:       translateY(20px);
  transition:      var(--transicion);
  pointer-events:  none;
}
.btn-arriba.visible {
  opacity:        1;
  transform:      translateY(0);
  pointer-events: auto;
}
.btn-arriba:hover {
  background: var(--color-primario-hover);
  transform:  translateY(-3px);
}
.btn-arriba:focus-visible { outline: 3px solid var(--color-secundario); }

/* ═══════════════════════════════════════════════════════════
   5. AVISO DE COOKIES (solo index.html)
   ═══════════════════════════════════════════════════════════ */
.aviso-cookies {
  position:        fixed;
  bottom:          0;
  left:            0;
  width:           100%;
  background:      var(--color-titulo);
  color:           rgba(255,255,255,0.9);
  padding:         16px 24px;
  display:         flex;
  align-items:     center;
  justify-content: space-between;
  gap:             16px;
  z-index:         9999;
  box-shadow:      0 -4px 20px rgba(0,0,0,0.2);
  flex-wrap:       wrap;
}
.aviso-cookies p {
  margin:    0;
  font-size: 0.9rem;
  color:     rgba(255,255,255,0.9);
  flex:      1;
  min-width: 200px;
}
.aviso-cookies a {
  color:       var(--color-primario);
  font-weight: 700;
}
.aviso-cookies__acciones { display: flex; gap: 12px; flex-shrink: 0; }
.aviso-cookies.oculto    { display: none; }

/* ═══════════════════════════════════════════════════════════
   6. SECCIÓN DIVIDIDA (texto + imagen en columnas)
   ═══════════════════════════════════════════════════════════ */
.seccion-dividida {
  display:     grid;
  gap:         48px;
  align-items: center;
}
.seccion-dividida--1-2 { grid-template-columns: 1fr 2fr; }
.seccion-dividida--2-1 { grid-template-columns: 2fr 1fr; }
.seccion-dividida--1-1 { grid-template-columns: 1fr 1fr; }

.seccion-dividida__imagen img {
  width:         100%;
  height:        100%;
  object-fit:    cover;
  border-radius: var(--radio-borde-xl);
  box-shadow:    var(--sombra-lg);
}

.seccion-dividida__texto .seccion__titulo { margin-bottom: 16px; }
.seccion-dividida__texto .seccion__intro  { margin-bottom: 24px; font-size: 1.05rem; }

@media (max-width: 767px) {
  .seccion-dividida { grid-template-columns: 1fr; }
  /* En móvil la imagen va siempre debajo */
  .seccion-dividida--1-2 .seccion-dividida__imagen,
  .seccion-dividida--2-1 .seccion-dividida__imagen { order: 2; }
}

/* ═══════════════════════════════════════════════════════════
   7. TARJETAS (incluye/valores)
   ═══════════════════════════════════════════════════════════ */
.tarjetas-grid {
  display:               grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap:                   28px;
}

.tarjeta {
  background:    var(--color-fondo-1);
  border-radius: var(--radio-borde-xl);
  padding:       32px 24px;
  text-align:    center;
  box-shadow:    var(--sombra-sm);
  transition:    var(--transicion);
}
.tarjeta:hover {
  transform:  translateY(-6px);
  box-shadow: var(--sombra-lg);
}

/* Fondos diferenciados por posición */
.tarjeta:nth-child(1) { background: var(--card-color-1); }
.tarjeta:nth-child(2) { background: var(--card-color-2); }
.tarjeta:nth-child(3) { background: var(--card-color-3); }
.tarjeta:nth-child(4) { background: var(--card-color-4); }

.tarjeta__icono  { font-size: 3rem; margin-bottom: 16px; display: block; }
.tarjeta__titulo { font-size: 1.1rem; font-weight: 800; margin-bottom: 8px; color: var(--color-titulo); }
.tarjeta__texto  { font-size: 0.92rem; color: var(--color-texto); line-height: 1.5; margin: 0; }

/* ═══════════════════════════════════════════════════════════
   8. TARJETAS DE LIBROS (sección libros en index.html)
   ═══════════════════════════════════════════════════════════ */
.libros-grid {
  display:               grid;
  grid-template-columns: repeat(3, 1fr);
  gap:                   36px;
}

.libro-tarjeta {
  background:     white;
  border-radius:  var(--radio-borde-xl);
  overflow:       hidden;
  box-shadow:     var(--sombra-md);
  transition:     var(--transicion);
  display:        flex;
  flex-direction: column;
}
.libro-tarjeta:hover {
  transform:  translateY(-8px);
  box-shadow: var(--sombra-lg);
}

.libro-tarjeta__imagen {
  aspect-ratio: 3/4;
  overflow:     hidden;
}
.libro-tarjeta__imagen img {
  width:      100%;
  height:     100%;
  object-fit: cover;
  transition: var(--transicion-lenta);
}
.libro-tarjeta:hover .libro-tarjeta__imagen img { transform: scale(1.05); }

.libro-tarjeta__cuerpo {
  padding:        24px;
  flex:           1;
  display:        flex;
  flex-direction: column;
}
.libro-tarjeta__titulo    { font-size: 1.2rem; margin-bottom: 4px; }
.libro-tarjeta__subtitulo {
  font-size:     0.85rem;
  font-weight:   700;
  color:         var(--color-primario);
  margin-bottom: 12px;
}
.libro-tarjeta__texto {
  font-size:     0.9rem;
  color:         var(--color-texto-muted);
  flex:          1;
  margin-bottom: 16px;
}

@media (max-width: 991px) {
  .libros-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 576px) {
  .libros-grid { grid-template-columns: 1fr; max-width: 360px; margin: 0 auto; }
}

/* ═══════════════════════════════════════════════════════════
   9. TABS (pestañas)
   ═══════════════════════════════════════════════════════════ */
.tabs-contenedor { width: 100%; }

.tabs-lista {
  display:         flex;
  gap:             8px;
  margin-bottom:   32px;
  border-bottom:   2px solid rgba(0,0,0,0.08);
  padding-bottom:  0;
}

.tab-btn {
  padding:       12px 28px;
  background:    transparent;
  border:        none;
  border-bottom: 3px solid transparent;
  margin-bottom: -2px;
  font-family:   var(--fuente-titulo);
  font-weight:   700;
  font-size:     1rem;
  cursor:        pointer;
  color:         var(--color-texto-muted);
  transition:    var(--transicion);
  border-radius: var(--radio-borde-sm) var(--radio-borde-sm) 0 0;
}
.tab-btn:hover                    { color: var(--color-primario); }
.tab-btn[aria-selected="true"] {
  color:        var(--color-primario);
  border-color: var(--color-primario);
}

.tab-panel        { display: none; }
.tab-panel.activo {
  display:               grid;
  grid-template-columns: 1fr 1fr;
  gap:                   40px;
  align-items:           center;
}

@media (max-width: 767px) {
  .tab-panel.activo { grid-template-columns: 1fr; }
}

/* ═══════════════════════════════════════════════════════════
   10. SLIDER / CARRUSEL (Swiper.js 11)
   ═══════════════════════════════════════════════════════════ */
.swiper {
  width:          100%;
  padding-bottom: 48px !important;
}

.swiper-slide {
  border-radius: var(--radio-borde-xl);
  overflow:      hidden;
  box-shadow:    var(--sombra-md);
}

.swiper-slide img {
  width:        100%;
  aspect-ratio: 4/3;
  object-fit:   cover;
  display:      block;
}

.swiper-slide figcaption {
  padding:     12px 16px;
  background:  white;
  font-size:   0.88rem;
  color:       var(--color-texto-muted);
  text-align:  center;
  font-weight: 600;
}

/* Flechas de navegación */
.swiper-button-next,
.swiper-button-prev {
  color:         var(--color-primario) !important;
  background:    white;
  width:         44px !important;
  height:        44px !important;
  border-radius: 50%;
  box-shadow:    var(--sombra-md);
}
.swiper-button-next::after,
.swiper-button-prev::after { font-size: 16px !important; font-weight: 900; }

/* Puntos de paginación */
.swiper-pagination-bullet-active { background: var(--color-primario) !important; }

/* ═══════════════════════════════════════════════════════════
   11. STEPPER (línea de tiempo — ¿Cómo funciona?)
   ═══════════════════════════════════════════════════════════ */
.stepper { position: relative; }

.stepper__item {
  display:       flex;
  gap:           20px;
  margin-bottom: 36px;
  position:      relative;
}

.stepper__numero {
  flex-shrink:     0;
  width:           52px;
  height:          52px;
  background:      var(--color-primario);
  color:           white;
  border-radius:   50%;
  display:         flex;
  align-items:     center;
  justify-content: center;
  font-family:     var(--fuente-titulo);
  font-weight:     800;
  font-size:       1.2rem;
  box-shadow:      var(--sombra-sm);
  position:        relative;
  z-index:         1;
}

/* Línea vertical entre pasos */
.stepper__item:not(:last-child) .stepper__numero::after {
  content:    '';
  position:   absolute;
  top:        100%;
  left:       50%;
  transform:  translateX(-50%);
  width:      3px;
  height:     calc(100% + 20px);
  /* v09: color coherente con nuevo primario #B85500 */
  background: linear-gradient(var(--color-primario), rgba(184,85,0,0.2));
  z-index:    0;
}

.stepper__contenido { padding-top: 8px; }
.stepper__contenido h3 {
  font-size:     1.1rem;
  margin-bottom: 4px;
  color:         var(--color-titulo);
}
.stepper__contenido p {
  font-size: 0.9rem;
  color:     var(--color-texto-muted);
  margin:    0;
}

/* ═══════════════════════════════════════════════════════════
   12. ACCORDION (FAQ)
   ═══════════════════════════════════════════════════════════ */
.accordion { display: flex; flex-direction: column; gap: 12px; }

.accordion__item {
  background:    white;
  border-radius: var(--radio-borde);
  overflow:      hidden;
  box-shadow:    var(--sombra-sm);
}

.accordion__cabecera {
  width:       100%;
  background:  transparent;
  border:      none;
  padding:     18px 24px;
  text-align:  left;
  cursor:      pointer;
  display:     flex;
  justify-content: space-between;
  align-items: center;
  font-family: var(--fuente-titulo);
  font-weight: 700;
  font-size:   1rem;
  color:       var(--color-titulo);
  transition:  var(--transicion);
}
.accordion__cabecera:hover { color: var(--color-primario); }

.accordion__cabecera[aria-expanded="true"] {
  color:         var(--color-primario);
  border-bottom: 2px solid var(--color-fondo-1);
}

.accordion__icono {
  font-size:   1.2rem;
  transition:  transform 0.3s ease;
  flex-shrink: 0;
}
.accordion__cabecera[aria-expanded="true"] .accordion__icono { transform: rotate(45deg); }

.accordion__cuerpo {
  max-height: 0;
  overflow:   hidden;
  transition: max-height none ease, padding 0.35s ease;
  padding:    0 24px;
}
.accordion__cuerpo.abierto { padding: 12px 24px 18px; }
.accordion__cuerpo p { margin: 0; font-size: 0.95rem; color: var(--color-texto); }

/* ═══════════════════════════════════════════════════════════
   13. CABECERA DE SECCIÓN (título centrado)
   ═══════════════════════════════════════════════════════════ */
.seccion-titulo {
  text-align:    center;
  margin-bottom: 48px;
}
.seccion-titulo h2 { margin-bottom: 12px; }
.seccion-titulo .separador {
  width:         72px;
  height:        4px;
  background:    var(--color-primario);
  border-radius: 2px;
  margin:        0 auto 16px;
}
.seccion-titulo p {
  max-width:  600px;
  margin:     0 auto;
  color:      var(--color-texto-muted);
  font-size:  1.05rem;
}

/* ═══════════════════════════════════════════════════════════
   14. PASOS "¿COMENZAMOS?" (sección 5 de index)
   ═══════════════════════════════════════════════════════════ */
.pasos-grid {
  display:               grid;
  grid-template-columns: repeat(4, 1fr);
  gap:                   28px;
}
@media (max-width: 991px) { .pasos-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 576px) { .pasos-grid { grid-template-columns: 1fr; } }

.paso-tarjeta {
  padding:       36px 24px;
  border-radius: var(--radio-borde-xl);
  text-align:    center;
  position:      relative;
  transition:    var(--transicion);
}
.paso-tarjeta:hover { transform: translateY(-6px); box-shadow: var(--sombra-lg); }

.paso-tarjeta:nth-child(1) { background: var(--card-color-1); }
.paso-tarjeta:nth-child(2) { background: var(--card-color-2); }
.paso-tarjeta:nth-child(3) { background: var(--card-color-3); }
.paso-tarjeta:nth-child(4) { background: var(--card-color-4); }

.paso-tarjeta__numero {
  font-family:  var(--fuente-titulo);
  font-weight:  800;
  font-size:    2.5rem;
  color:        rgba(0,0,0,0.12);
  position:     absolute;
  top:          16px;
  right:        20px;
  line-height:  1;
}
.paso-tarjeta__icono  { font-size: 2.8rem; margin-bottom: 12px; display: block; }
.paso-tarjeta__titulo { font-size: 1.05rem; font-weight: 800; margin-bottom: 8px; color: var(--color-titulo); }
.paso-tarjeta__texto  { font-size: 0.88rem; color: var(--color-texto); margin: 0; }

/* ═══════════════════════════════════════════════════════════
   15. OTROS LIBROS (sección 5 en páginas de libro)
   ═══════════════════════════════════════════════════════════ */
.otros-libros-grid {
  display:               grid;
  grid-template-columns: repeat(2, 1fr);
  gap:                   48px;
  max-width:             800px;
  margin:                0 auto;
}
@media (max-width: 576px) {
  .otros-libros-grid { grid-template-columns: 1fr; max-width: 320px; }
}

.otro-libro {
  text-align: center;
  transition: var(--transicion);
}
.otro-libro:hover { transform: translateY(-6px); }
.otro-libro img {
  border-radius: var(--radio-borde-xl);
  box-shadow:    var(--sombra-md);
  margin-bottom: 20px;
  width:         100%;
  aspect-ratio:  3/4;
  object-fit:    cover;
}
.otro-libro h3 { margin-bottom: 16px; }

/* ═══════════════════════════════════════════════════════════
   16. PÁGINAS LEGALES
   ═══════════════════════════════════════════════════════════ */
.pagina-legal {
  padding-top:    120px;
  padding-bottom: 80px;
  min-height:     80vh;
}
.pagina-legal h1 {
  margin-bottom:  32px;
  padding-bottom: 16px;
  border-bottom:  3px solid var(--color-primario);
}
.pagina-legal h2 {
  margin-top:    32px;
  margin-bottom: 12px;
  font-size:     1.3rem;
  color:         var(--color-primario);
}
.pagina-legal p,
.pagina-legal li { font-size: 0.95rem; margin-bottom: 8px; }
.pagina-legal ul { padding-left: 20px; list-style: disc; }

/* Indicador de datos a completar */
.pagina-legal .placeholder-dato {
  background:    #FFD9A0;   /* v09: mejorado, menos amarillo */
  border:        1px solid var(--color-primario);
  border-radius: 4px;
  padding:       2px 8px;
  color:         #5A2A00;
  font-weight:   700;
  font-size:     0.85rem;
}

/* ═══════════════════════════════════════════════════════════
   17. CONTACTO — bloque email
   ═══════════════════════════════════════════════════════════ */
.contacto-email-bloque {
  display:       flex;
  align-items:   center;
  gap:           16px;
  margin-bottom: 24px;
}
.contacto-email-bloque .email-icono { font-size: 2.5rem; flex-shrink: 0; }
.contacto-email-bloque a {
  font-family: var(--fuente-titulo);
  font-weight: 700;
  font-size:   1.3rem;
  color:       var(--color-primario);
}

/* ═══════════════════════════════════════════════════════════
   18. RANGOS DE EDAD (que-es.html)
   ═══════════════════════════════════════════════════════════ */
.rangos-grid {
  display:               grid;
  grid-template-columns: repeat(3, 1fr);
  gap:                   28px;
}
@media (max-width: 767px) { .rangos-grid { grid-template-columns: 1fr; } }

.rango-tarjeta {
  background:    white;
  border-radius: var(--radio-borde-xl);
  padding:       36px 24px;
  text-align:    center;
  box-shadow:    var(--sombra-md);
  border-top:    5px solid var(--color-primario);
  transition:    var(--transicion);
}
.rango-tarjeta:nth-child(1) { border-color: var(--color-primario); }
.rango-tarjeta:nth-child(2) { border-color: var(--color-secundario); }
.rango-tarjeta:nth-child(3) { border-color: var(--color-acento-2); }
.rango-tarjeta:hover { transform: translateY(-6px); box-shadow: var(--sombra-lg); }

.rango-tarjeta__icono { font-size: 3rem; margin-bottom: 12px; display: block; }
.rango-tarjeta__edad  { font-size: 1.8rem; font-weight: 800; color: var(--color-titulo); margin-bottom: 4px; }
.rango-tarjeta__curso { font-size: 0.9rem; color: var(--color-texto-muted); margin-bottom: 16px; font-weight: 600; }
.rango-tarjeta__libro { font-size: 1rem; font-weight: 700; }
