/* ============================================================
   public.css — Estilos del sitio público
   Juan, el espíritu del amor · Montaje de Denis Rafter
   ============================================================ */

:root {
  --bg: #0a0603;
  --bg-2: #120a04;
  --bg-3: #1a0f07;
  --cream: #f5ebd9;
  --cream-dim: #c9bda5;
  --cream-mute: #8a7f6a;
  --gold: #d4a657;
  --gold-bright: #f4c878;
  --gold-deep: #8a6a2a;
  --red-deep: #8b3a2e;
  --border: rgba(212,166,87,.22);
  --border-soft: rgba(212,166,87,.1);
  --display: "Parisienne", cursive;
  --serif: "Cormorant Garamond", Georgia, serif;
  --ui: "Jost", system-ui, sans-serif;
  --max: 1240px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--bg);
  color:var(--cream);
  font-family:var(--serif);
  font-weight:400;
  font-size:19px;
  line-height:1.7;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  background-image:
    radial-gradient(ellipse 80% 50% at 50% -10%, rgba(139,58,46,.08), transparent 70%),
    radial-gradient(ellipse 60% 40% at 90% 20%, rgba(212,166,87,.05), transparent 70%);
}
::selection{background:var(--gold);color:var(--bg)}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none;transition:color .3s ease}
a:hover{color:var(--gold-bright)}

/* ============================================================
   NAV (fijo, con estado scrolled)
   Brand: "Juan, el espíritu del amor" (nombre completo, visible
   tanto en escritorio como en móvil).
   Menú plano con todas las secciones al mismo nivel.
   ============================================================ */
nav.top{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 40px;
  gap:20px;
  transition:all .4s ease;
}
nav.top.scrolled{
  background:rgba(10,6,3,.92);
  backdrop-filter:blur(12px);
  padding:12px 40px;
  border-bottom:1px solid var(--border-soft);
}
nav .brand{
  display:inline-flex;align-items:baseline;gap:10px;
  color:var(--gold-bright);
  white-space:nowrap;
  line-height:1;
  flex-shrink:0;
}
nav .brand .brand-main{
  font-family:var(--display);
  font-size:30px;
  color:var(--gold-bright);
  letter-spacing:.5px;
}
nav .brand .brand-sub{
  font-family:var(--serif);
  font-style:italic;font-weight:300;
  font-size:18px;
  color:var(--cream-dim);
  letter-spacing:.2px;
}
/* En pantallas medianas, ocultamos el subtítulo para dar aire al menú */
@media (max-width: 1280px){
  nav .brand .brand-sub{font-size:16px}
}
@media (max-width: 1150px){
  nav .brand .brand-sub{display:none}
}

nav ul{
  list-style:none;display:flex;gap:22px;align-items:center;
  font-family:var(--ui);
  font-size:12px;letter-spacing:1.4px;font-weight:500;
  text-transform:uppercase;
}
nav ul > li > a{
  color:var(--cream-dim);
  display:inline-flex;align-items:center;
  transition:color .2s ease;
}
nav ul > li > a:hover,
nav ul > li > a.active{
  color:var(--gold-bright);
}
/* Con tantos items, reducimos aún más el espaciado en pantallas medias */
@media (max-width: 1280px){
  nav ul{gap:18px;font-size:11.5px;letter-spacing:1.3px}
}

nav .burger{display:none;cursor:pointer;font-size:26px;color:var(--gold);background:none;border:0}

@media (max-width: 1024px){
  nav.top{padding:14px 24px}
  nav.top.scrolled{padding:12px 24px}
  /* En móvil mostramos el nombre COMPLETO, en Parisienne, pequeño y elegante */
  nav .brand{gap:0}
  nav .brand .brand-main{
    font-size:22px;
    /* Se mostrará el nombre completo gracias al ::after */
  }
  nav .brand .brand-sub{
    display:inline;
    font-family:var(--display);
    font-style:normal;font-weight:400;
    font-size:22px;
    color:var(--gold-bright);
    margin-left:6px;
  }
  nav .burger{display:block}
  nav ul{
    position:fixed;inset:64px 0 auto 0;
    flex-direction:column;gap:0;
    align-items:stretch;
    background:rgba(10,6,3,.98);
    backdrop-filter:blur(16px);
    padding:16px 24px 24px;
    border-bottom:1px solid var(--border-soft);
    transform:translateY(-120%);
    transition:transform .4s ease;
    max-height:calc(100vh - 64px);
    overflow-y:auto;
    font-size:13px;letter-spacing:2px;
  }
  nav ul.open{transform:translateY(0)}
  nav ul li{border-bottom:1px solid var(--border-soft)}
  nav ul li:last-child{border-bottom:0}
  nav ul > li > a{
    display:flex;width:100%;
    padding:16px 0;
  }
}

/* Móvil pequeño: brand ligeramente más corto para que quepa al lado del burger */
@media (max-width: 480px){
  nav.top{padding:12px 18px}
  nav .brand .brand-main,
  nav .brand .brand-sub{font-size:20px}
}

/* ============================================================
   HERO (home)
   ============================================================ */
