/* =========================================================
   PAISAJE SONORO — Hoja de estilos compartida
   Versión 1.0 · 2026
   ========================================================= */


/* === VARIABLES === */
:root {
  --tierra: #3d2b1f;
  --tierra-medio: #6b4c38;
  --arena: #c4a882;
  --arena-claro: #e8d9c4;
  --papel: #f5ede0;
  --musgo: #5a6b4a;
  --musgo-claro: #8a9e78;
  --piedra: #8c7b6e;
  --niebla: #d4c9bb;
  --blanco: #faf6f0;
}


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

html { scroll-behavior: smooth; }

body {
  background: var(--blanco);
  color: var(--tierra);
  font-family: 'Jost', sans-serif;
  font-weight: 300;
  overflow-x: hidden;
}

/* Textura de grano sutil sobre toda la página */
body::before {
  content: '';
  position: fixed;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
  pointer-events: none;
  z-index: 1000;
  opacity: .5;
}


/* === TOGGLE DE IDIOMA === */
/* Pastilla translúcida con blur — no se confunde con el texto al escrolear */
.lang-toggle {
  position: fixed;
  top: 1.2rem;
  right: 1.5rem;
  z-index: 200;
  display: flex;
  gap: .4rem;
  align-items: center;
  background: rgba(245, 237, 224, 0.85);
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
  padding: .45rem .9rem;
  border-radius: 100px;
  border: 1px solid rgba(196, 168, 130, 0.35);
  box-shadow: 0 2px 14px rgba(61, 43, 31, 0.10);
}

.lang-btn {
  background: none;
  border: none;
  font-family: 'Jost', sans-serif;
  font-weight: 300;
  font-size: .7rem;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: var(--piedra);
  cursor: pointer;
  padding: .15rem .35rem;
  transition: color .3s;
}

.lang-btn.active {
  color: var(--tierra);
  font-weight: 500;
}

.lang-divider {
  width: 1px;
  height: 10px;
  background: var(--niebla);
}

.en { display: none; }


/* === HERO === */
.hero {
  position: relative;
  min-height: 100vh;
  background-image: url('../img/hero-grabacion.jpg');
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 4rem 2.5rem 3rem;
  isolation: isolate;
}

/* Overlay oscuro para legibilidad del texto */
.hero::before {
  content: '';
  position: absolute;
  inset: 0;
  z-index: -1;
  background:
    linear-gradient(180deg, rgba(61,43,31,.55) 0%, rgba(61,43,31,.45) 40%, rgba(61,43,31,.7) 100%),
    linear-gradient(90deg, rgba(61,43,31,.35) 0%, rgba(61,43,31,0) 60%);
}

.hero-content {
  display: flex;
  flex-direction: column;
  justify-content: center;
  max-width: 850px;
  padding-top: 5rem;
}

.proyecto-label {
  font-size: .7rem;
  letter-spacing: .3em;
  text-transform: uppercase;
  color: var(--arena-claro);
  margin-bottom: 2.5rem;
  opacity: 0;
  animation: fadeUp 1s ease .3s forwards;
}

.titulo-principal {
  font-family: 'Cormorant Garamond', serif;
  font-weight: 300;
  font-size: clamp(3.5rem, 9vw, 7rem);
  line-height: .93;
  color: var(--blanco);
  margin-bottom: .25em;
  text-shadow: 0 2px 18px rgba(0,0,0,.25);
  opacity: 0;
  animation: fadeUp 1.2s ease .5s forwards;
}

.titulo-secundario {
  font-family: 'Cormorant Garamond', serif;
  font-weight: 300;
  font-style: italic;
  font-size: clamp(1.1rem, 2.5vw, 1.8rem);
  color: var(--arena-claro);
  margin-bottom: 3rem;
  opacity: 0;
  animation: fadeUp 1.2s ease .7s forwards;
}

.descripcion {
  max-width: 540px;
  font-size: .95rem;
  line-height: 1.9;
  color: var(--niebla);
  opacity: 0;
  animation: fadeUp 1.2s ease .9s forwards;
}


/* === ACCESO AL ARCHIVO === */
.s-acceso {
  padding: 6rem 2.5rem 7rem;
  background: var(--papel);
  text-align: center;
}

.acceso-link {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  gap: 1.3rem;
  text-decoration: none;
  color: inherit;
  padding: 2rem 1.5rem;
  max-width: 720px;
  width: 100%;
  cursor: pointer;
  transition: transform .4s ease;
}

.acceso-link:hover {
  transform: translateY(-3px);
}

.acceso-label {
  font-size: .62rem;
  letter-spacing: .3em;
  text-transform: uppercase;
  color: var(--musgo);
  margin-bottom: .3rem;
}

