/*
Theme Name:  MueveTicket
Theme URI:   https://mueveticket.es
Author:      Mueve 2020 / mueveticket.es
Author URI:  https://mueveticket.es
Description: Tema oficial de MueveTicket.es — Ticketera profesional con soporte para venta propia y enlaces a plataformas externas. Gestión de eventos, categorías, entradas y cartelera completa.
Version:     1.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 8.0
License:     Propietario
Text Domain: mueveticket
Tags:        ticketera, eventos, conciertos, teatro, custom-colors, custom-logo, featured-images, full-width-template, sticky-post, translation-ready

/* ══════════════════════════════════════════════════════════════
   VARIABLES GLOBALES — PERSONALIZACIÓN CENTRAL
   ══════════════════════════════════════════════════════════════ */

:root {
  /* ── Marca MueveTicket ────────────────────────── */
  --mt-purple:       #5c2d91;   /* Púrpura profundo */
  --mt-magenta:      #c8298a;   /* Magenta vibrante */
  --mt-pink:         #e0449a;   /* Rosa intermedio  */
  --mt-gold:         #d4a017;   /* Dorado ámbar     */
  --mt-gold-light:   #f0c040;   /* Dorado claro     */
  --mt-coral:        #e8603a;   /* Coral cálido     */

  /* ── Gradiente principal (logo) ───────────────── */
  --mt-gradient:         linear-gradient(135deg, var(--mt-purple) 0%, var(--mt-magenta) 60%, var(--mt-pink) 100%);
  --mt-gradient-gold:    linear-gradient(90deg, var(--mt-coral) 0%, var(--mt-gold) 100%);
  --mt-gradient-hero:    linear-gradient(160deg, #1a0533 0%, #2d0b5a 40%, #1f062e 100%);
  --mt-gradient-card:    linear-gradient(180deg, transparent 40%, rgba(28,5,52,.95) 100%);

  /* ── Fondo y superficies ──────────────────────── */
  --mt-bg:           #0e0518;
  --mt-surface:      #160828;
  --mt-surface-2:    #1e0f35;
  --mt-surface-3:    #261545;
  --mt-border:       rgba(200, 41, 138, .15);
  --mt-border-light: rgba(255,255,255,.07);

  /* ── Texto ────────────────────────────────────── */
  --mt-text:         #f0e8ff;
  --mt-text-muted:   #9b84b8;
  --mt-text-dim:     #6a5585;

  /* ── Estados ──────────────────────────────────── */
  --mt-success:      #34d399;
  --mt-warning:      #f59e0b;
  --mt-danger:       #ef4444;
  --mt-info:         #60a5fa;

  /* ── Sombras ──────────────────────────────────── */
  --mt-shadow-sm:    0 2px 8px rgba(0,0,0,.4);
  --mt-shadow-md:    0 4px 24px rgba(0,0,0,.5);
  --mt-shadow-lg:    0 8px 48px rgba(0,0,0,.65);
  --mt-shadow-glow:  0 0 40px rgba(200, 41, 138, .25);
  --mt-shadow-gold:  0 0 30px rgba(212, 160, 23, .3);

  /* ── Tipografía ───────────────────────────────── */
  --mt-font-display: 'Syne', system-ui, sans-serif;
  --mt-font-body:    'Plus Jakarta Sans', system-ui, sans-serif;

  /* ── Espaciado y forma ────────────────────────── */
  --mt-radius-sm:    6px;
  --mt-radius-md:    12px;
  --mt-radius-lg:    20px;
  --mt-radius-xl:    32px;
  --mt-radius-pill:  999px;

  /* ── Transición ───────────────────────────────── */
  --mt-ease:         cubic-bezier(.4, 0, .2, 1);
  --mt-dur:          240ms;
  --mt-dur-lg:       400ms;
}

/* ══════════════════════════════════════════════════════════════
   RESET Y BASE
   ══════════════════════════════════════════════════════════════ */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 16px; }

body {
  background-color: var(--mt-bg);
  color: var(--mt-text);
  font-family: var(--mt-font-body);
  font-size: 15px;
  line-height: 1.7;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow-x: hidden;
}

/* Textura de fondo sutil */
body::before {
  content: '';
  position: fixed;
  inset: 0;
  background-image:
    radial-gradient(ellipse 80% 50% at 20% 10%, rgba(92,45,145,.18) 0%, transparent 60%),
    radial-gradient(ellipse 60% 40% at 80% 80%, rgba(200,41,138,.12) 0%, transparent 50%);
  pointer-events: none;
  z-index: 0;
}

a { color: var(--mt-magenta); text-decoration: none; transition: color var(--mt-dur) var(--mt-ease); }
a:hover { color: var(--mt-gold-light); }
img { max-width: 100%; height: auto; display: block; }
button, input, select, textarea { font-family: inherit; }
button { cursor: pointer; }

/* ── Contenedor ───────────────────────────────── */
.container,
.mt-container {
  width: min(1200px, 100% - 2.5rem);
  margin-inline: auto;
}

/* ── Encabezados ──────────────────────────────── */
h1, h2, h3, h4, h5, h6 {
  font-family: var(--mt-font-display);
  line-height: 1.15;
  font-weight: 700;
  letter-spacing: -.02em;
}
h1 { font-size: clamp(2rem, 5vw, 3.5rem); }
h2 { font-size: clamp(1.5rem, 3.5vw, 2.4rem); }
h3 { font-size: clamp(1.1rem, 2.5vw, 1.5rem); }

/* ── Párrafos ─────────────────────────────────── */
p { margin-bottom: 1em; }
p:last-child { margin-bottom: 0; }

