@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&display=swap');

:root {
  --cosmos: #1A0A3B;
  --cosmos-dark: #12082A;
  --cosmos-medium: #3D1F6E;
  --magenta: #CC0070;
  --nebulosa: #873D99;
  --nebulosa-clara: #C480D9;
  --dorado: #FFC832;
  --dorado-suave: #FFE085;
  --polvo: #F5EEF8;
  --lila: #E8D0F8;
  --azul-estelar: #4D90D0;
  --blanco: #FFFFFF;
  --blanco-76: rgba(255, 255, 255, .76);
  --blanco-56: rgba(255, 255, 255, .56);
  --blanco-42: rgba(255, 255, 255, .42);
  --borde: rgba(196, 128, 217, .24);
  --borde-magenta: rgba(204, 0, 112, .56);
  --sombra: 0 18px 42px rgba(0, 0, 0, .22);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  min-height: 100vh;
  margin: 0;
  background: var(--cosmos);
  color: var(--lila);
  font-family: 'Space Grotesk', system-ui, sans-serif;
  line-height: 1.48;
  overflow-x: hidden;
}

body::before,
body::after {
  content: '';
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: -2;
}
body::before {
  background:
    radial-gradient(circle at 16% 14%, rgba(204, 0, 112, .16), transparent 24%),
    radial-gradient(circle at 88% 20%, rgba(135, 61, 153, .22), transparent 26%),
    radial-gradient(circle at 72% 82%, rgba(4, 64, 128, .22), transparent 26%),
    linear-gradient(145deg, var(--cosmos-dark), var(--cosmos) 50%, #210d49);
}
body::after {
  opacity: .7;
  background-image:
    radial-gradient(1px 1px at 8% 12%, var(--dorado) 0, transparent 100%),
    radial-gradient(1px 1px at 18% 68%, var(--nebulosa-clara) 0, transparent 100%),
    radial-gradient(1.2px 1.2px at 32% 26%, rgba(255,255,255,.72) 0, transparent 100%),
    radial-gradient(1px 1px at 44% 84%, var(--dorado) 0, transparent 100%),
    radial-gradient(1.2px 1.2px at 58% 44%, rgba(255,255,255,.64) 0, transparent 100%),
    radial-gradient(1px 1px at 68% 18%, var(--nebulosa-clara) 0, transparent 100%),
    radial-gradient(1px 1px at 79% 72%, var(--dorado) 0, transparent 100%),
    radial-gradient(1.2px 1.2px at 92% 34%, rgba(255,255,255,.7) 0, transparent 100%);
  background-size: 280px 280px;
}

a { color: inherit; }
button, input { font: inherit; }
button { cursor: pointer; }
img { max-width: 100%; display: block; }

.shell { width: min(100% - 32px, 760px); margin-inline: auto; }
.shell-wide { width: min(100% - 22px, 1380px); margin-inline: auto; }

.site-header {
  position: sticky;
  top: 0;
  z-index: 30;
  backdrop-filter: blur(18px);
  background: rgba(18, 8, 42, .76);
  border-bottom: 1px solid var(--borde);
}
.site-header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  min-height: 56px;
}
.brand-mini { display: flex; align-items: center; gap: 9px; text-decoration: none; }
.brand-mini img { width: 26px; height: 34px; object-fit: contain; }
.brand-mini span { color: var(--blanco); font-size: .88rem; font-weight: 700; letter-spacing: .02em; }
.header-link { color: var(--nebulosa-clara); font-size: .75rem; text-decoration: none; }
.header-link:hover { color: var(--dorado); }

.hero { padding: 58px 0 24px; text-align: center; }
.hero--home { padding-top: 76px; }
.hero__isotipo { width: 84px; margin: 0 auto 20px; filter: drop-shadow(0 12px 22px rgba(204,0,112,.26)); }
.hero__logo { width: min(360px, 82vw); margin: 0 auto 16px; }
.hero__eyebrow,
.section-label {
  margin: 0 0 8px;
  color: var(--dorado);
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: .17em;
  text-transform: uppercase;
}
h1, h2, h3, p { margin-top: 0; }
h1 { margin-bottom: 14px; color: var(--blanco); font-size: clamp(2.1rem, 8vw, 4rem); line-height: .98; letter-spacing: -.055em; }
h2 { color: var(--blanco); font-size: clamp(1.55rem, 4vw, 2.25rem); line-height: 1.08; letter-spacing: -.035em; }
h3 { color: var(--blanco); }
.hero__text { max-width: 650px; margin: 0 auto; color: var(--lila); font-size: .98rem; }
.hero__tagline { margin-top: 18px; color: var(--dorado-suave); font-size: .9rem; font-style: italic; }