.acceso-titulo {
  font-family: 'Cormorant Garamond', serif;
  font-weight: 300;
  font-size: clamp(2rem, 4.5vw, 3.2rem);
  color: var(--tierra);
  line-height: 1.1;
  margin-bottom: .8rem;
}

.acceso-subtitulo {
  font-family: 'Cormorant Garamond', serif;
  font-style: italic;
  font-size: 1.1rem;
  color: var(--tierra-medio);
  margin-bottom: 1.5rem;
}

.acceso-onda {
  width: 100%;
  max-width: 620px;
  opacity: .85;
  transition: opacity .4s ease;
  mix-blend-mode: multiply;
}

.acceso-onda img {
  width: 100%;
  height: auto;
  display: block;
}

.acceso-link:hover .acceso-onda {
  opacity: 1;
}

.acceso-cta {
  display: inline-flex;
  align-items: center;
  gap: .8rem;
  font-size: .72rem;
  letter-spacing: .25em;
  text-transform: uppercase;
  color: var(--tierra);
  padding: 1rem 2.2rem;
  border: 1px solid var(--tierra);
  margin-top: .5rem;
  transition: background .35s ease, color .35s ease;
}

.acceso-link:hover .acceso-cta {
  background: var(--tierra);
  color: var(--blanco);
}


/* === CONCEPTO === */
.s-concepto {
  padding: 7rem 2.5rem;
  background: var(--tierra);
  position: relative;
  overflow: hidden;
}

.s-concepto::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--arena), transparent);
}

.concepto-inner {
  max-width: 980px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 5rem;
  align-items: start;
}

.c-num {
  font-family: 'Cormorant Garamond', serif;
  font-size: 7rem;
  line-height: 1;
  color: var(--tierra-medio);
  opacity: .35;
  margin-bottom: -1.5rem;
}

.c-titulo {
  font-family: 'Cormorant Garamond', serif;
  font-weight: 400;
  font-size: 2.6rem;
  color: var(--arena-claro);
  line-height: 1.15;
  margin-bottom: 1.5rem;
}

.c-texto {
  font-size: .92rem;
  line-height: 1.95;
  color: var(--niebla);
}

.c-cita {
  font-family: 'Cormorant Garamond', serif;
  font-style: italic;
  font-size: 1.45rem;
  color: var(--arena);
  line-height: 1.55;
  padding-left: 1.5rem;
  border-left: 2px solid var(--musgo-claro);
  margin-top: 2.5rem;
}

.c-cita small {
  display: block;
  font-size: .65rem;
  font-family: 'Jost', sans-serif;
  font-style: normal;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: var(--musgo-claro);
  margin-top: .7rem;
}


/* === MÉTODO === */
.s-metodo {
  padding: 7rem 2.5rem;
  background: var(--papel);
}

.m-header {
  max-width: 980px;
  margin: 0 auto 4.5rem;
}

.s-etiqueta {
  font-size: .62rem;
  letter-spacing: .3em;
  text-transform: uppercase;
  color: var(--musgo);
  margin-bottom: .8rem;
}

.s-titulo {
  font-family: 'Cormorant Garamond', serif;
  font-weight: 300;
  font-size: clamp(1.8rem, 3.5vw, 3rem);
  color: var(--tierra);
  line-height: 1.2;
}

.m-grid {
  max-width: 980px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2.5rem;
}

.m-item {
  padding-top: 1.8rem;
  border-top: 2px solid var(--musgo-claro);
}

.m-icono {
  font-family: 'Cormorant Garamond', serif;
  font-size: 2.2rem;
  color: var(--arena);
  margin-bottom: .8rem;
  display: block;
}

.m-nombre {
  font-size: .65rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--musgo);
  margin-bottom: .7rem;
}

.m-desc {
  font-size: .9rem;
  line-height: 1.85;
  color: var(--tierra-medio);
}


/* === PROTOCOLO === */
.s-protocolo {
  padding: 7rem 2.5rem;
  background: var(--blanco);
  position: relative;
}

.proto-inner {
  max-width: 980px;
  margin: 0 auto;
}

.proto-intro {
  margin-bottom: 5rem;
  max-width: 720px;
}

.proto-intro-texto p {
  margin-top: 1.4rem;
  font-size: .92rem;
  line-height: 1.95;
  color: var(--tierra-medio);
}

.proto-version {
  display: inline-block;
  margin-top: 2rem;
  font-size: .58rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--musgo);
  padding: .35rem .8rem;
  border: 1px solid var(--niebla);
}

.proto-list {
  border-top: 1px solid var(--niebla);
}

.proto-item {
  border-bottom: 1px solid var(--niebla);
}

