#live {
  padding: clamp(80px,12vh,140px) clamp(18px,5vw,56px);
  background: var(--bg);
  overflow: hidden;
}
.live-inner {
  max-width: 1200px;
  margin: 0 auto;
}

/* ── FESTIVAL TILES ── */
.festival-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
}
@media(max-width:640px) {
  .festival-grid { grid-template-columns: 1fr; }
}

.festival-tile {
  background: var(--bg2);
  border: 1px solid transparent;
  overflow: hidden;
  position: relative;
  cursor: pointer;
  transition: border-color .2s, transform .2s;
}
.festival-tile:hover {
  border-color: rgba(191,28,18,.35);
  transform: translate(-2px,-2px);
}
.festival-tile::before {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(191,28,18,.08) 0%, transparent 60%);
  opacity: 0;
  transition: opacity .2s;
  pointer-events: none;
  z-index: 0;
}
.festival-tile:hover::before { opacity: 1; }

.festival-tile-img {
  width: 100%;
  aspect-ratio: 16/9;
  overflow: hidden;
  background: var(--bg3);
  position: relative;
  opacity: .7;
  transition: opacity .2s;
  cursor: pointer;
}
.festival-tile:hover .festival-tile-img { opacity: 1; }
.festival-tile-img img {
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: center top;
  display: block;
  transition: transform .4s;
}
.festival-tile:hover .festival-tile-img img { transform: scale(1.03); }
.festival-tile-fallback {
  width: 100%; height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-d);
  font-size: clamp(18px,3vw,32px);
  letter-spacing: .2em;
  color: var(--fg-off);
  text-align: center;
  position: absolute; inset: 0;
}

.festival-tile-body {
  padding: 20px 24px;
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: nowrap;
  position: relative;
  z-index: 1;
  border-top: 1px solid rgba(191,28,18,.15);
}

.festival-tile-label {
  font-family: var(--font-s);
  font-size: 10px;
  letter-spacing: .4em;
  color: var(--red);
  text-transform: uppercase;
  display: flex;
  align-items: center;
  gap: 6px;
  flex-shrink: 0;
}
.festival-tile-label::before { content: '//'; opacity: .5; }
.festival-tile-title {
  font-family: var(--font-b);
  font-size: clamp(15px,1.8vw,20px);
  font-weight: 700;
  color: var(--fg);
  letter-spacing: .05em;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  min-width: 0;
}
.festival-tile-meta {
  font-family: var(--font-s);
  font-size: 10px;
  letter-spacing: .3em;
  color: var(--fg-off);
  text-transform: uppercase;
}
.festival-gallery-btn {
  margin-left: auto;
  font-family: var(--font-s);
  font-size: 10px;
  letter-spacing: .3em;
  color: var(--red);
  text-transform: uppercase;
  background: none;
  border: 1px solid rgba(191,28,18,.35);
  padding: 8px 16px;
  cursor: pointer;
  transition: background .15s, color .15s;
  white-space: nowrap;
  flex-shrink: 0;
}
.festival-gallery-btn:hover {
  background: var(--red);
  color: var(--bg);
}

/* ── LIVE SHOW INFINITE SCROLL ── */
.live-scroll-wrap {
  display: flex;
  flex-direction: column;
  gap: 20px;
  overflow: hidden;
}

.live-scroll-row {
  overflow: hidden;
  width: 100%;
}

.live-scroll-track {
  display: flex;
  gap: 20px;
  width: max-content;
  animation: scrollLeft 30s linear infinite;
}

.live-scroll-row.reverse .live-scroll-track {
  animation: scrollRight 30s linear infinite;
}

.live-scroll-row:hover .live-scroll-track {
  animation-play-state: paused;
}

@keyframes scrollLeft {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

@keyframes scrollRight {
  0%   { transform: translateX(-50%); }
  100% { transform: translateX(0); }
}

.live-card {
  flex: 0 0 300px;
  min-width: 0;
  background: var(--bg2);
  border: 1px solid transparent;
  position: relative;
  transition: border-color .2s, transform .2s, background .2s;
  overflow: hidden;
  cursor: pointer;
}
.live-card:hover {
  border-color: rgba(191,28,18,.35);
  transform: translateY(-4px);
  background: var(--bg3);
}
.live-card::before {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(191,28,18,.08) 0%, transparent 60%);
  opacity: 0;
  transition: opacity .2s;
  pointer-events: none;
  z-index: 0;
}
.live-card:hover::before { opacity: 1; }