/* ── Clases de utilidad ───────────────────────── */
.text-gradient {
  background: var(--mt-gradient);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.text-gold {
  background: var(--mt-gradient-gold);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.sr-only { position:absolute; width:1px; height:1px; overflow:hidden; clip:rect(0,0,0,0); }

/* ══════════════════════════════════════════════════════════════
   BOTONES GLOBALES
   ══════════════════════════════════════════════════════════════ */

.mt-btn {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  padding: .7rem 1.6rem;
  border-radius: var(--mt-radius-pill);
  font-weight: 600;
  font-size: .875rem;
  letter-spacing: .03em;
  text-transform: uppercase;
  transition: all var(--mt-dur) var(--mt-ease);
  white-space: nowrap;
  position: relative;
  overflow: hidden;
}
.mt-btn::before {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(255,255,255,.1);
  opacity: 0;
  transition: opacity var(--mt-dur) var(--mt-ease);
}
.mt-btn:hover::before { opacity: 1; }

/* Primario — venta propia */
.mt-btn-primary {
  background: var(--mt-gradient);
  color: #fff;
  box-shadow: 0 4px 20px rgba(200,41,138,.4);
}
.mt-btn-primary:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 32px rgba(200,41,138,.55);
  color: #fff;
}

/* Externo — enlace a otra plataforma */
.mt-btn-external {
  background: transparent;
  color: var(--mt-gold-light);
  border: 1.5px solid var(--mt-gold);
  box-shadow: 0 0 16px rgba(212,160,23,.15);
}
.mt-btn-external:hover {
  background: rgba(212,160,23,.12);
  transform: translateY(-2px);
  color: var(--mt-gold-light);
  box-shadow: 0 0 28px rgba(212,160,23,.3);
}
.mt-btn-external .mt-ext-icon::after {
  content: ' ↗';
  font-size: .85em;
}

/* Secundario / outline */
.mt-btn-outline {
  background: transparent;
  color: var(--mt-text);
  border: 1.5px solid var(--color-border-light, rgba(255,255,255,.15));
}
.mt-btn-outline:hover {
  border-color: var(--mt-magenta);
  color: var(--mt-text);
}

/* Agotado / deshabilitado */
.mt-btn-sold-out {
  background: rgba(255,255,255,.06);
  color: var(--mt-text-dim);
  border: 1.5px solid rgba(255,255,255,.08);
  cursor: not-allowed;
  opacity: .7;
}

/* ══════════════════════════════════════════════════════════════
   BADGES / ETIQUETAS
   ══════════════════════════════════════════════════════════════ */

.mt-badge {
  display: inline-flex;
  align-items: center;
  gap: .3rem;
  padding: .2rem .65rem;
  border-radius: var(--mt-radius-pill);
  font-size: .7rem;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
}
.mt-badge-own       { background: rgba(200,41,138,.2); color: var(--mt-pink); border: 1px solid rgba(200,41,138,.35); }
.mt-badge-external  { background: rgba(212,160,23,.15); color: var(--mt-gold-light); border: 1px solid rgba(212,160,23,.3); }
.mt-badge-free      { background: rgba(52,211,153,.15); color: var(--mt-success); border: 1px solid rgba(52,211,153,.3); }
.mt-badge-sold-out  { background: rgba(239,68,68,.12); color: var(--mt-danger); border: 1px solid rgba(239,68,68,.25); }
.mt-badge-soon      { background: rgba(245,158,11,.15); color: var(--mt-warning); border: 1px solid rgba(245,158,11,.3); }
.mt-badge-new       { background: var(--mt-gradient); color: #fff; }

/* ══════════════════════════════════════════════════════════════
   HEADER / NAVEGACIÓN
   ══════════════════════════════════════════════════════════════ */

.site-header {
  position: sticky;
  top: 0;
  z-index: 200;
  background: rgba(14, 5, 24, .85);
  backdrop-filter: blur(24px) saturate(180%);
  -webkit-backdrop-filter: blur(24px) saturate(180%);
  border-bottom: 1px solid var(--mt-border);
  transition: box-shadow var(--mt-dur) var(--mt-ease);
}
.site-header.scrolled {
  box-shadow: 0 4px 32px rgba(0,0,0,.6);
}

.header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding-block: .9rem;
}

/* Logo */
.site-logo img {
  height: 44px;
  width: auto;
}
.site-logo-text {
  font-family: var(--mt-font-display);
  font-size: 1.5rem;
  font-weight: 800;
  background: var(--mt-gradient);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* Nav principal */
.main-nav { display: flex; align-items: center; gap: .15rem; list-style: none; }
.main-nav li { position: relative; }
.main-nav > li > a {
  display: block;
  padding: .45rem 1rem;
  border-radius: var(--mt-radius-pill);
  font-size: .875rem;
  font-weight: 500;
  color: var(--mt-text-muted);
  transition: color var(--mt-dur) var(--mt-ease), background var(--mt-dur) var(--mt-ease);
}
.main-nav > li > a:hover,
.main-nav > li.current-menu-item > a {
  color: var(--mt-text);
  background: rgba(255,255,255,.06);
}

/* Submenú dropdown */
.main-nav .sub-menu {
  position: absolute;
  top: calc(100% + .5rem);
  left: 0;
  min-width: 200px;
  background: var(--mt-surface);
  border: 1px solid var(--mt-border);
  border-radius: var(--mt-radius-md);
  padding: .5rem;
  list-style: none;
  opacity: 0;
  visibility: hidden;
  transform: translateY(-6px);
  transition: all var(--mt-dur) var(--mt-ease);
  box-shadow: var(--mt-shadow-lg);
}
.main-nav li:hover .sub-menu {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}
.main-nav .sub-menu a {
  display: block;
  padding: .45rem .75rem;
  border-radius: var(--mt-radius-sm);
  font-size: .85rem;
  color: var(--mt-text-muted);
}
.main-nav .sub-menu a:hover {
  color: var(--mt-text);
  background: rgba(255,255,255,.06);
}

/* Acciones header */
.header-actions { display: flex; align-items: center; gap: .75rem; }

/* Búsqueda header */
.header-search { position: relative; }
.header-search-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px; height: 36px;
  border-radius: 50%;
  background: rgba(255,255,255,.06);
  color: var(--mt-text-muted);
  transition: all var(--mt-dur) var(--mt-ease);
}
.header-search-btn:hover { background: rgba(255,255,255,.12); color: var(--mt-text); }
.header-search-btn svg { width:16px; height:16px; }

/* Hamburger mobile */
.nav-toggle {
  display: none;
  flex-direction: column;
  gap: 5px;
  padding: .5rem;
  background: none;
  border: none;
}
.nav-toggle span {
  display: block;
  width: 22px; height: 2px;
  background: var(--mt-text);
  border-radius: 2px;
  transition: transform var(--mt-dur) var(--mt-ease), opacity var(--mt-dur) var(--mt-ease);
}
.nav-toggle.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav-toggle.open span:nth-child(2) { opacity: 0; }
.nav-toggle.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* ══════════════════════════════════════════════════════════════
   HERO PRINCIPAL
   ══════════════════════════════════════════════════════════════ */

.hero-section {
  position: relative;
  min-height: 92vh;
  display: flex;
  align-items: center;
  overflow: hidden;
  background: var(--mt-gradient-hero);
}

.hero-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}
.hero-bg img {
  width: 100%; height: 100%;
  object-fit: cover;
  opacity: .25;
}
.hero-bg::after {
  content: '';
  position: absolute;
  inset: 0;
  background: var(--mt-gradient-hero);
  opacity: .75;
}