.hero{
  position:relative;
  min-height:100vh;
  padding:130px 48px 100px;
  overflow:hidden;
  isolation:isolate;
  display:flex;align-items:center;
}
.hero::before{
  content:"";position:absolute;inset:0;z-index:-2;
  background:
    radial-gradient(ellipse 50% 60% at 30% 50%, rgba(212,166,87,.14), transparent 70%),
    radial-gradient(ellipse 70% 80% at 80% 30%, rgba(139,58,46,.12), transparent 80%),
    linear-gradient(180deg, #0a0603 0%, #120a04 70%, #1a0f07 100%);
}
.hero canvas{
  position:absolute;inset:0;z-index:-1;
  opacity:.7;pointer-events:none;
}
.hero-grid{
  max-width:var(--max);
  margin:0 auto;
  width:100%;
  display:grid;
  grid-template-columns:minmax(0, 1fr) minmax(0, 1fr);
  gap:80px;
  align-items:center;
}

.hero-poster{
  position:relative;
  opacity:0;animation:fadeUp 1.2s ease .4s forwards;
}
.hero-poster .poster-frame{
  position:relative;
  padding:16px;
  background:linear-gradient(145deg, rgba(212,166,87,.1), rgba(212,166,87,.02) 60%, transparent);
  border:1px solid var(--border);
  box-shadow:
    0 40px 100px rgba(0,0,0,.7),
    0 0 0 1px rgba(212,166,87,.08) inset,
    0 0 120px rgba(212,166,87,.08);
  max-width:480px;
  margin-left:auto;
  transform:rotate(-1.2deg);
  transition:transform .8s ease;
}
.hero-poster:hover .poster-frame{transform:rotate(-.3deg) translateY(-4px)}
.hero-poster .poster-frame::before,
.hero-poster .poster-frame::after{
  content:"";position:absolute;width:20px;height:20px;
  border:1px solid var(--gold);opacity:.5;
  pointer-events:none;
}
.hero-poster .poster-frame::before{top:-1px;left:-1px;border-right:none;border-bottom:none}
.hero-poster .poster-frame::after{bottom:-1px;right:-1px;border-left:none;border-top:none}
.hero-poster .poster-frame img{
  width:100%;height:auto;display:block;
}
.hero-poster .poster-placeholder{
  width:100%;aspect-ratio:2339/3308;
  background:
    repeating-linear-gradient(45deg, rgba(212,166,87,.04) 0 12px, transparent 12px 24px),
    linear-gradient(145deg, rgba(212,166,87,.08), rgba(139,58,46,.04));
  display:grid;place-items:center;
  font-family:var(--display);font-size:70px;color:var(--gold-deep);
  text-align:center;line-height:1.1;
}
.hero-poster .poster-seal{
  position:absolute;right:-28px;bottom:60px;
  width:100px;height:100px;border-radius:50%;
  background:var(--bg-2);
  border:1px solid var(--gold);
  display:grid;place-items:center;
  font-family:var(--display);
  font-size:38px;
  color:var(--gold-bright);
  box-shadow:0 20px 50px rgba(0,0,0,.6), 0 0 40px rgba(212,166,87,.15);
  transform:rotate(10deg);
}

.hero-content{max-width:540px;}
.hero-content .ornament{
  font-family:var(--ui);
  letter-spacing:3.5px;font-size:11px;font-weight:600;
  text-transform:uppercase;
  color:var(--gold);
  margin-bottom:28px;
  opacity:0;animation:fadeUp 1s ease .6s forwards;
}
.hero-content .ornament::before{content:"◦  ";color:var(--gold-deep)}
.hero-content .ornament::after{content:"  ◦";color:var(--gold-deep)}
.hero-content .hero-title{
  font-family:var(--serif);
  font-weight:300;
  font-size:clamp(44px, 5.8vw, 82px);
  line-height:1.02;
  color:var(--cream);
  letter-spacing:-.5px;
  margin-bottom:28px;
  opacity:0;animation:fadeUp 1.2s ease .8s forwards;
}
.hero-content .hero-title em{
  font-family:var(--display);
  font-style:normal;
  font-weight:400;
  color:var(--gold-bright);
  font-size:1.15em;
  letter-spacing:2px;
}
.hero-content .hero-lead{
  font-size:21px;line-height:1.65;
  color:var(--cream);
  font-weight:400;
  margin-bottom:38px;
  opacity:0;animation:fadeUp 1.2s ease 1s forwards;
}
.hero-content .hero-lead b{color:var(--cream);font-weight:500}
.hero-content .hero-actions{
  display:flex;gap:18px;flex-wrap:wrap;
  margin-bottom:50px;
  opacity:0;animation:fadeUp 1.2s ease 1.2s forwards;
}
.hero-content .hero-meta{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:28px;
  padding-top:32px;
  border-top:1px solid var(--border-soft);
  opacity:0;animation:fadeUp 1.2s ease 1.4s forwards;
}
.hero-content .meta-item .meta-label{
  font-family:var(--ui);
  font-size:10px;letter-spacing:2px;font-weight:600;
  text-transform:uppercase;
  color:var(--cream-mute);
  margin-bottom:6px;
}
.hero-content .meta-item .meta-val{
  font-family:var(--serif);
  font-style:italic;font-weight:400;
  font-size:16px;
  color:var(--gold-bright);
  line-height:1.3;
}
.hero .scroll-ind{
  position:absolute;bottom:30px;left:50%;transform:translateX(-50%);
  width:1px;height:50px;
  background:linear-gradient(to bottom, transparent, var(--gold), transparent);
  animation:scrollInd 2.4s ease-in-out infinite;
}

@keyframes fadeUp{to{opacity:1}}
@keyframes scrollInd{
  0%,100%{opacity:.2}
  50%{opacity:1}
}

@media (max-width: 900px){
  .hero{padding:110px 24px 80px}
  .hero-grid{grid-template-columns:1fr;gap:50px}
  .hero-poster .poster-frame{max-width:360px;margin:0 auto}
  .hero-poster .poster-seal{right:-12px;bottom:40px;width:72px;height:72px;font-size:26px}
  .hero-content{max-width:none}
  .hero-content .hero-meta{grid-template-columns:1fr;gap:18px}
}

/* ============================================================
   CENTENARIO STRIP
   ============================================================ */
.centenario{
  position:relative;
  padding:50px 24px;
  background:
    linear-gradient(90deg, transparent, rgba(212,166,87,.06) 50%, transparent),
    linear-gradient(180deg, var(--bg-3), var(--bg-2));
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  text-align:center;
  overflow:hidden;
}
.centenario::before,.centenario::after{
  content:"";position:absolute;top:50%;transform:translateY(-50%);
  width:120px;height:1px;background:linear-gradient(90deg,transparent,var(--gold-deep),transparent);
}
.centenario::before{left:0}
.centenario::after{right:0}
.centenario .year{
  font-family:var(--display);font-size:80px;color:var(--gold-bright);
  line-height:.9;
}
.centenario .lines{
  display:flex;gap:50px;align-items:center;justify-content:center;flex-wrap:wrap;
  margin-top:14px;
  font-family:var(--ui);font-size:13px;letter-spacing:2px;font-weight:500;
  text-transform:uppercase;
  color:var(--cream-dim);
}
.centenario .lines b{color:var(--gold-bright);font-weight:600}

/* ============================================================
   SECCIÓN BASE
   ============================================================ */
.section{
  max-width:var(--max);
  margin:0 auto;
  padding:120px 32px;
  position:relative;
}

/* Franja clara (tipo papel antiguo) para secciones destacadas en la home.
   El calendario va aquí para que salte al ojo, y también la franja de citas. */
.section-light{
  background:
    radial-gradient(ellipse 60% 100% at 50% 0%, rgba(212,166,87,.1), transparent 70%),
    linear-gradient(180deg, #f5ebd9 0%, #ebdec2 100%);
  padding:110px 32px 100px;
  color:#2a1f10;
  position:relative;
  overflow:hidden;
}
.section-light::before,
.section-light::after{
  content:"";
  position:absolute;left:50%;transform:translateX(-50%);
  width:120px;height:1px;
  background:linear-gradient(90deg, transparent, rgba(139,106,42,.5), transparent);
}
.section-light::before{top:40px}
.section-light::after{bottom:40px}
.section-light-inner{
  max-width:var(--max);
  margin:0 auto;
  position:relative;z-index:1;
}
/* En el calendario de la home, queremos que el contenido sea más ancho que
   el layout genérico (--max:1240px), para que los 2 eventos por fila no
   queden tan apretados y el título no se parta. */
#calendario.section-light{padding-left:32px;padding-right:32px}
#calendario.section-light .section-light-inner{
  max-width:1600px;
}
@media (min-width: 1700px){
  #calendario.section-light .section-light-inner{max-width:1700px}
}
/* Sobrescribir colores dentro de la franja clara */
.section-light .eyebrow{color:#8b6a2a}
.section-light .h2{color:#2a1f10}
.section-light .h2 em{color:#a8742a}
.section-light p, .section-light li{color:#3d2f1c}
.section-light h4{color:#2a1f10}
.section-light .link-more{
  color:#8b6a2a;
  border-bottom:1px solid rgba(139,106,42,.4);
}
.section-light .link-more:hover{color:#6d4e14;border-color:#6d4e14}

/* Eventos/calendario dentro de la franja clara (home y /calendario).
   Tres eventos por fila en desktop (2 en tablet 1000-1200, 1 por debajo).
   Layout horizontal dentro de la caja: cartel a la izquierda + info al lado
   (título, lugar, fecha, hora). El cartel es compacto (180 px) para dejar
   ancho suficiente a la info aunque haya 3 cajas por fila. */
.section-light .calendario{gap:50px; max-width:none}
/* Grid: 3 cols en PC, 2 en tablet (≤1200), 1 en móvil (≤1000) */
.section-light .events-grid{
  display:grid !important;
  grid-template-columns:repeat(3, 1fr) !important;
  gap:28px !important;
}
@media (max-width: 1200px){
  .section-light .events-grid{grid-template-columns:repeat(2, 1fr) !important}
}
@media (max-width: 1000px){
  .section-light .events-grid{grid-template-columns:1fr !important}
}

.section-light .event{
  background:rgba(255,253,246,.85) !important;
  border:1px solid rgba(139,106,42,.28) !important;
  padding:22px 24px !important;
  display:grid !important;
  /* cartel | info */
  grid-template-columns:auto minmax(0, 1fr) !important;
  gap:22px !important;
  align-items:center !important;
  transition:all .35s ease;
  box-shadow:0 4px 14px rgba(0,0,0,.04);
  border-radius:2px;
  min-width:0;
}
.section-light .event:hover{
  background:#fffdf6 !important;
  border-color:rgba(139,106,42,.5) !important;
  transform:translateY(-3px);
  box-shadow:0 8px 22px rgba(139,106,42,.12);
}
/* Cartel a la izquierda, 230 px (ratio A4 1:1.414). */
.section-light .event .cartel-thumb{
  width:230px !important;
  height:auto !important;
  aspect-ratio:1/1.414 !important;
  object-fit:cover !important;
  border:1px solid rgba(139,106,42,.35) !important;
  background:#fffdf6 !important;
  padding:8px !important;
  box-shadow:0 10px 22px rgba(0,0,0,.15) !important;
  display:block !important;
}
/* Info al lado (a la derecha del cartel) */
.section-light .event .info{
  padding:0 !important;
  display:flex !important;
  flex-direction:column !important;
  justify-content:center !important;
  min-width:0 !important;
  overflow-wrap:break-word;
  word-break:normal;
}
.section-light .event .info h4{
  font-family:var(--serif) !important;
  font-style:italic !important;
  font-weight:400 !important;
  font-size:20px !important;
  color:#2a1f10 !important;
  margin-bottom:10px !important;
  line-height:1.25 !important;
  letter-spacing:-.2px !important;
}
.section-light .event .info .place{
  color:#2a1f10 !important;
  font-size:17px !important;
  line-height:1.35 !important;
  font-weight:500 !important;
  margin-bottom:8px !important;
}
.section-light .event .info .desc{
  color:#6d4e14 !important;
  font-style:italic !important;
  font-size:14px !important;
  margin-top:4px !important;
  line-height:1.5 !important;
}
.section-light .event .info .meta-fecha{
  font-family:var(--ui) !important;
  font-size:13px !important;
  letter-spacing:2.3px !important;
  font-weight:600 !important;
  text-transform:uppercase !important;
  color:#6d4e14 !important;
  margin-top:2px !important;
  margin-bottom:10px !important;
}
/* HORA — debajo de la fecha, dentro del info */
.section-light .event .info .hour{
  color:#fffdf6 !important;
  font-family:var(--ui) !important;
  font-weight:600 !important;
  font-size:15px !important;
  letter-spacing:1px !important;
  white-space:nowrap !important;
  padding:7px 13px !important;
  background:#8b6a2a !important;
  border:1px solid #6d4e14 !important;
  align-self:flex-start !important;
  box-shadow:0 3px 8px rgba(0,0,0,.12) !important;
}
/* Date bloque (sólo cuando NO hay cartel) */
.section-light .event > .date{
  text-align:center;line-height:1;
  padding:8px;min-width:80px;
}
.section-light .event > .date .d{
  font-family:var(--display) !important;
  font-size:56px !important;
  color:#a8742a !important;
  line-height:.9 !important;
}
.section-light .event > .date .m{
  font-family:var(--ui) !important;
  font-size:10px !important;
  letter-spacing:2.5px !important;
  font-weight:600 !important;
  text-transform:uppercase !important;
  color:#6d4e14 !important;
  margin-top:8px !important;
}
.section-light .empty{
  padding:60px 30px;text-align:center;
  background:rgba(255,253,246,.5);
  border:1px dashed rgba(139,106,42,.3);
  color:#6d4e14;font-style:italic;font-size:17px;
}
.section-light .link-more{
  color:#8b6a2a;
  border-bottom:1px solid rgba(139,106,42,.4);
  font-size:13px;
}
.section-light .link-more:hover{color:#6d4e14;border-color:#6d4e14}

/* Tablet grande (≤1200): 2 columnas, el cartel puede crecer un poco
   porque cada caja tiene más ancho */
@media (max-width: 1200px){
  .section-light .event{
    padding:24px !important;
    gap:24px !important;
  }
  .section-light .event .cartel-thumb{width:200px !important}
  .section-light .event .info h4{font-size:21px !important;margin-bottom:11px !important}
  .section-light .event .info .place{font-size:18px !important}
  .section-light .event .info .meta-fecha{font-size:14px !important}
  .section-light .event .info .hour{font-size:16px !important;padding:8px 14px !important}
}

/* Tablet (≤1000): 1 columna pero aún horizontal (cartel izq + info dcha) */
@media (max-width: 1000px){
  .section-light .event{
    padding:26px !important;
    gap:26px !important;
  }
  .section-light .event .cartel-thumb{width:240px !important}
  .section-light .event .info h4{font-size:22px !important}
  .section-light .event .info .place{font-size:19px !important}
}

/* Móvil (≤720): 1 columna, todavía horizontal pero cartel más compacto */
@media (max-width: 720px){
  .section-light .event{
    gap:18px !important;
    padding:20px !important;
  }
  .section-light .event .cartel-thumb{width:160px !important}
  .section-light .event .info h4{font-size:19px !important;margin-bottom:8px !important}
  .section-light .event .info .place{font-size:16px !important}
  .section-light .event .info .meta-fecha{font-size:12px !important;letter-spacing:2px !important;margin-bottom:10px !important}
  .section-light .event .info .hour{font-size:14px !important;padding:6px 12px !important}
}

/* Móvil pequeño (≤480): apilado vertical (cartel arriba centrado, info debajo) */
@media (max-width: 480px){
  .section-light .event{
    grid-template-columns:1fr !important;
    padding:20px !important;
    text-align:left;
  }
  .section-light .event .cartel-thumb{
    width:100% !important;max-width:200px !important;
    margin:0 auto !important;
  }
  .section-light .event .info{text-align:left}
  .section-light .event .info h4{font-size:19px !important}
  .section-light .event .info .place{font-size:17px !important}
}

.eyebrow{
  font-family:var(--ui);
  letter-spacing:3.5px;font-size:12px;font-weight:600;
  text-transform:uppercase;
  color:var(--gold);
  margin-bottom:18px;
}
.eyebrow::before{content:"— ";color:var(--gold-deep);font-weight:400}
.h2{
  font-family:var(--serif);
  font-weight:300;font-style:italic;
  font-size:clamp(34px,5vw,62px);
  line-height:1.1;
  color:var(--cream);
  margin-bottom:28px;
  letter-spacing:-.5px;
}
.h2 em{color:var(--gold-bright);font-style:italic;font-family:var(--display);font-weight:400;letter-spacing:2px}
/* Variante "serif" para <em> cuyas palabras son mayúsculas/largas y se leerían
   mal con Parisienne (TRILOGÍA, MUNICIPIO, ESCUCHARLO, ELENCO...).
   Uso: <em class="em-serif">MUNICIPIO</em> o simplemente <em class="em-serif">trilogía</em> */
.h2 em.em-serif,
.callout h3 em.em-serif,
.article h2 em.em-serif,
.article h3 em.em-serif,
.page-hero h1 em.em-serif{
  font-family:var(--serif);
  font-style:italic;
  font-weight:500;
  letter-spacing:0;
  color:var(--gold-bright);
}
.lead{
  font-size:21px;line-height:1.7;
  color:var(--cream-dim);
  font-weight:300;
  max-width:720px;
}

/* Reveal on scroll */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .8s ease, transform .8s ease}
.reveal.in{opacity:1;transform:none}

/* ============================================================
   QUOTE HERO
   ============================================================ */
.quote-hero{
  padding:140px 32px;
  text-align:center;
  position:relative;
  background:radial-gradient(ellipse 60% 80% at 50% 50%, rgba(139,58,46,.08), transparent 70%);
}
.quote-hero .mark{
  font-family:var(--display);
  font-size:180px;line-height:.5;color:var(--gold-deep);
  opacity:.5;height:60px;
}
.quote-hero blockquote{
  font-family:var(--serif);
  font-style:italic;font-weight:300;
  font-size:clamp(30px,4.5vw,54px);
  line-height:1.25;
  color:var(--cream);
  max-width:1000px;margin:0 auto;
  letter-spacing:-.3px;
}
.quote-hero blockquote b{color:var(--gold-bright);font-weight:500;font-style:normal;font-family:var(--display);font-size:1.15em;letter-spacing:2px}
.quote-hero cite{
  display:block;
  font-family:var(--ui);font-style:normal;font-weight:500;
  letter-spacing:3px;font-size:12px;text-transform:uppercase;
  color:var(--cream-mute);
  margin-top:40px;
}

/* ============================================================
   OBRA GRID
   ============================================================ */
.obra-grid{
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:80px;align-items:center;
}
.obra-grid .copy p{margin-bottom:22px;color:var(--cream-dim);font-size:21px;line-height:1.7}
.obra-grid .copy p:first-of-type::first-letter{
  font-family:var(--display);
  font-size:72px;
  float:left;
  line-height:.85;
  padding:8px 14px 0 0;
  color:var(--gold-bright);
}
.obra-grid .copy strong{color:var(--cream);font-weight:500}
.obra-grid .visual{position:relative;}
.obra-grid .visual .photo-wrap{
  position:relative;
  border:1px solid var(--border);
  padding:14px;
  background:linear-gradient(145deg, rgba(212,166,87,.04), transparent);
  box-shadow:
    0 30px 80px rgba(0,0,0,.6),
    0 0 0 1px rgba(212,166,87,.08) inset;
  transition:transform .6s ease;
}
.obra-grid .visual:hover .photo-wrap{transform:translateY(-6px)}
.obra-grid .visual .photo-wrap img{
  aspect-ratio:4/3;
  object-fit:cover;
  width:100%;
  filter:contrast(1.05) saturate(.95);
}
.obra-grid .visual .photo-caption{
  margin-top:14px;
  font-family:var(--serif);
  font-style:italic;
  font-size:14px;
  color:var(--cream-mute);
  line-height:1.45;
  text-align:center;
  padding:0 10px;
}
.obra-grid .visual .stamp{
  position:absolute;right:-24px;top:30px;
  width:110px;height:110px;
  border-radius:50%;
  border:1px solid var(--gold);
  background:var(--bg-2);
  display:grid;place-items:center;
  font-family:var(--ui);font-size:10px;letter-spacing:1.8px;font-weight:600;
  text-transform:uppercase;
  color:var(--gold-bright);text-align:center;
  line-height:1.3;
  transform:rotate(8deg);
  padding:12px;
}
@media (max-width: 900px){
  .obra-grid{grid-template-columns:1fr;gap:50px}
  .obra-grid .visual .stamp{right:10px;top:-15px;width:86px;height:86px}
}

/* ============================================================
   DÚO: San Juan + Rafter
   ============================================================ */
.duo{
  display:grid;grid-template-columns:1fr 1fr;gap:2px;
  background:var(--border);
  margin:0;
}
.duo .block{
  padding:80px 48px;
  background:var(--bg);
  position:relative;
  overflow:hidden;
  display:grid;
  grid-template-rows:auto 1fr;
  gap:40px;
  align-items:start;
}
.duo .block .photo{
  position:relative;
  width:100%;
  display:flex;align-items:center;justify-content:center;
  height:auto;
}
.duo .block.san .photo{
  min-height:140px;
  background:
    radial-gradient(ellipse 60% 80% at 50% 50%, rgba(139,58,46,.12), transparent 70%);
  padding:30px 20px;
}
.duo .block.san .photo img{
  max-width:480px;width:100%;
  opacity:.85;
  filter:drop-shadow(0 4px 12px rgba(0,0,0,.5));
}
/* Foto de Denis: más pequeña, con marco tipo "polaroid" como el cartel */
.duo .block.rafter .photo{
  max-width:380px;margin:0 auto;
  padding:14px;
  border:1px solid var(--border);
  background:linear-gradient(145deg, rgba(212,166,87,.08), rgba(212,166,87,.02) 60%, transparent);
  box-shadow:
    0 30px 70px rgba(0,0,0,.6),
    0 0 0 1px rgba(212,166,87,.06) inset,
    0 0 80px rgba(212,166,87,.06);
  transform:rotate(1deg);
  transition:transform .8s ease;
  position:relative;
}
.duo .block.rafter .photo::before,
.duo .block.rafter .photo::after{
  content:"";position:absolute;width:18px;height:18px;
  border:1px solid var(--gold);opacity:.45;
  pointer-events:none;
}
.duo .block.rafter .photo::before{top:-1px;left:-1px;border-right:none;border-bottom:none}
.duo .block.rafter .photo::after{bottom:-1px;right:-1px;border-left:none;border-top:none}
.duo .block.rafter:hover .photo{transform:rotate(.2deg) translateY(-3px)}
.duo .block.rafter .photo img{
  width:100%;display:block;
  aspect-ratio:4/3;object-fit:cover;
}
.duo .block .content{
  position:relative;z-index:1;max-width:520px;
}
.duo .block h3{
  font-family:var(--serif);font-style:italic;font-weight:400;
  font-size:clamp(36px,4.5vw,52px);line-height:1.05;
  color:var(--cream);letter-spacing:-.3px;
  margin:18px 0 30px;
}
.duo .block p{
  color:var(--cream);font-size:19px;line-height:1.7;margin-bottom:16px;
}
.duo .block .link{
  display:inline-block;margin-top:16px;
  font-family:var(--ui);font-size:12px;letter-spacing:2.2px;font-weight:600;
  text-transform:uppercase;color:var(--gold);
  border-bottom:1px solid var(--gold-deep);padding-bottom:4px;
}
.duo .block .link:hover{color:var(--gold-bright);border-color:var(--gold)}
@media (max-width: 820px){
  .duo{grid-template-columns:1fr}
  .duo .block{padding:60px 28px}
}

/* ============================================================
   TRILOGÍA
   ============================================================ */
.trilogia{
  background:linear-gradient(180deg, var(--bg) 0%, var(--bg-2) 50%, var(--bg) 100%);
  padding:120px 32px;
  position:relative;
}
.trilogia .inner{max-width:var(--max);margin:0 auto;text-align:center}
.trilogia .cards{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:28px;margin-top:60px;
}
.trilogia .card{
  padding:48px 32px;
  border:1px solid var(--border-soft);
  background:linear-gradient(180deg, rgba(212,166,87,.03), rgba(212,166,87,0));
  position:relative;
  transition:all .5s ease;
  text-align:left;
}
.trilogia .card:hover{
  border-color:var(--gold);
  background:linear-gradient(180deg, rgba(212,166,87,.07), rgba(212,166,87,0));
  transform:translateY(-4px);
}
.trilogia .card.active{
  border-color:var(--gold);
  background:linear-gradient(180deg, rgba(212,166,87,.1), rgba(139,58,46,.06));
}
.trilogia .card .roman{
  font-family:var(--display);font-size:48px;
  color:var(--gold);line-height:1;
  margin-bottom:20px;
}
.trilogia .card h3{
  font-family:var(--serif);font-style:italic;font-weight:400;
  font-size:28px;color:var(--cream);line-height:1.2;
  margin-bottom:12px;
}
.trilogia .card .years{
  font-family:var(--ui);font-size:11px;letter-spacing:2.5px;font-weight:500;
  text-transform:uppercase;color:var(--cream-mute);margin-bottom:24px;
}
.trilogia .card .desc{
  font-size:15px;color:var(--cream-dim);line-height:1.6;font-weight:300;
  margin-bottom:28px;
}
.trilogia .card .count{
  display:flex;align-items:baseline;gap:10px;
  padding-top:20px;border-top:1px solid var(--border-soft);
}
.trilogia .card .count .n{
  font-family:var(--display);font-size:44px;color:var(--gold-bright);line-height:1;
}
.trilogia .card .count .l{
  font-family:var(--ui);font-size:11px;letter-spacing:2px;font-weight:600;
  text-transform:uppercase;color:var(--cream-mute);
}
.trilogia .total{
  margin-top:50px;
  font-family:var(--ui);font-size:13px;letter-spacing:3px;font-weight:500;
  text-transform:uppercase;color:var(--cream-mute);
}
.trilogia .total b{color:var(--gold-bright);font-weight:600;font-size:1.3em}
@media (max-width: 820px){
  .trilogia .cards{grid-template-columns:1fr}
}

/* ============================================================
   CALENDARIO (en home + página completa)
   ============================================================ */
.calendario{
  max-width:920px;
  margin:0 auto;
}
.calendario .list{display:flex;flex-direction:column;gap:0}
.calendario .event{
  display:grid;
  grid-template-columns:120px 1fr auto;
  gap:30px;align-items:center;
  padding:28px 0;
  border-bottom:1px solid var(--border-soft);
  transition:all .3s ease;
}
.calendario .event:hover{
  background:linear-gradient(90deg, rgba(212,166,87,.04), transparent);
  padding-left:16px;
}
.calendario .event.past{opacity:.55}
.calendario .event.past:hover{opacity:.85}
.calendario .event .date .d{
  font-family:var(--display);font-size:48px;color:var(--gold-bright);line-height:1;
}
.calendario .event .date .m{
  font-family:var(--ui);font-size:11px;letter-spacing:2.5px;font-weight:600;
  text-transform:uppercase;color:var(--cream-mute);margin-top:4px;
}
.calendario .event .info h4{
  font-family:var(--serif);font-style:italic;font-size:24px;font-weight:400;
  color:var(--cream);margin-bottom:4px;
}
.calendario .event .info .place{font-size:15px;color:var(--cream-dim);}
.calendario .event .info .desc{font-size:14px;color:var(--cream-mute);font-style:italic;margin-top:6px;line-height:1.4}
.calendario .event .hour{
  font-family:var(--ui);font-size:14px;letter-spacing:1.5px;font-weight:500;color:var(--gold);
  white-space:nowrap;
}
.calendario .event .cartel-thumb{
  width:60px;height:80px;object-fit:cover;border:1px solid var(--border-soft);
}
.calendario .cta-area{
  padding:40px;border:1px solid var(--border);
  background:linear-gradient(145deg, rgba(212,166,87,.05), transparent);
}
.calendario .cta-area h4{
  font-family:var(--serif);font-style:italic;font-weight:400;
  font-size:24px;color:var(--cream);margin-bottom:14px;line-height:1.3;
}
.calendario .cta-area p{font-size:16px;color:var(--cream-dim);margin-bottom:24px;}
.calendario .empty{
  padding:60px 30px;text-align:center;
  color:var(--cream-mute);font-style:italic;
  border:1px dashed var(--border-soft);
}
@media (max-width: 900px){
  .calendario .event{grid-template-columns:80px 1fr;gap:20px}
  .calendario .event .hour{grid-column:2;font-size:13px}
  .calendario .event .date .d{font-size:36px}
}

.btn{
  display:inline-flex;align-items:center;gap:12px;
  padding:18px 36px;
  font-family:var(--ui);font-size:14px;letter-spacing:2.2px;font-weight:600;
  text-transform:uppercase;
  color:var(--bg);background:var(--gold-bright);
  border:1px solid var(--gold-bright);
  transition:all .3s ease;cursor:pointer;
}
.btn:hover{background:transparent;color:var(--gold-bright);}
.btn.ghost{color:var(--gold-bright);background:transparent;}
.btn.ghost:hover{background:var(--gold-bright);color:var(--bg)}

.link-more{
  font-family:var(--ui);font-size:13px;letter-spacing:2.2px;font-weight:600;
  text-transform:uppercase;color:var(--gold);
  border-bottom:1px solid var(--gold-deep);padding-bottom:4px;
}
.link-more:hover{color:var(--gold-bright);border-color:var(--gold)}

/* ============================================================
   CITAS CARRUSEL
   ============================================================ */
.citas{
  padding:120px 24px;
  background:
    radial-gradient(ellipse 80% 60% at 50% 50%, rgba(139,58,46,.1), transparent 70%),
    var(--bg);
  text-align:center;
  overflow:hidden;
  position:relative;
}
/* Variante clara de la franja de citas, con logo de San Juan decorativo */
.citas-light{
  background:
    radial-gradient(ellipse 60% 100% at 50% 0%, rgba(212,166,87,.12), transparent 70%),
    linear-gradient(180deg, #f5ebd9 0%, #ebdec2 100%);
  padding:90px 24px 100px;
  color:#2a1f10;
}
.citas-light::before,
.citas-light::after{
  content:"";
  position:absolute;left:50%;transform:translateX(-50%);
  width:120px;height:1px;
  background:linear-gradient(90deg, transparent, rgba(139,106,42,.5), transparent);
}
.citas-light::before{top:30px}
.citas-light::after{bottom:30px}
.citas-light .citas-inner{
  max-width:1000px;margin:0 auto;
  position:relative;
}
.citas-light .logo-sanjuan{
  display:flex;justify-content:center;
  margin-bottom:30px;
}
.citas-light .logo-sanjuan img{
  max-width:130px;
  height:auto;
  opacity:.85;
}
.citas-light .eyebrow{color:#8b6a2a}
.citas-light .h2{color:#2a1f10}
.citas-light .h2 em{color:#a8742a}
.citas-light .cita q,
.citas.citas-light .cita q{color:#2a1f10 !important}
.citas-light .cita .autor,
.citas.citas-light .cita .autor{color:#a8742a !important}
.citas-light .dots button{
  border-color:rgba(139,106,42,.6);
}
.citas-light .dots button.active{
  background:#8b6a2a;border-color:#8b6a2a;
}
.citas .track{
  position:relative;
  min-height:260px;
  max-width:1000px;margin:40px auto 0;
}
.citas .cita{
  position:absolute;inset:0;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  opacity:0;transition:opacity 1s ease;
  padding:0 20px;
}
.citas .cita.active{opacity:1}
.citas .cita q{
  display:block;quotes:none;
  font-family:var(--serif);font-style:italic;font-weight:400;
  font-size:clamp(22px,3vw,32px);
  line-height:1.4;color:var(--cream);
  max-width:820px;
}
.citas .cita q::before,.citas .cita q::after{content:none;}
.citas .cita .autor{
  margin-top:26px;
  font-family:var(--display);font-size:28px;color:var(--gold-bright);
}
.citas .dots{
  display:flex;gap:10px;justify-content:center;margin-top:50px;flex-wrap:wrap;
}
.citas .dots button{
  width:8px;height:8px;border-radius:50%;
  border:1px solid var(--gold-deep);background:transparent;
  cursor:pointer;padding:0;transition:all .3s ease;
}
.citas .dots button.active{background:var(--gold-bright);border-color:var(--gold-bright);transform:scale(1.3)}

/* ============================================================
   LOGOS
   ============================================================ */
.logos{
  max-width:var(--max);margin:0 auto;
  padding:80px 32px;
  text-align:center;
  border-top:1px solid var(--border-soft);
}
.logos .label{
  font-family:var(--ui);font-size:10px;letter-spacing:3px;font-weight:600;
  text-transform:uppercase;color:var(--cream-mute);
  margin-bottom:40px;
}
.logos .row{
  display:flex;gap:40px;justify-content:center;align-items:center;flex-wrap:wrap;
}
.logos .placeholder{
  padding:16px 24px;border:1px solid var(--border-soft);
  font-family:var(--ui);font-size:10px;letter-spacing:1.5px;font-weight:500;
  text-transform:uppercase;color:var(--cream-mute);
  min-width:160px;text-align:center;
  transition:all .3s ease;
}
.logos .placeholder:hover{border-color:var(--gold-deep);color:var(--cream-dim)}

/* ============================================================
   FOOTER
   ============================================================ */
footer{
  background:var(--bg-2);
  padding:80px 32px 30px;
  border-top:1px solid var(--border);
}
footer .cols{
  max-width:var(--max);margin:0 auto;
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:50px;
  padding-bottom:50px;
  border-bottom:1px solid var(--border-soft);
}
footer .brand-block .title{
  font-family:var(--display);font-size:38px;color:var(--gold-bright);
  line-height:1;margin-bottom:18px;
}
footer .brand-block p{color:var(--cream-dim);font-size:16px;line-height:1.6;max-width:360px;}
footer h5{
  font-family:var(--ui);font-size:10px;letter-spacing:2.5px;font-weight:600;
  text-transform:uppercase;color:var(--gold);margin-bottom:18px;
}
footer ul{list-style:none;}
footer ul li{margin-bottom:10px;}
footer ul a{color:var(--cream-dim);font-size:15px;}
footer ul a:hover{color:var(--gold-bright)}
footer .legal{
  max-width:var(--max);margin:30px auto 0;
  display:flex;flex-direction:column;align-items:center;
  gap:18px;
  font-family:var(--ui);font-size:10px;letter-spacing:1.8px;font-weight:500;
  text-transform:uppercase;color:var(--cream-mute);
  text-align:center;
}
footer .legal-links{
  display:flex;flex-wrap:wrap;justify-content:center;align-items:center;
  gap:8px 16px;
}
footer .legal-links a,
footer .legal-links .cookie-reopen{
  color:var(--cream-dim);
  transition:color .2s ease;
  background:none;border:0;padding:0;cursor:pointer;
  font:inherit;letter-spacing:inherit;text-transform:inherit;
}
footer .legal-links a:hover,
footer .legal-links .cookie-reopen:hover{color:var(--gold-bright)}
footer .legal-links .sep{color:var(--border)}
footer .legal-meta{
  display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;
  gap:14px 64px;
  width:100%;max-width:900px;
  margin:0 auto;
}
footer .legal-meta > span{
  display:inline-flex;align-items:center;gap:8px;
}
footer .legal-meta a{
  color:var(--gold);
  border-bottom:1px solid var(--border-soft);
  transition:all .2s ease;
}
footer .legal-meta a:hover{color:var(--gold-bright);border-bottom-color:var(--gold)}
@media (max-width: 820px){
  footer .cols{grid-template-columns:1fr 1fr;gap:36px}
  footer .brand-block{grid-column:1 / -1}
  footer .legal-meta{justify-content:center;text-align:center;gap:10px 0}
}

/* ============================================================
   BANNER DE COOKIES
   Fijo abajo, coherente con la paleta oscura del sitio.
   Solo se muestra si no hay cookie "cookies_consent".
   ============================================================ */
.cookie-banner{
  position:fixed;bottom:0;left:0;right:0;z-index:200;
  background:rgba(10,6,3,.97);
  backdrop-filter:blur(16px);
  border-top:1px solid var(--gold-deep);
  padding:24px 32px;
  box-shadow:0 -25px 60px rgba(0,0,0,.6);
  animation:slideUp .5s ease .4s backwards;
}
@keyframes slideUp{
  from{transform:translateY(100%);opacity:0}
  to  {transform:translateY(0);opacity:1}
}
.cookie-banner .cookie-inner{
  max-width:1100px;margin:0 auto;
  display:grid;
  grid-template-columns:1fr auto;
  gap:28px;align-items:center;
}
.cookie-banner h2{
  font-family:var(--ui);
  font-size:11px;letter-spacing:3px;font-weight:600;
  text-transform:uppercase;color:var(--gold);
  margin-bottom:10px;
}
.cookie-banner p{
  font-family:var(--ui);
  font-size:14px;line-height:1.55;
  color:var(--cream-dim);
  margin:0;max-width:720px;
}
.cookie-banner p a{
  color:var(--gold-bright);
  border-bottom:1px solid var(--gold-deep);
}
.cookie-banner p a:hover{border-bottom-color:var(--gold)}
.cookie-banner .cookie-actions{
  display:flex;gap:12px;flex-wrap:wrap;
}
.cookie-banner .btn{
  padding:12px 22px;
  font-size:11px;letter-spacing:2px;
  white-space:nowrap;
}
@media (max-width: 760px){
  .cookie-banner{padding:20px 22px}
  .cookie-banner .cookie-inner{
    grid-template-columns:1fr;
    gap:18px;
  }
  .cookie-banner .cookie-actions{justify-content:flex-end}
}

/* ============================================================
   PAGE HEADER (páginas interiores: /calendario, /noticias, etc.)
   ============================================================ */
.page-header{
  padding:150px 32px 80px;
  text-align:center;
  max-width:var(--max);margin:0 auto;
  position:relative;
}
.page-header .eyebrow{margin-bottom:18px}
.page-header h1{
  font-family:var(--serif);
  font-weight:300;font-style:italic;
  font-size:clamp(44px,6vw,78px);
  line-height:1.05;color:var(--cream);
  letter-spacing:-.5px;
  margin-bottom:20px;
}
.page-header h1 em{color:var(--gold-bright);font-family:var(--display);font-style:normal;font-weight:400;letter-spacing:2px}
.page-header .lead{
  margin:0 auto;
  font-size:19px;line-height:1.6;
  color:var(--cream-dim);
  max-width:640px;
}
.page-header::after{
  content:"◦";
  display:block;margin-top:40px;
  color:var(--gold-deep);font-size:14px;letter-spacing:30px;
}

/* ============================================================
   PÁGINA CALENDARIO COMPLETA (/calendario.php)
   ============================================================ */
.cal-full{
  max-width:980px;margin:0 auto;padding:40px 32px 120px;
}
/* Cuando /calendario usa .section-light, queremos full-bleed: la franja crema
   ocupa todo el ancho del viewport y el contenido usa casi toda la pantalla
   (sin limitar a 1400px como antes). */
.cal-full.section-light{
  max-width:none !important;
  width:100% !important;
  margin:0 !important;
  padding:60px 0 90px !important;
}
.cal-full.section-light .section-light-inner{
  max-width:none !important;
  width:100% !important;
  padding:0 40px !important;
  margin:0 !important;
}
@media (min-width: 1400px){
  .cal-full.section-light .section-light-inner{padding:0 60px !important}
}
@media (max-width: 720px){
  .cal-full.section-light .section-light-inner{padding:0 20px !important}
}
.cal-group{margin-bottom:70px}
.cal-group h2{
  font-family:var(--ui);font-size:12px;letter-spacing:3.5px;font-weight:600;
  text-transform:uppercase;color:var(--gold);
  margin-bottom:28px;padding-bottom:14px;
  border-bottom:1px solid var(--border-soft);
}

/* ============================================================
   PÁGINA GALERÍAS (/galerias.php)
   ============================================================ */
.galerias-grid{
  max-width:var(--max);margin:0 auto;
  padding:40px 32px 120px;
  display:grid;grid-template-columns:repeat(auto-fill, minmax(320px, 1fr));
  gap:30px;
}
.gal-card{
  position:relative;
  background:var(--bg-2);
  border:1px solid var(--border-soft);
  overflow:hidden;
  transition:all .4s ease;
  display:block;
}
.gal-card:hover{
  border-color:var(--gold);
  transform:translateY(-4px);
  box-shadow:0 30px 70px rgba(0,0,0,.5);
}
.gal-card .cover{
  aspect-ratio:4/3;
  background:var(--bg-3);
  overflow:hidden;
  position:relative;
}
.gal-card .cover img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .8s ease;
}
.gal-card:hover .cover img{transform:scale(1.05)}
.gal-card .cover.empty{
  display:grid;place-items:center;
  color:var(--cream-mute);font-style:italic;font-size:14px;
  background:
    repeating-linear-gradient(45deg, rgba(212,166,87,.03) 0 8px, transparent 8px 16px),
    var(--bg-3);
}
.gal-card .meta{
  padding:22px 26px 28px;
}
.gal-card .gal-date{
  font-family:var(--ui);font-size:10px;letter-spacing:2px;font-weight:600;
  text-transform:uppercase;color:var(--gold);margin-bottom:8px;
}
.gal-card h3{
  font-family:var(--serif);font-style:italic;font-weight:400;
  font-size:26px;line-height:1.15;color:var(--cream);
  letter-spacing:-.2px;margin-bottom:10px;
}
.gal-card:hover h3{color:var(--gold-bright)}
.gal-card .count{
  font-family:var(--ui);font-size:11px;letter-spacing:1.5px;font-weight:500;
  text-transform:uppercase;color:var(--cream-mute);
  margin-top:14px;
}

/* ============================================================
   GALERÍA INDIVIDUAL (/galeria.php)
   ============================================================ */
.gal-single{
  max-width:var(--max);margin:0 auto;
  padding:40px 32px 60px;
}
.gal-single .back{
  display:inline-block;margin-bottom:30px;
  font-family:var(--ui);font-size:10px;letter-spacing:2px;font-weight:600;
  text-transform:uppercase;color:var(--cream-mute);
}
.gal-single .back:hover{color:var(--gold)}
.gal-single .desc{
  max-width:720px;margin:0 auto 50px;text-align:center;
  color:var(--cream-dim);font-size:17px;font-style:italic;line-height:1.6;
}

.gal-masonry{
  padding:20px 32px 120px;
  max-width:1400px;margin:0 auto;
  column-count:3;column-gap:18px;
}
.gal-masonry figure{
  break-inside:avoid;
  margin-bottom:18px;
  position:relative;
  border:1px solid var(--border-soft);
  overflow:hidden;
  cursor:zoom-in;
  background:var(--bg-2);
}
.gal-masonry figure img{
  width:100%;height:auto;display:block;
  transition:all .5s ease;
}
.gal-masonry figure:hover img{
  transform:scale(1.03);
  filter:brightness(1.1);
}
.gal-masonry figure::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(135deg, rgba(212,166,87,.12), transparent 40%);
  opacity:0;transition:opacity .4s ease;pointer-events:none;
}
.gal-masonry figure:hover::after{opacity:1}
@media (max-width: 900px){ .gal-masonry{column-count:2} }
@media (max-width: 580px){ .gal-masonry{column-count:1} }

/* Lightbox */
.lightbox{
  position:fixed;inset:0;z-index:1000;
  background:rgba(5,3,1,.96);
  display:none;align-items:center;justify-content:center;
  padding:40px;
  animation:fadeIn .3s ease;
}
.lightbox.open{display:flex}
.lightbox img{
  max-width:100%;max-height:90vh;object-fit:contain;
  box-shadow:0 30px 80px rgba(0,0,0,.8);
}
.lightbox .lb-close,
.lightbox .lb-prev,
.lightbox .lb-next{
  position:absolute;
  background:transparent;border:1px solid var(--border);
  color:var(--gold);cursor:pointer;
  font-family:var(--display);
  transition:all .3s ease;
  z-index:2;
}
.lightbox .lb-close{
  top:20px;right:20px;
  width:44px;height:44px;border-radius:50%;
  font-size:24px;line-height:1;
}
.lightbox .lb-prev, .lightbox .lb-next{
  top:50%;transform:translateY(-50%);
  width:56px;height:56px;border-radius:50%;
  font-size:28px;
}
.lightbox .lb-prev{left:20px}
.lightbox .lb-next{right:20px}
.lightbox .lb-close:hover,
.lightbox .lb-prev:hover,
.lightbox .lb-next:hover{
  background:var(--gold);color:var(--bg);border-color:var(--gold);
}
.lightbox .lb-count{
  position:absolute;bottom:24px;left:50%;transform:translateX(-50%);
  font-family:var(--ui);font-size:11px;letter-spacing:2px;font-weight:500;
  color:var(--cream-mute);
}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}

/* ============================================================
   NOTICIAS / PRENSA (/noticias.php)
   Tres noticias por fila en desktop (2 en tablet, 1 en móvil).
   Cada caja es vertical: foto arriba a ancho completo con altura
   proporcional (sin recorte — ningún "object-fit:cover"), info
   debajo (medio, fecha, titular, enlace).
   ============================================================ */
.noticias-list{
  max-width:1600px;margin:0 auto;
  padding:40px 32px 120px;
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:32px;
  align-items:start;
}
@media (max-width: 1200px){ .noticias-list{grid-template-columns:repeat(2, 1fr)} }
@media (max-width: 720px){  .noticias-list{grid-template-columns:1fr; max-width:720px} }

.noticia{
  position:relative;
  display:flex;flex-direction:column;
  padding:0;
  border:1px solid var(--border-soft);
  background:linear-gradient(145deg, rgba(212,166,87,.02), transparent 60%);
  transition:all .4s ease;
  overflow:hidden;
}
.noticia:hover{
  border-color:var(--gold);
  background:linear-gradient(145deg, rgba(212,166,87,.06), transparent 60%);
  transform:translateY(-3px);
}
/* Foto arriba a ancho completo, altura proporcional, SIN recortar. */
.noticia .thumb{
  width:100%;
  height:auto;
  display:block;
  border-bottom:1px solid var(--border-soft);
}
/* Fallback cuando no hay foto: firma de San Juan de la Cruz sobre
   fondo oscuro tramado. Altura fija para mantener consistencia visual
   con las fotos del resto de la fila. */
.noticia .thumb-empty{
  width:100%;
  aspect-ratio:16/9;
  background:
    repeating-linear-gradient(45deg, rgba(212,166,87,.03) 0 8px, transparent 8px 16px),
    var(--bg-3);
  display:grid;place-items:center;
  border-bottom:1px solid var(--border-soft);
  padding:28px;
}
.noticia .thumb-empty img{
  max-width:72%;
  max-height:100%;
  width:auto;height:auto;
  opacity:.85;
  filter:drop-shadow(0 2px 6px rgba(0,0,0,.4));
}
/* Info debajo de la foto */
.noticia .info{
  padding:24px 26px 26px;
  display:flex;flex-direction:column;
  flex:1;
}
.noticia .info .meta{
  display:flex;flex-direction:column;align-items:flex-start;gap:8px;
  margin-bottom:14px;
}
.noticia .info .medio{
  display:inline-block;
  font-family:var(--ui);font-size:11px;letter-spacing:2px;font-weight:600;
  text-transform:uppercase;color:var(--gold);
  padding:4px 12px;
  border:1px solid var(--gold-deep);
  white-space:nowrap;
}
.noticia .info .fecha{
  font-family:var(--ui);font-size:13px;letter-spacing:1.5px;
  color:var(--cream-mute);
  white-space:nowrap;
}
.noticia .info h3{
  font-family:var(--serif);font-style:italic;font-weight:400;
  font-size:21px;line-height:1.3;color:var(--cream);
  margin-bottom:14px;
}
.noticia:hover .info h3{color:var(--gold-bright)}
.noticia .info .link{
  font-family:var(--ui);font-size:12px;letter-spacing:1.8px;font-weight:600;
  text-transform:uppercase;color:var(--gold);
  margin-top:auto;
}
.noticia .info .link:hover{color:var(--gold-bright)}

/* Vacío */
.empty-state{
  text-align:center;padding:80px 32px;
  color:var(--cream-mute);font-style:italic;font-size:17px;
  max-width:600px;margin:0 auto;
}
.empty-state h3{
  font-family:var(--display);font-size:56px;color:var(--gold-deep);
  margin-bottom:14px;font-style:normal;
}

/* ============================================================
   PÁGINAS DE CONTENIDO EDITORIAL (/la-obra, /denis-rafter,
   /san-juan-salamanca, /trilogia)
   Mismo lenguaje visual que la home: fondos trabajados, grids,
   marcos decorativos reales, tipografía con carácter.
   ============================================================ */

/* ---------- Hero de página interior ---------- */
.page-hero{
  position:relative;
  padding:140px 32px 80px;
  overflow:hidden;
  text-align:center;
}
.page-hero::before{
  content:"";position:absolute;inset:0;z-index:0;
  background:
    radial-gradient(ellipse 60% 80% at 50% 0%, rgba(212,166,87,.12), transparent 65%),
    radial-gradient(ellipse 90% 40% at 50% 100%, rgba(139,58,46,.06), transparent 70%);
  pointer-events:none;
}
.page-hero::after{
  content:"";position:absolute;z-index:0;
  left:50%;bottom:30px;transform:translateX(-50%);
  width:1px;height:60px;
  background:linear-gradient(180deg, transparent, var(--gold-deep), transparent);
}
.page-hero .inner{
  position:relative;z-index:1;
  max-width:780px;margin:0 auto;
}
.page-hero .eyebrow{
  margin-bottom:22px;
  display:inline-flex;align-items:center;gap:14px;
  color:var(--gold);
}
.page-hero .eyebrow::before,
.page-hero .eyebrow::after{
  content:"";display:block;width:24px;height:1px;background:var(--gold-deep);
}
.page-hero h1{
  font-family:var(--serif);
  font-weight:300;font-style:italic;
  font-size:clamp(46px,7vw,92px);
  line-height:1.02;color:var(--cream);
  letter-spacing:-.8px;
  margin-bottom:28px;
}
.page-hero h1 em{
  color:var(--gold-bright);
  font-family:var(--display);font-style:normal;font-weight:400;
  letter-spacing:1px;
}
.page-hero .lead{
  margin:0 auto;
  font-size:clamp(17px,1.8vw,21px);line-height:1.55;
  color:var(--cream-dim);
  max-width:620px;
  font-family:var(--serif);font-weight:300;
}

/* ---------- Cuerpo del artículo ---------- */
.article{
  max-width:780px;margin:0 auto;
  padding:20px 28px 100px;
  font-size:19px;
  color:var(--cream-dim);
  line-height:1.78;
  position:relative;
}

/* Margen lateral más generoso en pantallas amplias */
@media (min-width: 900px){
  .article{padding:20px 40px 120px;font-size:20px}
}

.article > p{margin-bottom:26px}
.article strong{color:var(--cream);font-weight:500}
.article em{color:var(--gold-bright);font-style:italic}

/* Intro con dropcap más refinado y espacio superior */
.article .intro{
  margin-bottom:30px;
  padding-top:20px;
  position:relative;
}
.article .intro::before{
  content:"";
  position:absolute;
  top:0;left:50%;transform:translateX(-50%);
  width:40px;height:1px;
  background:var(--gold-deep);
  opacity:.6;
}
.article .intro p:first-of-type::first-letter{
  font-family:var(--display);
  font-size:84px;
  float:left;
  line-height:.82;
  padding:10px 16px 0 0;
  color:var(--gold-bright);
}
.article .intro p{
  font-size:22px;line-height:1.65;color:var(--cream);
}

/* Títulos de sección: numerados con romano */
.article h2{
  font-family:var(--serif);font-style:italic;font-weight:400;
  font-size:clamp(30px,3.8vw,46px);
  line-height:1.08;color:var(--cream);
  margin:90px 0 30px;
  letter-spacing:-.4px;
  padding-top:30px;
  position:relative;
}
.article h2::before{
  content:"";
  position:absolute;top:0;left:0;
  width:36px;height:1px;
  background:var(--gold);
}
.article h2 em{
  color:var(--gold-bright);
  font-family:var(--display);font-style:normal;font-weight:400;
}

/* Subtítulos pequeños */
.article h3{
  font-family:var(--ui);
  font-size:11px;letter-spacing:3.5px;font-weight:600;
  text-transform:uppercase;color:var(--gold);
  margin:60px 0 22px;
}
.article h3::before{
  content:"◦  ";color:var(--gold-deep);letter-spacing:0;
}

/* Citas grandes (mejoradas: comillas decorativas + ornamento) */
.article blockquote{
  margin:60px -20px;
  padding:50px 48px 44px;
  position:relative;
  background:
    linear-gradient(135deg, rgba(212,166,87,.08), rgba(212,166,87,.02) 60%, transparent),
    linear-gradient(180deg, var(--bg-2), var(--bg));
  border:1px solid var(--border);
  border-top:1px solid var(--gold-deep);
  font-family:var(--serif);
  font-style:italic;font-weight:300;
  font-size:clamp(21px,2.7vw,29px);
  line-height:1.4;
  color:var(--cream);
  text-align:center;
  overflow:hidden;
}
.article blockquote::before{
  content:"“";
  position:absolute;top:-20px;left:30px;
  font-family:var(--display);font-style:italic;
  font-size:140px;
  line-height:1;
  color:var(--gold);
  opacity:.35;
}
.article blockquote::after{
  content:"";
  position:absolute;
  bottom:18px;left:50%;transform:translateX(-50%);
  width:40px;height:1px;
  background:linear-gradient(90deg, transparent, var(--gold-deep), transparent);
}
.article blockquote cite{
  display:block;margin-top:24px;
  font-family:var(--ui);font-style:normal;font-weight:500;
  letter-spacing:3px;font-size:11px;text-transform:uppercase;
  color:var(--cream-mute);
}
.article blockquote cite::before{content:"— "}
@media (min-width: 720px){
  .article blockquote{margin:60px -40px;padding:56px 64px 50px}
}

/* Listas con ornamento de diamante */
.article ul{
  margin:26px 0 32px;
  padding-left:0;
  list-style:none;
}
.article ul li{
  position:relative;
  padding-left:36px;
  margin-bottom:14px;
  color:var(--cream-dim);
}
.article ul li::before{
  content:"◆";
  position:absolute;
  left:8px;top:1px;
  color:var(--gold);
  font-size:11px;
}

/* Separador decorativo */
.article hr{
  border:0;
  margin:80px auto;
  width:100%;height:14px;
  background:none;
  position:relative;
  display:flex;align-items:center;justify-content:center;
}
.article hr::before{
  content:"◦  ◦  ◦";
  letter-spacing:10px;
  color:var(--gold-deep);
  font-size:12px;
  background:var(--bg);
  padding:0 16px;
  z-index:1;
}
.article hr::after{
  content:"";
  position:absolute;
  left:0;right:0;top:50%;
  height:1px;
  background:linear-gradient(90deg, transparent, var(--gold-deep) 20%, var(--gold-deep) 80%, transparent);
  opacity:.3;
}

/* ---------- Retratos con marco como el poster del hero ---------- */
.portrait{
  max-width:380px;margin:50px auto 16px;
  padding:14px;
  background:linear-gradient(145deg, rgba(212,166,87,.1), rgba(212,166,87,.03) 60%, transparent);
  border:1px solid var(--border);
  box-shadow:
    0 30px 80px rgba(0,0,0,.6),
    0 0 0 1px rgba(212,166,87,.06) inset,
    0 0 80px rgba(212,166,87,.06);
  transform:rotate(-.8deg);
  transition:transform .8s ease;
  position:relative;
}
.portrait:hover{transform:rotate(-.2deg) translateY(-3px)}
.portrait::before,
.portrait::after{
  content:"";position:absolute;width:18px;height:18px;
  border:1px solid var(--gold);opacity:.45;
}
.portrait::before{top:-1px;left:-1px;border-right:none;border-bottom:none}
.portrait::after{bottom:-1px;right:-1px;border-left:none;border-top:none}
.portrait img{
  width:100%;display:block;
  aspect-ratio:3/4;object-fit:cover;
}
/* Variante horizontal */
.portrait.portrait-wide{
  max-width:820px;
}
.portrait.portrait-wide img{
  aspect-ratio:4/3;object-fit:cover;
}
/* Placeholder */
.portrait.placeholder{
  aspect-ratio:3/4;
  display:grid;place-items:center;
  color:var(--gold-deep);
  font-family:var(--display);font-size:48px;font-style:italic;
  background:
    repeating-linear-gradient(45deg, rgba(212,166,87,.03) 0 10px, transparent 10px 20px),
    linear-gradient(145deg, rgba(212,166,87,.05), rgba(139,58,46,.04));
}
.portrait-caption{
  margin:-6px auto 60px;
  max-width:620px;
  font-family:var(--serif);font-style:italic;
  font-size:14px;color:var(--cream-mute);text-align:center;
  padding:0 32px;
  line-height:1.5;
}

/* ---------- Elenco: tarjetas con más personalidad ---------- */
.cast-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(220px, 1fr));
  gap:0;
  margin:36px -20px 50px;
  border:1px solid var(--border);
  background:linear-gradient(180deg, rgba(212,166,87,.03), transparent);
}
@media (min-width: 720px){
  .cast-grid{margin:36px -40px 50px}
}
.cast-item{
  padding:28px 26px;
  border-right:1px solid var(--border-soft);
  border-bottom:1px solid var(--border-soft);
  transition:all .4s ease;
  text-align:center;
}
.cast-item:hover{
  background:linear-gradient(180deg, rgba(212,166,87,.08), transparent);
}
.cast-item .role{
  display:inline-block;
  font-family:var(--ui);font-size:10px;letter-spacing:2.5px;font-weight:600;
  text-transform:uppercase;color:var(--gold);
  margin-bottom:10px;
  padding-bottom:6px;
  border-bottom:1px solid var(--gold-deep);
}
.cast-item .name{
  font-family:var(--serif);font-style:italic;font-weight:400;
  font-size:21px;color:var(--cream);line-height:1.2;
}

/* ---------- Ficha técnica: más ornamentada ---------- */
.crew-list{
  display:grid;
  grid-template-columns:200px 1fr;
  gap:0;
  margin:26px -20px 50px;
  padding:0;
  border:1px solid var(--border);
  background:
    linear-gradient(145deg, rgba(212,166,87,.04), transparent),
    var(--bg);
}
@media (min-width: 720px){
  .crew-list{margin:26px -40px 50px}
}
.crew-list dt,
.crew-list dd{
  padding:18px 26px;
  border-bottom:1px solid var(--border-soft);
  margin:0;
}
.crew-list dt{
  font-family:var(--ui);font-size:10px;letter-spacing:2.5px;font-weight:600;
  text-transform:uppercase;color:var(--gold);
  background:rgba(212,166,87,.04);
  border-right:1px solid var(--border-soft);
  display:flex;align-items:center;
}
.crew-list dd{
  font-family:var(--serif);font-size:17px;color:var(--cream);
  font-weight:300;
}
.crew-list dt:last-of-type,
.crew-list dd:last-of-type{border-bottom:none}
@media (max-width: 600px){
  .crew-list{grid-template-columns:1fr}
  .crew-list dt{border-right:none;padding:14px 22px 6px}
  .crew-list dd{padding:6px 22px 16px;font-size:16px}
  .crew-list dt:last-of-type{padding-bottom:6px}
}

/* ---------- Tarjetas de la trilogía: muy trabajadas ---------- */
.big-cards{
  display:grid;
  grid-template-columns:1fr;
  gap:22px;
  margin:50px -20px;
}
@media (min-width: 720px){
  .big-cards{
    grid-template-columns:repeat(3, 1fr);
    gap:28px;
    /* Técnica "full bleed": extiende al ancho de viewport aunque el padre
       tenga max-width (el <article> tiene max-width 780px). */
    width:calc(100vw - 40px);
    max-width:1400px;
    margin-left:calc(50% - 50vw + 20px);
    margin-right:calc(50% - 50vw + 20px);
    margin-top:50px;margin-bottom:50px;
  }
}
@media (min-width: 1440px){
  /* En pantallas muy amplias, fijamos a 1400px centrado */
  .big-cards{
    width:1400px;
    margin-left:calc(50% - 700px);
    margin-right:calc(50% - 700px);
  }
}
@media (max-width: 719px) and (min-width: 560px){
  .big-cards{
    grid-template-columns:repeat(2, 1fr);
    gap:20px;
  }
}
.big-card{
  padding:0 0 38px;
  border:1px solid var(--border);
  background:
    radial-gradient(ellipse 100% 60% at 50% 0%, rgba(212,166,87,.06), transparent 70%),
    linear-gradient(180deg, rgba(212,166,87,.03), rgba(212,166,87,0));
  transition:all .5s ease;
  position:relative;
  overflow:hidden;
  display:flex;flex-direction:column;
}
.big-card::before{
  content:"";
  position:absolute;top:0;left:50%;transform:translateX(-50%);
  width:50px;height:1px;
  background:linear-gradient(90deg, transparent, var(--gold-deep), transparent);
  z-index:2;
}
.big-card:hover{
  border-color:var(--gold-deep);
  transform:translateY(-6px);
  background:
    radial-gradient(ellipse 100% 60% at 50% 0%, rgba(212,166,87,.12), transparent 70%),
    linear-gradient(180deg, rgba(212,166,87,.06), rgba(212,166,87,0));
}
.big-card.featured{
  border-color:var(--gold);
  background:
    radial-gradient(ellipse 100% 60% at 50% 0%, rgba(212,166,87,.18), transparent 70%),
    linear-gradient(180deg, rgba(212,166,87,.08), rgba(139,58,46,.04));
}
.big-card.featured::before{
  width:80px;background:var(--gold);height:2px;
}

/* Cartel en la parte superior de la tarjeta */
.big-card .poster{
  width:100%;
  aspect-ratio:3/4.3;
  background:var(--bg-2);
  overflow:hidden;
  display:flex;align-items:center;justify-content:center;
  border-bottom:1px solid var(--border-soft);
  position:relative;
}
.big-card .poster picture{width:100%;height:100%;display:block}
.big-card .poster img{
  width:100%;height:100%;
  object-fit:cover;
  object-position:center center;
  display:block;
  transition:transform .6s ease;
}
.big-card:hover .poster img{transform:scale(1.03)}

/* Contenido dentro de la tarjeta (debajo del cartel) */
.big-card .roman,
.big-card h3,
.big-card .years,
.big-card p,
.big-card .count{
  padding-left:32px;padding-right:32px;
}
.big-card .roman{
  font-family:var(--display);font-size:62px;font-style:italic;
  color:var(--gold);line-height:.9;
  margin:24px 0 14px;
  text-align:center;
}
.big-card.featured .roman{color:var(--gold-bright)}
.big-card h3{
  font-family:var(--serif);font-style:italic;font-weight:400;
  font-size:30px;color:var(--cream);line-height:1.15;
  margin-bottom:12px;letter-spacing:-.3px;
  text-align:center;
}
.big-card .years{
  text-align:center;
  font-family:var(--ui);font-size:12px;letter-spacing:3px;font-weight:500;
  text-transform:uppercase;color:var(--cream-mute);
  margin-bottom:26px;
  padding-bottom:18px;
  border-bottom:1px solid var(--border-soft);
  margin-left:32px;margin-right:32px;
  padding-left:0;padding-right:0;
}
.big-card p{
  font-size:17px;color:var(--cream);line-height:1.65;
  margin-bottom:16px;
}
.big-card .count{
  display:flex;align-items:baseline;justify-content:center;gap:12px;
  margin-top:28px;padding-top:22px;
  border-top:1px solid var(--border-soft);
  text-align:center;
  margin-left:32px;margin-right:32px;
  padding-left:0;padding-right:0;
}
.big-card .count .n{
  font-family:var(--display);font-style:italic;
  font-size:52px;color:var(--gold-bright);line-height:.9;
}
.big-card .count .l{
  font-family:var(--ui);font-size:12px;letter-spacing:2px;font-weight:600;
  text-transform:uppercase;color:var(--cream-mute);
}

/* ---------- Callout: box destacado al final ---------- */
.callout{
  margin:90px -20px 30px;
  padding:56px 44px 52px;
  border:1px solid var(--border);
  background:
    radial-gradient(ellipse 80% 120% at 50% 0%, rgba(212,166,87,.12), transparent 70%),
    linear-gradient(180deg, rgba(212,166,87,.05), rgba(212,166,87,.01));
  text-align:center;
  position:relative;
  overflow:hidden;
}
.callout::before{
  content:"";
  position:absolute;top:0;left:50%;transform:translateX(-50%);
  width:80px;height:2px;background:var(--gold);
}
@media (min-width: 720px){
  .callout{margin:90px -40px 30px;padding:64px 52px 58px}
}
.callout h3{
  font-family:var(--serif);font-style:italic;font-weight:400;
  font-size:clamp(26px,3.2vw,36px);
  line-height:1.2;color:var(--cream);
  margin-bottom:18px;letter-spacing:-.3px;
}
.callout h3 em{
  color:var(--gold-bright);
  font-family:var(--display);font-style:normal;font-weight:400;
}
.callout p{
  font-size:16px;color:var(--cream-dim);margin-bottom:28px;
  max-width:520px;margin-left:auto;margin-right:auto;line-height:1.65;
}
.callout .actions{
  display:flex;gap:14px;justify-content:center;flex-wrap:wrap;
}

/* ---------- Firma (al final de cartas / autorías) ---------- */
.signature{
  margin-top:50px;padding-top:28px;
  border-top:1px solid var(--border-soft);
  text-align:right;
  font-family:var(--serif);font-style:italic;
  color:var(--cream-dim);font-size:17px;
}
.signature .name{
  display:block;
  font-family:var(--display);font-size:30px;font-style:normal;
  color:var(--gold-bright);line-height:1;
  margin-bottom:6px;
}
.signature .role{
  font-family:var(--ui);font-size:10px;letter-spacing:2.5px;font-weight:600;
  text-transform:uppercase;color:var(--cream-mute);font-style:normal;
}

/* ============================================================
   BANDA INSTITUCIONAL (entidades colaboradoras)
   Aparece en el pie de todas las páginas, antes del footer.
   Fondo claro para respetar los colores oficiales de los logos.
   ============================================================ */
.institutions{
  background:#ffffff;
  padding:48px 32px 52px;
  border-top:1px solid rgba(212,166,87,.3);
  border-bottom:1px solid rgba(212,166,87,.2);
  position:relative;
}
.institutions::before{
  content:"";position:absolute;top:0;left:50%;transform:translateX(-50%);
  width:120px;height:1px;background:linear-gradient(90deg, transparent, var(--gold-deep), transparent);
}
.institutions-inner{
  max-width:1100px;margin:0 auto;
  display:flex;flex-direction:column;align-items:center;gap:32px;
}
.institutions-label{
  font-family:var(--ui);
  font-size:10px;letter-spacing:3.5px;font-weight:600;
  text-transform:uppercase;color:#8b6a3a;
}
/* Grid: en móvil 2x2, en pantallas medianas/grandes 4x1 */
.institutions-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:28px 24px;align-items:center;justify-items:center;
  width:100%;
}
/* En desktop: 3 columnas iguales para las diócesis + 1 columna 1.7 veces más
   grande para la Diputación (+30% sobre el +30% anterior). */
@media (min-width: 720px){
  .institutions-grid{
    grid-template-columns: 1fr 1fr 1fr 1.7fr;
    gap:24px 40px;
  }
}
.institution{
  display:flex;align-items:center;justify-content:center;
  width:100%;
  max-width:180px;
  transition:opacity .3s ease, transform .3s ease;
}
.institution img{
  max-width:100%;
  width:auto;max-height:70px;
  object-fit:contain;
  display:block;
}
/* Diputación (destacada, +30% sobre las otras, aumentado otro +30% = 1.69x total) */
.institution.institution-big{max-width:312px}
.institution.institution-big img{max-height:120px}

.institution:hover{
  opacity:.7;
  transform:translateY(-2px);
}
@media (min-width: 720px){
  .institution{max-width:200px}
  .institution img{max-height:80px}
  .institution.institution-big{max-width:338px}
  .institution.institution-big img{max-height:135px}
}

/* ============================================================
   PÁGINA DE MATERIALES
   Cards de descarga con vista previa + botón.
   ============================================================ */
.materials-list{
  padding:20px 24px 100px;
}
.materials-inner{
  max-width:1100px;margin:0 auto;
}
.materials-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(280px, 1fr));
  gap:28px;
  margin-top:20px;
}
@media (min-width: 900px){
  .materials-grid{
    grid-template-columns:repeat(auto-fit, minmax(320px, 1fr));
    gap:36px;
  }
}

.material-card{
  border:1px solid var(--border);
  background:
    radial-gradient(ellipse 100% 60% at 50% 0%, rgba(212,166,87,.06), transparent 70%),
    linear-gradient(180deg, rgba(212,166,87,.03), rgba(212,166,87,0));
  display:flex;flex-direction:column;
  transition:all .4s ease;
  overflow:hidden;
}
.material-card:hover{
  border-color:var(--gold-deep);
  transform:translateY(-4px);
}

.material-preview{
  aspect-ratio:3/4;
  background:var(--bg-2);
  border-bottom:1px solid var(--border-soft);
  overflow:hidden;
  position:relative;
}
.material-preview img{
  width:100%;height:100%;
  object-fit:cover;
  object-position:center top;
  display:block;
  transition:transform .6s ease;
}
.material-card:hover .material-preview img{transform:scale(1.03)}

.material-preview-placeholder{
  width:100%;height:100%;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:10px;
  background:
    repeating-linear-gradient(45deg, rgba(212,166,87,.04) 0 14px, transparent 14px 28px),
    linear-gradient(145deg, rgba(212,166,87,.06), rgba(139,58,46,.03));
}
.material-preview-placeholder .ext{
  font-family:var(--display);
  font-size:72px;font-style:italic;
  color:var(--gold);
  line-height:1;
}

.material-body{
  padding:28px 28px 32px;
  display:flex;flex-direction:column;flex:1;
}
.material-title{
  font-family:var(--serif);font-style:italic;font-weight:400;
  font-size:26px;line-height:1.2;
  color:var(--cream);
  margin-bottom:12px;
  letter-spacing:-.3px;
}
.material-desc{
  font-size:16px;color:var(--cream-dim);line-height:1.6;
  margin-bottom:20px;
  flex:1;
}
.material-meta{
  display:flex;gap:16px;align-items:center;
  margin-bottom:22px;
  font-family:var(--ui);font-size:11px;letter-spacing:2px;font-weight:500;
  text-transform:uppercase;color:var(--cream-mute);
}
.material-meta .material-type{
  display:inline-block;
  padding:4px 10px;
  border:1px solid var(--gold-deep);
  color:var(--gold);
}
.material-meta .material-size{
  color:var(--cream-mute);
}
.material-actions{
  display:flex;gap:12px;flex-wrap:wrap;
}
.material-actions .btn{
  padding:14px 24px;
  font-size:12px;letter-spacing:2px;
}

/* ============================================================
   CALENDARIO MENSUAL (/calendario-mensual)
   ============================================================ */
.cal-month-wrap{padding:20px 24px 100px}
.cal-month-inner{max-width:980px;margin:0 auto}
@media (max-width: 720px){
  .cal-month-wrap{padding:16px 14px 80px}
}

.cal-toolbar{
  display:grid;grid-template-columns:1fr auto 1fr;
  gap:18px;align-items:center;
  margin-bottom:14px;
  padding:18px 0;
  border-top:1px solid var(--border-soft);
  border-bottom:1px solid var(--border-soft);
}
.cal-nav{
  font-family:var(--ui);font-size:12px;letter-spacing:1.5px;font-weight:600;
  text-transform:uppercase;color:var(--cream-dim);
  padding:8px 14px;
  border:1px solid var(--border-soft);
  display:inline-block;
  transition:all .25s ease;
}
.cal-nav:hover{color:var(--gold-bright);border-color:var(--gold-deep)}
.cal-nav-prev{justify-self:start}
.cal-nav-next{justify-self:end}
.cal-nav-disabled{
  justify-self:start;
  color:rgba(212,166,87,.2);
  border-color:rgba(212,166,87,.06);
  cursor:not-allowed;
}
.cal-toolbar-center{
  font-family:var(--serif);font-style:italic;
  font-size:22px;color:var(--cream);
  text-align:center;
  letter-spacing:.5px;
}
.cal-views{
  text-align:right;margin-bottom:24px;
}
.view-toggle{
  font-family:var(--ui);font-size:11px;letter-spacing:2px;font-weight:600;
  text-transform:uppercase;color:var(--gold);
  border-bottom:1px solid var(--gold-deep);padding-bottom:3px;
}
.view-toggle:hover{color:var(--gold-bright);border-color:var(--gold)}

.cal-grid{
  width:100%;border-collapse:separate;border-spacing:6px;
  table-layout:fixed;
}
.cal-grid thead th{
  font-family:var(--ui);font-size:10px;letter-spacing:2.5px;font-weight:600;
  text-transform:uppercase;color:var(--gold);
  padding:10px 4px;text-align:center;
}
.cal-cell{
  background:var(--bg-2);
  border:1px solid var(--border-soft);
  height:88px;
  vertical-align:top;
  padding:8px;
  position:relative;
  transition:all .3s ease;
}
.cal-cell.cal-empty{background:transparent;border-color:transparent}
.cal-cell .cal-day-num{
  font-family:var(--ui);font-size:14px;font-weight:500;color:var(--cream-mute);
  display:block;
}
.cal-cell.cal-today{
  border-color:var(--gold);
  box-shadow:0 0 0 1px rgba(212,166,87,.18) inset;
}
.cal-cell.cal-today .cal-day-num{color:var(--gold-bright);font-weight:700}
.cal-cell.cal-has-event{
  background:linear-gradient(180deg, rgba(212,166,87,.08), rgba(212,166,87,.02));
  border-color:rgba(212,166,87,.45);
  cursor:pointer;
}
.cal-cell.cal-has-event:hover{
  background:linear-gradient(180deg, rgba(212,166,87,.18), rgba(212,166,87,.04));
  border-color:var(--gold);
  transform:translateY(-1px);
  box-shadow:0 6px 16px rgba(0,0,0,.3);
}
.cal-day-btn{
  background:none;border:0;padding:0;
  width:100%;height:100%;
  cursor:pointer;
  text-align:left;
  display:flex;flex-direction:column;justify-content:space-between;
  color:inherit;
}
.cal-day-btn .cal-day-num{
  color:var(--cream);font-weight:700;font-size:16px;
}
.cal-day-dot{
  display:block;width:8px;height:8px;border-radius:50%;
  background:var(--gold);
  margin-top:auto;
  align-self:flex-end;
  box-shadow:0 0 8px rgba(212,166,87,.5);
}
.cal-day-count{
  position:absolute;top:6px;right:8px;
  font-family:var(--ui);font-size:10px;font-weight:600;
  color:var(--gold-bright);
  background:rgba(10,6,3,.85);
  padding:1px 6px;
  border:1px solid var(--gold-deep);
  border-radius:8px;
  min-width:18px;text-align:center;
}
.cal-cell.cal-has-event:hover .cal-day-count{
  background:var(--gold);color:var(--bg);border-color:var(--gold);
}

.cal-legend{
  margin-top:24px;
  display:flex;gap:24px;justify-content:center;flex-wrap:wrap;
  font-family:var(--ui);font-size:11px;letter-spacing:1.5px;
  color:var(--cream-mute);text-transform:uppercase;font-weight:500;
}
.cal-legend-item{display:inline-flex;align-items:center;gap:8px}
.cal-legend-item .dot{
  display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--gold);
}
.cal-legend-item .dot.today{
  background:transparent;border:1px solid var(--gold);
}

@media (max-width: 720px){
  /* Quitar el padding horizontal del wrap y dar margen real a la toolbar/grid */
  .cal-grid{border-spacing:4px}
  .cal-cell{height:54px;padding:4px 3px}
  .cal-grid thead th{font-size:10px;letter-spacing:1px;padding:8px 2px}
  .cal-day-btn .cal-day-num,
  .cal-cell .cal-day-num{font-size:14px}
  .cal-day-count{font-size:9px;padding:1px 5px;top:3px;right:3px;min-width:16px}
  .cal-day-dot{width:6px;height:6px}
  .cal-toolbar{
    grid-template-columns:1fr;
    gap:10px;
    padding:14px 0;
    margin-bottom:10px;
  }
  .cal-nav{
    justify-self:stretch !important;
    text-align:center;
    padding:10px 14px;
    font-size:11px;
  }
  .cal-toolbar-center{
    order:-1;
    font-size:20px;
    padding:8px 0 4px;
  }
  .cal-views{margin-bottom:16px}
  .cal-legend{
    margin-top:20px;
    gap:16px;
    font-size:10px;
  }
}

/* Móvil muy pequeño (≤400) — priorizar el nº del día */
@media (max-width: 400px){
  .cal-cell{height:46px;padding:3px 2px}
  .cal-day-btn .cal-day-num,
  .cal-cell .cal-day-num{font-size:13px}
  .cal-grid thead th{font-size:9px;padding:6px 1px}
  .cal-day-count{display:none}
}

/* ============================================================
   LIGHTBOX del calendario mensual
   ============================================================ */
.cal-lightbox{
  position:fixed;inset:0;z-index:300;
  display:flex;align-items:center;justify-content:center;
  padding:24px;
}
.cal-lightbox[hidden]{display:none}
.cal-lightbox-backdrop{
  position:absolute;inset:0;
  background:rgba(10,6,3,.85);
  backdrop-filter:blur(8px);
  cursor:pointer;
}
/* Lightbox: mismo diseño que los eventos de la home */
.cal-lightbox-dialog{
  position:relative;
  background:linear-gradient(180deg, #f5ebd9 0%, #ebdec2 100%);
  color:#2a1f10;
  border:1px solid rgba(139,106,42,.4);
  max-width:820px;width:100%;
  max-height:90vh;overflow-y:auto;
  padding:44px 40px;
  box-shadow:0 30px 80px rgba(0,0,0,.7);
  animation:lbIn .35s ease;
}
.cal-lightbox-close{
  position:absolute;top:12px;right:14px;
  background:none;border:0;color:#8b6a2a;
  font-size:32px;line-height:1;cursor:pointer;
  width:38px;height:38px;
  display:grid;place-items:center;
  transition:color .2s ease;
}
.cal-lightbox-close:hover{color:#2a1f10}
.cal-lb-fecha{
  font-family:var(--ui);font-size:12px;letter-spacing:3px;font-weight:600;
  text-transform:uppercase;color:#8b6a2a;
  margin-bottom:28px;text-align:center;
  padding-bottom:16px;
  border-bottom:1px solid rgba(139,106,42,.3);
}
.cal-lb-event{
  background:rgba(255,253,246,.85);
  border:1px solid rgba(139,106,42,.28);
  padding:24px 26px;
  display:grid;
  grid-template-columns:auto 1fr;
  gap:24px;
  align-items:center;
  margin-bottom:18px;
  box-shadow:0 4px 14px rgba(0,0,0,.04);
}
.cal-lb-event:last-child{margin-bottom:0}
.cal-lb-cartel{
  width:234px;height:auto;aspect-ratio:1/1.414;
  object-fit:cover;
  border:1px solid rgba(139,106,42,.35);padding:8px;background:#fffdf6;
  box-shadow:0 10px 22px rgba(0,0,0,.15);
  display:block;
}
.cal-lb-info{
  display:flex;flex-direction:column;justify-content:center;
}
.cal-lb-info h3{
  font-family:var(--serif);font-style:italic;font-weight:400;
  font-size:22px;color:#2a1f10;line-height:1.25;
  margin-bottom:12px;letter-spacing:-.2px;
}
.cal-lb-lugar{
  font-size:19px;color:#2a1f10;font-weight:500;
  line-height:1.35;margin-bottom:10px;
}
.cal-lb-fecha-ev{
  font-family:var(--ui);font-size:14px;letter-spacing:2.5px;font-weight:600;
  text-transform:uppercase;color:#6d4e14;margin-bottom:12px;
}
.cal-lb-hora{
  color:#fffdf6;background:#8b6a2a;
  font-family:var(--ui);font-weight:600;font-size:17px;letter-spacing:1px;
  padding:8px 14px;align-self:flex-start;
  border:1px solid #6d4e14;
  box-shadow:0 3px 8px rgba(0,0,0,.12);
}
.cal-lb-desc{
  font-style:italic;color:#6d4e14;font-size:14px;line-height:1.55;
  margin-top:10px;
}
@media (max-width: 600px){
  .cal-lightbox-dialog{padding:30px 22px}
  .cal-lb-event{grid-template-columns:180px 1fr;gap:18px;padding:18px 20px}
  .cal-lb-cartel{width:180px}
  .cal-lb-info h3{font-size:19px}
  .cal-lb-lugar{font-size:17px}
  .cal-lb-fecha-ev{font-size:13px}
  .cal-lb-hora{font-size:15px;padding:7px 12px}
}
@media (max-width: 480px){
  .cal-lb-event{grid-template-columns:1fr}
  .cal-lb-cartel{width:100%;max-width:220px;margin:0 auto}
}
@keyframes lbIn{
  from{opacity:0;transform:translateY(20px) scale(.97)}
  to  {opacity:1;transform:translateY(0)    scale(1)}
}

/* ============================================================
   CTA "Ver calendario completo" (en franja clara)
   ============================================================ */
.section-light .ver-completo{
  text-align:center;
  margin-top:40px;
}
.section-light .ver-completo .btn-light{
  display:inline-block;
  font-family:var(--ui);
  font-size:13px;font-weight:600;letter-spacing:2.5px;
  text-transform:uppercase;
  color:#fffdf6 !important;
  background:#8b6a2a;
  border:1px solid #6d4e14;
  padding:16px 36px;
  transition:all .3s ease;
  box-shadow:0 4px 12px rgba(0,0,0,.1);
}
.section-light .ver-completo .btn-light:hover{
  background:#6d4e14;
  transform:translateY(-2px);
  box-shadow:0 6px 16px rgba(0,0,0,.15);
}

/* ============================================================
   /calendario en formato lista — overrides para ajustarlo a la franja clara
   ============================================================ */
.cal-full .cal-group{margin-bottom:60px}
.cal-full .cal-group:last-child{margin-bottom:0}
.cal-full .cal-group-title{
  font-family:var(--serif);font-style:italic;font-weight:400;
  font-size:26px;color:#2a1f10;
  margin-bottom:30px;
  padding-bottom:14px;
  border-bottom:1px solid rgba(139,106,42,.25);
}
.cal-full .cal-group-past .cal-group-title{color:#6d4e14;opacity:.75}
.cal-full .cal-group-past .event{opacity:.65}
.cal-full .cal-group-past .event:hover{opacity:.9;transform:none}

/* Toggle "Ver vista mensual" en fondo claro */
.section-light .view-toggle-light,
a.view-toggle-light{
  font-family:var(--ui);font-size:12px;letter-spacing:2px;font-weight:600;
  text-transform:uppercase;
  color:#8b6a2a;
  border-bottom:1px solid rgba(139,106,42,.4);
  padding-bottom:3px;
  display:inline-block;
}
.section-light .view-toggle-light:hover,
a.view-toggle-light:hover{
  color:#6d4e14;
  border-bottom-color:#6d4e14;
}

/* En la página /calendario (grid de 2 columnas) reducimos un poco el cartel
   para que con la descripción extra (que no aparece en home) no se
   desproporcione */
.cal-full .event .info .desc{
  color:#6d4e14 !important;
  font-style:italic !important;
  font-size:14px !important;
  margin-top:8px !important;
  margin-bottom:12px !important;
  line-height:1.5 !important;
}
