/* ============================================================
   CasaLa Teatro — styles.css (único CSS del sitio)
   Mobile-first. Sin frameworks. Paleta: sala oscura, madera,
   rojo flamenco. Bloques de compra e info práctica en claro.
   ============================================================ */

:root {
  --bg-dark: #181210;
  --bg-dark-2: #241b15;
  --crema: #f7f1e7;
  --blanco: #ffffff;
  --texto-claro: #f2e9dd;
  --texto-suave: #cfc2b2;
  --texto-oscuro: #27201a;
  --cta: #b3261e;          /* rojo flamenco: contraste AA con blanco (≈6.4:1) */
  --cta-hover: #8e1c15;
  --oro: #d9a441;
  --borde: #3a2d23;
  --max: 1100px;
  --font-display: Georgia, "Times New Roman", serif;
  --font-body: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
}

* { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; }

body {
  font-family: var(--font-body);
  background: var(--bg-dark);
  color: var(--texto-claro);
  line-height: 1.6;
  font-size: 1rem;
  /* hueco para el CTA sticky en móvil */
  padding-bottom: 72px;
}

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

a { color: var(--oro); }
a:focus-visible, button:focus-visible {
  outline: 3px solid var(--oro);
  outline-offset: 2px;
}

h1, h2, h3 { font-family: var(--font-display); line-height: 1.2; }
h1 { font-size: clamp(2rem, 6vw, 3.2rem); }
h2 { font-size: clamp(1.5rem, 4vw, 2.2rem); margin-bottom: .75rem; }
h3 { font-size: 1.2rem; margin-bottom: .4rem; }

.contenedor { max-width: var(--max); margin: 0 auto; padding: 0 1.25rem; }

.skip-link {
  position: absolute; left: -999px; top: 0;
  background: var(--cta); color: #fff; padding: .75rem 1.25rem; z-index: 200;
}
.skip-link:focus { left: 0; }

/* ---------- Header / navegación ---------- */

.site-header {
  background: var(--bg-dark-2);
  border-bottom: 1px solid var(--borde);
  position: relative;
  z-index: 50;
}
.barra {
  max-width: var(--max); margin: 0 auto; padding: .65rem 1.25rem;
  display: flex; align-items: center; gap: 1rem; flex-wrap: wrap;
}
.logo {
  font-family: var(--font-display); font-size: 1.35rem; font-weight: 700;
  color: var(--texto-claro); text-decoration: none; margin-right: auto;
}
.logo span { color: var(--oro); }

.menu-btn {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 44px; min-height: 44px;
  background: none; border: 1px solid var(--borde); border-radius: 6px;
  color: var(--texto-claro); font-size: 1.4rem; cursor: pointer;
}

.nav-principal { display: none; width: 100%; }
.nav-principal.abierto { display: block; }
.nav-principal ul { list-style: none; }
.nav-principal a {
  display: block; padding: .8rem .25rem;
  color: var(--texto-claro); text-decoration: none;
  border-bottom: 1px solid var(--borde);
}
.nav-principal a:hover, .nav-principal a[aria-current="page"] { color: var(--oro); }

.idiomas {
  font-size: .9rem; letter-spacing: .05em;
}
.idiomas a { color: var(--texto-suave); text-decoration: none; padding: .5rem .25rem; }
.idiomas a:hover { color: var(--oro); }
.idiomas .activo { color: var(--texto-claro); font-weight: 700; }

/* ---------- Botones ---------- */

.btn {
  display: inline-block;
  background: var(--cta); color: #fff;
  font-weight: 700; font-size: 1.05rem;
  text-decoration: none; text-align: center;
  padding: .9rem 1.9rem; border-radius: 6px;
  min-height: 44px; min-width: 44px;
  border: 0; cursor: pointer;
}
.btn:hover { background: var(--cta-hover); }
.btn-nav { padding: .6rem 1.1rem; font-size: .95rem; }
.btn-secundario {
  background: transparent; color: var(--texto-claro);
  border: 2px solid var(--oro);
}
.btn-secundario:hover { background: var(--oro); color: var(--texto-oscuro); }