/* Elementos decorativos */
.hero-orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(80px);
  pointer-events: none;
}
.hero-orb-1 {
  width: 600px; height: 600px;
  background: radial-gradient(circle, rgba(92,45,145,.5) 0%, transparent 70%);
  top: -200px; left: -100px;
  animation: orb-float 8s ease-in-out infinite;
}
.hero-orb-2 {
  width: 400px; height: 400px;
  background: radial-gradient(circle, rgba(200,41,138,.4) 0%, transparent 70%);
  bottom: -100px; right: 10%;
  animation: orb-float 10s ease-in-out infinite reverse;
}
.hero-orb-3 {
  width: 300px; height: 300px;
  background: radial-gradient(circle, rgba(212,160,23,.3) 0%, transparent 70%);
  top: 30%; right: 20%;
  animation: orb-float 12s ease-in-out infinite 2s;
}

@keyframes orb-float {
  0%, 100% { transform: translate(0, 0) scale(1); }
  33%       { transform: translate(20px, -30px) scale(1.05); }
  66%       { transform: translate(-15px, 15px) scale(.97); }
}

.hero-content {
  position: relative;
  z-index: 1;
  max-width: 700px;
}

.hero-label {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  padding: .35rem 1rem;
  border-radius: var(--mt-radius-pill);
  background: rgba(200,41,138,.15);
  border: 1px solid rgba(200,41,138,.3);
  font-size: .8rem;
  font-weight: 600;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--mt-pink);
  margin-bottom: 1.25rem;
  animation: fade-up .6s var(--mt-ease) both;
}
.hero-label-dot {
  width: 7px; height: 7px;
  background: var(--mt-magenta);
  border-radius: 50%;
  animation: pulse-dot 2s ease infinite;
}
@keyframes pulse-dot {
  0%, 100% { transform: scale(1); opacity: 1; }
  50%       { transform: scale(1.5); opacity: .6; }
}

.hero-title {
  font-size: clamp(2.5rem, 6vw, 4.5rem);
  font-weight: 900;
  line-height: 1.05;
  letter-spacing: -.03em;
  margin-bottom: 1.25rem;
  animation: fade-up .6s var(--mt-ease) .1s both;
}
.hero-title .accent { background: var(--mt-gradient); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }

.hero-description {
  font-size: 1.1rem;
  color: var(--mt-text-muted);
  margin-bottom: 2rem;
  max-width: 520px;
  animation: fade-up .6s var(--mt-ease) .2s both;
}

.hero-ctas {
  display: flex;
  flex-wrap: wrap;
  gap: .75rem;
  animation: fade-up .6s var(--mt-ease) .3s both;
}

/* Buscador hero */
.hero-search {
  display: flex;
  width: 100%;
  max-width: 560px;
  background: rgba(255,255,255,.06);
  border: 1px solid var(--mt-border);
  border-radius: var(--mt-radius-pill);
  overflow: hidden;
  margin-bottom: 1.5rem;
  backdrop-filter: blur(10px);
  transition: border-color var(--mt-dur) var(--mt-ease), box-shadow var(--mt-dur) var(--mt-ease);
  animation: fade-up .6s var(--mt-ease) .15s both;
}
.hero-search:focus-within {
  border-color: rgba(200,41,138,.5);
  box-shadow: 0 0 0 4px rgba(200,41,138,.12);
}
.hero-search-input {
  flex: 1;
  background: none;
  border: none;
  outline: none;
  padding: .85rem 1.25rem;
  color: var(--mt-text);
  font-size: .95rem;
}
.hero-search-input::placeholder { color: var(--mt-text-dim); }
.hero-search-btn {
  padding: .6rem 1.25rem;
  margin: .35rem;
  background: var(--mt-gradient);
  color: #fff;
  border: none;
  border-radius: var(--mt-radius-pill);
  font-size: .85rem;
  font-weight: 600;
  display: flex;
  align-items: center;
  gap: .4rem;
  transition: opacity var(--mt-dur) var(--mt-ease);
}
.hero-search-btn:hover { opacity: .88; }