.proto-header {
  display: flex;
  align-items: baseline;
  gap: 1.5rem;
  padding: 1.3rem 0;
  cursor: pointer;
  list-style: none;
  user-select: none;
  -webkit-user-select: none;
}

.proto-header::-webkit-details-marker { display: none; }

.proto-num {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1rem;
  color: var(--arena);
  flex-shrink: 0;
  width: 1.8rem;
}

.proto-titulo {
  flex: 1;
  font-size: .7rem;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: var(--tierra);
  font-weight: 400;
}

.proto-flecha {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.4rem;
  color: var(--niebla);
  margin-left: auto;
  flex-shrink: 0;
  transition: transform .35s ease, color .35s ease;
}

details[open] .proto-flecha {
  transform: rotate(45deg);
  color: var(--musgo-claro);
}

.proto-body {
  padding: 0 0 2.2rem 3.3rem;
  font-size: .9rem;
  line-height: 2;
  color: var(--tierra-medio);
}

.proto-body p + p { margin-top: .8rem; }

.proto-body ul {
  margin: .9rem 0;
  list-style: none;
}

.proto-body ul li {
  position: relative;
  padding-left: 1.2rem;
  margin-bottom: .6rem;
}

.proto-body ul li::before {
  content: '·';
  position: absolute;
  left: 0;
  color: var(--musgo-claro);
}

.proto-body strong {
  color: var(--tierra);
  font-weight: 400;
}

.proto-principio {
  margin: 4rem 0;
  padding: 2.5rem 3rem;
  background: var(--tierra);
  position: relative;
}

.proto-principio::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--musgo-claro), transparent);
}

.proto-p-label {
  font-size: .58rem;
  letter-spacing: .25em;
  text-transform: uppercase;
  color: var(--musgo-claro);
  margin-bottom: 1.1rem;
}

.proto-p-texto {
  font-family: 'Cormorant Garamond', serif;
  font-style: italic;
  font-size: 1.3rem;
  color: var(--arena-claro);
  line-height: 1.75;
}

.proto-cita {
  font-family: 'Cormorant Garamond', serif;
  font-style: italic;
  font-size: 1.15rem;
  color: var(--tierra-medio);
  line-height: 1.55;
  padding-left: 1.5rem;
  border-left: 2px solid var(--musgo-claro);
  margin: 1.2rem 0;
}

.proto-cita small {
  display: block;
  font-size: .62rem;
  font-family: 'Jost', sans-serif;
  font-style: normal;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: var(--musgo);
  margin-top: .6rem;
}


/* === FOOTER === */
footer {
  padding: 3.5rem 2.5rem 2.8rem;
  background: var(--tierra);
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  flex-wrap: wrap;
  gap: 2.5rem;
  border-top: 1px solid var(--tierra-medio);
}

.f-marca {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.25rem;
  color: var(--arena);
  letter-spacing: .04em;
  margin-bottom: .9rem;
}

.f-contacto {
  font-size: .88rem;
  color: var(--arena-claro);
  letter-spacing: .03em;
  line-height: 1.7;
}

.f-contacto a {
  color: var(--blanco);
  text-decoration: none;
  border-bottom: 1px solid var(--musgo-claro);
  padding-bottom: 1px;
  transition: color .3s, border-color .3s;
}

.f-contacto a:hover {
  color: var(--arena);
  border-bottom-color: var(--arena);
}

.f-info {
  font-size: .88rem;
  color: var(--niebla);
  text-align: right;
  letter-spacing: .03em;
  line-height: 1.7;
  max-width: 360px;
}

.f-info a {
  color: var(--arena-claro);
  text-decoration: none;
  border-bottom: 1px solid transparent;
  transition: color .3s, border-color .3s;
}

.f-info a:hover {
  color: var(--blanco);
  border-bottom-color: var(--arena-claro);
}

.f-licencia {
  margin-top: .6rem;
  color: var(--niebla);
}

.f-privacidad {
  margin-top: .35rem;
  color: var(--niebla);
  font-size: .8rem;
  font-style: italic;
}


/* === ANIMACIONES === */
@keyframes fadeUp {
  from { opacity: 0; transform: translateY(18px); }
  to   { opacity: 1; transform: translateY(0); }
}

@keyframes fadeIn {
  from { opacity: 0; }
  to   { opacity: 1; }
}