.live-img-wrap {
  width: 100%;
  aspect-ratio: 1;
  overflow: hidden;
  background: var(--bg3);
  border-bottom: 1px solid var(--fg-off);
  position: relative;
  opacity: .65;
  transition: opacity .2s;
}
.live-card:hover .live-img-wrap { opacity: 1; }
.live-img-wrap img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
  filter: grayscale(40%) contrast(1.1) brightness(.85);
  transition: transform .4s;
}
.live-card:hover .live-img-wrap img { transform: scale(1.04); }
.live-img-fallback {
  width: 100%; height: 100%;
  display: none;
  align-items: center;
  justify-content: center;
  font-family: var(--font-d);
  font-size: clamp(14px,2vw,20px);
  letter-spacing: .2em;
  color: var(--fg-off);
  text-align: center;
  padding: 16px;
  position: absolute; inset: 0;
}
.live-body {
  padding: 20px 22px;
  position: relative;
  z-index: 1;
}
.live-outlet {
  font-family: var(--font-s);
  font-size: 10px;
  letter-spacing: .4em;
  color: var(--red);
  text-transform: uppercase;
  margin-bottom: 10px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.live-outlet::before { content: '//'; opacity: .5; }
.live-title {
  font-family: var(--font-b);
  font-size: clamp(14px,1.5vw,17px);
  font-weight: 700;
  color: var(--fg);
  line-height: 1.3;
  margin-bottom: 8px;
}
.live-meta {
  font-family: var(--font-s);
  font-size: 10px;
  letter-spacing: .25em;
  color: var(--fg-off);
  text-transform: uppercase;
}
.live-arrow {
  position: absolute;
  bottom: 18px; right: 18px;
  font-size: 16px;
  color: var(--red);
  opacity: 0;
  transform: translateX(-6px);
  transition: opacity .2s, transform .2s;
}
.live-card:hover .live-arrow { opacity: 1; transform: translateX(0); }

/* ── SHOW MODAL ── */
.show-modal {
  display: none;
  position: fixed; inset: 0;
  background: rgba(8,6,4,.92);
  z-index: 900;
  align-items: center;
  justify-content: center;
}
.show-modal.active {
  display: flex;
  animation: fadeIn .25s ease forwards;
}
@keyframes fadeIn {
  from { opacity: 0; }
  to   { opacity: 1; }
}
.show-modal-inner {
  background: var(--bg2);
  border: 1px solid rgba(191,28,18,.25);
  width: min(900px, 92vw);
  max-height: 85vh;
  overflow-y: auto;
  padding: clamp(24px,4vw,48px);
  position: relative;
  animation: slideUp .3s ease forwards;
}
@keyframes slideUp {
  from { opacity: 0; transform: translateY(24px); }
  to   { opacity: 1; transform: translateY(0); }
}
.show-modal-close {
  position: absolute;
  top: 20px; right: 20px;
  background: none;
  border: 1px solid rgba(191,28,18,.4);
  color: var(--fg);
  font-size: 16px;
  width: 36px; height: 36px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background .15s;
}
.show-modal-close:hover { background: var(--red); border-color: var(--red); }
.show-modal-title {
  font-family: var(--font-d);
  font-size: clamp(28px,4vw,48px);
  letter-spacing: .06em;
  color: var(--fg);
  margin-bottom: 32px;
  padding-right: 48px;
}
.show-modal-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px,1fr));
  gap: 8px;
}
.show-modal-grid .grid-photo {
  aspect-ratio: 4/3;
  overflow: hidden;
  cursor: pointer;
  background: var(--bg3);
  position: relative;
}
.show-modal-grid .grid-photo img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
  filter: grayscale(20%) brightness(.9);
  transition: transform .3s, filter .3s;
}
.show-modal-grid .grid-photo:hover img {
  transform: scale(1.04);
  filter: grayscale(0) brightness(1);
}
.show-modal-grid .grid-photo.placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px dashed var(--fg-off);
}
.show-modal-grid .grid-photo.placeholder span {
  font-family: var(--font-s);
  font-size: 10px;
  letter-spacing: .3em;
  color: var(--fg-off);
  text-transform: uppercase;
}

/* ── LIGHTBOX ── */
.lightbox {
  display: none;
  position: fixed; inset: 0;
  background: rgba(8,6,4,.97);
  z-index: 1000;
  align-items: center;
  justify-content: center;
}
.lightbox.active { display: flex; }
.lightbox-inner {
  max-width: 90vw;
  max-height: 90vh;
}
.lightbox-img {
  max-width: 90vw;
  max-height: 90vh;
  object-fit: contain;
  display: block;
}
.lightbox-close {
  position: fixed;
  top: 24px; right: 32px;
  background: none;
  border: 1px solid rgba(191,28,18,.4);
  color: var(--fg);
  font-size: 18px;
  width: 40px; height: 40px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background .15s;
}

/* ── LIGHTBOX FILMSTRIP ── */
.lightbox-filmstrip {
  position: fixed;
  bottom: 24px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  gap: 8px;
  z-index: 1001;
  max-width: 90vw;
  overflow-x: auto;
  padding: 8px;
  background: rgba(8,6,4,.6);
  backdrop-filter: blur(8px);
  scrollbar-width: none;
}
.lightbox-filmstrip::-webkit-scrollbar { display: none; }
.lightbox-filmstrip-thumb {
  width: 56px;
  height: 56px;
  flex-shrink: 0;
  object-fit: cover;
  opacity: .45;
  cursor: pointer;
  border: 2px solid transparent;
  transition: opacity .2s, border-color .2s;
}
.lightbox-filmstrip-thumb:hover {
  opacity: .8;
}
.lightbox-filmstrip-thumb.active {
  opacity: 1;
  border-color: var(--red);
}
.lightbox-close:hover { background: var(--red); border-color: var(--red); }
.lightbox-prev,
.lightbox-next {
  position: fixed;
  top: 50%; transform: translateY(-50%);
  background: rgba(8,6,4,.65);
  border: 1px solid rgba(191,28,18,.35);
  color: var(--fg);
  font-size: 20px;
  width: 44px; height: 44px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background .15s;
}
.lightbox-prev { left: 20px; }
.lightbox-next { right: 20px; }
.lightbox-prev:hover,
.lightbox-next:hover { background: var(--red); border-color: var(--red); }