/* Stats hero */
.hero-stats {
  display: flex;
  gap: 2rem;
  margin-top: 2.5rem;
  animation: fade-up .6s var(--mt-ease) .4s both;
}
.hero-stat-number {
  font-family: var(--mt-font-display);
  font-size: 1.6rem;
  font-weight: 800;
  background: var(--mt-gradient);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  display: block;
}
.hero-stat-label { font-size: .78rem; color: var(--mt-text-muted); text-transform: uppercase; letter-spacing: .06em; }

/* Featured evento en hero (lado derecho) */
.hero-featured {
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  width: min(460px, 38%);
  animation: fade-in .8s var(--mt-ease) .5s both;
}

@keyframes fade-up {
  from { opacity: 0; transform: translateY(24px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes fade-in {
  from { opacity: 0; transform: translateY(-50%) scale(.95); }
  to   { opacity: 1; transform: translateY(-50%) scale(1); }
}

/* ══════════════════════════════════════════════════════════════
   SECCIÓN: PRÓXIMOS EVENTOS / CARTELERA
   ══════════════════════════════════════════════════════════════ */

.section-events { padding: 5rem 0; }
.section-events-featured { padding: 4rem 0; background: var(--mt-surface); }

/* Cabecera de sección */
.section-header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 2.5rem;
  flex-wrap: wrap;
}
.section-label {
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--mt-magenta);
  margin-bottom: .4rem;
}
.section-title { margin-bottom: 0; }
.section-see-all {
  color: var(--mt-text-muted);
  font-size: .875rem;
  font-weight: 500;
  white-space: nowrap;
  transition: color var(--mt-dur) var(--mt-ease);
}
.section-see-all:hover { color: var(--mt-magenta); }

/* Filtros de categoría */
.events-filters {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
  margin-bottom: 2rem;
}
.filter-btn {
  padding: .4rem 1rem;
  border-radius: var(--mt-radius-pill);
  font-size: .8rem;
  font-weight: 600;
  background: rgba(255,255,255,.05);
  color: var(--mt-text-muted);
  border: 1px solid var(--mt-border-light);
  transition: all var(--mt-dur) var(--mt-ease);
}
.filter-btn:hover { background: rgba(255,255,255,.1); color: var(--mt-text); }
.filter-btn.active {
  background: var(--mt-gradient);
  color: #fff;
  border-color: transparent;
  box-shadow: 0 2px 16px rgba(200,41,138,.35);
}

/* GRID DE EVENTOS */
.events-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 1.5rem;
}
.events-grid-large {
  grid-template-columns: repeat(auto-fill, minmax(340px, 1fr));
}

/* ── TARJETA DE EVENTO ────────────────────────── */
.event-card {
  background: var(--mt-surface);
  border: 1px solid var(--mt-border-light);
  border-radius: var(--mt-radius-lg);
  overflow: hidden;
  transition: transform var(--mt-dur) var(--mt-ease),
              box-shadow var(--mt-dur) var(--mt-ease),
              border-color var(--mt-dur) var(--mt-ease);
  position: relative;
  display: flex;
  flex-direction: column;
}
.event-card:hover {
  transform: translateY(-5px);
  box-shadow: var(--mt-shadow-glow), var(--mt-shadow-lg);
  border-color: rgba(200,41,138,.35);
}

/* Indicador lateral: venta propia vs externa */
.event-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0;
  width: 3px;
  height: 100%;
  background: var(--mt-gradient);
  opacity: 0;
  transition: opacity var(--mt-dur) var(--mt-ease);
}
.event-card:hover::before { opacity: 1; }
.event-card.is-external::before { background: var(--mt-gradient-gold); }
.event-card.is-external:hover { border-color: rgba(212,160,23,.35); box-shadow: var(--mt-shadow-gold), var(--mt-shadow-lg); }

/* Imagen del evento */
.event-card-image {
  position: relative;
  aspect-ratio: 16/9;
  overflow: hidden;
  background: var(--mt-surface-2);
}
.event-card-image img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform var(--mt-dur-lg) var(--mt-ease);
}
.event-card:hover .event-card-image img { transform: scale(1.06); }
.event-card-image-overlay {
  position: absolute;
  inset: 0;
  background: var(--mt-gradient-card);
}

/* Badge de categoría sobre imagen */
.event-card-cat {
  position: absolute;
  top: .75rem;
  left: .75rem;
}

/* Badge de tipo (propio/externo) sobre imagen */
.event-card-type {
  position: absolute;
  top: .75rem;
  right: .75rem;
}