.orbit-rule {
  width: min(260px, 70vw);
  height: 1px;
  margin: 28px auto;
  background: linear-gradient(90deg, transparent, var(--nebulosa-clara), var(--magenta), transparent);
  position: relative;
}
.orbit-rule::after {
  content: '';
  position: absolute;
  top: -4px;
  left: 68%;
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: var(--dorado);
  box-shadow: 0 0 18px rgba(255,200,50,.72);
}

.link-grid { display: grid; gap: 12px; padding: 12px 0 62px; }
.link-card {
  display: grid;
  grid-template-columns: 48px 1fr auto;
  align-items: center;
  gap: 14px;
  padding: 16px;
  border: 1px solid var(--borde);
  border-radius: 18px;
  background: linear-gradient(140deg, rgba(61,31,110,.92), rgba(34,15,74,.92));
  color: inherit;
  text-decoration: none;
  box-shadow: 0 12px 30px rgba(0,0,0,.13);
  transition: transform .18s ease, border-color .18s ease, background .18s ease;
}
.link-card:hover { transform: translateY(-3px); border-color: var(--nebulosa-clara); }
.link-card--featured { border-color: var(--borde-magenta); background: linear-gradient(140deg, rgba(204,0,112,.32), rgba(61,31,110,.94)); }
.link-card--disabled { opacity: .6; cursor: default; }
.link-card--disabled:hover { transform: none; border-color: var(--borde); }
.link-card__icon {
  display: grid;
  place-items: center;
  width: 48px;
  height: 48px;
  border-radius: 16px;
  background: rgba(18,8,42,.68);
  color: var(--dorado);
  font-size: 1.28rem;
  border: 1px solid var(--borde);
}
.link-card__title { display: block; margin-bottom: 3px; color: var(--blanco); font-size: .94rem; font-weight: 700; }
.link-card__text { display: block; color: var(--blanco-76); font-size: .78rem; }
.link-card__arrow { color: var(--nebulosa-clara); font-size: 1.05rem; }
.link-card__status { color: var(--dorado-suave); font-size: .62rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; }

.footer { padding: 26px 0 40px; text-align: center; color: var(--blanco-42); font-size: .72rem; }
.footer img { width: 122px; margin: 0 auto 12px; opacity: .72; }

.agenda-top { padding: 25px 0 6px; }
.agenda-top__intro { max-width: 760px; }
.agenda-top p { color: var(--blanco-76); }
.source-note { margin-top: 12px; color: var(--nebulosa-clara); font-size: .73rem; }
.source-note a:hover { color: var(--dorado); }
.back-link { display: inline-flex; gap: 7px; align-items: center; color: var(--nebulosa-clara); font-size: .73rem; text-decoration: none; }
.back-link:hover { color: var(--dorado); }

.toolbar {
  display: grid;
  grid-template-columns: minmax(210px, 360px) 1fr;
  align-items: center;
  gap: 10px;
  margin: 12px 0 15px;
  padding: 9px;
  border-radius: 16px;
  background: rgba(18,8,42,.66);
  border: 1px solid var(--borde);
  backdrop-filter: blur(12px);
}
.search-box {
  width: 100%;
  padding: 9px 12px;
  border: 1px solid var(--borde);
  border-radius: 11px;
  background: rgba(61,31,110,.44);
  color: var(--blanco);
  font-size: .76rem;
  outline: none;
}
.search-box::placeholder { color: var(--blanco-56); }
.search-box:focus { border-color: var(--nebulosa-clara); box-shadow: 0 0 0 3px rgba(196,128,217,.14); }
.filter-list { display: flex; gap: 6px; flex-wrap: wrap; }
.filter-button {
  border: 1px solid var(--borde);
  border-radius: 999px;
  padding: 5px 9px;
  background: rgba(61,31,110,.45);
  color: var(--lila);
  font-size: .66rem;
  font-weight: 700;
  transition: all .18s ease;
}
.filter-button:hover,
.filter-button.is-active { border-color: var(--magenta); background: rgba(204,0,112,.22); color: var(--blanco); }

