/* ============================================================
   Galería Toros del Valle — V2 (Bento + Lightbox cinema)
   Reglas con alta especificidad + reset de botón para resistir
   los estilos de cualquier theme/Elementor.
   ============================================================ */

.tdv-gallery {
  --toros-red: #D4202E;
  --toros-red-deep: #A0151E;
  --tdv-ink: #111315;
  --tdv-ink-2: rgba(255,255,255,0.06);
  --tdv-text: inherit;
  --tdv-muted: rgba(255,255,255,0.55);
  --tdv-hairline: rgba(255,255,255,0.12);

  font-family: 'Inter', -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;
  color: var(--tdv-text);
  background: transparent;
  padding: 48px 0 56px;
  -webkit-font-smoothing: antialiased;
}
.tdv-gallery *, .tdv-gallery *::before, .tdv-gallery *::after { box-sizing: border-box; }

/* Reset de botón para que el theme no rompa width/height/padding/border */
.tdv-gallery button {
  appearance: none; -webkit-appearance: none;
  font-family: inherit; cursor: pointer;
  background: transparent; color: inherit;
  border: 0; margin: 0; padding: 0;
  text-align: left; line-height: 1.2;
}

/* Header */
.tdv-gallery .tdv-head {
  max-width: 1280px; margin: 0 auto 24px;
  display: flex; justify-content: space-between; align-items: flex-end;
  gap: 24px; padding: 0 16px;
}
.tdv-gallery .tdv-kicker {
  display: inline-flex; align-items: center; gap: 10px;
  font-size: 11px; letter-spacing: 0.18em; font-weight: 700;
  color: var(--toros-red);
  text-transform: uppercase;
}
.tdv-gallery .tdv-kicker-mark { display: inline-block; width: 22px; height: 2px; background: var(--toros-red); }
.tdv-gallery .tdv-title {
  margin: 12px 0 0;
  font-family: 'Archivo Black', 'Inter', sans-serif;
  font-size: 56px; line-height: 0.92; letter-spacing: -0.035em;
  color: inherit; font-weight: 900;
  text-transform: uppercase;
}
.tdv-gallery .tdv-title-line { display: block; }
.tdv-gallery .tdv-title-accent { color: var(--toros-red); font-style: italic; }

.tdv-gallery .tdv-score {
  display: flex; align-items: center; gap: 18px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  padding: 12px 20px; border-radius: 4px;
  flex-shrink: 0;
}
.tdv-gallery .tdv-score-team { display: flex; align-items: center; gap: 12px; }
.tdv-gallery .tdv-score-team-away { flex-direction: row-reverse; }
.tdv-gallery .tdv-score-label {
  font-size: 10px; letter-spacing: 0.18em; font-weight: 700;
  color: rgba(255,255,255,0.55);
}
.tdv-gallery .tdv-score-num {
  font-family: 'Archivo Black', sans-serif;
  font-size: 36px; line-height: 1; font-variant-numeric: tabular-nums;
  color: #fff;
}
.tdv-gallery .tdv-score-team:first-child .tdv-score-num { color: var(--toros-red); }
.tdv-gallery .tdv-score-sep { color: rgba(255,255,255,0.3); font-size: 22px; }

/* Grid bento */
.tdv-gallery .tdv-grid {
  max-width: 1280px; margin: 0 auto;
  display: grid; gap: 8px;
  grid-template-columns: repeat(12, 1fr);
  grid-auto-rows: 110px;
  grid-auto-flow: dense;
  padding: 0 16px;
}