/* Fecha flotante */
.event-card-date-badge {
  position: absolute;
  bottom: .75rem;
  left: .75rem;
  background: rgba(14,5,24,.85);
  backdrop-filter: blur(12px);
  border: 1px solid var(--mt-border);
  border-radius: var(--mt-radius-md);
  padding: .4rem .7rem;
  text-align: center;
  min-width: 52px;
}
.event-card-date-badge .day {
  font-family: var(--mt-font-display);
  font-size: 1.3rem;
  font-weight: 800;
  line-height: 1;
  background: var(--mt-gradient);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.event-card-date-badge .month {
  font-size: .65rem;
  font-weight: 700;
  text-transform: uppercase;
  color: var(--mt-text-muted);
  letter-spacing: .06em;
}

/* Cuerpo de la tarjeta */
.event-card-body {
  padding: 1.25rem;
  display: flex;
  flex-direction: column;
  flex: 1;
  gap: .6rem;
}

.event-card-venue {
  display: flex;
  align-items: center;
  gap: .35rem;
  font-size: .75rem;
  color: var(--mt-text-dim);
  text-transform: uppercase;
  letter-spacing: .05em;
  font-weight: 600;
}
.event-card-venue svg { width: 12px; height: 12px; flex-shrink: 0; }

.event-card-title {
  font-family: var(--mt-font-display);
  font-size: 1.05rem;
  font-weight: 700;
  line-height: 1.25;
  color: var(--mt-text);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.event-card-time {
  font-size: .8rem;
  color: var(--mt-text-muted);
  display: flex;
  align-items: center;
  gap: .3rem;
}

/* Footer tarjeta */
.event-card-footer {
  padding: 0 1.25rem 1.25rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .75rem;
  margin-top: auto;
  border-top: 1px solid var(--mt-border-light);
  padding-top: 1rem;
}

.event-card-price {
  font-family: var(--mt-font-display);
  font-weight: 700;
  font-size: 1.1rem;
  color: var(--mt-text);
}
.event-card-price .price-from { font-size: .7rem; color: var(--mt-text-muted); font-family: var(--mt-font-body); font-weight: 400; display: block; line-height: 1; }
.event-card-price.is-free { color: var(--mt-success); }
.event-card-price.is-sold { color: var(--mt-danger); font-size: .85rem; }

.event-card-btn { flex-shrink: 0; }

/* ── TARJETA DESTACADA (horizontal) ────────────── */
.event-card-featured {
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: 280px;
}
.event-card-featured .event-card-image {
  aspect-ratio: auto;
  height: 100%;
}
.event-card-featured .event-card-body { padding: 2rem; justify-content: center; gap: 1rem; }
.event-card-featured .event-card-title { font-size: 1.4rem; -webkit-line-clamp: 3; }
.event-card-featured .event-card-footer { border-top: none; padding: 0; margin-top: 0; }

/* ── TARJETA LISTA (horizontal compacta) ────────── */
.event-card-list {
  display: grid;
  grid-template-columns: 100px 1fr auto;
  align-items: center;
  gap: 0;
  border-radius: var(--mt-radius-md);
}
.event-card-list .event-card-image { aspect-ratio: 1/1; width: 100px; flex-shrink: 0; }
.event-card-list .event-card-body { padding: .75rem 1rem; gap: .3rem; }
.event-card-list .event-card-footer { padding: .75rem 1rem .75rem 0; border: none; flex-direction: column; align-items: flex-end; }

/* ══════════════════════════════════════════════════════════════
   SECCIÓN: CATEGORÍAS
   ══════════════════════════════════════════════════════════════ */

.section-categories { padding: 4rem 0; }

.categories-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap: 1rem;
}

.category-card {
  position: relative;
  border-radius: var(--mt-radius-lg);
  overflow: hidden;
  aspect-ratio: 1/1;
  background: var(--mt-surface-2);
  border: 1px solid var(--mt-border-light);
  transition: transform var(--mt-dur) var(--mt-ease), box-shadow var(--mt-dur) var(--mt-ease);
  display: flex;
  align-items: flex-end;
  padding: 1rem;
}
.category-card:hover { transform: scale(1.03); box-shadow: var(--mt-shadow-glow); }
.category-card img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; opacity: .4; transition: opacity var(--mt-dur) var(--mt-ease); }
.category-card:hover img { opacity: .55; }
.category-card::after { content: ''; position: absolute; inset: 0; background: linear-gradient(180deg, transparent 30%, rgba(14,5,24,.92) 100%); }
.category-card-content { position: relative; z-index: 1; }
.category-card-icon { font-size: 1.6rem; margin-bottom: .3rem; }
.category-card-name { font-family: var(--mt-font-display); font-size: .9rem; font-weight: 700; color: var(--mt-text); }
.category-card-count { font-size: .72rem; color: var(--mt-text-muted); }

/* ══════════════════════════════════════════════════════════════
   SECCIÓN: PLATAFORMAS EXTERNAS
   ══════════════════════════════════════════════════════════════ */

.section-external {
  padding: 4rem 0;
  background: var(--mt-surface);
  border-top: 1px solid var(--mt-border);
  border-bottom: 1px solid var(--mt-border);
}

.external-info-box {
  background: rgba(212,160,23,.08);
  border: 1px solid rgba(212,160,23,.2);
  border-radius: var(--mt-radius-lg);
  padding: 1.5rem 2rem;
  display: flex;
  align-items: flex-start;
  gap: 1rem;
  margin-bottom: 2rem;
}
.external-info-icon { font-size: 1.4rem; flex-shrink: 0; margin-top: .1rem; }
.external-info-text { font-size: .88rem; color: var(--mt-text-muted); }
.external-info-text strong { color: var(--mt-gold-light); display: block; margin-bottom: .2rem; }

/* ══════════════════════════════════════════════════════════════
   SINGLE EVENTO (página individual)
   ══════════════════════════════════════════════════════════════ */

.single-event-hero {
  position: relative;
  padding: 5rem 0 3rem;
  overflow: hidden;
}
.single-event-hero-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}
.single-event-hero-bg img { width: 100%; height: 100%; object-fit: cover; opacity: .15; filter: blur(40px) saturate(200%); transform: scale(1.1); }
.single-event-hero-bg::after { content: ''; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(14,5,24,.7) 0%, rgba(14,5,24,.95) 100%); }
.single-event-hero-content { position: relative; z-index: 1; }

.single-event-layout {
  display: grid;
  grid-template-columns: 1fr 360px;
  gap: 2.5rem;
  align-items: start;
  padding: 3rem 0 5rem;
}