.agenda-summary { display: flex; justify-content: space-between; gap: 12px; margin-bottom: 8px; color: var(--blanco-76); font-size: .72rem; }
.event-list { display: grid; gap: 9px; padding-bottom: 52px; }
.event-card {
  display: grid;
  grid-template-columns: 160px minmax(0, 1fr) 205px;
  gap: 0;
  min-height: 182px;
  overflow: hidden;
  border: 1px solid var(--borde);
  border-radius: 34px;
  background: linear-gradient(150deg, rgba(58, 29, 111, .98), rgba(48, 23, 94, .98));
  box-shadow: var(--sombra);
}
.event-card--featured { border-color: rgba(255,200,50,.68); box-shadow: 0 16px 40px rgba(255,200,50,.10); }

.event-card__date {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-width: 0;
  padding: 16px 16px 14px;
  text-align: center;
  border-right: 1px solid rgba(196,128,217,.18);
}
.event-card__weekday { margin-bottom: 2px; color: var(--dorado); font-size: .73rem; text-transform: lowercase; }
.event-card__day { display: block; color: var(--blanco); font-size: 3.55rem; font-weight: 700; line-height: .95; letter-spacing: -.075em; }
.event-card__month { display: block; margin-top: 3px; color: var(--nebulosa-clara); font-size: .88rem; font-weight: 700; letter-spacing: .04em; text-transform: uppercase; }
.event-card__year { display: block; color: var(--blanco); font-size: .78rem; line-height: 1.1; }

.event-card__content { min-width: 0; padding: 11px 18px 10px 26px; }
.event-card__topline { display: flex; align-items: center; gap: 12px; min-height: 28px; margin-bottom: 5px; }
.event-card__status {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 150px;
  padding: 3px 12px;
  border-radius: 999px;
  background: rgba(204,0,112,.30);
  color: var(--dorado-suave);
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .05em;
  text-transform: uppercase;
}
.event-card__status--past { background: rgba(255,255,255,.08); color: var(--blanco-56); }
.event-card__status--today { background: rgba(255,200,50,.18); color: var(--dorado); }
.event-card__status--soon { background: rgba(204,0,112,.38); color: var(--dorado-suave); }

.event-card__actions { display: flex; align-items: center; gap: 7px; }
.event-action {
  display: grid;
  place-items: center;
  width: 40px;
  height: 30px;
  border: 1px solid rgba(196,128,217,.14);
  border-radius: 999px;
  background: rgba(135,61,153,.34);
  color: var(--lila);
  font-size: 1.05rem;
  text-decoration: none;
  transition: border-color .16s ease, color .16s ease, background .16s ease, transform .16s ease;
}
.event-action:hover { transform: translateY(-1px); border-color: var(--nebulosa-clara); background: rgba(135,61,153,.55); color: var(--dorado); }