/* Variant 1 — Hero izquierda (default histórico) */
.tdv-gallery .tdv-grid--v1 .tdv-cell:nth-child(1) { grid-column: span 6; grid-row: span 4; }
.tdv-gallery .tdv-grid--v1 .tdv-cell:nth-child(2) { grid-column: span 3; grid-row: span 2; }
.tdv-gallery .tdv-grid--v1 .tdv-cell:nth-child(3) { grid-column: span 3; grid-row: span 2; }
.tdv-gallery .tdv-grid--v1 .tdv-cell:nth-child(4) { grid-column: span 3; grid-row: span 2; }
.tdv-gallery .tdv-grid--v1 .tdv-cell:nth-child(5) { grid-column: span 3; grid-row: span 5; }
.tdv-gallery .tdv-grid--v1 .tdv-cell:nth-child(6) { grid-column: span 3; grid-row: span 3; }
.tdv-gallery .tdv-grid--v1 .tdv-cell:nth-child(7) { grid-column: span 6; grid-row: span 2; }
.tdv-gallery .tdv-grid--v1 .tdv-cell:nth-child(8) { grid-column: span 3; grid-row: span 4; }

/* Variant 2 — Hero derecha + columna alta izquierda */
.tdv-gallery .tdv-grid--v2 .tdv-cell:nth-child(1) { grid-column: 7 / span 6; grid-row: 1 / span 4; }
.tdv-gallery .tdv-grid--v2 .tdv-cell:nth-child(2) { grid-column: 1 / span 3; grid-row: 1 / span 2; }
.tdv-gallery .tdv-grid--v2 .tdv-cell:nth-child(3) { grid-column: 4 / span 3; grid-row: 1 / span 2; }
.tdv-gallery .tdv-grid--v2 .tdv-cell:nth-child(4) { grid-column: 1 / span 3; grid-row: 3 / span 4; }
.tdv-gallery .tdv-grid--v2 .tdv-cell:nth-child(5) { grid-column: 4 / span 3; grid-row: 3 / span 2; }
.tdv-gallery .tdv-grid--v2 .tdv-cell:nth-child(6) { grid-column: 4 / span 3; grid-row: 5 / span 2; }
.tdv-gallery .tdv-grid--v2 .tdv-cell:nth-child(7) { grid-column: 7 / span 6; grid-row: 5 / span 2; }
.tdv-gallery .tdv-grid--v2 .tdv-cell:nth-child(8) { grid-column: 1 / span 12; grid-row: 7 / span 2; }

/* Variant 3 — Mosaico centrado, dos heroes simétricos */
.tdv-gallery .tdv-grid--v3 .tdv-cell:nth-child(1) { grid-column: 1 / span 8; grid-row: 1 / span 3; }
.tdv-gallery .tdv-grid--v3 .tdv-cell:nth-child(2) { grid-column: 9 / span 4; grid-row: 1 / span 2; }
.tdv-gallery .tdv-grid--v3 .tdv-cell:nth-child(3) { grid-column: 9 / span 4; grid-row: 3 / span 2; }
.tdv-gallery .tdv-grid--v3 .tdv-cell:nth-child(4) { grid-column: 1 / span 4; grid-row: 4 / span 2; }
.tdv-gallery .tdv-grid--v3 .tdv-cell:nth-child(5) { grid-column: 5 / span 4; grid-row: 4 / span 2; }
.tdv-gallery .tdv-grid--v3 .tdv-cell:nth-child(6) { grid-column: 1 / span 4; grid-row: 6 / span 3; }
.tdv-gallery .tdv-grid--v3 .tdv-cell:nth-child(7) { grid-column: 5 / span 8; grid-row: 6 / span 2; }
.tdv-gallery .tdv-grid--v3 .tdv-cell:nth-child(8) { grid-column: 5 / span 8; grid-row: 8 / span 2; }

/* Variant 4 — Hero superior ancho */
.tdv-gallery .tdv-grid--v4 .tdv-cell:nth-child(1) { grid-column: 1 / span 12; grid-row: 1 / span 3; }
.tdv-gallery .tdv-grid--v4 .tdv-cell:nth-child(2) { grid-column: 1 / span 4; grid-row: 4 / span 3; }
.tdv-gallery .tdv-grid--v4 .tdv-cell:nth-child(3) { grid-column: 5 / span 4; grid-row: 4 / span 2; }
.tdv-gallery .tdv-grid--v4 .tdv-cell:nth-child(4) { grid-column: 9 / span 4; grid-row: 4 / span 2; }
.tdv-gallery .tdv-grid--v4 .tdv-cell:nth-child(5) { grid-column: 5 / span 4; grid-row: 6 / span 3; }
.tdv-gallery .tdv-grid--v4 .tdv-cell:nth-child(6) { grid-column: 9 / span 4; grid-row: 6 / span 3; }
.tdv-gallery .tdv-grid--v4 .tdv-cell:nth-child(7) { grid-column: 1 / span 6; grid-row: 7 / span 2; }
.tdv-gallery .tdv-grid--v4 .tdv-cell:nth-child(8) { grid-column: 7 / span 6; grid-row: 9 / span 2; }