/* === RESPONSIVE === */
@media (max-width: 768px) {
  .lang-toggle {
    top: .9rem;
    right: 1rem;
    padding: .4rem .75rem;
  }

  .hero {
    padding: 3rem 1.5rem 2rem;
    background-position: center center;
  }

  /* En móvil vertical, variante con encuadre portrait del hero */
  @media (orientation: portrait) {
    .hero {
      background-image: url('../img/hero-grabacion-movil.jpg');
    }
  }

  .hero-content {
    padding-top: 4rem;
  }

  .descripcion {
    font-size: .95rem;
  }

  .s-acceso {
    padding: 4.5rem 1.5rem 5rem;
  }

  .s-concepto, .s-metodo, .s-protocolo {
    padding: 5rem 1.5rem;
  }

  .concepto-inner {
    grid-template-columns: 1fr;
    gap: 3rem;
  }

  .m-grid {
    grid-template-columns: 1fr;
    gap: 2rem;
  }

  .proto-body {
    padding-left: 1.5rem;
  }

  .proto-principio {
    padding: 2rem 1.5rem;
  }

  footer {
    flex-direction: column;
    text-align: center;
    padding: 3rem 1.5rem 2.5rem;
    gap: 2rem;
  }

  .f-info {
    text-align: center;
    max-width: none;
  }
}


/* =========================================================
   PÁGINAS INTERNAS — archivo, municipios, paisajes
   ========================================================= */

/* === CABECERA INTERNA === */
.cabecera-interna {
  padding: 6.5rem 2.5rem 1.8rem;
  background: var(--papel);
  border-bottom: 1px solid var(--niebla);
}

.cabecera-inner {
  max-width: 1280px;
  margin: 0 auto;
}

.breadcrumb {
  font-size: .68rem;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: var(--piedra);
  margin-bottom: 1rem;
}

.breadcrumb a {
  color: var(--musgo);
  text-decoration: none;
  transition: color .3s;
}

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

.breadcrumb .sep {
  margin: 0 .6rem;
  color: var(--niebla);
}

.cabecera-titulo {
  font-family: 'Cormorant Garamond', serif;
  font-weight: 300;
  font-size: clamp(2rem, 4vw, 3rem);
  color: var(--tierra);
  line-height: 1.1;
}

.cabecera-sub {
  font-family: 'Cormorant Garamond', serif;
  font-style: italic;
  font-size: 1.1rem;
  color: var(--tierra-medio);
  margin-top: .4rem;
}


/* === FILTROS === */
.filtros-bar {
  background: var(--blanco);
  border-bottom: 1px solid var(--niebla);
  padding: 1.2rem 2.5rem;
}

.filtros-inner {
  max-width: 1280px;
  margin: 0 auto;
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
  align-items: center;
}

.filtros-label {
  font-size: .6rem;
  letter-spacing: .25em;
  text-transform: uppercase;
  color: var(--musgo);
  margin-right: .8rem;
}

.filtro-chip {
  background: none;
  border: 1px solid var(--niebla);
  font-family: 'Jost', sans-serif;
  font-weight: 300;
  font-size: .68rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--tierra-medio);
  padding: .45rem 1rem;
  cursor: pointer;
  border-radius: 100px;
  transition: background .3s, color .3s, border-color .3s;
}

.filtro-chip:hover {
  border-color: var(--musgo-claro);
  color: var(--tierra);
}

.filtro-chip.activo {
  background: var(--musgo);
  border-color: var(--musgo);
  color: var(--blanco);
}

.filtro-reset {
  background: none;
  border: none;
  font-size: .65rem;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: var(--piedra);
  cursor: pointer;
  padding: .45rem .7rem;
  margin-left: auto;
  transition: color .3s;
}

.filtro-reset:hover { color: var(--tierra); }


/* === LAYOUT ARCHIVO === */
/* Una sola columna: mapa a todo ancho arriba, lista de municipios y
   paisajes debajo. La página crece verticalmente conforme se añaden
   municipios nuevos, sin scroll interno. */
.archivo-main {
  display: block;
  max-width: 1280px;
  margin: 0 auto;
  padding: 2rem 2.5rem;
}

.mapa-contenedor {
  height: 60vh;
  min-height: 460px;
  border: 1px solid var(--niebla);
  background: var(--papel);
  margin-bottom: 3.5rem;
}

#mapa { width: 100%; height: 100%; }


/* === LISTA DE MUNICIPIOS Y PAISAJES === */
/* Antes era un sidebar lateral con scroll propio; ahora flota como
   sección de lectura debajo del mapa, con un ancho de columna
   consistente con el resto del sitio. */
.archivo-sidebar {
  max-width: 820px;
  margin: 0 auto;
}

.sidebar-header {
  display: flex;
  align-items: baseline;
  flex-wrap: wrap;
  gap: .6rem;
  margin-bottom: 1.5rem;
  padding-bottom: .8rem;
  border-bottom: 1px solid var(--niebla);
}

.sidebar-titulo {
  font-size: .68rem;
  letter-spacing: .25em;
  text-transform: uppercase;
  color: var(--musgo);
}