.event-card__title {
  margin: 0 0 2px;
  color: var(--blanco);
  font-size: clamp(1.04rem, 2vw, 1.48rem);
  line-height: 1.14;
  letter-spacing: -.025em;
}
.event-card__description {
  display: -webkit-box;
  max-width: 930px;
  margin: 0 0 8px;
  overflow: hidden;
  color: var(--blanco-76);
  font-size: .83rem;
  line-height: 1.22;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 1;
}
.event-card__meta { display: flex; flex-wrap: wrap; align-items: center; gap: 5px 8px; }
.event-meta {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  max-width: 100%;
  min-height: 24px;
  padding: 2px 10px;
  border: 1px solid rgba(204,0,112,.56);
  border-radius: 999px;
  background: rgba(18,8,42,.46);
  color: var(--nebulosa-clara);
  font-size: .74rem;
  line-height: 1.1;
}
.event-meta i { flex: 0 0 auto; color: var(--dorado); font-size: .92rem; }
.event-meta span { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.event-meta--place { max-width: min(430px, 48vw); }
.event-meta--type { max-width: min(620px, 68vw); }
.event-meta--range { max-width: min(350px, 46vw); }
.event-card__note { margin: 8px 0 0; padding: 6px 9px; border-left: 2px solid var(--dorado); background: rgba(255,200,50,.08); color: var(--dorado-suave); font-size: .68rem; }

.event-card__visual {
  position: relative;
  display: grid;
  place-items: center;
  min-height: 100%;
  padding: 15px;
  overflow: hidden;
  border-left: 1px solid rgba(196,128,217,.16);
  background:
    radial-gradient(circle at 18% 20%, rgba(255,200,50,.34), transparent 18%),
    radial-gradient(circle at 82% 74%, rgba(204,0,112,.44), transparent 26%),
    linear-gradient(140deg, rgba(135,61,153,.92), rgba(18,8,42,.98));
}
.event-card__visual::before,
.event-card__visual::after {
  content: '';
  position: absolute;
  border-radius: 50%;
  pointer-events: none;
}
.event-card__visual::before { width: 150px; height: 52px; border: 1px solid rgba(255,200,50,.42); transform: rotate(-24deg); }
.event-card__visual::after { width: 8px; height: 8px; background: var(--dorado); box-shadow: 42px -36px 0 rgba(255,255,255,.72), -48px 31px 0 rgba(196,128,217,.72); }
.event-card__visual--cine { background: radial-gradient(circle at 72% 28%, rgba(77,144,208,.52), transparent 26%), linear-gradient(140deg, rgba(61,31,110,.98), rgba(18,8,42,.98)); }
.event-card__visual--fiestas { background: radial-gradient(circle at 72% 24%, rgba(204,0,112,.60), transparent 30%), linear-gradient(140deg, rgba(135,61,153,.98), rgba(18,8,42,.98)); }
.event-card__visual--marcha { background: radial-gradient(circle at 60% 25%, rgba(255,200,50,.52), transparent 50%), linear-gradient(140deg, rgba(204,0,112,.82), rgba(18,8,42,.98)); }
.event-card__visual--bienestar { background: radial-gradient(circle at 70% 22%, rgba(77,144,208,.54), transparent 30%), linear-gradient(140deg, rgba(135,61,153,.90), rgba(18,8,42,.98)); }
.event-card__image {
  position: relative;
  z-index: 2;
  width: 100%;
  aspect-ratio: 1 / 1;
  border: 1px solid rgba(245,238,248,.76);
  border-radius: 24px;
  object-fit: cover;
  box-shadow: 0 12px 24px rgba(0,0,0,.22);
}
.event-card__fallback { position: absolute; z-index: 1; display: grid; place-items: center; color: rgba(251, 255, 44, 0.78); font-size: 2.5rem; }
.event-card__visual:not(.is-fallback) .event-card__fallback { opacity: 0; }

.empty-state { padding: 28px 16px; border: 1px dashed var(--borde); border-radius: 18px; color: var(--blanco-76); text-align: center; }
.loading { padding: 24px; color: var(--nebulosa-clara); text-align: center; }

@media (max-width: 980px) {
  .toolbar { grid-template-columns: 1fr; }
  .event-card { grid-template-columns: 118px minmax(0, 1fr) 162px; min-height: 154px; border-radius: 26px; }
  .event-card__date { padding-inline: 10px; }
  .event-card__day { font-size: 2.9rem; }
  .event-card__content { padding: 10px 12px 9px 16px; }
  .event-card__visual { padding: 10px; }
  .event-card__image { border-radius: 18px; }
  .event-action { width: 33px; height: 27px; font-size: .92rem; }
  .event-card__status { min-width: 112px; padding-inline: 9px; font-size: .62rem; }
  .event-meta { font-size: .66rem; min-height: 21px; padding-inline: 8px; }
  .event-meta--place { max-width: min(270px, 44vw); }
  .event-meta--type { max-width: min(420px, 56vw); }
}

@media (max-width: 660px) {
  .shell-wide { width: min(100% - 12px, 660px); }
  .site-header__inner { min-height: 46px; }
  .brand-mini img { width: 22px; height: 29px; }
  .brand-mini span { font-size: .78rem; }
  .header-link { font-size: .67rem; }
  .agenda-top { padding: 12px 3px 0; }
  .agenda-top .back-link,
  .agenda-top__intro > p:not(.hero__eyebrow) { display: none; }
  .agenda-top .hero__eyebrow { margin: 0 0 2px; font-size: .54rem; }
  .agenda-top h1 { margin: 0; font-size: 1.58rem; line-height: 1; }
  .agenda-top h1 br { display: none; }
  .toolbar { gap: 7px; margin: 8px 0 8px; padding: 6px; border-radius: 12px; }
  .search-box { padding: 7px 9px; border-radius: 9px; font-size: .66rem; }
  .filter-list { flex-wrap: nowrap; gap: 5px; overflow-x: auto; scrollbar-width: none; }
  .filter-list::-webkit-scrollbar { display: none; }
  .filter-button { flex: 0 0 auto; padding: 4px 7px; font-size: .58rem; }
  .agenda-summary { margin-bottom: 5px; padding: 0 2px; font-size: .62rem; }
  .event-list { gap: 6px; }

  .event-card {
    grid-template-columns: 56px minmax(0, 1fr) 78px;
    min-height: 100px;
    border-radius: 19px;
  }
  .event-card__date { justify-content: center; padding: 7px 4px; border-right-color: rgba(196,128,217,.18); }
  .event-card__weekday { display: none; }
  .event-card__day { font-size: 2rem; line-height: .9; }
  .event-card__month { margin-top: 4px; font-size: .62rem; line-height: 1; }
  .event-card__year { margin-top: 2px; font-size: .57rem; }
  .event-card__content { padding: 5px 5px 5px 8px; overflow: hidden; }
  .event-card__topline { gap: 4px; min-height: 22px; margin-bottom: 2px; }
  .event-card__status { min-width: auto; padding: 2px 6px; font-size: .49rem; line-height: 1.1; letter-spacing: .04em; white-space: nowrap; }
  .event-card__actions { gap: 3px; margin-left: auto; }
  .event-action { width: 21px; height: 20px; border-radius: 999px; font-size: .67rem; }
  .event-card__title {
    display: -webkit-box;
    margin-bottom: 3px;
    overflow: hidden;
    font-size: .75rem;
    line-height: 1.08;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
  }
  .event-card__description,
  .event-card__note,
  .event-meta--type,
  .event-meta--range { display: none; }
  .event-card__meta { flex-wrap: nowrap; gap: 3px; overflow: hidden; }
  .event-meta { gap: 3px; min-height: 17px; padding: 1px 5px; font-size: .52rem; white-space: nowrap; }
  .event-meta i { font-size: .62rem; }
  .event-meta--time { flex: 0 0 auto; }
  .event-meta--place { max-width: 92px; }
  .event-meta--entry { max-width: 88px; }
  .event-card__visual { min-height: 100%; padding: 5px; }
  .event-card__image { border-radius: 13px; }
  .event-card__visual::before { width: 70px; height: 24px; }
  .event-card__visual::after { width: 5px; height: 5px; box-shadow: 20px -16px 0 rgba(255,255,255,.72), -22px 15px 0 rgba(196,128,217,.72); }
  .event-card__fallback { font-size: 1.45rem; }
  .footer { padding-top: 16px; }
}

@media (max-width: 390px) {
  .event-card { grid-template-columns: 52px minmax(0, 1fr) 70px; min-height: 94px; }
  .event-card__day { font-size: 1.82rem; }
  .event-card__content { padding-left: 6px; }
  .event-action { width: 19px; height: 19px; font-size: .61rem; }
  .event-card__status { padding-inline: 5px; font-size: .45rem; }
  .event-card__title { font-size: .70rem; }
  .event-meta { font-size: .48rem; }
  .event-meta--place { max-width: 76px; }
  .event-meta--entry { max-width: 68px; }
}


/* === Agenda v3 · divulgación progresiva === */
.event-card {
  grid-template-columns: 126px minmax(0, 1fr) 176px;
  min-height: 126px;
  border-radius: 28px;
  cursor: pointer;
  transition: min-height .24s ease, border-color .2s ease, box-shadow .2s ease, transform .2s ease;
}
.event-card:hover { transform: translateY(-1px); }
.event-card:focus-visible { outline: 2px solid var(--dorado); outline-offset: 3px; }
.event-card.is-expanded { min-height: 268px; }

.event-card__date {
  justify-content: center;
  padding: 12px 10px;
}
.event-card__weekday { margin-bottom: 2px; font-size: .72rem; }
.event-card__day { font-size: 3.18rem; }
.event-card__month { margin-top: 4px; font-size: .82rem; }
.event-card__year { margin-top: 1px; font-size: .74rem; }

.event-card__content {
  align-self: stretch;
  padding: 11px 16px 10px 18px;
}
.event-card__topline {
  flex-wrap: wrap;
  gap: 6px 10px;
  min-height: 24px;
  margin-bottom: 5px;
}
.event-card__status {
  min-width: 0;
  padding: 3px 12px;
  font-size: .64rem;
}
.event-card__status--featured {
  background: rgba(255,200,50,.16);
  color: var(--dorado);
  border: 1px solid rgba(255,200,50,.24);
}

.event-card__organizers {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 5px;
}
.organizer-chip {
  display: inline-flex;
  align-items: center;
  max-width: 175px;
  min-height: 20px;
  padding: 2px 10px;
  overflow: hidden;
  border: 1px solid rgba(77,144,208,.26);
  border-radius: 999px;
  background: rgba(18,8,42,.58);
  color: var(--azul-estelar);
  font-size: .65rem;
  line-height: 1.15;
  text-decoration: none;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.organizer-chip:hover {
  border-color: var(--azul-estelar);
  color: var(--blanco);
}
.organizer-chip--more {
  border-color: rgba(196,128,217,.22);
  color: var(--nebulosa-clara);
}
.event-card__organizers--expanded {
  display: none;
  margin: 3px 0 7px;
}
.event-card.is-expanded .event-card__organizers--compact:has(.organizer-chip--more) {
  display: none;
}
.event-card.is-expanded .event-card__organizers--expanded {
  display: flex;
}

.event-card__title {
  margin-bottom: 3px;
  font-size: clamp(1rem, 2vw, 1.34rem);
}
.event-card__description {
  display: -webkit-box;
  margin: 0;
  overflow: hidden;
  font-size: .82rem;
  line-height: 1.28;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}
.event-card.is-expanded .event-card__description {
  display: block;
  margin-bottom: 9px;
  overflow: visible;
}

.event-card__expanded { display: none; }
.event-card.is-expanded .event-card__expanded { display: block; }

.event-card__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 5px 7px;
  margin-bottom: 7px;
}
.event-meta {
  min-height: 23px;
  padding: 2px 9px;
  font-size: .71rem;
}
.event-meta--place { max-width: min(520px, 62vw); }
.event-meta--range { max-width: min(350px, 52vw); }

.event-card__tags {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  margin-bottom: 8px;
}
.event-tag {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  min-height: 21px;
  padding: 2px 9px;
  border: 1px solid rgba(204,0,112,.44);
  border-radius: 999px;
  background: rgba(18,8,42,.40);
  color: var(--nebulosa-clara);
  font-size: .67rem;
}
.event-tag i { color: var(--dorado); font-size: .72rem; }

.event-card__actions {
  display: flex;
  gap: 7px;
}
.event-action {
  width: 36px;
  height: 30px;
  font-size: .96rem;
}

.event-card__visual {
  display: grid;
  place-items: start center;
  min-height: 100%;
  padding: 10px;
  border: 0;
  border-left: 1px solid rgba(196,128,217,.16);
  cursor: zoom-in;
}
.event-card__image {
  width: 100%;
  aspect-ratio: 1 / 1;
  border-radius: 18px;
}
.event-card__fallback {
  inset: 0;
  margin: auto;
  pointer-events: none;
}

.poster-lightbox[hidden] { display: none; }
.poster-lightbox {
  position: fixed;
  inset: 0;
  z-index: 1000;
  display: grid;
  place-items: center;
  padding: 18px;
}
.poster-lightbox__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(18,8,42,.86);
  backdrop-filter: blur(8px);
}
.poster-lightbox__panel {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 10px;
  width: min(92vw, 720px);
  max-height: 92vh;
  padding: 12px;
  border: 1px solid rgba(196,128,217,.38);
  border-radius: 22px;
  background: var(--cosmos-dark);
  box-shadow: 0 20px 70px rgba(0,0,0,.52);
}
.poster-lightbox__image {
  width: 100%;
  max-height: calc(92vh - 78px);
  border-radius: 14px;
  object-fit: contain;
}
.poster-lightbox__close {
  position: absolute;
  top: 18px;
  right: 18px;
  display: grid;
  place-items: center;
  width: 38px;
  height: 38px;
  border: 1px solid rgba(245,238,248,.32);
  border-radius: 999px;
  background: rgba(18,8,42,.82);
  color: var(--blanco);
  cursor: pointer;
}
.poster-lightbox__source {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  color: var(--dorado);
  font-size: .76rem;
  text-decoration: none;
}
.is-lightbox-open { overflow: hidden; }