/* Fallback si llega un .tdv-grid sin clase de variant */
.tdv-gallery .tdv-grid:not([class*="tdv-grid--v"]) .tdv-cell:nth-child(1) { grid-column: span 6; grid-row: span 4; }
.tdv-gallery .tdv-grid:not([class*="tdv-grid--v"]) .tdv-cell:nth-child(2) { grid-column: span 3; grid-row: span 2; }
.tdv-gallery .tdv-grid:not([class*="tdv-grid--v"]) .tdv-cell:nth-child(3) { grid-column: span 3; grid-row: span 2; }
.tdv-gallery .tdv-grid:not([class*="tdv-grid--v"]) .tdv-cell:nth-child(4) { grid-column: span 3; grid-row: span 2; }
.tdv-gallery .tdv-grid:not([class*="tdv-grid--v"]) .tdv-cell:nth-child(5) { grid-column: span 3; grid-row: span 5; }
.tdv-gallery .tdv-grid:not([class*="tdv-grid--v"]) .tdv-cell:nth-child(6) { grid-column: span 3; grid-row: span 3; }
.tdv-gallery .tdv-grid:not([class*="tdv-grid--v"]) .tdv-cell:nth-child(7) { grid-column: span 6; grid-row: span 2; }
.tdv-gallery .tdv-grid:not([class*="tdv-grid--v"]) .tdv-cell:nth-child(8) { grid-column: span 3; grid-row: span 4; }

.tdv-gallery .tdv-cell {
  position: relative;
  background: #000;
  overflow: hidden;
  border-radius: 4px;
  display: block;
  width: 100%; height: 100%;
}
.tdv-gallery .tdv-cell-img-wrap { position: absolute; inset: 0; overflow: hidden; }
.tdv-gallery .tdv-cell img {
  width: 100% !important; height: 100% !important;
  object-fit: cover; display: block;
  transition: transform .6s cubic-bezier(.2,.7,.2,1), filter .3s ease;
  filter: saturate(0.95);
  max-width: none;
}
.tdv-gallery .tdv-cell:hover img { transform: scale(1.06); filter: saturate(1.05); }
.tdv-gallery .tdv-cell-tag {
  position: absolute; top: 10px; left: 10px;
  background: var(--toros-red); color: #fff;
  font-size: 11px; font-weight: 700; letter-spacing: 0.08em;
  padding: 4px 8px; border-radius: 2px;
  font-variant-numeric: tabular-nums;
  z-index: 2; line-height: 1;
}
.tdv-gallery .tdv-cell-cta {
  position: absolute; left: 12px; right: 12px; bottom: 12px;
  display: flex; align-items: center; justify-content: space-between;
  color: #fff;
  opacity: 0; transform: translateY(8px);
  transition: opacity .25s ease, transform .25s ease;
  z-index: 2;
}
.tdv-gallery .tdv-cell:hover .tdv-cell-cta { opacity: 1; transform: translateY(0); }
.tdv-gallery .tdv-cell-cta-text {
  font-size: 12px; letter-spacing: 0.04em; font-weight: 600;
  text-shadow: 0 1px 6px rgba(0,0,0,0.4);
}
.tdv-gallery .tdv-cell-cta-arrow {
  width: 28px !important; height: 28px !important;
  aspect-ratio: 1 !important; flex: 0 0 28px !important;
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--toros-red); border-radius: 50% !important;
  font-size: 14px; font-weight: 600; color: #fff;
  line-height: 1;
}