/* CTA sticky inferior (solo móvil) */
.cta-sticky {
  position: fixed; left: 0; right: 0; bottom: 0; z-index: 100;
  display: flex; align-items: center; justify-content: center;
  min-height: 56px; padding: .6rem 1rem;
  background: var(--cta); color: #fff;
  font-weight: 700; font-size: 1.1rem; text-decoration: none;
  box-shadow: 0 -2px 10px rgba(0,0,0,.5);
}
.cta-sticky:hover { background: var(--cta-hover); }

/* ---------- Hero ---------- */

.hero { background: var(--bg-dark); }
.hero-con-foto { padding: 0 1.25rem; }   /* margen lateral en móvil (en escritorio lo redefine el grid) */
.hero-media { text-align: center; }
.hero-media img { width: auto; max-width: 100%; max-height: 58vh; height: auto; margin: 0 auto; border-radius: 8px; }
.hero-media .ph { width: 100%; }
@media (min-width: 800px) {
  .hero-media img { max-height: 440px; }
}
.hero-texto { padding: 1.75rem 0 2.25rem; }
.hero-texto .subtitulo {
  font-size: 1.15rem; color: var(--texto-suave); max-width: 38em;
  margin: .75rem 0 1.1rem;
}

.datos-clave {
  list-style: none;
  display: flex; flex-wrap: wrap; gap: .5rem 1.4rem;
  margin: 0 0 1.4rem;
  font-size: 1.05rem;
}
.datos-clave li strong { color: var(--oro); }

/* ---------- Secciones ---------- */

.seccion { padding: 2.75rem 0; }
.seccion-oscura-2 { background: var(--bg-dark-2); }
.seccion-clara { background: var(--crema); color: var(--texto-oscuro); }
.seccion-clara a { color: var(--cta); }
.seccion-clara .btn { color: var(--blanco); }   /* el botón mantiene texto blanco sobre rojo */
.seccion-clara h2, .seccion-clara h3 { color: var(--texto-oscuro); }

.texto-ancho p { max-width: 42em; margin-bottom: 1rem; font-size: 1.06rem; }

/* Prueba social */
.nota-resenas {
  font-size: 1.25rem; font-weight: 700; color: var(--oro); margin-bottom: 1.25rem;
}
.citas { display: grid; gap: 1rem; }
.citas blockquote {
  border-left: 3px solid var(--oro); padding: .25rem 0 .25rem 1rem;
  font-style: italic; color: var(--texto-claro);
}
.citas cite { display: block; font-style: normal; font-size: .85rem; color: var(--texto-suave); margin-top: .3rem; }