/* Sidebar de compra */
.event-buy-sidebar {
  position: sticky;
  top: 90px;
}
.event-buy-box {
  background: var(--mt-surface);
  border: 1px solid var(--mt-border);
  border-radius: var(--mt-radius-xl);
  overflow: hidden;
  box-shadow: var(--mt-shadow-lg);
}
.event-buy-box-header {
  padding: 1.5rem;
  background: var(--mt-surface-2);
  border-bottom: 1px solid var(--mt-border);
}
.event-buy-box-body { padding: 1.5rem; }

/* Selector de entradas */
.ticket-type {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1rem;
  border: 1px solid var(--mt-border-light);
  border-radius: var(--mt-radius-md);
  margin-bottom: .75rem;
  transition: border-color var(--mt-dur) var(--mt-ease);
}
.ticket-type:hover { border-color: rgba(200,41,138,.3); }
.ticket-type-name { font-weight: 600; font-size: .9rem; }
.ticket-type-price { font-family: var(--mt-font-display); font-weight: 700; color: var(--mt-magenta); }
.ticket-type-desc { font-size: .75rem; color: var(--mt-text-muted); }

/* Contador cantidad */
.qty-control {
  display: flex;
  align-items: center;
  gap: .5rem;
}
.qty-btn {
  width: 28px; height: 28px;
  border-radius: 50%;
  background: rgba(255,255,255,.08);
  color: var(--mt-text);
  font-size: 1rem;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background var(--mt-dur) var(--mt-ease);
}
.qty-btn:hover { background: rgba(200,41,138,.25); }
.qty-value { font-weight: 700; min-width: 24px; text-align: center; }

/* Enlace externo en sidebar */
.event-external-link {
  text-align: center;
  padding: 1.5rem;
  border-top: 1px solid var(--mt-border);
}
.event-external-platform {
  font-size: .78rem;
  color: var(--mt-text-dim);
  margin-bottom: .75rem;
}
.event-external-platform strong { color: var(--mt-gold-light); }

/* Ficha de detalles */
.event-details-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
  margin: 2rem 0;
}
.event-detail-item {
  background: var(--mt-surface);
  border: 1px solid var(--mt-border-light);
  border-radius: var(--mt-radius-md);
  padding: 1rem 1.25rem;
}
.event-detail-label {
  font-size: .72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .07em;
  color: var(--mt-text-dim);
  margin-bottom: .25rem;
}
.event-detail-value { font-weight: 600; font-size: .95rem; }

/* ══════════════════════════════════════════════════════════════
   PÁGINA: LISTADO / ARCHIVO
   ══════════════════════════════════════════════════════════════ */

.archive-layout {
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: 2rem;
  padding: 3rem 0 5rem;
  align-items: start;
}

.archive-sidebar {
  position: sticky;
  top: 90px;
  background: var(--mt-surface);
  border: 1px solid var(--mt-border-light);
  border-radius: var(--mt-radius-xl);
  padding: 1.5rem;
}
.sidebar-title {
  font-size: .8rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--mt-magenta);
  margin-bottom: 1rem;
}
.sidebar-filter-group { margin-bottom: 1.5rem; }
.sidebar-filter-label {
  font-size: .78rem;
  font-weight: 600;
  color: var(--mt-text-muted);
  margin-bottom: .5rem;
  display: block;
}

/* Checkboxes filtro */
.filter-check { display: flex; align-items: center; gap: .5rem; margin-bottom: .35rem; }
.filter-check input[type="checkbox"] {
  appearance: none;
  width: 16px; height: 16px;
  border: 1.5px solid var(--mt-border);
  border-radius: 4px;
  background: var(--mt-surface-2);
  transition: all var(--mt-dur) var(--mt-ease);
  cursor: pointer;
  flex-shrink: 0;
}
.filter-check input[type="checkbox"]:checked {
  background: var(--mt-magenta);
  border-color: var(--mt-magenta);
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 16 16' fill='white' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M12.207 4.793a1 1 0 010 1.414l-5 5a1 1 0 01-1.414 0l-2-2a1 1 0 011.414-1.414L6.5 9.086l4.293-4.293a1 1 0 011.414 0z'/%3E%3C/svg%3E");
}
.filter-check label { font-size: .85rem; color: var(--mt-text-muted); cursor: pointer; }

/* Input rango precio */
.price-range input[type="range"] {
  width: 100%;
  appearance: none;
  height: 4px;
  background: linear-gradient(to right, var(--mt-magenta) 0%, var(--mt-magenta) 50%, var(--mt-surface-3) 50%);
  border-radius: 2px;
  outline: none;
}
.price-range input[type="range"]::-webkit-slider-thumb {
  appearance: none;
  width: 16px; height: 16px;
  border-radius: 50%;
  background: var(--mt-magenta);
  cursor: pointer;
  box-shadow: 0 0 8px rgba(200,41,138,.5);
}

/* ══════════════════════════════════════════════════════════════
   PAGINACIÓN
   ══════════════════════════════════════════════════════════════ */

.pagination {
  display: flex;
  justify-content: center;
  gap: .4rem;
  margin-top: 3rem;
}
.page-numbers {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px; height: 40px;
  border-radius: var(--mt-radius-sm);
  font-size: .875rem;
  font-weight: 600;
  color: var(--mt-text-muted);
  background: var(--mt-surface);
  border: 1px solid var(--mt-border-light);
  transition: all var(--mt-dur) var(--mt-ease);
}
.page-numbers:hover, .page-numbers.current {
  background: var(--mt-gradient);
  color: #fff;
  border-color: transparent;
}

/* ══════════════════════════════════════════════════════════════
   FOOTER
   ══════════════════════════════════════════════════════════════ */

.site-footer {
  background: var(--mt-surface);
  border-top: 1px solid var(--mt-border);
  padding: 4rem 0 0;
}

.footer-grid {
  display: grid;
  grid-template-columns: 1.5fr 1fr 1fr 1fr;
  gap: 3rem;
  margin-bottom: 3rem;
}