/* Actions row — botón circular elegante */
.tdv-gallery .tdv-actions {
  max-width: 1280px; margin: 24px auto 0;
  display: flex; align-items: center; gap: 16px;
  padding: 16px 16px 0;
  border-top: 1px solid var(--tdv-hairline);
}
.tdv-gallery .tdv-action-btn {
  display: inline-flex !important; align-items: center; gap: 12px;
  background: transparent !important; color: inherit !important;
  padding: 0 !important; border-radius: 0 !important;
  font-size: 13px; font-weight: 600; letter-spacing: 0.02em;
}
.tdv-gallery .tdv-action-btn-circle {
  width: 44px !important; height: 44px !important;
  aspect-ratio: 1 !important; flex: 0 0 44px !important;
  display: inline-flex !important; align-items: center; justify-content: center;
  background: var(--toros-red) !important;
  border-radius: 50% !important;
  color: #fff !important;
  transition: background .2s ease, transform .2s ease;
  box-shadow: 0 6px 20px -4px rgba(212, 32, 46, 0.5);
}
.tdv-gallery .tdv-action-btn:hover .tdv-action-btn-circle {
  background: var(--toros-red-deep) !important;
  transform: scale(1.05);
}
.tdv-gallery .tdv-action-btn-circle svg { width: 14px; height: 14px; margin-left: 2px; }
.tdv-gallery .tdv-actions-meta { margin-left: auto; font-size: 12px; color: rgba(255,255,255,0.55); }

/* Mobile */
@media (max-width: 720px) {
  .tdv-gallery { padding: 28px 0 36px; }
  .tdv-gallery .tdv-head { flex-direction: column; align-items: flex-start; gap: 18px; margin-bottom: 22px; }
  .tdv-gallery .tdv-title { font-size: 36px; }
  .tdv-gallery .tdv-grid { grid-template-columns: repeat(6, 1fr); grid-auto-rows: 70px; }
  .tdv-gallery .tdv-grid .tdv-cell { grid-column: auto !important; grid-row: auto !important; }
  .tdv-gallery .tdv-grid .tdv-cell:nth-child(1) { grid-column: span 6 !important; grid-row: span 4 !important; }
  .tdv-gallery .tdv-grid .tdv-cell:nth-child(2) { grid-column: span 3 !important; grid-row: span 2 !important; }
  .tdv-gallery .tdv-grid .tdv-cell:nth-child(3) { grid-column: span 3 !important; grid-row: span 2 !important; }
  .tdv-gallery .tdv-grid .tdv-cell:nth-child(4) { grid-column: span 6 !important; grid-row: span 2 !important; }
  .tdv-gallery .tdv-grid .tdv-cell:nth-child(5) { grid-column: span 3 !important; grid-row: span 4 !important; }
  .tdv-gallery .tdv-grid .tdv-cell:nth-child(6) { grid-column: span 3 !important; grid-row: span 4 !important; }
  .tdv-gallery .tdv-grid .tdv-cell:nth-child(7) { grid-column: span 6 !important; grid-row: span 2 !important; }
  .tdv-gallery .tdv-grid .tdv-cell:nth-child(8) { grid-column: span 6 !important; grid-row: span 3 !important; }
}

/* ============================================================
   LIGHTBOX cinema
   ============================================================ */
.tdv-lb {
  position: fixed; inset: 0; z-index: 99999;
  display: flex; align-items: center; justify-content: center;
  background: #000;
  font-family: 'Inter', sans-serif;
  animation: tdv-lb-in .25s ease;
}
@keyframes tdv-lb-in { from { opacity: 0; } to { opacity: 1; } }

