/* ============================================================
   Boletíssimo — capa responsiva (375px → 4K) para las 5 superficies.
   Layout-only; los componentes inyectan su propio CSS.
   ============================================================ */

*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; }
body { background: var(--surface-page); color: var(--text-body); font-family: var(--font-sans); }
.appframe { min-height: 100vh; }

/* Icon wrapper (React-safe lucide) — svg sizing still comes from existing `… svg` rules */
.licon { display: inline-flex; align-items: center; justify-content: center; line-height: 0; }
.licon svg { display: block; }
.co__method-icon svg { width: 22px; height: 22px; }
.acc__qricon svg { width: 100%; height: 100%; }

/* ===================== Chrome móvil compartido ===================== */
/* Drawer */
.bls-drawer { position: fixed; inset: 0; z-index: var(--z-modal); pointer-events: none; }
.bls-drawer.is-open { pointer-events: auto; }
.bls-drawer__scrim { position: absolute; inset: 0; background: var(--surface-overlay, rgba(28,20,16,.5)); opacity: 0; transition: opacity var(--dur-base) var(--ease-standard); }
.bls-drawer.is-open .bls-drawer__scrim { opacity: 1; }
.bls-drawer__panel { position: absolute; top: 0; bottom: 0; width: min(82%, 320px); background: var(--surface-card); box-shadow: var(--shadow-xl); padding: 16px; overflow-y: auto; transition: transform var(--dur-base) var(--ease-out); }
.bls-drawer__panel--left { left: 0; transform: translateX(-100%); }
.bls-drawer.is-open .bls-drawer__panel--left { transform: translateX(0); }

/* Sheet inferior */
.bls-sheet { position: fixed; inset: 0; z-index: var(--z-modal); pointer-events: none; }
.bls-sheet.is-open { pointer-events: auto; }
.bls-sheet__scrim { position: absolute; inset: 0; background: var(--surface-overlay, rgba(28,20,16,.5)); opacity: 0; transition: opacity var(--dur-base) var(--ease-standard); }
.bls-sheet.is-open .bls-sheet__scrim { opacity: 1; }
.bls-sheet__panel { position: absolute; left: 0; right: 0; bottom: 0; max-height: 88%; background: var(--surface-card); border-radius: var(--radius-2xl) var(--radius-2xl) 0 0; box-shadow: var(--shadow-xl); padding: 10px 18px calc(18px + env(safe-area-inset-bottom)); transform: translateY(100%); transition: transform var(--dur-base) var(--ease-out); display: flex; flex-direction: column; }
.bls-sheet.is-open .bls-sheet__panel { transform: translateY(0); }
.bls-sheet__grip { width: 40px; height: 4px; border-radius: var(--radius-pill); background: var(--border-strong); margin: 4px auto 10px; }
.bls-sheet__hd { display: flex; align-items: center; justify-content: space-between; margin-bottom: 6px; }
.bls-sheet__hd h3 { font-family: var(--font-display); font-weight: 700; font-size: var(--size-xl); color: var(--text-strong); }
.bls-sheet__x { width: 36px; height: 36px; border: none; background: var(--surface-sunken); border-radius: var(--radius-pill); color: var(--text-muted); cursor: pointer; display: flex; align-items: center; justify-content: center; }
.bls-sheet__x svg { width: 18px; height: 18px; }
.bls-sheet__body { overflow-y: auto; }

/* Bottom nav */
.bls-bottomnav { position: fixed; left: 0; right: 0; bottom: 0; z-index: var(--z-sticky); display: grid; grid-auto-flow: column; grid-auto-columns: 1fr; background: color-mix(in oklch, var(--surface-card) 92%, transparent); backdrop-filter: blur(12px); border-top: 1px solid var(--border-subtle); padding-bottom: env(safe-area-inset-bottom); }
.bls-bottomnav__item { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 3px; min-height: 56px; border: none; background: none; cursor: pointer; color: var(--text-muted); font: var(--text-caption); font-weight: 600; transition: var(--transition-colors); }
.bls-bottomnav__item svg { width: 22px; height: 22px; }
.bls-bottomnav__item.is-active { color: var(--brand); }

/* ===================== PÚBLICO ===================== */
.pub { min-height: 100vh; display: flex; flex-direction: column; background: var(--surface-page); }
.pub__main { flex: 1; }
.pub--hasbottom { padding-bottom: 56px; }