.sidebar-contador {
  font-family: 'Cormorant Garamond', serif;
  font-style: italic;
  font-size: .95rem;
  color: var(--tierra-medio);
}

.sidebar-contador::before {
  content: '·';
  margin-right: .5rem;
  color: var(--niebla);
  font-style: normal;
}

.municipio-grupo { margin-bottom: 3rem; }

.municipio-link {
  display: block;
  text-decoration: none;
  color: inherit;
  padding-bottom: 1rem;
  border-bottom: 2px solid var(--musgo-claro);
  margin-bottom: 1rem;
  transition: border-color .3s, transform .3s;
}

.municipio-link:hover {
  border-bottom-color: var(--musgo);
  transform: translateX(3px);
}

.municipio-link::after {
  content: ' →';
  font-family: 'Cormorant Garamond', serif;
  color: var(--arena);
  opacity: 0;
  transition: opacity .3s;
}

.municipio-link:hover::after { opacity: 1; }

.municipio-cabecera {
  font-family: 'Cormorant Garamond', serif;
  font-size: 2.2rem;
  color: var(--tierra);
  margin-bottom: .3rem;
  font-weight: 500;
  display: inline;
}

.municipio-comunidad {
  font-size: .58rem;
  letter-spacing: .25em;
  text-transform: uppercase;
  color: var(--piedra);
  margin-bottom: 1rem;
}

.paisaje-card {
  display: block;
  text-decoration: none;
  color: inherit;
  padding: 1rem 0;
  border-bottom: 1px solid var(--niebla);
  transition: padding-left .3s ease;
}

.paisaje-card:hover { padding-left: .5rem; }

.paisaje-card-num {
  font-family: 'Cormorant Garamond', serif;
  font-size: .85rem;
  color: var(--arena);
  letter-spacing: .08em;
  margin-right: .6rem;
}

.paisaje-card-titulo {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.15rem;
  color: var(--tierra);
}

.paisaje-card-meta {
  margin-top: .35rem;
  font-size: .68rem;
  letter-spacing: .08em;
  color: var(--piedra);
  line-height: 1.7;
}

.paisaje-card-tag {
  display: inline-block;
  font-size: .55rem;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: var(--musgo);
  padding: .2rem .55rem;
  border: 1px solid var(--musgo-claro);
  margin-top: .4rem;
}

.sidebar-vacio {
  font-style: italic;
  color: var(--piedra);
  font-size: .9rem;
  padding: 2rem 0;
  text-align: center;
}


/* === POPUP DE LEAFLET === */
.leaflet-popup-content-wrapper {
  border-radius: 0 !important;
  background: var(--blanco);
}

.leaflet-popup-tip { background: var(--blanco); }

.leaflet-popup-content {
  margin: 1rem 1.2rem !important;
  font-family: 'Jost', sans-serif;
  color: var(--tierra);
  min-width: 200px;
}

.popup-titulo {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.2rem;
  color: var(--tierra);
  margin-bottom: .3rem;
}

.popup-meta {
  font-size: .62rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--piedra);
  margin-bottom: .8rem;
}

.popup-cta {
  display: inline-block;
  font-size: .65rem;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: var(--blanco) !important;
  background: var(--tierra);
  padding: .5rem 1rem;
  text-decoration: none;
  transition: background .3s;
}

.popup-cta:hover { background: var(--musgo); }


/* === RESPONSIVE PÁGINAS INTERNAS === */
@media (max-width: 900px) {
  .cabecera-interna {
    padding: 5.5rem 1.5rem 1.5rem;
  }

  .filtros-bar { padding: 1rem 1.5rem; }

  .filtros-label {
    width: 100%;
    margin-bottom: .3rem;
  }

  .filtro-reset {
    margin-left: 0;
    margin-top: .3rem;
  }

  .archivo-main {
    padding: 1.5rem 1.5rem 2rem;
  }

  .mapa-contenedor {
    height: 55vh;
    min-height: 380px;
    margin-bottom: 2.5rem;
  }

  .municipio-cabecera {
    font-size: 1.8rem;
  }
}


/* =========================================================
   PÁGINA DE MUNICIPIO
   ========================================================= */

/* === Descripción + cita Wikipedia === */
.municipio-descripcion {
  max-width: 820px;
  margin: 0 auto;
  padding: 3.5rem 2.5rem 2.5rem;
}

.municipio-descripcion p {
  font-size: 1.05rem;
  line-height: 1.85;
  color: var(--tierra-medio);
  margin-bottom: 1.5rem;
}

.municipio-cita {
  font-size: .65rem !important;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--piedra) !important;
  font-style: italic;
  line-height: 1.7 !important;
}