/* Cartelera / tarjetas de espectáculo */
.tarjetas { display: grid; gap: 1.5rem; margin-top: 1.5rem; }
.tarjeta {
  background: var(--bg-dark-2); border: 1px solid var(--borde); border-radius: 8px;
  overflow: hidden; display: flex; flex-direction: column;
}
.seccion-clara .tarjeta { background: var(--blanco); border-color: #e0d6c6; }
.tarjeta-cuerpo { padding: 1.1rem 1.2rem 1.4rem; display: flex; flex-direction: column; gap: .6rem; flex: 1; }
.tarjeta-cuerpo .tipo { font-size: .8rem; text-transform: uppercase; letter-spacing: .12em; color: var(--oro); }
.seccion-clara .tarjeta-cuerpo .tipo { color: var(--cta); }
.tarjeta-cuerpo .enlace-ficha { font-weight: 700; }
.tarjeta-acciones { margin-top: auto; display: grid; gap: .55rem; }

/* Galería */
.galeria { display: grid; grid-template-columns: repeat(2, 1fr); gap: .6rem; margin-top: 1.25rem; }
.galeria img { width: 100%; aspect-ratio: 3 / 2; object-fit: cover; border-radius: 6px; }

/* El envoltorio <picture> debe ocupar el sitio como lo hacía la <img> */
picture { display: block; }

/* Imágenes de tarjeta (cartelera) y hero: recorte uniforme */
.tarjeta > picture img { width: 100%; aspect-ratio: 3 / 2; object-fit: cover; }

/* Ficha de espectáculo */
.ficha-datos {
  list-style: none; background: var(--bg-dark-2);
  border: 1px solid var(--borde); border-radius: 8px;
  padding: 1.1rem 1.3rem; margin: 1.25rem 0;
  display: grid; gap: .35rem;
}
.ficha-datos strong { color: var(--oro); }

/* Info práctica / listas claras */
.lista-info { list-style: none; display: grid; gap: .8rem; max-width: 46em; }
.lista-info li { padding-left: 1.4rem; position: relative; }
.lista-info li::before { content: "—"; position: absolute; left: 0; color: var(--cta); }

/* Cronología (El teatro) */
.cronologia { list-style: none; margin-top: 1.25rem; display: grid; gap: .5rem; max-width: 36em; }
.cronologia li { border-left: 3px solid var(--oro); padding-left: 1rem; }
.cronologia strong { color: var(--oro); }
.seccion-clara .cronologia strong { color: var(--cta); }

/* FAQ */
.faq-lista { max-width: 46em; display: grid; gap: .6rem; }
.faq-lista details {
  background: var(--blanco); border: 1px solid #e0d6c6; border-radius: 8px;
  padding: .9rem 1.1rem;
}
.faq-lista summary {
  font-weight: 700; cursor: pointer; min-height: 44px;
  display: flex; align-items: center;
}
.faq-lista details p { margin-top: .6rem; }

/* Zona de compra */
.zona-compra {
  background: var(--blanco); border: 2px solid #e0d6c6; border-radius: 10px;
  padding: 1.75rem 1.4rem; text-align: center; margin-top: 1.5rem;
}
.zona-compra .nota-aforo { margin-top: .8rem; font-size: .95rem; color: #5d5246; }

/* Cartel del espectáculo (póster) */
.cartel { max-width: 340px; margin: 1.5rem auto 0; }
.cartel img { width: 100%; height: auto; border-radius: 8px; border: 1px solid var(--borde); }

/* Mapa bajo consentimiento (carga al pulsar) */
.mapa-consent { background: var(--blanco); border: 1px solid #e0d6c6; border-radius: 8px; padding: 1.5rem; text-align: center; margin: 1.25rem 0; }
.cargar-mapa { background: var(--bg-dark-2); }
.cargar-mapa:hover { background: var(--bg-dark); }
.nota-mapa { font-size: .9rem; color: #5d5246; margin: .6rem 0 0; }

/* CTA final */
.cta-final { text-align: center; padding: 3rem 0; }
.cta-final p { font-size: 1.2rem; margin-bottom: 1.2rem; }

/* ---------- Footer ---------- */

.site-footer {
  background: var(--bg-dark-2); border-top: 1px solid var(--borde);
  padding: 2.25rem 0 2.75rem; font-size: .92rem; color: var(--texto-suave);
}
.site-footer .contenedor { display: grid; gap: 1.5rem; }
.site-footer a { color: var(--texto-suave); }
.site-footer a:hover { color: var(--oro); }
.site-footer ul { list-style: none; display: grid; gap: .4rem; }
.site-footer address { font-style: normal; }

/* ---------- Placeholder de imagen pendiente ---------- */
.ph { background: #6b6b6b; }

/* ---------- Escritorio ---------- */

@media (min-width: 800px) {
  body { padding-bottom: 0; }
  .cta-sticky { display: none; }

  .menu-btn { display: none; }
  .nav-principal { display: block; width: auto; }
  .nav-principal ul { display: flex; gap: .25rem; }
  .nav-principal a { border-bottom: 0; padding: .6rem .7rem; }

  .hero-con-foto {
    display: grid; grid-template-columns: 1.05fr 1fr; gap: 2.5rem;
    align-items: center; max-width: var(--max); margin: 0 auto; padding: 3rem 1.25rem;
  }
  .hero-texto { padding: 0; }

  .tarjetas { grid-template-columns: repeat(2, 1fr); }
  .galeria { grid-template-columns: repeat(3, 1fr); }
  .citas { grid-template-columns: repeat(3, 1fr); }
  .site-footer .contenedor { grid-template-columns: 2fr 1fr 1fr; }
}