@media (max-width: 980px) {
  .event-card {
    grid-template-columns: 106px minmax(0, 1fr) 148px;
    min-height: 132px;
  }
  .event-card.is-expanded { min-height: 270px; }
  .event-card__day { font-size: 2.76rem; }
  .event-card__content { padding: 10px 12px 9px 14px; }
  .event-card__visual { padding: 9px; }
}

@media (max-width: 660px) {
  .event-list { gap: 8px; }

  .event-card {
    grid-template-columns: 74px minmax(0, 1fr) 94px;
    min-height: 128px;
    border-radius: 20px;
  }
  .event-card.is-expanded {
    min-height: 272px;
  }
  .event-card__date {
    justify-content: flex-start;
    padding: 9px 5px;
  }
  .event-card__weekday {
    display: block;
    margin-bottom: 4px;
    font-size: .56rem;
  }
  .event-card__day {
    font-size: 2.25rem;
    line-height: .92;
  }
  .event-card__month {
    margin-top: 5px;
    font-size: .62rem;
  }
  .event-card__year {
    margin-top: 2px;
    font-size: .57rem;
  }
  .event-card__content {
    padding: 7px 7px 7px 9px;
  }
  .event-card__topline {
    gap: 4px;
    min-height: auto;
    margin-bottom: 4px;
  }
  .event-card__status {
    padding: 2px 7px;
    font-size: .49rem;
  }
  .event-card__organizers {
    gap: 3px;
  }
  .organizer-chip {
    max-width: 98px;
    min-height: 17px;
    padding: 1px 6px;
    font-size: .50rem;
  }
  .event-card__title {
    margin-bottom: 3px;
    font-size: .79rem;
    line-height: 1.08;
  }
  .event-card__description {
    font-size: .64rem;
    line-height: 1.2;
    -webkit-line-clamp: 3;
  }
  .event-card.is-expanded .event-card__description {
    margin-bottom: 7px;
  }
  .event-meta {
    min-height: 19px;
    padding: 1px 6px;
    font-size: .54rem;
  }
  .event-meta i {
    font-size: .64rem;
  }
  .event-meta--place,
  .event-meta--range {
    max-width: 100%;
  }
  .event-tag {
    min-height: 18px;
    padding: 1px 6px;
    font-size: .52rem;
  }
  .event-action {
    width: 27px;
    height: 24px;
    font-size: .73rem;
  }
  .event-card__visual {
    min-height: 100%;
    padding: 5px;
  }
  .event-card__image {
    border-radius: 13px;
  }
}