.municipio-cita a {
  color: var(--musgo);
  text-decoration: none;
  border-bottom: 1px solid var(--musgo-claro);
  padding-bottom: 1px;
  transition: color .3s, border-color .3s;
}

.municipio-cita a:hover {
  color: var(--tierra);
  border-bottom-color: var(--tierra);
}


/* === Mapa local === */
.mapa-local-contenedor {
  max-width: 1280px;
  margin: 0 auto 4rem;
  padding: 0 2.5rem;
}

.mapa-local {
  width: 100%;
  height: 50vh;
  min-height: 380px;
  border: 1px solid var(--niebla);
  background: var(--papel);
}


/* === Cabecera de la sección de tarjetas === */
.tarjetas-header {
  max-width: 1280px;
  margin: 0 auto 2rem;
  padding: 0 2.5rem;
  display: flex;
  align-items: baseline;
  gap: .8rem;
  flex-wrap: wrap;
}

.tarjetas-titulo {
  font-size: .68rem;
  letter-spacing: .25em;
  text-transform: uppercase;
  color: var(--musgo);
}

.tarjetas-contador {
  font-family: 'Cormorant Garamond', serif;
  font-style: italic;
  font-size: .95rem;
  color: var(--tierra-medio);
}

.tarjetas-contador::before {
  content: '·';
  margin-right: .5rem;
  color: var(--niebla);
  font-style: normal;
}


/* === Grid de tarjetas grandes === */
.tarjetas-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 1.8rem;
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 2.5rem 5rem;
}

.tarjeta {
  display: block;
  text-decoration: none;
  color: inherit;
  background: var(--blanco);
  border: 1px solid var(--niebla);
  transition: transform .35s ease, box-shadow .35s ease;
  overflow: hidden;
}

.tarjeta:hover {
  transform: translateY(-4px);
  box-shadow: 0 14px 30px rgba(61, 43, 31, 0.10);
}

.tarjeta-imagen {
  width: 100%;
  aspect-ratio: 4 / 3;
  background-color: var(--arena-claro);
  background-image: linear-gradient(135deg, var(--arena-claro) 0%, var(--niebla) 100%);
  background-size: cover;
  background-position: center;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  border-bottom: 1px solid var(--niebla);
}

.tarjeta-num {
  font-family: 'Cormorant Garamond', serif;
  font-size: 4.5rem;
  color: var(--arena);
  opacity: .6;
  letter-spacing: .03em;
  font-weight: 300;
}

.tarjeta-imagen.con-imagen .tarjeta-num {
  opacity: 0;
}

.tarjeta-info {
  padding: 1.3rem 1.4rem 1.4rem;
}

.tarjeta-titulo {
  font-family: 'Cormorant Garamond', serif;
  font-weight: 400;
  font-size: 1.4rem;
  color: var(--tierra);
  line-height: 1.2;
  margin-bottom: .35rem;
}

.tarjeta-lugar {
  font-size: .8rem;
  color: var(--tierra-medio);
  margin-bottom: .2rem;
  line-height: 1.5;
}

.tarjeta-fecha {
  font-size: .62rem;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: var(--piedra);
  margin-bottom: 1rem;
}

.tarjeta-meta {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: .9rem;
  border-top: 1px solid var(--niebla);
  gap: .6rem;
}

.tarjeta-tag {
  display: inline-block;
  font-size: .55rem;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: var(--musgo);
  padding: .25rem .55rem;
  border: 1px solid var(--musgo-claro);
}

.tarjeta-cta {
  font-size: .65rem;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: var(--tierra);
  font-weight: 400;
}

.tarjetas-vacio {
  grid-column: 1 / -1;
  font-style: italic;
  color: var(--piedra);
  font-size: 1rem;
  padding: 4rem 0;
  text-align: center;
}


/* === Responsive municipio === */
@media (max-width: 900px) {
  .municipio-descripcion {
    padding: 2.5rem 1.5rem 2rem;
  }

  .municipio-descripcion p {
    font-size: .98rem;
  }

  .mapa-local-contenedor {
    padding: 0 1.5rem;
    margin-bottom: 3rem;
  }

  .mapa-local {
    height: 45vh;
    min-height: 320px;
  }

  .tarjetas-header {
    padding: 0 1.5rem;
  }

  .tarjetas-grid {
    padding: 0 1.5rem 4rem;
    gap: 1.5rem;
  }
}


/* =========================================================
   PÁGINA INDIVIDUAL DE PAISAJE
   ========================================================= */

/* === Cabecera del paisaje === */
.paisaje-cabecera {
  padding: 6.5rem 2.5rem 2.5rem;
  background: var(--papel);
  border-bottom: 1px solid var(--niebla);
  text-align: center;
}