.footer-brand-desc {
  font-size: .875rem;
  color: var(--mt-text-muted);
  margin-top: .75rem;
  margin-bottom: 1.25rem;
  line-height: 1.65;
}
.footer-logo img { height: 40px; width: auto; }

/* Redes sociales */
.social-links { display: flex; gap: .5rem; flex-wrap: wrap; }
.social-link {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px; height: 36px;
  border-radius: var(--mt-radius-sm);
  background: rgba(255,255,255,.06);
  color: var(--mt-text-muted);
  border: 1px solid var(--mt-border-light);
  transition: all var(--mt-dur) var(--mt-ease);
  font-size: .9rem;
}
.social-link:hover {
  background: var(--mt-magenta);
  color: #fff;
  border-color: var(--mt-magenta);
  transform: translateY(-2px);
}

/* Columnas de links */
.footer-col-title {
  font-size: .78rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--mt-text);
  margin-bottom: 1rem;
}
.footer-links { list-style: none; display: flex; flex-direction: column; gap: .5rem; }
.footer-links a { font-size: .875rem; color: var(--mt-text-muted); transition: color var(--mt-dur) var(--mt-ease); }
.footer-links a:hover { color: var(--mt-magenta); }

/* Barra inferior */
.footer-bottom {
  border-top: 1px solid var(--mt-border-light);
  padding: 1.25rem 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  flex-wrap: wrap;
}
.footer-copy { font-size: .8rem; color: var(--mt-text-dim); }
.footer-legal { display: flex; gap: 1.25rem; }
.footer-legal a { font-size: .8rem; color: var(--mt-text-dim); transition: color var(--mt-dur) var(--mt-ease); }
.footer-legal a:hover { color: var(--mt-text-muted); }

/* Badge "Powered by" */
.powered-by {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  padding: .25rem .75rem;
  border-radius: var(--mt-radius-pill);
  background: var(--mt-gradient);
  font-size: .7rem;
  font-weight: 700;
  color: #fff;
  letter-spacing: .04em;
}

/* ══════════════════════════════════════════════════════════════
   WIDGETS DE SIDEBAR (WordPress)
   ══════════════════════════════════════════════════════════════ */

.widget {
  background: var(--mt-surface);
  border: 1px solid var(--mt-border-light);
  border-radius: var(--mt-radius-lg);
  padding: 1.5rem;
  margin-bottom: 1.5rem;
}
.widget-title {
  font-size: .8rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--mt-magenta);
  margin-bottom: 1rem;
  padding-bottom: .75rem;
  border-bottom: 1px solid var(--mt-border-light);
}
.widget ul { list-style: none; }
.widget ul li { padding: .4rem 0; border-bottom: 1px solid var(--mt-border-light); }
.widget ul li:last-child { border-bottom: none; }
.widget ul li a { font-size: .875rem; color: var(--mt-text-muted); }
.widget ul li a:hover { color: var(--mt-magenta); }

/* Widget calendario WP */
.widget_calendar table { width: 100%; border-collapse: collapse; font-size: .8rem; }
.widget_calendar th { color: var(--mt-magenta); font-weight: 700; padding: .3rem; text-align: center; }
.widget_calendar td { text-align: center; padding: .3rem; color: var(--mt-text-muted); }
.widget_calendar td a { color: var(--mt-gold-light); font-weight: 700; }

/* ══════════════════════════════════════════════════════════════
   FORMULARIOS GLOBALES
   ══════════════════════════════════════════════════════════════ */

.mt-form-group { margin-bottom: 1.25rem; }
.mt-label { display: block; font-size: .8rem; font-weight: 600; color: var(--mt-text-muted); margin-bottom: .45rem; letter-spacing: .03em; }
.mt-input,
.mt-select,
.mt-textarea {
  width: 100%;
  background: var(--mt-surface-2);
  border: 1.5px solid var(--mt-border);
  border-radius: var(--mt-radius-md);
  padding: .7rem 1rem;
  color: var(--mt-text);
  font-size: .9rem;
  transition: border-color var(--mt-dur) var(--mt-ease), box-shadow var(--mt-dur) var(--mt-ease);
  outline: none;
}
.mt-input:focus,
.mt-select:focus,
.mt-textarea:focus {
  border-color: var(--mt-magenta);
  box-shadow: 0 0 0 3px rgba(200,41,138,.15);
}
.mt-input::placeholder { color: var(--mt-text-dim); }
.mt-select { appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%239b84b8' viewBox='0 0 20 20'%3E%3Cpath fill-rule='evenodd' d='M5.293 7.293a1 1 0 011.414 0L10 10.586l3.293-3.293a1 1 0 111.414 1.414l-4 4a1 1 0 01-1.414 0l-4-4a1 1 0 010-1.414z'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right .75rem center; background-size: 16px; padding-right: 2.5rem; }

/* ══════════════════════════════════════════════════════════════
   NOTIFICACIONES / ALERTAS
   ══════════════════════════════════════════════════════════════ */

.mt-alert {
  padding: 1rem 1.25rem;
  border-radius: var(--mt-radius-md);
  font-size: .875rem;
  display: flex;
  align-items: flex-start;
  gap: .75rem;
  margin-bottom: 1rem;
}
.mt-alert-success { background: rgba(52,211,153,.1); border: 1px solid rgba(52,211,153,.25); color: var(--mt-success); }
.mt-alert-warning { background: rgba(245,158,11,.1); border: 1px solid rgba(245,158,11,.25); color: var(--mt-warning); }
.mt-alert-danger  { background: rgba(239,68,68,.1); border: 1px solid rgba(239,68,68,.25); color: var(--mt-danger); }
.mt-alert-info    { background: rgba(96,165,250,.1); border: 1px solid rgba(96,165,250,.25); color: var(--mt-info); }

/* ══════════════════════════════════════════════════════════════
   LOADING / SKELETON
   ══════════════════════════════════════════════════════════════ */

.skeleton {
  background: linear-gradient(90deg, var(--mt-surface) 25%, var(--mt-surface-2) 50%, var(--mt-surface) 75%);
  background-size: 200% 100%;
  animation: skeleton-load 1.5s ease infinite;
  border-radius: var(--mt-radius-sm);
}
@keyframes skeleton-load { 0% { background-position: 200% 0; } 100% { background-position: -200% 0; } }

/* ══════════════════════════════════════════════════════════════
   RESPONSIVE — MOBILE FIRST
   ══════════════════════════════════════════════════════════════ */

@media (max-width: 1024px) {
  .single-event-layout { grid-template-columns: 1fr; }
  .event-buy-sidebar { position: static; }
  .hero-featured { display: none; }
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 2rem; }
  .archive-layout { grid-template-columns: 1fr; }
  .archive-sidebar { position: static; }
}