/* Header */
.pub-hd { position: sticky; top: 0; z-index: var(--z-sticky); background: color-mix(in oklch, var(--surface-card) 86%, transparent); backdrop-filter: blur(12px); border-bottom: 1px solid var(--border-subtle); }
.pub-hd__inner { max-width: var(--container-2xl); margin: 0 auto; padding: 12px var(--gutter-desktop); display: flex; align-items: center; gap: 16px; }
.pub-hd__logo { display: flex; align-items: center; gap: 9px; font-family: var(--font-display); font-weight: 800; font-size: 21px; letter-spacing: -0.02em; color: var(--text-strong); cursor: pointer; text-decoration: none; flex: none; }
.pub-hd__i { color: var(--brand); }
.pub-hd__search { flex: 1; max-width: 520px; display: flex; align-items: center; gap: 9px; height: 44px; padding: 0 14px; background: var(--surface-sunken); border: 1px solid var(--border-default); border-radius: var(--radius-pill); color: var(--text-subtle); }
.pub-hd__search svg { width: 18px; height: 18px; flex: none; }
.pub-hd__search input { flex: 1; border: none; background: transparent; outline: none; font: var(--text-body-md); color: var(--text-strong); min-width: 0; }
.pub-hd__city, .pub-hd__tickets { display: inline-flex; align-items: center; gap: 7px; height: 44px; padding: 0 14px; border-radius: var(--radius-md); border: 1px solid transparent; background: transparent; color: var(--text-body); font: var(--text-label-sm); cursor: pointer; transition: var(--transition-colors); white-space: nowrap; }
.pub-hd__city:hover, .pub-hd__tickets:hover { background: var(--surface-sunken); }
.pub-hd__city svg, .pub-hd__tickets svg { width: 17px; height: 17px; }
.pub-hd__tickets { border-color: var(--border-default); }
.pub-hd__menu, .pub-hd__iconbtn { width: 44px; height: 44px; border: none; background: transparent; border-radius: var(--radius-md); color: var(--text-strong); cursor: pointer; display: flex; align-items: center; justify-content: center; flex: none; }
.pub-hd__menu:hover, .pub-hd__iconbtn:hover { background: var(--surface-sunken); }
.pub-hd__menu svg, .pub-hd__iconbtn svg { width: 22px; height: 22px; }
.pub-hd--mobile .pub-hd__inner { gap: 8px; padding: 10px var(--gutter-mobile); }
.pub-hd--mobile .pub-hd__logo { font-size: 18px; margin-right: auto; }
.pub-hd__city--mini { height: 38px; padding: 0 10px; border: 1px solid var(--border-default); border-radius: var(--radius-pill); font-size: 12px; }
.pub-hd__city--mini span { max-width: 80px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.pub-hd__searchrow { padding: 0 var(--gutter-mobile) 12px; }
.pub-hd__searchrow .pub-hd__search { max-width: none; }
@media (max-width: 1023px) and (min-width: 768px) { .pub-hd__city span, .pub-hd__tickets span { display: none; } }

/* Drawer (público) */
.pub-drawer { display: flex; flex-direction: column; gap: 18px; }
.pub-drawer .pub-hd__logo { font-size: 20px; padding: 6px 0; }
.pub-drawer__nav { display: flex; flex-direction: column; gap: 2px; }
.pub-drawer__nav button { display: flex; align-items: center; gap: 12px; padding: 13px 12px; border: none; background: none; border-radius: var(--radius-md); font: var(--text-body-md); color: var(--text-strong); cursor: pointer; text-align: left; }
.pub-drawer__nav button:hover { background: var(--surface-sunken); }
.pub-drawer__nav svg { width: 20px; height: 20px; color: var(--text-muted); }
.pub-drawer__cats { border-top: 1px solid var(--border-subtle); padding-top: 14px; display: flex; flex-wrap: wrap; gap: 8px; }
.pub-drawer__lbl { width: 100%; font: var(--text-eyebrow); letter-spacing: var(--ls-caps); text-transform: uppercase; color: var(--text-muted); margin-bottom: 4px; }
.pub-drawer__cats button { padding: 8px 14px; border: 1px solid var(--border-default); background: var(--surface-card); border-radius: var(--radius-pill); font: var(--text-label-sm); color: var(--text-body); cursor: pointer; }

/* Footer */
.pub-ft { background: var(--ink-980); color: var(--ink-200); margin-top: var(--space-11); }
.pub-ft__inner { max-width: var(--container-2xl); margin: 0 auto; padding: var(--space-9) var(--gutter-desktop) var(--space-7); display: grid; grid-template-columns: 1.6fr 1fr 1fr 1fr; gap: var(--space-7); }
.pub-ft__brand p { font: var(--text-body-sm); color: var(--ink-400); margin-top: 12px; max-width: 320px; }
.pub-ft__pay { display: flex; gap: 8px; margin-top: 16px; flex-wrap: wrap; }
.pub-ft__pay span { font: var(--text-caption); color: var(--ink-200); border: 1px solid var(--ink-800); border-radius: var(--radius-sm); padding: 4px 9px; font-family: var(--font-mono); }
.pub-ft__col h4 { font: var(--text-eyebrow); letter-spacing: var(--ls-caps); text-transform: uppercase; color: var(--ink-400); margin-bottom: 14px; font-family: var(--font-sans); }
.pub-ft__col a { display: block; font: var(--text-body-sm); color: var(--ink-200); padding: 5px 0; cursor: pointer; text-decoration: none; }
.pub-ft__col a:hover { color: #fff; }
.pub-ft__legal { max-width: var(--container-2xl); margin: 0 auto; padding: var(--space-5) var(--gutter-desktop); border-top: 1px solid var(--ink-850); font: var(--text-caption); color: var(--ink-500); }
@media (max-width: 760px) { .pub-ft__inner { grid-template-columns: 1fr 1fr; } }

/* Home */
.home__hero { color: #fff; }
.home__hero-in { max-width: var(--container-2xl); margin: 0 auto; padding: var(--space-10) var(--gutter-desktop); display: grid; grid-template-columns: 1.2fr 0.85fr; gap: var(--space-9); align-items: center; }
.home__hero-copy h1 { font-family: var(--font-display); font-weight: 800; font-size: clamp(2rem, 1rem + 3.4vw, 3.75rem); line-height: 1.04; letter-spacing: -0.025em; color: #fff; margin: 12px 0 16px; }
.home__eyebrow { display: inline-flex; align-items: center; gap: 7px; font: var(--text-eyebrow); letter-spacing: var(--ls-caps); text-transform: uppercase; color: var(--oro-300); }
.home__eyebrow svg { width: 14px; height: 14px; }
.home__hero-meta { font: var(--text-body-lg); color: rgba(255,255,255,.86); margin-bottom: 10px; }
.home__hero-blurb { font: var(--text-body-md); color: rgba(255,255,255,.74); max-width: 460px; margin-bottom: 24px; text-wrap: pretty; }
.home__hero-cta { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }
.home__hero-poster { aspect-ratio: 4/5; border-radius: var(--radius-2xl); box-shadow: var(--shadow-xl); display: flex; flex-direction: column; justify-content: flex-end; gap: 4px; padding: 26px; position: relative; overflow: hidden; }
.home__poster-cat { font: var(--text-eyebrow); letter-spacing: var(--ls-caps); text-transform: uppercase; color: rgba(255,255,255,.85); }
.home__poster-title { font-family: var(--font-display); font-weight: 800; font-size: var(--size-3xl); line-height: 1.05; color: #fff; }
.home__poster-date { font: var(--text-label); color: rgba(255,255,255,.9); }

.home__filters { max-width: var(--container-2xl); margin: 0 auto; padding: var(--space-7) var(--gutter-desktop) 0; display: flex; gap: 10px; flex-wrap: wrap; overflow-x: auto; }
.home__sec { max-width: var(--container-2xl); margin: 0 auto; padding: var(--space-6) var(--gutter-desktop) var(--space-9); }
.home__sec-hd { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 20px; gap: 12px; }
.home__sec-hd h2 { font-family: var(--font-display); font-weight: 700; font-size: var(--size-3xl); color: var(--text-strong); letter-spacing: -0.015em; text-wrap: balance; }
.home__count { font: var(--text-body-sm); color: var(--text-muted); white-space: nowrap; }
.home__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-6); }
.home__empty { text-align: center; padding: var(--space-10); color: var(--text-muted); }
.home__empty svg { width: 40px; height: 40px; margin-bottom: 12px; color: var(--text-subtle); }

/* Event detail */
.ev__hero { position: relative; min-height: 340px; display: flex; flex-direction: column; color: #fff; }
.ev__hero-scrim { position: absolute; inset: 0; background: linear-gradient(to top, rgba(20,12,10,.7), rgba(20,12,10,.1) 60%); }
.ev__hero-bar { position: relative; z-index: 1; max-width: var(--container-xl); width: 100%; margin: 0 auto; padding: 18px var(--gutter-desktop) 0; display: flex; justify-content: space-between; }
.ev__hero-actions { display: flex; gap: 10px; }
.ev__hero-copy { position: relative; z-index: 1; max-width: var(--container-xl); width: 100%; margin: auto auto 0; padding: 0 var(--gutter-desktop) var(--space-8); }
.ev__cat { font: var(--text-eyebrow); letter-spacing: var(--ls-caps); text-transform: uppercase; background: rgba(0,0,0,.32); padding: 6px 12px; border-radius: var(--radius-pill); backdrop-filter: blur(6px); }
.ev__hero-copy h1 { font-family: var(--font-display); font-weight: 800; font-size: clamp(1.6rem, 0.9rem + 2.6vw, 3rem); line-height: 1.06; letter-spacing: -0.02em; color: #fff; margin: 14px 0 8px; max-width: 720px; }
.ev__hero-copy p { font: var(--text-body-lg); color: rgba(255,255,255,.9); }
.ev__body { max-width: var(--container-xl); margin: 0 auto; padding: var(--space-8) var(--gutter-desktop) var(--space-10); display: grid; grid-template-columns: 1fr 380px; gap: var(--space-9); align-items: start; }
.ev__block { margin-bottom: var(--space-8); }
.ev__block h3 { font-family: var(--font-display); font-weight: 700; font-size: var(--size-2xl); color: var(--text-strong); margin-bottom: 12px; }
.ev__block p { font: var(--text-body-lg); color: var(--text-body); max-width: 620px; text-wrap: pretty; }
.ev__info { list-style: none; padding: 0; margin: 0; display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.ev__info li { display: flex; gap: 12px; align-items: flex-start; }
.ev__info svg { width: 22px; height: 22px; color: var(--brand); flex: none; margin-top: 2px; }
.ev__info b { display: block; font: var(--text-label-sm); color: var(--text-strong); }
.ev__info span { font: var(--text-body-sm); color: var(--text-muted); }
.ev__map { height: 180px; border-radius: var(--radius-lg); background: var(--surface-sunken); border: 1px solid var(--border-default); display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 8px; color: var(--text-muted); }
.ev__map svg { width: 32px; height: 32px; }
.ev__buy { position: sticky; top: 84px; }
.ev__buy-card { background: var(--surface-card); border: 1px solid var(--border-default); border-radius: var(--radius-xl); box-shadow: var(--shadow-md); padding: var(--space-6); }
.ev__buy-card h3 { font-family: var(--font-display); font-weight: 700; font-size: var(--size-xl); color: var(--text-strong); margin-bottom: 16px; }
.ev__zones { display: flex; flex-direction: column; gap: 10px; margin-bottom: 18px; }
.ev__zone { display: flex; align-items: center; gap: 12px; padding: 14px; border: 1.5px solid var(--border-default); border-radius: var(--radius-md); background: var(--surface-card); cursor: pointer; text-align: left; transition: var(--transition-colors); }
.ev__zone:hover { border-color: var(--border-strong); }
.ev__zone.is-sel { border-color: var(--brand); background: var(--brand-softer); }
.ev__zone.is-off { opacity: .5; cursor: not-allowed; }
.ev__zone-radio { width: 20px; height: 20px; border-radius: 50%; border: 2px solid var(--border-strong); flex: none; position: relative; }
.ev__zone.is-sel .ev__zone-radio { border-color: var(--brand); }
.ev__zone.is-sel .ev__zone-radio::after { content: ""; position: absolute; inset: 3px; border-radius: 50%; background: var(--brand); }
.ev__zone-info { flex: 1; display: flex; flex-direction: column; gap: 2px; }
.ev__zone-name { font: var(--text-label); color: var(--text-strong); display: flex; align-items: center; gap: 8px; }
.ev__zone-desc { font: var(--text-caption); color: var(--text-muted); }
.ev__zone-price { font-family: var(--font-mono); font-weight: 600; font-size: var(--size-lg); color: var(--text-strong); }
.ev__qty-row { display: flex; align-items: center; justify-content: space-between; padding: 14px 0; border-top: 1px solid var(--border-subtle); }
.ev__qty-row span { font: var(--text-label); color: var(--text-strong); }
.ev__total-row { display: flex; align-items: center; justify-content: space-between; padding: 14px 0 18px; border-top: 1px solid var(--border-subtle); }
.ev__total-lbl { display: block; font: var(--text-label); color: var(--text-strong); }
.ev__total-sub { font: var(--text-caption); color: var(--text-muted); }
.ev__total-amt { font-family: var(--font-mono); font-weight: 600; font-size: var(--size-3xl); color: var(--text-strong); }
.ev__buy-note { display: flex; align-items: center; gap: 6px; justify-content: center; font: var(--text-caption); color: var(--text-muted); margin-top: 12px; }
.ev__buy-note svg { width: 13px; height: 13px; }
/* CTA fijo móvil */
.ev__cta { position: fixed; left: 0; right: 0; bottom: 0; z-index: var(--z-sticky); display: flex; align-items: center; gap: 14px; padding: 12px var(--gutter-mobile) calc(12px + env(safe-area-inset-bottom)); background: color-mix(in oklch, var(--surface-card) 94%, transparent); backdrop-filter: blur(12px); border-top: 1px solid var(--border-subtle); }
.ev__cta-price { display: flex; flex-direction: column; line-height: 1.1; }
.ev__cta-from { font: var(--text-caption); color: var(--text-muted); }
.ev__cta-price b { font-family: var(--font-mono); font-weight: 700; font-size: var(--size-xl); color: var(--text-strong); }
.ev__cta-btn { flex: 1; height: 52px; border: none; border-radius: var(--radius-md); background: var(--brand); color: var(--brand-on); font-family: var(--font-sans); font-weight: var(--fw-semibold); font-size: var(--size-md); cursor: pointer; }
.ev__cta-btn:disabled { opacity: .5; }

/* Checkout */
.co { max-width: var(--container-xl); margin: 0 auto; padding: var(--space-6) var(--gutter-desktop) var(--space-10); }
.co__bar { display: flex; align-items: center; justify-content: space-between; padding: 8px 0 22px; gap: 10px; }
.co__back { display: inline-flex; align-items: center; gap: 6px; background: none; border: none; cursor: pointer; font: var(--text-label-sm); color: var(--text-body); }
.co__back svg { width: 17px; height: 17px; }
.co__bar-title { font-family: var(--font-display); font-weight: 700; font-size: var(--size-xl); color: var(--text-strong); }
.co__timer { display: inline-flex; align-items: center; gap: 7px; font-family: var(--font-mono); font-weight: 600; font-size: var(--size-md); color: var(--warning); background: var(--warning-soft); padding: 7px 12px; border-radius: var(--radius-pill); white-space: nowrap; }
.co__timer svg { width: 15px; height: 15px; }
.co__grid { display: grid; grid-template-columns: 1fr 400px; gap: var(--space-8); align-items: start; }
.co__sec { background: var(--surface-card); border: 1px solid var(--border-default); border-radius: var(--radius-lg); padding: var(--space-6); margin-bottom: var(--space-5); }
.co__sec h3 { font-family: var(--font-display); font-weight: 700; font-size: var(--size-lg); color: var(--text-strong); margin-bottom: 16px; }
.co__fields { display: grid; gap: 14px; }
.co__methods { display: flex; flex-direction: column; gap: 10px; }
.co__method { display: flex; align-items: center; gap: 12px; padding: 14px; border: 1.5px solid var(--border-default); border-radius: var(--radius-md); background: var(--surface-card); cursor: pointer; text-align: left; transition: var(--transition-colors); }
.co__method:hover { border-color: var(--border-strong); }
.co__method.is-sel { border-color: var(--brand); background: var(--brand-softer); }
.co__method-radio { width: 20px; height: 20px; border-radius: 50%; border: 2px solid var(--border-strong); flex: none; position: relative; }
.co__method.is-sel .co__method-radio { border-color: var(--brand); }
.co__method.is-sel .co__method-radio::after { content: ""; position: absolute; inset: 3px; border-radius: 50%; background: var(--brand); }
.co__method-icon { width: 22px; height: 22px; color: var(--text-muted); flex: none; }
.co__method.is-sel .co__method-icon { color: var(--brand); }
.co__method-text { display: flex; flex-direction: column; gap: 1px; }
.co__method-text b { font: var(--text-label); color: var(--text-strong); }
.co__method-text span { font: var(--text-caption); color: var(--text-muted); }
.co__card-fields { margin-top: 16px; display: grid; gap: 14px; }
.co__card-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.co__summary { position: sticky; top: 84px; }
.co__sum-card { background: var(--surface-card); border: 1px solid var(--border-default); border-radius: var(--radius-xl); box-shadow: var(--shadow-md); padding: var(--space-6); }
.co__sum-ev { display: flex; gap: 14px; align-items: center; padding-bottom: 16px; border-bottom: 1px solid var(--border-subtle); margin-bottom: 14px; }
.co__sum-poster { width: 56px; height: 70px; border-radius: var(--radius-md); flex: none; display: flex; align-items: center; justify-content: center; color: #fff; font-family: var(--font-mono); font-weight: 600; font-size: 12px; }
.co__sum-ev b { display: block; font: var(--text-label); color: var(--text-strong); }
.co__sum-ev span { display: block; font: var(--text-caption); color: var(--text-muted); }
.co__sum-line { display: flex; align-items: center; justify-content: space-between; margin-bottom: 14px; font: var(--text-body-sm); color: var(--text-body); }
.co__sum-card .bls-pb { margin-bottom: 18px; }
.co__trust { display: flex; align-items: center; gap: 6px; justify-content: center; font: var(--text-caption); color: var(--text-muted); margin-top: 12px; }
.co__trust svg { width: 14px; height: 14px; color: var(--success); }
/* Barra de pago fija móvil */
.co__paybar { position: fixed; left: 0; right: 0; bottom: 0; z-index: var(--z-sticky); display: flex; align-items: center; gap: 14px; padding: 12px var(--gutter-mobile) calc(12px + env(safe-area-inset-bottom)); background: color-mix(in oklch, var(--surface-card) 94%, transparent); backdrop-filter: blur(12px); border-top: 1px solid var(--border-subtle); }
.co__paybar-total { display: flex; flex-direction: column; line-height: 1.1; }
.co__paybar-total span { font: var(--text-caption); color: var(--text-muted); }
.co__paybar-total b { font-family: var(--font-mono); font-weight: 700; font-size: var(--size-xl); color: var(--text-strong); }
.co__paybar-btn { flex: 1; height: 52px; border: none; border-radius: var(--radius-md); background: var(--brand); color: var(--brand-on); font-family: var(--font-sans); font-weight: var(--fw-semibold); font-size: var(--size-md); cursor: pointer; display: inline-flex; align-items: center; justify-content: center; gap: 8px; }
.co__paybar-btn svg { width: 18px; height: 18px; }

/* Confirmation */
.cf { max-width: 880px; margin: 0 auto; padding: var(--space-10) var(--gutter-desktop); text-align: center; }
.cf__check { width: 76px; height: 76px; border-radius: 50%; background: var(--success); color: #fff; display: flex; align-items: center; justify-content: center; margin: 0 auto 20px; box-shadow: var(--shadow-lg); }
.cf__check svg { width: 42px; height: 42px; stroke-width: 3; }
.cf__head h1 { font-family: var(--font-display); font-weight: 800; font-size: var(--size-4xl); color: var(--text-strong); letter-spacing: -0.02em; margin-bottom: 10px; text-wrap: balance; }
.cf__head p { font: var(--text-body-lg); color: var(--text-muted); max-width: 480px; margin: 0 auto; }
.cf__tickets { display: flex; flex-wrap: wrap; gap: var(--space-6); justify-content: center; margin: var(--space-8) 0; }
.cf__actions { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; }

/* Mis boletos */
.mb { max-width: var(--container-xl); margin: 0 auto; padding: var(--space-7) var(--gutter-desktop) var(--space-10); }
.mb__hd { margin-bottom: var(--space-7); }
.mb__hd h1 { font-family: var(--font-display); font-weight: 800; font-size: var(--size-4xl); color: var(--text-strong); letter-spacing: -0.02em; margin: 12px 0 4px; }
.mb__hd p { font: var(--text-body-md); color: var(--text-muted); }
.mb__grid { display: flex; flex-wrap: wrap; gap: var(--space-6); }
.mb__past { margin-top: var(--space-9); }
.mb__past h3 { font-family: var(--font-display); font-weight: 700; font-size: var(--size-2xl); color: var(--text-strong); margin-bottom: 16px; }
.mb__pastrow { display: flex; align-items: center; gap: 16px; background: var(--surface-card); border: 1px solid var(--border-default); border-radius: var(--radius-lg); padding: 14px 18px; box-shadow: var(--shadow-xs); }
.mb__poster { width: 48px; height: 60px; border-radius: var(--radius-sm); flex: none; display: flex; align-items: center; justify-content: center; color: #fff; font-family: var(--font-mono); font-weight: 600; font-size: 11px; }
.mb__pastinfo { flex: 1; }
.mb__pastinfo b { display: block; font: var(--text-label); color: var(--text-strong); }
.mb__pastinfo span { font: var(--text-caption); color: var(--text-muted); }

/* ---------- Cola virtual (sala de espera) ---------- */
.cola { min-height: calc(100vh - 0px); display: flex; align-items: center; justify-content: center; padding: var(--space-8) var(--gutter-mobile); background:
    radial-gradient(120% 70% at 50% -10%, color-mix(in oklch, var(--azul-500) 12%, var(--surface-page)), var(--surface-page)); }
.cola__card { width: 100%; max-width: 480px; background: var(--surface-card); border: 1px solid var(--border-default); border-radius: var(--radius-2xl); box-shadow: var(--shadow-lg); padding: 32px 28px; text-align: center; display: flex; flex-direction: column; align-items: center; }
.cola__eyebrow { display: inline-flex; align-items: center; gap: 8px; font: var(--text-eyebrow); letter-spacing: var(--ls-caps); text-transform: uppercase; color: var(--brand); margin-bottom: 18px; }
.cola__dot { width: 8px; height: 8px; border-radius: 50%; background: var(--brand); animation: ad-pulse 1.4s ease-in-out infinite; }
.cola__poster { width: 72px; height: 90px; border-radius: var(--radius-md); display: flex; align-items: center; justify-content: center; color: #fff; font-family: var(--font-mono); font-weight: 600; font-size: 12px; margin-bottom: 18px; box-shadow: var(--shadow-md); }
.cola__card h1 { font-family: var(--font-display); font-weight: 800; font-size: var(--size-3xl); color: var(--text-strong); letter-spacing: -0.02em; }
.cola__sub { font: var(--text-body-md); color: var(--text-muted); margin-top: 4px; }
.cola__pos { margin: 24px 0 10px; }
.cola__pos-lbl { display: block; font: var(--text-eyebrow); letter-spacing: var(--ls-caps); text-transform: uppercase; color: var(--text-muted); margin-bottom: 4px; }
.cola__pos-n { font-family: var(--font-mono); font-weight: 700; font-size: 52px; color: var(--brand); line-height: 1; letter-spacing: -0.02em; }
.cola__bar { width: 100%; height: 10px; border-radius: var(--radius-pill); background: var(--surface-sunken); overflow: hidden; box-shadow: var(--shadow-inset); margin: 8px 0 16px; }
.cola__bar-fill { height: 100%; border-radius: var(--radius-pill); background: linear-gradient(90deg, var(--brand), var(--azul-400)); transition: width 0.6s var(--ease-out); }
.cola__meta { display: flex; gap: 24px; justify-content: center; margin-bottom: 22px; }
.cola__meta div { display: inline-flex; align-items: center; gap: 7px; font: var(--text-body-sm); color: var(--text-body); }
.cola__meta svg { width: 17px; height: 17px; color: var(--text-muted); }
.cola__tips { width: 100%; display: flex; flex-direction: column; gap: 10px; padding: 16px; border-radius: var(--radius-lg); background: var(--surface-sunken); margin-bottom: 18px; }
.cola__tip { display: flex; align-items: center; gap: 10px; font: var(--text-body-sm); color: var(--text-body); text-align: left; }
.cola__tip svg { width: 17px; height: 17px; color: var(--brand); flex: none; }
.cola__leave { background: none; border: none; color: var(--text-muted); font: var(--text-label-sm); cursor: pointer; text-decoration: underline; }
.cola--turn .cola__turn-ic { width: 84px; height: 84px; border-radius: 50%; background: var(--success); color: #fff; display: flex; align-items: center; justify-content: center; box-shadow: var(--shadow-lg); margin-bottom: 18px; }
.cola--turn .cola__turn-ic svg { width: 42px; height: 42px; }
.cola--turn .cola__card p { font: var(--text-body-lg); color: var(--text-muted); margin: 8px 0 18px; text-wrap: pretty; }
.cola__hold { display: inline-flex; align-items: center; gap: 8px; font: var(--text-body-sm); color: var(--warning); background: var(--warning-soft); padding: 9px 14px; border-radius: var(--radius-pill); margin-bottom: 20px; }
.cola__hold svg { width: 16px; height: 16px; }

/* ---------- Header: dropdown de ciudad + responsividad ---------- */
.pub-hd__citywrap { position: relative; flex: none; }
.pub-hd__citymenu { position: absolute; top: calc(100% + 8px); right: 0; min-width: 230px; background: var(--surface-card); border: 1px solid var(--border-default); border-radius: var(--radius-lg); box-shadow: var(--shadow-lg); padding: 8px; z-index: var(--z-dropdown); display: flex; flex-direction: column; gap: 2px; animation: od-pop var(--dur-fast) var(--ease-out); }
@keyframes od-pop { from { opacity: 0; transform: translateY(-4px); } to { opacity: 1; transform: translateY(0); } }
.pub-hd__citymenu-lbl { font: var(--text-eyebrow); letter-spacing: var(--ls-caps); text-transform: uppercase; color: var(--text-muted); padding: 6px 10px 8px; }
.pub-hd__cityopt { display: flex; align-items: center; gap: 9px; padding: 9px 10px; border: none; background: none; border-radius: var(--radius-md); cursor: pointer; font: var(--text-label-sm); color: var(--text-body); text-align: left; }
.pub-hd__cityopt:hover { background: var(--surface-sunken); }
.pub-hd__cityopt > span:not(.licon) { flex: 1; }
.pub-hd__cityopt svg { width: 16px; height: 16px; color: var(--text-subtle); }
.pub-hd__cityopt.is-sel { color: var(--brand); }
.pub-hd__cityopt.is-sel svg { color: var(--brand); }
.pub-hd__city svg:last-child { transition: transform var(--dur-fast) var(--ease-standard); }
.pub-hd__city[aria-expanded="true"] svg:last-child { transform: rotate(180deg); }
.pub-hd__citywrap--mini .pub-hd__citymenu { min-width: 200px; }
@media (min-width: 1024px) and (max-width: 1140px) { .pub-hd__tickets span { display: none; } }

/* ---------- Home: tablero editorial (Pinterest/periódico) ---------- */
.board { column-count: 3; column-gap: var(--space-6); }
.board > * { break-inside: avoid; margin-bottom: var(--space-6); width: 100%; }
.board__poster { position: relative; display: flex; flex-direction: column; justify-content: flex-end; aspect-ratio: 3/4; border-radius: var(--radius-xl); overflow: hidden; padding: 18px; color: #fff; cursor: pointer; box-shadow: var(--shadow-md); transition: transform var(--dur-base) var(--ease-out), box-shadow var(--dur-base) var(--ease-standard); }
.board__poster:hover { transform: translateY(-3px); box-shadow: var(--shadow-xl); }
.board__poster-scrim { position: absolute; inset: 0; background: linear-gradient(to top, rgba(20,12,10,.82), rgba(20,12,10,.05) 62%); }
.board__poster-cat { position: absolute; top: 14px; left: 14px; z-index: 1; font: var(--text-eyebrow); letter-spacing: var(--ls-caps); text-transform: uppercase; background: rgba(0,0,0,.34); backdrop-filter: blur(6px); padding: 5px 10px; border-radius: var(--radius-pill); }
.board__fav { position: absolute; top: 12px; right: 12px; z-index: 1; width: 36px; height: 36px; border: none; border-radius: var(--radius-pill); background: rgba(255,255,255,.92); color: var(--text-strong); display: flex; align-items: center; justify-content: center; cursor: pointer; box-shadow: var(--shadow-sm); }
.board__fav[aria-pressed="true"] { background: var(--brand); color: var(--brand-on); }
.board__fav svg { width: 17px; height: 17px; }
.board__poster-foot { position: relative; z-index: 1; display: flex; flex-direction: column; gap: 4px; }
.board__poster-foot h3 { font-family: var(--font-display); font-weight: 800; font-size: var(--size-xl); line-height: 1.1; letter-spacing: -0.01em; }
.board__poster-foot p { font: var(--text-body-sm); color: rgba(255,255,255,.82); }
.board__poster-price { font: var(--text-body-sm); color: rgba(255,255,255,.82); margin-top: 4px; }
.board__poster-price b { font-family: var(--font-mono); font-weight: 700; font-size: var(--size-lg); color: #fff; }
.board__cat { display: flex; flex-direction: column; align-items: flex-start; justify-content: flex-end; gap: 6px; aspect-ratio: 3/2; border: none; border-radius: var(--radius-xl); padding: 18px; color: #fff; cursor: pointer; text-align: left; box-shadow: var(--shadow-sm); transition: transform var(--dur-base) var(--ease-out); }
.board__cat:hover { transform: translateY(-3px); }
.board__cat > svg { width: 28px; height: 28px; opacity: .9; }
.board__cat-name { font-family: var(--font-display); font-weight: 800; font-size: var(--size-2xl); letter-spacing: -0.015em; }
.board__cat-go { display: inline-flex; align-items: center; gap: 6px; font: var(--text-label-sm); opacity: .92; }
.board__cat-go svg { width: 15px; height: 15px; }
.board__promo { background: var(--brand-softer); border: 1px solid var(--border-default); border-radius: var(--radius-xl); padding: 20px; display: flex; flex-direction: column; gap: 4px; }
.board__promo-ic { width: 44px; height: 44px; border-radius: var(--radius-md); background: var(--surface-card); color: var(--brand-stronger); display: flex; align-items: center; justify-content: center; margin-bottom: 8px; box-shadow: var(--shadow-xs); }
.board__promo-ic svg { width: 22px; height: 22px; }
.board__promo-kicker { font: var(--text-eyebrow); letter-spacing: var(--ls-caps); text-transform: uppercase; color: var(--brand-stronger); }
.board__promo-title { font-family: var(--font-display); font-weight: 700; font-size: var(--size-lg); color: var(--text-strong); line-height: 1.1; }
.board__promo-sub { font: var(--text-body-sm); color: var(--text-muted); }
.board__mini { background: var(--surface-card); border: 1px solid var(--border-default); border-radius: var(--radius-xl); padding: 16px; box-shadow: var(--shadow-xs); }
.board__mini-hd { display: block; font: var(--text-eyebrow); letter-spacing: var(--ls-caps); text-transform: uppercase; color: var(--text-muted); margin-bottom: 10px; }
.board__mini-row { display: flex; align-items: center; gap: 12px; width: 100%; padding: 10px 0; border-top: 1px solid var(--border-subtle); background: none; border-left: none; border-right: none; border-bottom: none; cursor: pointer; text-align: left; }
.board__mini-row:first-of-type { border-top: none; }
.board__mini-date { width: 44px; height: 44px; border-radius: var(--radius-md); color: #fff; display: flex; align-items: center; justify-content: center; flex: none; font-family: var(--font-mono); font-weight: 600; font-size: 10px; text-align: center; line-height: 1.1; }
.board__mini-info { flex: 1; min-width: 0; }
.board__mini-info b { display: block; font: var(--text-label-sm); color: var(--text-strong); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.board__mini-info span { font: var(--text-caption); color: var(--text-muted); }
.board__mini-row > svg { width: 18px; height: 18px; color: var(--text-subtle); flex: none; }
@media (max-width: 1100px) { .board { column-count: 2; } }
@media (max-width: 600px) { .board { column-count: 1; } }
@media (min-width: 1920px) { .board { column-count: 4; } }

/* ---------- Centro de ayuda ---------- */
.help { background: var(--surface-page); }
.help__hero { background: linear-gradient(120deg, var(--ink-980), var(--azul-800)); color: #fff; padding: var(--space-9) var(--gutter-desktop) var(--space-10); text-align: center; }
.help__hero h1 { font-family: var(--font-display); font-weight: 800; font-size: clamp(1.8rem, 1rem + 2.6vw, 2.8rem); letter-spacing: -0.02em; margin-bottom: 20px; color: #fff; }
.help__search { max-width: 560px; margin: 0 auto; display: flex; align-items: center; gap: 10px; height: 54px; padding: 0 18px; background: var(--surface-card); border-radius: var(--radius-pill); box-shadow: var(--shadow-lg); }
.help__search svg { width: 20px; height: 20px; color: var(--text-subtle); }
.help__search input { flex: 1; border: none; background: transparent; outline: none; font: var(--text-body-md); color: var(--text-strong); }
.help__body { max-width: var(--container-lg); margin: 0 auto; padding: var(--space-8) var(--gutter-desktop) var(--space-10); }
.help__topics { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; margin-bottom: var(--space-9); }
.help__topic { display: flex; flex-direction: column; gap: 3px; align-items: flex-start; padding: 18px; border: 1px solid var(--border-default); border-radius: var(--radius-lg); background: var(--surface-card); box-shadow: var(--shadow-xs); cursor: pointer; text-decoration: none; transition: transform var(--dur-base) var(--ease-out), box-shadow var(--dur-base) var(--ease-standard); }
.help__topic:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); }
.help__topic-ic { width: 42px; height: 42px; border-radius: var(--radius-md); background: var(--brand-soft); color: var(--brand-stronger); display: flex; align-items: center; justify-content: center; margin-bottom: 6px; }
.help__topic-ic svg { width: 21px; height: 21px; }
.help__topic b { font: var(--text-label); color: var(--text-strong); }
.help__topic span { font: var(--text-body-sm); color: var(--text-muted); }
.help__panel { background: var(--surface-card); border: 1px solid var(--border-default); border-radius: var(--radius-xl); padding: 24px; box-shadow: var(--shadow-sm); margin-bottom: var(--space-6); scroll-margin-top: 80px; transition: box-shadow var(--dur-base) var(--ease-standard); }
.help__panel.is-focus { box-shadow: 0 0 0 3px var(--brand-ring), var(--shadow-md); }
.help__panel-hd { display: flex; gap: 14px; align-items: flex-start; margin-bottom: 18px; }
.help__panel-ic { width: 46px; height: 46px; border-radius: var(--radius-md); background: var(--brand-soft); color: var(--brand-stronger); display: flex; align-items: center; justify-content: center; flex: none; }
.help__panel-ic svg { width: 22px; height: 22px; }
.help__panel-hd h2 { font-family: var(--font-display); font-weight: 700; font-size: var(--size-2xl); color: var(--text-strong); }
.help__panel-hd p { font: var(--text-body-md); color: var(--text-muted); margin-top: 2px; }
.help__form { display: flex; flex-direction: column; gap: 14px; max-width: 620px; }
.help__form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.help__note { display: flex; gap: 8px; align-items: flex-start; font: var(--text-caption); color: var(--text-muted); }
.help__note svg { width: 15px; height: 15px; color: var(--brand); flex: none; margin-top: 1px; }
.help__faq { display: flex; flex-direction: column; }
.help__faqrow { border-top: 1px solid var(--border-subtle); }
.help__faqrow:first-child { border-top: none; }
.help__faqrow summary { display: flex; align-items: center; justify-content: space-between; gap: 10px; padding: 15px 0; cursor: pointer; font: var(--text-label); color: var(--text-strong); list-style: none; }
.help__faqrow summary::-webkit-details-marker { display: none; }
.help__faqrow summary svg { width: 18px; height: 18px; color: var(--text-muted); transition: transform var(--dur-fast) var(--ease-standard); flex: none; }
.help__faqrow[open] summary svg { transform: rotate(180deg); }
.help__faqrow p { font: var(--text-body-md); color: var(--text-body); padding: 0 0 16px; max-width: 640px; }
.help__contact-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.help__contact-card { display: flex; flex-direction: column; align-items: flex-start; gap: 4px; padding: 18px; border: 1px solid var(--border-default); border-radius: var(--radius-lg); background: var(--surface-sunken); }
.help__contact-ic { width: 42px; height: 42px; border-radius: var(--radius-md); background: var(--surface-card); color: var(--brand); display: flex; align-items: center; justify-content: center; margin-bottom: 6px; box-shadow: var(--shadow-xs); }
.help__contact-ic svg { width: 20px; height: 20px; }
.help__contact-card b { font: var(--text-label); color: var(--text-strong); }
.help__contact-card > span { font: var(--text-body-sm); color: var(--text-muted); margin-bottom: 8px; }

/* Hub CTA + páginas de ayuda */
.help__hubcta { display: flex; align-items: center; justify-content: space-between; gap: 20px; flex-wrap: wrap; margin-top: var(--space-7); padding: 22px 24px; border-radius: var(--radius-xl); background: var(--brand-softer); border: 1px solid var(--border-default); }
.help__hubcta b { display: block; font-family: var(--font-display); font-weight: 700; font-size: var(--size-lg); color: var(--text-strong); }
.help__hubcta span { font: var(--text-body-sm); color: var(--text-muted); }
.helppage { max-width: var(--container-md); margin: 0 auto; padding: var(--space-7) var(--gutter-desktop) var(--space-10); }
.help2__back { display: inline-flex; align-items: center; gap: 6px; background: none; border: none; cursor: pointer; font: var(--text-label-sm); color: var(--brand); padding: 0; margin-bottom: 18px; }
.help2__back svg { width: 17px; height: 17px; }
.helppage__head { margin-bottom: 22px; }
.help2__eyebrow { font: var(--text-eyebrow); letter-spacing: var(--ls-caps); text-transform: uppercase; color: var(--brand); }
.helppage__head h1 { font-family: var(--font-display); font-weight: 800; font-size: var(--size-4xl); color: var(--text-strong); letter-spacing: -0.02em; margin: 8px 0 6px; }
.helppage__head p { font: var(--text-body-lg); color: var(--text-muted); text-wrap: pretty; }
.helppage__card { background: var(--surface-card); border: 1px solid var(--border-default); border-radius: var(--radius-xl); padding: 24px; box-shadow: var(--shadow-sm); margin-bottom: var(--space-6); }
.helppage__formtitle { font-family: var(--font-display); font-weight: 700; font-size: var(--size-lg); color: var(--text-strong); margin-bottom: 16px; }
.helppage .help__contact-grid { margin-bottom: var(--space-6); }

/* ---------- Para organizadores ---------- */
.org__hero { max-width: 860px; margin: 0 auto; padding: var(--space-10) var(--gutter-desktop) var(--space-9); text-align: center; }
.org__eyebrow { font: var(--text-eyebrow); letter-spacing: var(--ls-caps); text-transform: uppercase; color: var(--brand); }
.org__hero h1 { font-family: var(--font-display); font-weight: 800; font-size: clamp(2rem, 1rem + 3.2vw, 3.4rem); line-height: 1.05; letter-spacing: -0.025em; color: var(--text-strong); margin: 14px 0 16px; text-wrap: balance; }
.org__hero h1 em { color: var(--brand); font-style: italic; }
.org__hero > p { font: var(--text-body-lg); color: var(--text-muted); max-width: 600px; margin: 0 auto 26px; text-wrap: pretty; }
.org__hero-cta { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; }
.org__stats { display: flex; gap: 40px; justify-content: center; margin-top: 40px; flex-wrap: wrap; }
.org__stats div { display: flex; flex-direction: column; }
.org__stats b { font-family: var(--font-display); font-weight: 800; font-size: var(--size-4xl); color: var(--text-strong); letter-spacing: -0.02em; }
.org__stats span { font: var(--text-body-sm); color: var(--text-muted); }
.org__feats { max-width: var(--container-xl); margin: 0 auto; padding: var(--space-7) var(--gutter-desktop) var(--space-9); display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-6); }
.org__feat { background: var(--surface-card); border: 1px solid var(--border-default); border-radius: var(--radius-lg); padding: 24px; box-shadow: var(--shadow-xs); }
.org__feat-ic { width: 48px; height: 48px; border-radius: var(--radius-md); background: var(--brand-soft); color: var(--brand-stronger); display: flex; align-items: center; justify-content: center; margin-bottom: 14px; }
.org__feat-ic svg { width: 24px; height: 24px; }
.org__feat b { display: block; font-family: var(--font-display); font-weight: 700; font-size: var(--size-lg); color: var(--text-strong); margin-bottom: 6px; }
.org__feat p { font: var(--text-body-md); color: var(--text-muted); text-wrap: pretty; }
.org__band { max-width: var(--container-xl); margin: 0 auto var(--space-10); padding: var(--space-8) var(--space-8); display: flex; align-items: center; justify-content: space-between; gap: 24px; flex-wrap: wrap; background: linear-gradient(120deg, var(--ink-980), var(--azul-800)); border-radius: var(--radius-2xl); color: #fff; }
.org__band h2 { font-family: var(--font-display); font-weight: 800; font-size: var(--size-3xl); letter-spacing: -0.02em; color: #fff; }
.org__band p { font: var(--text-body-md); color: rgba(255,255,255,.82); margin-top: 4px; }

/* ---------- Legal ---------- */
.legal { max-width: 760px; margin: 0 auto; padding: var(--space-9) var(--gutter-desktop) var(--space-10); }
.legal__eyebrow { font: var(--text-eyebrow); letter-spacing: var(--ls-caps); text-transform: uppercase; color: var(--brand); }
.legal__head h1 { font-family: var(--font-display); font-weight: 800; font-size: var(--size-4xl); color: var(--text-strong); letter-spacing: -0.02em; margin: 10px 0 6px; }
.legal__updated { font: var(--text-body-sm); color: var(--text-subtle); }
.legal__intro { font: var(--text-body-lg); color: var(--text-body); margin: 24px 0 32px; padding-bottom: 24px; border-bottom: 1px solid var(--border-subtle); text-wrap: pretty; }
.legal__secs { display: flex; flex-direction: column; gap: 28px; }
.legal__sec h3 { display: flex; align-items: center; gap: 12px; font-family: var(--font-display); font-weight: 700; font-size: var(--size-xl); color: var(--text-strong); margin-bottom: 10px; }
.legal__n { width: 28px; height: 28px; border-radius: var(--radius-pill); background: var(--brand-soft); color: var(--brand-stronger); display: flex; align-items: center; justify-content: center; font-family: var(--font-mono); font-weight: 600; font-size: 14px; flex: none; }
.legal__sec p { font: var(--text-body-md); color: var(--text-body); line-height: var(--lh-relaxed); text-wrap: pretty; }

@media (max-width: 860px) {
  .help__topics, .help__contact-grid, .org__feats { grid-template-columns: 1fr 1fr; }
  .org__band { padding: var(--space-7); }
}
@media (max-width: 600px) {
  .help__topics, .help__contact-grid, .org__feats, .help__form-row { grid-template-columns: 1fr; }
  .org__stats { gap: 24px; }
}