.paisaje-cabecera-inner {
  max-width: 980px;
  margin: 0 auto;
  /* Reserva espacio para título + lugar + fecha mientras el JS rellena (anti-CLS) */
  min-height: 9rem;
}

.paisaje-cabecera .breadcrumb {
  text-align: left;
}

.paisaje-titulo {
  font-family: 'Cormorant Garamond', serif;
  font-weight: 300;
  font-size: clamp(2.2rem, 5vw, 3.8rem);
  color: var(--tierra);
  line-height: 1.1;
  margin: 1.5rem 0 .6rem;
}

.paisaje-lugar {
  font-family: 'Cormorant Garamond', serif;
  font-style: italic;
  font-size: 1.2rem;
  color: var(--tierra-medio);
  margin-bottom: .4rem;
}

.paisaje-fecha {
  font-size: .68rem;
  letter-spacing: .25em;
  text-transform: uppercase;
  color: var(--musgo);
}


/* === Reproductor de audio === */
.paisaje-audio {
  background: var(--tierra);
  padding: 2.5rem 2.5rem;
  position: relative;
}

.paisaje-audio::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--musgo-claro), transparent);
}

.paisaje-audio-inner {
  max-width: 980px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.paisaje-audio-label {
  font-size: .62rem;
  letter-spacing: .3em;
  text-transform: uppercase;
  color: var(--arena-claro);
}

#audio-player {
  width: 100%;
  height: 50px;
}

.paisaje-audio-nota {
  font-size: .85rem;
  font-style: italic;
  color: var(--niebla);
  margin: .25rem 0 0;
  letter-spacing: .02em;
}

.paisaje-audio-error {
  font-size: .85rem;
  font-style: italic;
  color: var(--arena-claro);
  margin: .35rem 0 0;
  letter-spacing: .02em;
  border-left: 2px solid var(--arena);
  padding-left: .65rem;
}


/* === Hero (foto a sangre) ===
   Como <img> a ancho completo y altura natural: la imagen se ve íntegra
   en cualquier orientación de pantalla, sin recortes. */
.paisaje-hero-wrap {
  position: relative;
  width: 100%;
  min-height: 220px;
  background-color: var(--arena-claro);
}

/* Una vez cargada la imagen, el wrapper se ajusta a la altura natural
   de la imagen y desaparece cualquier strip residual debajo. */
.paisaje-hero-wrap.loaded {
  min-height: 0;
}

.paisaje-hero {
  display: block;
  width: 100%;
  height: auto;
  background-color: var(--arena-claro);
}

/* Mensaje superpuesto mientras la imagen carga desde Internet Archive,
   o mensaje de error/retry si no llega en 15 s. */
.paisaje-hero-status {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  pointer-events: none;
  padding: 1.5rem;
}

/* El atributo [hidden] tiene que ganarle a `display: flex` de arriba. */
.paisaje-hero-status[hidden] {
  display: none;
}

.paisaje-hero-msg {
  margin: 0;
  max-width: 30rem;
  font-size: .85rem;
  font-style: italic;
  letter-spacing: .02em;
  color: var(--tierra-medio);
  text-align: center;
}

.paisaje-hero-msg[data-state="error"] {
  color: var(--tierra);
}


/* === Mapa del paisaje === */
.paisaje-mapa-cont {
  width: 100%;
  background: var(--papel);
}

.paisaje-mapa {
  width: 100%;
  height: 50vh;
  min-height: 380px;
  border-bottom: 1px solid var(--niebla);
}


/* === Descripción narrativa === */
.paisaje-descripcion {
  max-width: 820px;
  margin: 0 auto;
  padding: 4.5rem 2.5rem 3rem;
  /* Reserva espacio mientras el JS rellena (anti-CLS) */
  min-height: 12rem;
}

.paisaje-descripcion p {
  font-size: 1.1rem;
  line-height: 1.9;
  color: var(--tierra-medio);
  margin-bottom: 1.5rem;
}

.paisaje-sonidos {
  max-width: 820px;
  margin: 0 auto;
  padding: 0 2.5rem 4rem;
}

.sonidos-bloque {
  padding: 1.5rem 0;
  border-top: 1px solid var(--niebla);
}

.sonidos-bloque:last-child {
  border-bottom: 1px solid var(--niebla);
}

.sonidos-label {
  font-size: .62rem;
  letter-spacing: .25em;
  text-transform: uppercase;
  color: var(--musgo);
  margin-bottom: .5rem;
}

.sonidos-texto {
  font-size: .98rem;
  line-height: 1.75;
  color: var(--tierra);
  /* Reserva espacio mínimo mientras el JS rellena (anti-CLS) */
  min-height: 3.5rem;
  display: block;
}