@media (max-width: 768px) {
  .main-nav {
    display: none;
    flex-direction: column;
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: var(--mt-bg);
    border-bottom: 1px solid var(--mt-border);
    padding: 1rem;
    gap: .25rem;
  }
  .main-nav.open { display: flex; }
  .main-nav > li > a { border-radius: var(--mt-radius-md); }
  .main-nav .sub-menu { position: static; opacity: 1; visibility: visible; transform: none; box-shadow: none; background: var(--mt-surface-2); margin-top: .25rem; }
  .nav-toggle { display: flex; }
  .event-card-featured { grid-template-columns: 1fr; }
  .event-details-grid { grid-template-columns: 1fr; }
  .footer-grid { grid-template-columns: 1fr; }
  .hero-stats { gap: 1.25rem; }
  .section-header { flex-direction: column; align-items: flex-start; }
}

@media (max-width: 480px) {
  .events-grid { grid-template-columns: 1fr; }
  .categories-grid { grid-template-columns: repeat(2, 1fr); }
  .hero-ctas { flex-direction: column; }
  .hero-ctas .mt-btn { justify-content: center; }
}

/* ══════════════════════════════════════════════════════════════
   ANIMACIONES DE ENTRADA (scroll)
   ══════════════════════════════════════════════════════════════ */

[data-animate] {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity .6s var(--mt-ease), transform .6s var(--mt-ease);
}
[data-animate].visible {
  opacity: 1;
  transform: translateY(0);
}
[data-animate-delay="1"] { transition-delay: .1s; }
[data-animate-delay="2"] { transition-delay: .2s; }
[data-animate-delay="3"] { transition-delay: .3s; }
[data-animate-delay="4"] { transition-delay: .4s; }

/* ══════════════════════════════════════════════════════════════
   CLASES ESPECÍFICAS WORDPRESS
   ══════════════════════════════════════════════════════════════ */

/* Alineaciones nativas WP */
.alignleft  { float: left; margin: 0 1.5rem 1rem 0; }
.alignright { float: right; margin: 0 0 1rem 1.5rem; }
.aligncenter { display: block; margin: 1.5rem auto; }
.alignwide  { width: 100%; }
.alignfull  { width: 100vw; margin-left: calc(-50vw + 50%); }

/* Imágenes con caption */
.wp-caption { background: var(--mt-surface); border: 1px solid var(--mt-border); border-radius: var(--mt-radius-md); padding: .5rem; }
.wp-caption-text { font-size: .78rem; color: var(--mt-text-muted); text-align: center; padding: .5rem; }

/* Sticky posts */
.sticky .event-card { border-color: rgba(212,160,23,.3); }
.sticky .event-card::after { content: '⭐ Destacado'; position: absolute; top: .75rem; left: .75rem; background: var(--mt-gradient-gold); color: #1a0f00; padding: .2rem .6rem; border-radius: var(--mt-radius-pill); font-size: .65rem; font-weight: 700; }

/* Bloque de búsqueda WP */
.wp-block-search .wp-block-search__input { background: var(--mt-surface-2); border: 1.5px solid var(--mt-border); border-radius: var(--mt-radius-pill) 0 0 var(--mt-radius-pill); color: var(--mt-text); padding: .7rem 1.25rem; }
.wp-block-search .wp-block-search__button { background: var(--mt-gradient); color: #fff; border: none; padding: .7rem 1.25rem; border-radius: 0 var(--mt-radius-pill) var(--mt-radius-pill) 0; font-weight: 600; }

/* Bloque embed */
.wp-block-embed { margin: 2rem 0; }
.wp-block-embed iframe { border-radius: var(--mt-radius-lg); overflow: hidden; }

/* Galería WP */
.wp-block-gallery { display: grid; gap: .5rem; }
.wp-block-gallery .blocks-gallery-item img { border-radius: var(--mt-radius-sm); object-fit: cover; height: 100%; }

/* ══════════════════════════════════════════════════════════════
   MODO CLARO (si el usuario lo activa desde Personalizar)
   ══════════════════════════════════════════════════════════════ */

.light-mode {
  --mt-bg:           #f8f4ff;
  --mt-surface:      #ffffff;
  --mt-surface-2:    #f0eaf9;
  --mt-surface-3:    #e6dcf5;
  --mt-border:       rgba(92,45,145,.15);
  --mt-border-light: rgba(92,45,145,.1);
  --mt-text:         #1a0533;
  --mt-text-muted:   #6b5585;
  --mt-text-dim:     #a090b8;
  --mt-gradient-hero: linear-gradient(160deg, #e6dcf5 0%, #f0e8ff 40%, #fff 100%);
}