@media (max-width: 390px) {
  .event-card {
    grid-template-columns: 68px minmax(0, 1fr) 84px;
    min-height: 124px;
  }
  .event-card__day { font-size: 2.08rem; }
  .event-card__title { font-size: .74rem; }
  .event-card__description {
    font-size: .60rem;
    -webkit-line-clamp: 2;
  }
  .organizer-chip { max-width: 84px; }
}

/* Ajustar automáticamente la altura de las tarjetas según su contenido */
.event-card,
.event-card.is-expanded {
  height: auto;
  min-height: auto;
}

.event-card__visual {
  min-height: 0;
}

/* === Agenda v4 · badges compactos adaptativos === */
.event-card__content {
  position: relative;
}

.event-card__compact-badges {
  position: absolute;
  right: 16px;
  bottom: 10px;
  left: 18px;
  display: flex;
  flex-wrap: wrap;
  gap: 5px 7px;
  overflow: hidden;
  pointer-events: none;
}

.event-card.is-expanded .event-card__compact-badges {
  display: none;
}

.event-card__compact-badge.is-overflowing {
  display: none !important;
}

@media (max-width: 980px) {
  .event-card__compact-badges {
    right: 12px;
    bottom: 9px;
    left: 14px;
  }
}

@media (max-width: 660px) {
  .event-card__compact-badges {
    right: 7px;
    bottom: 7px;
    left: 9px;
    gap: 3px;
  }

  .event-card__compact-badges .event-meta,
  .event-card__compact-badges .event-tag {
    min-height: 17px;
    padding: 1px 5px;
    font-size: .50rem;
  }

  .event-card__compact-badges .event-meta i,
  .event-card__compact-badges .event-tag i {
    font-size: .60rem;
  }

  .event-card__compact-badges .event-meta--place {
    max-width: 118px;
  }

  .event-card__compact-badges .event-meta--entry {
    max-width: 96px;
  }

  .event-card__compact-badges .event-meta--range {
    max-width: 110px;
  }
}

@media (max-width: 390px) {
  .event-card__compact-badges .event-meta--place {
    max-width: 96px;
  }

  .event-card__compact-badges .event-meta--entry {
    max-width: 82px;
  }
}