/* === Ficha técnica === */
.ficha-tecnica {
  max-width: 980px;
  margin: 0 auto;
  padding: 2rem 2.5rem 5rem;
}

.ficha-grupo {
  margin-bottom: 3rem;
}

.ficha-grupo h2 {
  font-family: 'Cormorant Garamond', serif;
  font-weight: 400;
  font-size: 1.6rem;
  color: var(--tierra);
  margin-bottom: 1rem;
  padding-bottom: .6rem;
  border-bottom: 1px solid var(--niebla);
}

.ficha-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: .9rem 2rem;
}

.ficha-fila {
  display: flex;
  flex-direction: column;
  padding: .5rem 0;
  border-bottom: 1px dotted var(--niebla);
}

.ficha-fila dt {
  font-size: .58rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--musgo);
  margin-bottom: .3rem;
}

.ficha-fila dd {
  font-size: .92rem;
  color: var(--tierra);
  line-height: 1.5;
}


/* === Pie con metadatos === */
.paisaje-meta {
  background: var(--papel);
  padding: 2.5rem 2.5rem;
  border-top: 1px solid var(--niebla);
  border-bottom: 1px solid var(--niebla);
}

.paisaje-meta-inner {
  max-width: 980px;
  margin: 0 auto;
  display: flex;
  flex-wrap: wrap;
  gap: 1rem 2.5rem;
  align-items: center;
  justify-content: center;
  font-size: .65rem;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: var(--piedra);
  text-align: center;
}

.paisaje-meta-inner span {
  white-space: nowrap;
}

.paisaje-meta-inner a {
  color: var(--musgo);
  text-decoration: none;
  border-bottom: 1px solid var(--musgo-claro);
  padding-bottom: 1px;
  transition: color .3s, border-color .3s;
}

.paisaje-meta-inner a:hover {
  color: var(--tierra);
  border-bottom-color: var(--tierra);
}


/* === Navegación inferior === */
.paisaje-nav {
  max-width: 980px;
  margin: 0 auto;
  padding: 3rem 2.5rem 5rem;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.5rem;
}

.nav-link {
  display: flex;
  flex-direction: column;
  gap: .5rem;
  padding: 1.5rem 1.8rem;
  border: 1px solid var(--niebla);
  text-decoration: none;
  color: inherit;
  transition: border-color .3s, transform .3s, background .3s;
}

.nav-link:hover {
  border-color: var(--musgo-claro);
  transform: translateY(-2px);
  background: var(--papel);
}

.nav-link.disabled {
  opacity: .35;
  pointer-events: none;
}

.nav-link.next {
  text-align: right;
}

.nav-label {
  font-size: .55rem;
  letter-spacing: .25em;
  text-transform: uppercase;
  color: var(--musgo);
}

.nav-titulo {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.2rem;
  color: var(--tierra);
  line-height: 1.2;
}

.paisaje-nav-secundaria {
  max-width: 980px;
  margin: 0 auto 4rem;
  padding: 0 2.5rem;
  display: flex;
  flex-wrap: wrap;
  gap: 1.5rem;
  justify-content: center;
}

.paisaje-nav-secundaria a {
  font-size: .65rem;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: var(--tierra-medio);
  text-decoration: none;
  padding: .5rem 1rem;
  border: 1px solid var(--niebla);
  transition: color .3s, border-color .3s, background .3s;
}

.paisaje-nav-secundaria a:hover {
  color: var(--blanco);
  background: var(--musgo);
  border-color: var(--musgo);
}


/* === Responsive paisaje === */
@media (max-width: 768px) {
  .paisaje-cabecera {
    padding: 5.5rem 1.5rem 2rem;
  }

  .paisaje-audio {
    padding: 2rem 1.5rem;
  }

  .paisaje-hero {
    /* En móvil mantenemos ratio natural: nada que sobreescribir. */
  }

  .paisaje-mapa {
    height: 45vh;
    min-height: 320px;
  }

  .paisaje-descripcion {
    padding: 3rem 1.5rem 2rem;
  }

  .paisaje-descripcion p {
    font-size: 1rem;
  }

  .paisaje-sonidos {
    padding: 0 1.5rem 3rem;
  }

  .ficha-tecnica {
    padding: 2rem 1.5rem 4rem;
  }

  .ficha-grid {
    grid-template-columns: 1fr;
    gap: .4rem;
  }

  .paisaje-meta {
    padding: 2rem 1.5rem;
  }

  .paisaje-nav {
    grid-template-columns: 1fr;
    padding: 2.5rem 1.5rem 3rem;
  }

  .nav-link.next {
    text-align: left;
  }

  .paisaje-nav-secundaria {
    padding: 0 1.5rem;
    margin-bottom: 3rem;
  }
}