.tdv-lb-blur {
  position: absolute; inset: -40px;
  background-size: cover; background-position: center;
  filter: blur(40px) brightness(0.4) saturate(1.1);
  transform: scale(1.1);
}
.tdv-lb-overlay {
  position: absolute; inset: 0;
  background: radial-gradient(ellipse at center, rgba(0,0,0,0.2) 0%, rgba(0,0,0,0.85) 100%);
}
.tdv-lb-stage {
  position: relative; z-index: 5;
  max-width: 88vw; max-height: 78vh;
  display: flex; align-items: center; justify-content: center;
}
.tdv-lb-img {
  max-width: 88vw; max-height: 78vh;
  object-fit: contain;
  box-shadow: 0 40px 100px -20px rgba(0,0,0,0.7), 0 0 0 1px rgba(255,255,255,0.05);
  animation: tdv-img-in .35s cubic-bezier(.2,.7,.2,1);
}
@keyframes tdv-img-in {
  from { opacity: 0; transform: scale(0.97); }
  to   { opacity: 1; transform: scale(1); }
}

.tdv-lb-close, .tdv-lb-nav {
  position: absolute; z-index: 10;
  background: rgba(255,255,255,0.08) !important; color: #fff !important;
  border: 1px solid rgba(255,255,255,0.12) !important;
  width: 44px !important; height: 44px !important;
  aspect-ratio: 1 !important;
  border-radius: 50% !important;
  display: inline-flex !important; align-items: center; justify-content: center;
  font-size: 18px; cursor: pointer;
  backdrop-filter: blur(8px);
  transition: background .2s, transform .2s;
  padding: 0 !important;
  line-height: 1 !important;
}
.tdv-lb-close:hover { background: var(--toros-red, #D4202E) !important; border-color: var(--toros-red, #D4202E) !important; }
.tdv-lb-nav:hover { background: rgba(255,255,255,0.18) !important; }
.tdv-lb-close { top: 24px; right: 24px; }
.tdv-lb-nav { top: 50%; transform: translateY(-50%); font-size: 26px; }
.tdv-lb-prev { left: 24px; }
.tdv-lb-next { right: 24px; }

.tdv-lb-bottom {
  position: absolute; bottom: 0; left: 0; right: 0;
  padding: 18px 32px 22px;
  display: flex; align-items: center; gap: 20px;
  z-index: 6;
  background: linear-gradient(to top, rgba(0,0,0,0.6), transparent);
}
.tdv-lb-play {
  display: inline-flex !important; align-items: center; gap: 8px;
  background: #D4202E !important; color: #fff !important;
  padding: 9px 16px !important; border-radius: 100px !important;
  border: 0 !important;
  font-size: 12px; font-weight: 600; letter-spacing: 0.04em;
  transition: background .2s;
  line-height: 1;
}
.tdv-lb-play:hover { background: #A0151E !important; }
.tdv-lb-play.is-playing { background: rgba(255,255,255,0.12) !important; }
.tdv-lb-play-glyph {
  display: inline-block; width: 10px; height: 10px;
  background: #fff;
  clip-path: polygon(0 0, 100% 50%, 0 100%);
}
.tdv-lb-play.is-playing .tdv-lb-play-glyph {
  background: #fff;
  clip-path: polygon(0 0, 35% 0, 35% 100%, 0 100%, 65% 0, 100% 0, 100% 100%, 65% 100%);
}
.tdv-lb-counter {
  color: #fff; display: flex; align-items: baseline; gap: 4px;
  font-variant-numeric: tabular-nums;
}
.tdv-lb-counter-current { font-size: 22px; font-weight: 700; color: #D4202E; }
.tdv-lb-counter-sep { color: rgba(255,255,255,0.4); }
.tdv-lb-counter-total { font-size: 14px; color: rgba(255,255,255,0.6); }
.tdv-lb-progress {
  flex: 1; height: 2px; background: rgba(255,255,255,0.12);
  border-radius: 2px; overflow: hidden;
}
.tdv-lb-progress-bar {
  height: 100%; background: #D4202E;
  transition: width .35s ease;
}

@media (max-width: 720px) {
  .tdv-lb-close, .tdv-lb-nav { width: 40px !important; height: 40px !important; }
  .tdv-lb-prev { left: 12px; }
  .tdv-lb-next { right: 12px; }
  .tdv-lb-close { top: 14px; right: 14px; }
  .tdv-lb-bottom { padding: 14px 16px 18px; gap: 12px; }
}

body.tdv-no-scroll { overflow: hidden; }
