/* ============================================================
   Bruma — Sistema de diseño público
   Roboto · Paleta viva · Español chileno
   ============================================================ */

/* ── Variables ───────────────────────────────────────────────── */
:root {
    /* Paleta Bruma (más viva) */
    --bruma-lago:    #0D4F8B;
    --bruma-cielo:   #1A73C1;
    --bruma-neblina: #B8D4EA;
    --bruma-fondo:   #F2F5F9;
    --bruma-noche:   #0F1B2D;
    --bruma-pizarra: #4A5568;
    --bruma-lena:    #E8541E;
    --bruma-bosque:  #1A9E5F;
    --bruma-humo:    #FEF0E8;
    --bruma-blanco:  #FFFFFF;

    /* UI */
    --bruma-radio:    10px;
    --bruma-radio-lg: 16px;
    --bruma-radio-xl: 22px;
    --bruma-sombra:   0 1px 3px rgba(15,27,45,.08), 0 4px 16px rgba(15,27,45,.06);
    --bruma-sombra-lg:0 4px 12px rgba(15,27,45,.10), 0 16px 48px rgba(15,27,45,.12);
    --bruma-borde:    1px solid #E2EAF2;

    /* Tipografía */
    --font-ui:      'Roboto', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    --font-display: 'Roboto', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
}

/* ── Reset ────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }

body.bruma-public {
    margin: 0;
    font-family: var(--font-ui);
    font-size: 15px;
    line-height: 1.6;
    color: var(--bruma-noche);
    background: var(--bruma-fondo);
    -webkit-font-smoothing: antialiased;
}

/* ── Botones ──────────────────────────────────────────────────── */
.btn-bruma,
.btn-bruma-outline,
.btn-bruma-warm {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding: 11px 24px;
    border-radius: var(--bruma-radio);
    font-family: var(--font-ui);
    font-size: 14px;
    font-weight: 600;
    letter-spacing: .01em;
    line-height: 1;
    cursor: pointer;
    border: 2px solid transparent;
    text-decoration: none;
    transition: all .18s ease;
    white-space: nowrap;
}

.btn-bruma {
    background: var(--bruma-lago);
    color: #fff;
    border-color: var(--bruma-lago);
}
.btn-bruma:hover {
    background: var(--bruma-cielo);
    border-color: var(--bruma-cielo);
    color: #fff;
    text-decoration: none;
    transform: translateY(-1px);
    box-shadow: 0 4px 16px rgba(13,79,139,.3);
}
.btn-bruma:active { transform: translateY(0); }
.btn-bruma:disabled, .btn-bruma[disabled] { opacity: .5; cursor: not-allowed; transform: none; }

.btn-bruma-outline {
    background: transparent;
    color: var(--bruma-lago);
    border-color: var(--bruma-lago);
}
.btn-bruma-outline:hover {
    background: var(--bruma-lago);
    color: #fff;
    text-decoration: none;
    transform: translateY(-1px);
}

.btn-bruma-warm {
    background: var(--bruma-lena);
    color: #fff;
    border-color: var(--bruma-lena);
}
.btn-bruma-warm:hover {
    background: #d04818;
    border-color: #d04818;
    color: #fff;
    text-decoration: none;
    transform: translateY(-1px);
    box-shadow: 0 4px 16px rgba(232,84,30,.3);
}

.btn-bruma-lg { padding: 14px 32px; font-size: 15px; }
.btn-bruma-full { width: 100%; }
.btn-bruma-sm { padding: 7px 14px; font-size: 13px; }

/* ── Cards ────────────────────────────────────────────────────── */
.bruma-card {
    background: var(--bruma-blanco);
    border: var(--bruma-borde);
    border-radius: var(--bruma-radio-lg);
    box-shadow: var(--bruma-sombra);
    padding: 24px;
}
.bruma-card-warm {
    background: var(--bruma-humo);
    border: 1px solid #F0D8C8;
    border-radius: var(--bruma-radio-lg);
    padding: 24px;
}

/* ── Badges ───────────────────────────────────────────────────── */
.badge-bruma-ok, .badge-bruma-warn, .badge-bruma-off {
    display: inline-flex;
    align-items: center;
    padding: 3px 10px;
    border-radius: 100px;
    font-size: 12px;
    font-weight: 600;
    letter-spacing: .02em;
    white-space: nowrap;
}
.badge-bruma-ok   { background: #D1F5E0; color: #0D6B3C; }
.badge-bruma-warn { background: #FDEBD8; color: #B8440F; }
.badge-bruma-off  { background: #E8EDF4; color: #4A5568; }

/* ── Inputs ───────────────────────────────────────────────────── */
.input-bruma {
    display: block;
    width: 100%;
    padding: 11px 16px;
    border: 1.5px solid #D0DCE8;
    border-radius: var(--bruma-radio);
    font-family: var(--font-ui);
    font-size: 15px;
    color: var(--bruma-noche);
    background: var(--bruma-blanco);
    transition: border-color .18s, box-shadow .18s;
    outline: none;
    appearance: none;
    -webkit-appearance: none;
}
.input-bruma:focus {
    border-color: var(--bruma-cielo);
    box-shadow: 0 0 0 3px rgba(26,115,193,.15);
}
.input-bruma::placeholder { color: #A0AEC0; }
.input-bruma.error {
    border-color: #E53E3E;
    box-shadow: 0 0 0 3px rgba(229,62,62,.12);
}

label.bruma-label {
    display: block;
    font-size: 13px;
    font-weight: 600;
    color: var(--bruma-pizarra);
    margin-bottom: 6px;
    letter-spacing: .01em;
}
.bruma-field { margin-bottom: 18px; }
.bruma-error-msg { font-size: 12px; color: #E53E3E; margin-top: 4px; }

/* ── Navbar ───────────────────────────────────────────────────── */
.bruma-nav {
    background: var(--bruma-blanco);
    height: 64px;
    display: flex;
    align-items: center;
    padding: 0 28px;
    position: sticky;
    top: 0;
    z-index: 200;
    box-shadow: 0 1px 0 #E2EAF2, 0 2px 8px rgba(15,27,45,.06);
}
.bruma-nav-inner {
    max-width: 1100px;
    margin: 0 auto;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
}
.bruma-nav-logo { display: flex; align-items: center; text-decoration: none; flex-shrink: 0; }
.bruma-nav-links {
    display: flex;
    align-items: center;
    gap: 4px;
    list-style: none;
    margin: 0;
    padding: 0;
}
.bruma-nav-links a {
    font-size: 14px;
    font-weight: 500;
    color: var(--bruma-pizarra);
    text-decoration: none;
    padding: 7px 12px;
    border-radius: 8px;
    transition: background .15s, color .15s;
}
.bruma-nav-links a:hover {
    background: var(--bruma-fondo);
    color: var(--bruma-lago);
}
.bruma-nav-links a.active { color: var(--bruma-lago); font-weight: 600; }

/* ── Flash alerts ─────────────────────────────────────────────── */
.bruma-flash {
    padding: 13px 18px;
    border-radius: var(--bruma-radio);
    font-size: 14px;
    font-weight: 500;
    margin-bottom: 16px;
    display: flex;
    align-items: flex-start;
    gap: 10px;
}
.bruma-flash.ok    { background: #E6F9EF; color: #0D6B3C; border: 1px solid #A7E8C4; }
.bruma-flash.error { background: #FEE8E8; color: #9B1C1C; border: 1px solid #FCA5A5; }
.bruma-flash.warn  { background: #FFEFD4; color: #92400E; border: 1px solid #FCD38A; }

/* ── Layout wrap ──────────────────────────────────────────────── */
.bruma-wrap { min-height: 100vh; display: flex; flex-direction: column; }
.bruma-main { flex: 1; padding: 0; }

/* ── Hero homepage ────────────────────────────────────────────── */
.bruma-hero-wrap {
    background:
        linear-gradient(180deg, rgba(7,22,41,.70) 0%, rgba(7,22,41,.54) 45%, rgba(7,22,41,.82) 100%),
        url('../img/home.png') center center / cover no-repeat,
        linear-gradient(135deg, #071629 0%, #0D3A6B 45%, #0F4F8C 70%, #1A5E9A 100%);
    color: #fff;
    padding: 70px 28px 80px;
    text-align: center;
    position: relative;
    overflow: hidden;
}
.bruma-hero-wrap::before {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(ellipse at 50% 38%, rgba(232,84,30,.22) 0%, transparent 55%),
                linear-gradient(90deg, rgba(7,22,41,.25) 0%, transparent 35%, rgba(7,22,41,.25) 100%);
    pointer-events: none;
}
.bruma-hero-wrap > * {
    position: relative;
    z-index: 1;
}
.bruma-hero-isotipo {
    display: block;
    margin: 0 auto 20px;
    height: 48px;
    opacity: .35;
    filter: brightness(0) invert(1);
    position: relative;
}
.bruma-hero-title {
    font-family: var(--font-display);
    font-size: clamp(30px, 5.5vw, 54px);
    font-weight: 900;
    line-height: 1.08;
    letter-spacing: -.02em;
    margin: 0 0 14px;
    color: #fff;
    position: relative;
}
.bruma-hero-title span { color: #FF8C42; }
.bruma-hero-sub {
    font-size: clamp(14px, 2vw, 17px);
    font-weight: 300;
    color: rgba(255,255,255,.72);
    margin: 0 0 36px;
    max-width: 500px;
    margin-left: auto;
    margin-right: auto;
    line-height: 1.6;
    position: relative;
}

/* Buscador compacto */
.bruma-search-compact {
    display: flex;
    gap: 0;
    max-width: 420px;
    margin: 0 auto;
    position: relative;
    background: rgba(255,255,255,.12);
    border: 1.5px solid rgba(255,255,255,.25);
    border-radius: 12px;
    overflow: hidden;
    backdrop-filter: blur(8px);
    transition: border-color .18s, background .18s;
}
.bruma-search-compact:focus-within {
    border-color: rgba(255,255,255,.55);
    background: rgba(255,255,255,.18);
}
.bruma-search-compact input {
    flex: 1;
    background: transparent;
    border: none;
    outline: none;
    padding: 12px 16px;
    font-size: 14px;
    color: #fff;
    font-family: var(--font-ui);
    min-width: 0;
}
.bruma-search-compact input::placeholder { color: rgba(255,255,255,.5); }
.bruma-search-compact button {
    background: var(--bruma-lena);
    border: none;
    padding: 0 18px;
    color: #fff;
    font-weight: 700;
    font-size: 13px;
    cursor: pointer;
    font-family: var(--font-ui);
    letter-spacing: .03em;
    transition: background .18s;
    white-space: nowrap;
}
.bruma-search-compact button:hover { background: #d04818; }

/* ── Container ────────────────────────────────────────────────── */
.bruma-container {
    max-width: 1100px;
    margin: 0 auto;
    width: 100%;
    padding: 0 28px;
}

/* ── Métricas ─────────────────────────────────────────────────── */
.bruma-metrics {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    gap: 14px;
    margin-bottom: 28px;
}
.bruma-metric {
    background: var(--bruma-blanco);
    border: var(--bruma-borde);
    border-radius: var(--bruma-radio-lg);
    padding: 20px;
    box-shadow: var(--bruma-sombra);
}
.bruma-metric-value {
    font-size: 28px;
    font-weight: 900;
    color: var(--bruma-lago);
    line-height: 1;
    margin-bottom: 4px;
}
.bruma-metric-label {
    font-size: 12px;
    color: var(--bruma-pizarra);
    text-transform: uppercase;
    letter-spacing: .6px;
    font-weight: 600;
}

/* ── Tabla ─────────────────────────────────────────────────────── */
.bruma-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 14px;
}
.bruma-table th {
    text-align: left;
    padding: 11px 16px;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .6px;
    color: var(--bruma-pizarra);
    border-bottom: 2px solid var(--bruma-fondo);
    background: #FAFBFD;
}
.bruma-table td {
    padding: 13px 16px;
    border-bottom: 1px solid #F0F4F8;
    vertical-align: middle;
}
.bruma-table tr:last-child td { border-bottom: none; }
.bruma-table tr:hover td { background: #FAFBFD; }

/* ── Grid de eventos ──────────────────────────────────────────── */
.bruma-eventos-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 20px;
}

/* ── Card de evento ───────────────────────────────────────────── */
.bruma-evento-card {
    background: var(--bruma-blanco);
    border: var(--bruma-borde);
    border-radius: var(--bruma-radio-lg);
    overflow: hidden;
    display: flex;
    flex-direction: column;
    text-decoration: none;
    color: inherit;
    box-shadow: var(--bruma-sombra);
    transition: transform .22s ease, box-shadow .22s ease;
}
.bruma-evento-card:hover {
    transform: translateY(-5px);
    box-shadow: var(--bruma-sombra-lg);
    text-decoration: none;
    color: inherit;
}
.bruma-card-img {
    height: 180px;
    position: relative;
    overflow: hidden;
    background: linear-gradient(135deg, var(--bruma-lago), var(--bruma-cielo));
    flex-shrink: 0;
}
.bruma-card-img img { width: 100%; height: 100%; object-fit: cover; display: block; }
.bruma-card-img-placeholder {
    width: 100%; height: 100%;
    display: flex; align-items: center; justify-content: center;
}
.bruma-card-date-badge {
    position: absolute;
    top: 12px; left: 12px;
    background: rgba(15,27,45,.75);
    backdrop-filter: blur(6px);
    color: #fff;
    border-radius: 8px;
    padding: 6px 10px;
    text-align: center;
    line-height: 1.2;
    border: 1px solid rgba(255,255,255,.15);
}
.bruma-card-date-badge .day   { font-size: 20px; font-weight: 900; display: block; }
.bruma-card-date-badge .month { font-size: 10px; text-transform: uppercase; letter-spacing: .8px; opacity: .85; display: block; }
.bruma-card-body {
    padding: 16px;
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 4px;
}
.bruma-card-title {
    font-size: 16px;
    font-weight: 700;
    color: var(--bruma-noche);
    margin: 0 0 4px;
    line-height: 1.3;
    letter-spacing: -.01em;
}
.bruma-card-meta {
    font-size: 13px;
    color: var(--bruma-pizarra);
    display: flex;
    align-items: center;
    gap: 5px;
}
.bruma-card-precio {
    font-size: 15px;
    font-weight: 700;
    color: var(--bruma-lago);
    margin-top: 6px;
}
.bruma-card-cta { margin-top: auto; padding-top: 14px; }

/* ── Sección header ───────────────────────────────────────────── */
.bruma-section-header {
    display: flex; align-items: baseline;
    justify-content: space-between;
    margin-bottom: 20px; gap: 12px;
}
.bruma-section-header h2 {
    font-size: 20px;
    font-weight: 800;
    color: var(--bruma-noche);
    margin: 0;
    letter-spacing: -.02em;
}
.bruma-section-header small { font-size: 13px; color: var(--bruma-pizarra); }

/* ── Estado vacío ─────────────────────────────────────────────── */
.bruma-empty {
    text-align: center;
    padding: 64px 24px;
    color: var(--bruma-pizarra);
}
.bruma-empty-onda {
    font-size: 52px;
    color: var(--bruma-neblina);
    margin-bottom: 16px;
    line-height: 1;
}
.bruma-empty p { font-size: 15px; margin: 0; }

/* ── "Cómo funciona" ──────────────────────────────────────────── */
.bruma-how {
    padding: 72px 28px;
    background: var(--bruma-blanco);
}
.bruma-how-inner { max-width: 1100px; margin: 0 auto; text-align: center; }
.bruma-how h2 {
    font-size: clamp(22px,3vw,32px);
    font-weight: 900;
    color: var(--bruma-noche);
    margin: 0 0 8px;
    letter-spacing: -.02em;
}
.bruma-how-sub { font-size: 16px; color: var(--bruma-pizarra); margin: 0 0 48px; }
.bruma-how-steps {
    display: grid;
    grid-template-columns: repeat(3,1fr);
    gap: 20px;
    text-align: left;
}
.bruma-step {
    padding: 28px;
    border-radius: var(--bruma-radio-lg);
    border: var(--bruma-borde);
    background: var(--bruma-fondo);
}
.bruma-step-num {
    width: 40px; height: 40px;
    border-radius: 12px;
    background: var(--bruma-lago);
    color: #fff;
    font-weight: 900;
    font-size: 18px;
    display: flex; align-items: center; justify-content: center;
    margin-bottom: 16px;
}
.bruma-step h3 {
    font-size: 17px;
    font-weight: 700;
    color: var(--bruma-noche);
    margin: 0 0 6px;
    letter-spacing: -.01em;
}
.bruma-step p { font-size: 14px; color: var(--bruma-pizarra); margin: 0; line-height: 1.6; }

/* ── Validador QR ─────────────────────────────────────────────── */
.bruma-validador {
    background: var(--bruma-noche);
    min-height: 100vh;
    display: flex; flex-direction: column;
    align-items: center; justify-content: center;
    color: #fff;
    font-family: var(--font-ui);
    padding: 24px;
}

/* ── Animaciones ──────────────────────────────────────────────── */
@keyframes bruma-pop {
    from { transform: scale(0); opacity: 0; }
    to   { transform: scale(1); opacity: 1; }
}
@keyframes bruma-draw {
    to { stroke-dashoffset: 0; }
}
.bruma-check {
    width: 72px; height: 72px;
    border-radius: 50%;
    background: var(--bruma-bosque);
    display: flex; align-items: center; justify-content: center;
    margin: 0 auto 20px;
    animation: bruma-pop .45s cubic-bezier(.36,1.56,.64,1) both;
}
.bruma-check svg {
    stroke: #fff;
    stroke-width: 3;
    stroke-dasharray: 40;
    stroke-dashoffset: 40;
    animation: bruma-draw .4s .3s ease forwards;
}

/* ── Gate Mi panel ────────────────────────────────────────────── */
.bruma-gate-wrap {
    min-height: calc(100vh - 64px);
    display: flex; flex-direction: column;
    align-items: center; justify-content: center;
    padding: 48px 24px;
}
.bruma-gate-brand { text-align: center; margin-bottom: 44px; }
.bruma-gate-tagline { font-size: 16px; color: var(--bruma-pizarra); margin: 12px 0 0; }
.bruma-gate-options {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 18px;
    width: 100%;
    max-width: 560px;
}
.bruma-gate-card {
    display: flex; flex-direction: column; align-items: center;
    text-align: center; padding: 32px 24px;
    border-radius: var(--bruma-radio-lg);
    border: var(--bruma-borde);
    background: var(--bruma-blanco);
    text-decoration: none; color: var(--bruma-noche);
    box-shadow: var(--bruma-sombra);
    transition: transform .2s, box-shadow .2s, border-color .2s;
    gap: 10px; min-height: 240px;
}
.bruma-gate-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--bruma-sombra-lg);
    border-color: var(--bruma-cielo);
    text-decoration: none; color: var(--bruma-noche);
}
.bruma-gate-card--warm { border-color: #F0D8C8; background: var(--bruma-humo); }
.bruma-gate-card--warm:hover { border-color: var(--bruma-lena); }
.bruma-gate-icon {
    width: 56px; height: 56px; border-radius: 16px;
    display: flex; align-items: center; justify-content: center;
    margin-bottom: 4px;
}
.bruma-gate-icon--lago { background: #E0EDFC; color: var(--bruma-lago); }
.bruma-gate-icon--lena { background: #FDEBD8; color: var(--bruma-lena); }
.bruma-gate-titulo {
    font-size: 18px; font-weight: 700;
    margin: 0; color: var(--bruma-noche); letter-spacing: -.01em;
}
.bruma-gate-desc { font-size: 13px; color: var(--bruma-pizarra); margin: 0; }

/* ── Footer completo ──────────────────────────────────────────── */
.bruma-footer-full {
    background: var(--bruma-noche);
    padding: 56px 28px 0;
    margin-top: auto;
}
.bruma-footer-grid {
    display: grid;
    grid-template-columns: 2fr 1fr 1fr;
    gap: 40px;
    max-width: 1100px;
    margin: 0 auto;
    padding-bottom: 40px;
    border-bottom: 1px solid rgba(255,255,255,.07);
}
.bruma-footer-heading {
    font-size: 11px; font-weight: 700;
    text-transform: uppercase; letter-spacing: .8px;
    color: #4A6A80; margin-bottom: 14px;
}
.bruma-footer-links {
    list-style: none; margin: 0; padding: 0;
    display: flex; flex-direction: column; gap: 9px;
}
.bruma-footer-links a { font-size: 14px; color: #7A9AB5; text-decoration: none; transition: color .15s; }
.bruma-footer-links a:hover { color: #fff; }
.bruma-footer-bottom {
    max-width: 1100px; margin: 0 auto;
    display: flex; align-items: center;
    justify-content: space-between;
    padding: 20px 0;
    font-size: 13px; color: #4A6A80;
    flex-wrap: wrap; gap: 8px;
}

/* ── Página de evento ─────────────────────────────────────────── */
.bruma-evento-hero {
    min-height: 360px;
    background: var(--bruma-lago);
    overflow: hidden;
    position: relative;
    display: flex; align-items: flex-end;
    margin-bottom: 32px;
}
.bruma-evento-hero img {
    position: absolute; inset: 0;
    width: 100%; height: 100%;
    object-fit: cover; opacity: .55;
}
.bruma-evento-hero-content {
    position: relative; z-index: 1;
    padding: 36px;
    width: 100%;
    background: linear-gradient(to top, rgba(7,22,41,.95) 0%, rgba(7,22,41,.3) 65%, transparent 100%);
}
.bruma-evento-title {
    font-size: clamp(24px,4vw,44px);
    font-weight: 900;
    color: #fff; margin: 0 0 14px;
    line-height: 1.1;
    letter-spacing: -.02em;
}
.bruma-evento-chips { display: flex; flex-wrap: wrap; gap: 10px; }
.bruma-chip {
    display: inline-flex; align-items: center; gap: 6px;
    background: rgba(255,255,255,.15);
    backdrop-filter: blur(6px);
    border: 1px solid rgba(255,255,255,.2);
    color: #fff; border-radius: 100px;
    padding: 6px 14px; font-size: 13px; font-weight: 500;
}

/* ── Ticket widget ────────────────────────────────────────────── */
.bruma-ticket-widget {
    background: var(--bruma-blanco);
    border: var(--bruma-borde);
    border-radius: var(--bruma-radio-lg);
    overflow: hidden;
    box-shadow: var(--bruma-sombra-lg);
}
.bruma-ticket-header {
    padding: 18px 22px;
    border-bottom: 1px solid #F0F4F8;
    background: #FAFBFD;
}
.bruma-ticket-row {
    display: flex; align-items: center;
    justify-content: space-between; gap: 14px;
    padding: 16px 22px;
    border-bottom: 1px solid #F0F4F8;
    transition: background .15s;
}
.bruma-ticket-row:last-child { border-bottom: none; }
.bruma-ticket-row:hover { background: #FAFBFD; }
.bruma-ticket-name { font-weight: 700; color: var(--bruma-noche); margin-bottom: 2px; }
.bruma-ticket-detail { font-size: 12px; color: var(--bruma-pizarra); }
.bruma-ticket-price { font-size: 19px; font-weight: 900; color: var(--bruma-lago); white-space: nowrap; }
.bruma-ticket-actions { display: flex; align-items: center; gap: 8px; flex-shrink: 0; }

/* ── Checkout ─────────────────────────────────────────────────── */
.bruma-checkout-wrap {
    max-width: 960px;
    margin: 0 auto;
    padding: 36px 28px;
    display: grid;
    grid-template-columns: 1fr 400px;
    gap: 28px;
    align-items: start;
}
.bruma-checkout-summary { position: sticky; top: 80px; }

/* ── Confirmación ─────────────────────────────────────────────── */
.bruma-confirm-wrap {
    max-width: 560px; margin: 0 auto;
    padding: 48px 28px; text-align: center;
}
.bruma-confirm-icon {
    width: 84px; height: 84px; border-radius: 50%;
    background: var(--bruma-bosque);
    display: flex; align-items: center; justify-content: center;
    margin: 0 auto 24px;
    animation: bruma-pop .5s cubic-bezier(.36,1.56,.64,1) both;
}
.bruma-confirm-icon svg {
    stroke: #fff; stroke-width: 2.5;
    stroke-dasharray: 50; stroke-dashoffset: 50;
    animation: bruma-draw .4s .4s ease forwards;
}
.bruma-ticket-card {
    background: var(--bruma-blanco);
    border: var(--bruma-borde);
    border-radius: var(--bruma-radio-lg);
    padding: 18px;
    text-align: left;
    display: flex; align-items: center; gap: 16px;
    margin-bottom: 12px;
    box-shadow: var(--bruma-sombra);
}
.bruma-ticket-qr img {
    border-radius: 8px;
    border: 1px solid #E2EAF2;
    display: block;
}

/* ── Dashboard organizador ─────────────────────────────────────── */
.bd-sidebar {
    position: fixed; top: 0; left: 0; height: 100vh; width: 230px;
    background: var(--bruma-noche);
    display: flex; flex-direction: column;
    z-index: 100;
    border-right: 1px solid rgba(255,255,255,.05);
}
.bd-brand { padding: 18px 16px; border-bottom: 1px solid rgba(255,255,255,.05); flex-shrink: 0; }
.bd-nav { flex: 1; overflow-y: auto; padding: 12px 8px; }
.bd-item {
    display: flex; align-items: center; gap: 10px;
    padding: 9px 12px; border-radius: 8px;
    text-decoration: none; font-size: 13.5px; font-weight: 500;
    color: #6B8FAD; transition: background .15s, color .15s;
    margin-bottom: 2px;
}
.bd-item:hover { background: rgba(255,255,255,.06); color: #B8D4EA; }
.bd-item.active { background: rgba(13,79,139,.5); color: #fff; }
.bd-item svg { width: 17px; height: 17px; flex-shrink: 0; }
.bd-foot { border-top: 1px solid rgba(255,255,255,.05); padding: 14px 12px; flex-shrink: 0; }
.bd-user { display: flex; align-items: center; gap: 10px; margin-bottom: 10px; }
.bd-avatar {
    width: 34px; height: 34px; border-radius: 50%; flex-shrink: 0;
    background: var(--bruma-lago); color: #fff;
    display: flex; align-items: center; justify-content: center;
    font-size: 13px; font-weight: 700;
}
.bd-username { font-size: 13px; font-weight: 600; color: #B8D4EA; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.bd-role { font-size: 11px; color: #4A6A80; }
.bd-logout {
    display: flex; align-items: center; gap: 8px;
    padding: 8px 10px; border-radius: 7px; text-decoration: none;
    font-size: 12.5px; color: #4A6A80;
    transition: background .15s, color .15s;
}
.bd-logout:hover { background: rgba(255,255,255,.05); color: #7A9AB5; }
.bd-main { margin-left: 230px; min-height: 100vh; display: flex; flex-direction: column; }
.bd-topbar {
    height: 58px; background: var(--bruma-blanco);
    border-bottom: 1px solid #E2EAF2;
    display: flex; align-items: center;
    padding: 0 28px; gap: 12px;
    position: sticky; top: 0; z-index: 50;
    box-shadow: 0 1px 0 #E2EAF2;
}
.bd-topbar h1 { font-size: 15px; font-weight: 700; color: var(--bruma-noche); margin: 0; letter-spacing: -.01em; }
.bd-content { flex: 1; padding: 28px; background: var(--bruma-fondo); }
.bd-overlay { display: none; position: fixed; inset: 0; background: rgba(0,0,0,.45); z-index: 99; }
.bd-overlay.show { display: block; }

/* ── Registro / Auth forms ────────────────────────────────────── */
.bruma-rol-card { cursor: pointer; display: block; }
.bruma-rol-card input[type="radio"] { position: absolute; opacity: 0; pointer-events: none; }
.bruma-rol-inner {
    display: flex; flex-direction: column; align-items: center;
    gap: 6px; padding: 18px 12px;
    border: 2px solid #D0DCE8;
    border-radius: var(--bruma-radio-lg);
    text-align: center;
    transition: border-color .18s, background .18s, color .18s;
    color: var(--bruma-pizarra);
}
.bruma-rol-card input:checked + .bruma-rol-inner {
    border-color: var(--bruma-lago);
    background: #EBF4FF;
    color: var(--bruma-lago);
}
.bruma-rol-titulo { font-size: 13px; font-weight: 700; color: inherit; }
.bruma-rol-sub { font-size: 11px; color: var(--bruma-pizarra); }

/* ── Contenido de descripción (output del editor rich text) ─── */
.bruma-desc-contenido {
    font-size: 15px;
    color: var(--bruma-pizarra);
    line-height: 1.85;
}
.bruma-desc-contenido p   { margin: 0 0 14px; }
.bruma-desc-contenido p:last-child { margin-bottom: 0; }
.bruma-desc-contenido strong { color: var(--bruma-noche); font-weight: 600; }
.bruma-desc-contenido em   { font-style: italic; }
.bruma-desc-contenido ul,
.bruma-desc-contenido ol   { padding-left: 22px; margin: 0 0 14px; }
.bruma-desc-contenido li   { margin-bottom: 5px; }
.bruma-desc-contenido a    { color: var(--bruma-cielo); text-decoration: underline; }
.bruma-desc-contenido a:hover { color: var(--bruma-lago); }

/* ── Layout detalle de evento ────────────────────────────────── */
.bruma-evento-grid {
    display: grid;
    grid-template-columns: 1fr 360px;
    gap: 28px;
    align-items: start;
}
.bruma-evento-ticket-col { position: sticky; top: 80px; }

/* ── Galería de evento ────────────────────────────────────────── */
.bruma-galeria {
    margin-top: 36px;
    padding-top: 32px;
    border-top: 1px solid #E2EAF2;
}
.bruma-galeria-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    grid-auto-rows: 200px;
    gap: 8px;
}
.bruma-galeria-grid--featured .bruma-galeria-item:first-child {
    grid-column: 1 / 3;
    grid-row: 1 / 3;
}
.bruma-galeria-item {
    border-radius: 10px;
    overflow: hidden;
    cursor: pointer;
    background: var(--bruma-neblina);
    position: relative;
}
.bruma-galeria-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform .32s ease;
}
.bruma-galeria-item:hover img { transform: scale(1.05); }
.bruma-galeria-mas {
    position: absolute;
    inset: 0;
    background: rgba(15,27,45,.65);
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-size: 24px;
    font-weight: 700;
    letter-spacing: -.5px;
    pointer-events: none;
}

/* ── Tabla scrollable ─────────────────────────────────────────── */
.bruma-table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }

/* ── Grid 2 columnas → 1 en móvil ────────────────────────────── */
.bruma-grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }

/* ── Responsive ────────────────────────────────────────────────── */
@media (max-width: 768px) {
    .bruma-nav { padding: 0 16px; }
    .bruma-how-steps { grid-template-columns: 1fr; }
    .bruma-footer-grid { grid-template-columns: 1fr 1fr; gap: 24px; }
    .bruma-checkout-wrap { grid-template-columns: 1fr; }
    .bruma-checkout-summary { position: static; order: -1; }
    .bd-sidebar { transform: translateX(-100%); transition: transform .2s; }
    .bd-sidebar.open { transform: translateX(0); }
    .bd-main { margin-left: 0; }
    .bd-content { padding: 20px 16px; }
    .bruma-container { padding: 0 16px; }
    .bruma-grid-2 { grid-template-columns: 1fr; }
    .bruma-evento-grid { grid-template-columns: 1fr; }
    .bruma-evento-ticket-col { position: static; order: -1; }
    .bruma-galeria-grid {
        grid-template-columns: repeat(2, 1fr);
        grid-auto-rows: 150px;
    }
    .bruma-galeria-grid--featured .bruma-galeria-item:first-child {
        grid-column: 1 / -1;
        grid-row: auto;
    }
}
@media (max-width: 480px) {
    .bruma-hero-wrap { padding: 50px 20px 60px; }
    .bruma-gate-options { grid-template-columns: 1fr; max-width: 320px; }
    .bruma-footer-grid { grid-template-columns: 1fr; }
    .bruma-eventos-grid { grid-template-columns: 1fr; }
    .bruma-confirm-wrap { padding: 32px 16px; }
    .bruma-ticket-card { flex-direction: column; align-items: flex-start; }
    .bruma-ticket-qr img { width: 80px; height: 80px; }
    .bruma-evento-hero-content { padding: 24px 20px; }
}
