/* ── Variables de marca El Mentidero ───────────────── */
:root {
    --mb-rojo:        #EA2027;
    --mb-negro:       #221F1F;
    --mb-gris-osc:   #57585B;
    --mb-gris-cla:   #A6A8AB;
    --mb-fondo:      #F4F4F4;
    --mb-blanco:     #FFFFFF;
    --mb-exito:      #27AE60;
    --mb-alerta:     #F39C12;
    --mb-sombra:     0 2px 12px rgba(0,0,0,0.10);
    --mb-radio:      4px;
    --mb-transicion: 0.18s ease;
}

/* ── Contenedor base ────────────────────────────────── */
.mb-wrap {
    font-family: Arial, Helvetica, sans-serif;
    max-width: 960px;
    margin: 0 auto;
    padding: 24px 16px;
    color: var(--mb-negro);
    box-sizing: border-box;
}

/* ── Paso / sección ─────────────────────────────────── */
.mb-step { animation: mbFadeIn 0.25s ease; }
@keyframes mbFadeIn { from { opacity:0; transform:translateY(8px); } to { opacity:1; transform:none; } }

/* ── Títulos de paso ────────────────────────────────── */
.mb-step-title {
    font-size: 20px;
    font-weight: bold;
    color: #f0ece3;
    margin: 0 0 20px;
    padding-bottom: 10px;
    border-bottom: 3px solid var(--mb-rojo);
}

/* ── Selector de función ────────────────────────────── */
.mb-select {
    width: 100%;
    padding: 12px 16px;
    border: 2px solid var(--mb-gris-cla);
    border-radius: var(--mb-radio);
    font-size: 15px;
    background: var(--mb-blanco);
    color: var(--mb-negro);
    cursor: pointer;
    transition: border-color var(--mb-transicion);
}
.mb-select:focus { outline: none; border-color: var(--mb-rojo); }

/* ── Info de función seleccionada ───────────────────── */
.mb-funcion-header {
    background: var(--mb-negro);
    color: var(--mb-blanco);
    padding: 16px 20px;
    border-radius: var(--mb-radio);
    margin-bottom: 20px;
    border-left: 4px solid var(--mb-rojo);
}
.mb-funcion-nombre { font-size: 18px; font-weight: bold; margin-bottom: 4px; }
.mb-funcion-meta   { font-size: 14px; color: var(--mb-gris-cla); }

/* ── Mapa de asientos ───────────────────────────────── */
.mb-mapa {
    background: #1a1a1a;
    border-radius: var(--mb-radio);
    padding: 24px 20px 16px;
    overflow-x: auto;
    margin-bottom: 16px;
    display: flex;
    flex-direction: column;
    align-items: center;
    min-width: fit-content;
}
.mb-zona-leyenda {
    display: flex;
    gap: 16px;
    margin-bottom: 16px;
    width: 100%;
    justify-content: center;
}
.mb-zona-tag {
    font-size: 11px;
    font-weight: bold;
    letter-spacing: 1px;
}
.mb-escenario {
    text-align: center;
    background: #2a2a2a;
    color: #888;
    border: 1px solid #555;
    padding: 10px 24px;
    border-radius: 4px;
    font-size: 11px;
    letter-spacing: 3px;
    font-weight: bold;
    margin-top: 16px;
    text-transform: uppercase;
    width: 100%;
    box-sizing: border-box;
}
.mb-fila {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 5px;
    margin-bottom: 6px;
}
.mb-fila-label {
    color: var(--mb-gris-cla);
    font-size: 12px;
    width: 18px;
    text-align: center;
    flex-shrink: 0;
    margin-right: 4px;
}
.mb-wheelchair {
    font-size: 18px;
    margin-right: 4px;
    opacity: 0.8;
}
.mb-asiento {
    width: 32px;
    height: 32px;
    border-radius: 4px 4px 6px 6px;
    border: none;
    font-size: 10px;
    font-weight: bold;
    cursor: pointer;
    transition: transform var(--mb-transicion), background var(--mb-transicion);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}
.mb-asiento.disponible       { background: var(--seat-bg, transparent); color: var(--mb-blanco); }
.mb-asiento.disponible:hover { background: var(--seat-bg, transparent); filter: brightness(1.25); transform: scale(1.12); }
.mb-asiento.seleccionado     { background: #FFD700 !important; color: #111 !important; transform: scale(1.15); box-shadow: 0 0 0 3px #fff, 0 0 0 5px #FFD700; font-weight: bold; }
.mb-asiento.ocupado          { background: #555; color: #888; cursor: not-allowed; }

/* ── Leyenda ────────────────────────────────────────── */
.mb-leyenda {
    display: flex;
    gap: 16px;
    justify-content: center;
    flex-wrap: wrap;
    margin-bottom: 20px;
}
.mb-legen {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 13px;
    color: rgba(240,236,227,.7);
}
.mb-legen::before {
    content: '';
    width: 16px; height: 16px;
    border-radius: 3px;
    display: inline-block;
}
.mb-legen.disponible::before  { background: #3A9D5D; }
.mb-legen.seleccionado::before { background: #FFD700; }
.mb-legen.ocupado::before     { background: #555; }

/* ── Resumen de selección ───────────────────────────── */
.mb-resumen {
    background: var(--mb-blanco);
    border: 2px solid var(--mb-rojo);
    border-radius: var(--mb-radio);
    padding: 16px 20px;
    margin-bottom: 16px;
    color: var(--mb-negro);
}
.mb-resumen p { margin: 4px 0; font-size: 15px; color: var(--mb-negro); }
#mb-sel-fecha { color: #666 !important; }

/* ── Formulario ─────────────────────────────────────── */
.mb-form { max-width: 480px; }
.mb-campo { margin-bottom: 16px; }
.mb-campo label { display: block; font-size: 13px; font-weight: bold; color: rgba(240,236,227,.7); margin-bottom: 5px; }
.mb-campo input {
    width: 100%;
    padding: 10px 14px;
    border: 2px solid var(--mb-gris-cla);
    border-radius: var(--mb-radio);
    font-size: 15px;
    color: var(--mb-negro);
    transition: border-color var(--mb-transicion);
    box-sizing: border-box;
}
.mb-campo input:focus { outline: none; border-color: var(--mb-rojo); }

/* ── Resumen de compra ──────────────────────────────── */
.mb-resumen-compra {
    background: #f9f9f9;
    border-radius: var(--mb-radio);
    padding: 14px 16px;
    margin-bottom: 20px;
}
.mb-resumen-items {}
.mb-resumen-item {
    display: flex;
    justify-content: space-between;
    font-size: 14px;
    padding: 5px 0;
    border-bottom: 1px solid #eee;
}
.mb-resumen-item:last-child { border-bottom: none; }
.mb-resumen-total { font-weight: bold; font-size: 15px; padding-top: 8px; }

/* ── Código de descuento ────────────────────────────── */
.mb-descuento-wrap { display: flex; gap: 8px; }
.mb-descuento-wrap input { flex: 1; text-transform: uppercase; }
.mb-desc-ok    { color: var(--mb-exito); font-size: 13px; margin-top: 5px; display: block; }
.mb-desc-error { color: var(--mb-rojo);  font-size: 13px; margin-top: 5px; display: block; }

/* ── Total final ────────────────────────────────────── */
.mb-total-final {
    font-size: 18px;
    font-weight: bold;
    text-align: right;
    padding: 12px 0;
    border-top: 2px solid var(--mb-rojo);
    margin: 16px 0;
    color: #f0ece3;
}

/* ── Timer ──────────────────────────────────────────── */
.mb-timer {
    background: var(--mb-negro);
    color: var(--mb-blanco);
    padding: 10px 16px;
    border-radius: var(--mb-radio);
    font-size: 14px;
    text-align: center;
    margin-bottom: 16px;
}
.mb-timer strong { color: var(--mb-rojo); font-size: 18px; }

/* ── Botones ────────────────────────────────────────── */
.mb-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: 12px 24px;
    border: none;
    border-radius: var(--mb-radio);
    font-size: 15px;
    font-weight: bold;
    cursor: pointer;
    transition: background var(--mb-transicion), transform var(--mb-transicion);
    text-decoration: none;
}
.mb-btn:active { transform: scale(0.97); }
.mb-btn-primario  { background: var(--mb-rojo); color: var(--mb-blanco); width: 100%; text-align: center; }
.mb-btn-primario:hover { background: #c5151b; }
.mb-btn-secundario { background: var(--mb-negro); color: var(--mb-blanco); }
.mb-btn-secundario:hover { background: #3a3a3a; }
.mb-btn-pagar {
    background: var(--mb-rojo); color: var(--mb-blanco);
    width: 100%; text-align: center; font-size: 17px; padding: 14px;
}
.mb-btn-pagar:hover { background: #c5151b; }
.mb-btn-link { background: none; color: var(--mb-gris-osc); font-size: 14px; padding: 8px 0; }
.mb-btn-link:hover { color: var(--mb-rojo); }

/* ── Errores ────────────────────────────────────────── */
.mb-errores {
    background: #FFF0F0;
    border: 1px solid #FFCCCC;
    border-radius: var(--mb-radio);
    padding: 12px 16px;
    margin-bottom: 14px;
    color: #c0392b !important;
    font-size: 14px;
}
.mb-errores p { margin: 3px 0; color: #c0392b !important; }

/* ── Avisos genéricos ───────────────────────────────── */
.mb-aviso {
    background: var(--mb-fondo);
    border-radius: var(--mb-radio);
    padding: 30px;
    text-align: center;
    font-size: 16px;
    color: var(--mb-gris-osc);
}
.mb-aviso.mb-error { background: #FFF0F0; color: var(--mb-rojo); }
.mb-aviso-pendiente { text-align: center; padding: 40px; }
.mb-aviso-pendiente .mb-icon { font-size: 56px; margin-bottom: 16px; }

/* ── Loading ────────────────────────────────────────── */
.mb-loading-box {
    text-align: center;
    padding: 40px;
    color: var(--mb-gris-osc);
}
.mb-spinner {
    width: 36px; height: 36px;
    border: 4px solid var(--mb-fondo);
    border-top-color: var(--mb-rojo);
    border-radius: 50%;
    animation: mbSpin 0.8s linear infinite;
    margin: 0 auto 12px;
}
@keyframes mbSpin { to { transform: rotate(360deg); } }

/* ── Confirmación ───────────────────────────────────── */
.mb-confirmacion { max-width: 680px; }
.mb-conf-header { text-align: center; padding: 24px 0 16px; }
.mb-conf-check  { font-size: 56px; margin-bottom: 8px; }
.mb-conf-header h2 { font-size: 26px; color: var(--mb-exito); margin: 0 0 8px; }
.mb-conf-funcion {
    background: var(--mb-negro);
    color: var(--mb-blanco);
    border-radius: var(--mb-radio);
    padding: 20px 24px;
    margin: 16px 0;
    border-left: 4px solid var(--mb-rojo);
}
.mb-conf-obra { font-size: 20px; font-weight: bold; margin-bottom: 6px; }
.mb-conf-meta { font-size: 14px; color: var(--mb-gris-cla); margin-top: 3px; }
.mb-conf-boletos { display: flex; flex-wrap: wrap; gap: 16px; justify-content: center; margin: 20px 0; }
.mb-conf-boleto {
    background: var(--mb-blanco);
    color: var(--mb-negro);
    border: 2px solid var(--mb-rojo);
    border-radius: 8px;
    padding: 20px;
    text-align: center;
    min-width: 180px;
    box-shadow: var(--mb-sombra);
}
.mb-conf-asiento-num  { font-size: 38px; font-weight: bold; color: var(--mb-negro); }
.mb-conf-asiento-zona { font-size: 13px; color: var(--mb-gris-osc); margin-bottom: 12px; }
.mb-conf-qr           { width: 160px; height: 160px; border: 1px solid #eee; border-radius: 4px; }
.mb-conf-ticket-id    { font-size: 10px; color: var(--mb-gris-osc); margin-top: 8px; }
.mb-conf-instrucciones {
    background: #f9f9f9;
    border-radius: var(--mb-radio);
    padding: 16px;
    font-size: 14px;
    color: var(--mb-gris-osc);
    margin: 0 0 16px;
}
.mb-conf-total {
    font-size: 17px;
    text-align: right;
    border-top: 2px solid var(--mb-rojo);
    padding-top: 14px;
    margin-top: 14px;
}

/* ── Validador en puerta ────────────────────────────── */
.mb-validador { max-width: 540px; }
.mb-val-header { display: flex; align-items: center; gap: 12px; margin-bottom: 20px; }
.mb-val-logo   { height: 40px; }
.mb-val-header h2 { margin: 0; font-size: 22px; }
.mb-val-busqueda, .mb-val-busq-nombre { display: flex; gap: 8px; margin-bottom: 12px; }
.mb-val-busqueda input, .mb-val-busq-nombre input {
    flex: 1; padding: 12px 16px; border: 2px solid var(--mb-gris-cla);
    border-radius: var(--mb-radio); font-size: 16px;
}
.mb-val-busqueda input:focus, .mb-val-busq-nombre input:focus { outline: none; border-color: var(--mb-rojo); }
.mb-val-resultados { position: relative; }
.mb-val-result-item {
    padding: 10px 14px; background: var(--mb-blanco);
    border: 1px solid #eee; cursor: pointer; font-size: 14px;
}
.mb-val-result-item:hover { background: var(--mb-fondo); }
.mb-val-resultado { margin-top: 12px; }
.mb-val-tarjeta {
    border-radius: 8px; padding: 24px; text-align: center;
    animation: mbFadeIn 0.2s ease;
}
.mb-val-ok     { background: #D4EFDF; border: 3px solid var(--mb-exito); }
.mb-val-usado  { background: #FEF9E7; border: 3px solid var(--mb-alerta); }
.mb-val-error  { background: #FADBD8; border: 3px solid var(--mb-rojo); }
.mb-val-icono  { font-size: 48px; margin-bottom: 8px; }
.mb-val-msg    { font-size: 22px; font-weight: bold; margin-bottom: 8px; }
.mb-val-nombre { font-size: 20px; margin-bottom: 4px; }
.mb-val-asiento { font-size: 16px; color: var(--mb-gris-osc); }
.mb-val-canal   { font-size: 13px; color: var(--mb-gris-cla); margin-top: 4px; }
.mb-val-manual  { margin-top: 16px; background: var(--mb-fondo); border-radius: var(--mb-radio); padding: 16px; }
.mb-val-manual p { margin: 0 0 8px; font-size: 14px; }
.mb-val-manual input { padding: 8px 12px; border: 1px solid #ccc; border-radius: var(--mb-radio); width: 200px; margin-right: 8px; }
.mb-sin-res { font-size: 13px; color: var(--mb-gris-cla); padding: 8px; }

/* ── Hero horizontal móvil (solo visible en mobile) ─── */
.mb-evento-hero-mobile {
    display: none;
}
@media (max-width: 580px) {
    .mb-evento-hero-mobile {
        display: block;
        width: 100%;
        aspect-ratio: 16 / 9;
        overflow: hidden;
        border-radius: 8px;
        margin-bottom: 1rem;
        background: #0d0d0d;
    }
    .mb-evento-hero-video {
        width: 100%;
        height: 100%;
        object-fit: cover;
        display: block;
    }
}

/* ── Evento individual — layout Amazon ──────────────── */
.mb-evento-layout {
    display: grid;
    grid-template-columns: 220px 1fr 280px;
    gap: 2rem;
    align-items: start;
    margin-bottom: 2.5rem;
}

/* Columna 1: imagen/video vertical */
.mb-evento-img-col { position: sticky; top: 100px; }
.mb-evento-img {
    width: 100%;
    border-radius: 6px;
    display: block;
    box-shadow: 0 4px 20px rgba(0,0,0,.35);
    object-fit: cover;
}

/* Columna 2: información */
.mb-evento-titulo {
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-size: clamp(1.6rem, 3vw, 2.2rem);
    font-weight: 400;
    line-height: 1.2;
    margin: 0 0 .75rem;
    color: #f0ece3;
}
.mb-evento-subtitulo {
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-size: clamp(1rem, 1.8vw, 1.25rem);
    font-style: italic;
    font-weight: 300;
    color: rgba(240,236,227,.65);
    margin: -0.4rem 0 0.75rem;
    line-height: 1.3;
}
.mb-evento-sinopsis {
    font-size: .95rem;
    line-height: 1.7;
    color: rgba(240,236,227,.75);
    margin: 0 0 1.25rem;
}
.mb-evento-specs {
    width: 100%;
    border-collapse: collapse;
    font-size: .88rem;
    color: rgba(240,236,227,.85);
    margin-top: 1rem;
    border-top: 1px solid rgba(255,255,255,.12);
}
.mb-evento-specs tr { border-bottom: 1px solid rgba(255,255,255,.08); }
.mb-evento-specs th {
    text-align: left;
    padding: .6rem 1rem .6rem 0;
    font-weight: 600;
    color: rgba(240,236,227,.5);
    width: 130px;
    vertical-align: top;
}
.mb-evento-specs td { padding: .6rem 0; color: rgba(240,236,227,.85); }

/* Columna 3: buy box */
.mb-evento-buy-col { position: sticky; top: 100px; }
.mb-buybox {
    border: 1px solid #d5d9d9;
    border-radius: 8px;
    padding: 1.25rem;
    background: #fff;
}
.mb-buybox__precio {
    font-size: 1.75rem;
    font-weight: 700;
    color: #0f1111;
    margin-bottom: .25rem;
    line-height: 1;
}
.mb-buybox__precio-max {
    font-size: 1.2rem;
    font-weight: 400;
    color: #555;
}
.mb-buybox__disponible {
    font-size: .95rem;
    font-weight: 600;
    color: #007600;
    margin-bottom: .5rem;
}
.mb-buybox__divider {
    border: none;
    border-top: 1px solid #e8e8e8;
    margin: .75rem 0;
}
.mb-buybox__label {
    display: block;
    font-size: .8rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: #555;
    margin-bottom: .4rem;
}
.mb-buybox__select {
    width: 100%;
    margin-bottom: .75rem;
    font-size: .9rem;
}
.mb-buybox__btns { display: flex; flex-direction: column; gap: .5rem; }
.mb-buybox__cta {
    width: 100%;
    text-align: center;
    justify-content: center;
    font-size: 1rem;
    padding: .75rem 1rem;
    border-radius: 20px;
}

/* Responsive */
@media (max-width: 900px) {
    .mb-evento-layout { grid-template-columns: 160px 1fr; }
    .mb-evento-buy-col { grid-column: 1 / -1; position: static; }
    .mb-buybox { max-width: 420px; }
    .mb-evento-img-col { position: static; }
}
@media (max-width: 580px) {
    .mb-evento-layout { grid-template-columns: 1fr; }
    .mb-evento-img-col { display: none; }
}

/* ── Paso Extras ────────────────────────────────────── */
.mb-extras-subtitulo {
    font-size: .88rem;
    color: rgba(240,236,227,.55);
    margin: -12px 0 20px;
}
.mb-extras-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: 14px;
    margin-bottom: 24px;
}
.mb-extra-card {
    background: #1a1a1a;
    border: 2px solid #2a2a2a;
    border-radius: 8px;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    transition: border-color .2s;
}
.mb-extra-card--activa { border-color: var(--mb-rojo); }
.mb-extra-img {
    width: 100%;
    aspect-ratio: 4/3;
    object-fit: cover;
    display: block;
}
.mb-extra-img--placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 2.5rem;
    background: #111;
    color: #555;
}
.mb-extra-body {
    padding: 12px 14px;
    flex: 1;
}
.mb-extra-tipo {
    font-size: 11px;
    color: var(--mb-gris-cla);
    display: block;
    margin-bottom: 4px;
}
.mb-extra-nombre {
    font-size: 15px;
    font-weight: bold;
    color: #f0ece3;
    margin-bottom: 4px;
    line-height: 1.3;
}
.mb-extra-desc {
    font-size: 12px;
    color: #888;
    margin-bottom: 8px;
    line-height: 1.4;
}
.mb-extra-precio {
    font-size: 16px;
    font-weight: bold;
    color: var(--mb-rojo);
}
.mb-extra-ctrl {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 16px;
    padding: 10px 14px;
    border-top: 1px solid #2a2a2a;
    background: #111;
}
.mb-extra-btn {
    width: 32px; height: 32px;
    border-radius: 50%;
    border: 2px solid #444;
    background: none;
    color: #ccc;
    font-size: 18px;
    cursor: pointer;
    line-height: 1;
    display: flex; align-items: center; justify-content: center;
    transition: border-color .15s, color .15s;
}
.mb-extra-btn:hover { border-color: var(--mb-rojo); color: var(--mb-rojo); }
.mb-extra-qty {
    font-size: 18px;
    font-weight: bold;
    color: #f0ece3;
    min-width: 24px;
    text-align: center;
}
.mb-extras-footer {
    border-top: 1px solid #2a2a2a;
    padding-top: 20px;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
}
.mb-extras-total-wrap {
    font-size: 1.1rem;
    color: #f0ece3;
    margin-bottom: 4px;
}
.mb-extras-total-wrap strong { font-size: 1.4rem; color: var(--mb-rojo); margin-left: 6px; }
@media (max-width: 480px) {
    .mb-extras-grid { grid-template-columns: 1fr 1fr; gap: 10px; }
}

/* ── Taquilla ───────────────────────────────────────── */
.mb-taquilla { max-width: 680px; }
.mb-taq-header { display: flex; align-items: center; gap: 12px; background: var(--mb-negro); padding: 14px 20px; border-radius: var(--mb-radio); margin-bottom: 20px; border-left: 4px solid var(--mb-rojo); }
.mb-taq-logo   { height: 36px; }
.mb-taq-header h2 { margin: 0; font-size: 20px; color: var(--mb-blanco); flex: 1; }
.mb-taq-vendedor { font-size: 13px; color: var(--mb-gris-cla); }
.mb-taq-paso { animation: mbFadeIn 0.2s ease; }
.mb-taq-tipo-pago { display: flex; gap: 20px; margin: 12px 0; font-size: 15px; }
.mb-taq-tipo-pago label { cursor: pointer; display: flex; align-items: center; gap: 6px; }
.mb-taq-exito { text-align: center; padding: 30px 0; }
.mb-taq-exito .mb-icon { font-size: 56px; margin-bottom: 12px; }
.mb-taq-exito h3 { font-size: 22px; color: var(--mb-exito); }
.mb-taq-ticket-gen { background: var(--mb-blanco); color: var(--mb-negro); border-radius: var(--mb-radio); padding: 16px; margin-bottom: 12px; display: inline-block; }
.mb-taq-ticket-gen p { color: var(--mb-negro); }

/* ── Responsive ─────────────────────────────────────── */
@media (max-width: 600px) {
    .mb-asiento { width: 27px; height: 27px; font-size: 9px; }
    .mb-fila { gap: 3px; }
    .mb-conf-boletos { flex-direction: column; align-items: center; }
    .mb-taq-tipo-pago { flex-direction: column; gap: 8px; }
    .mb-val-busqueda, .mb-val-busq-nombre { flex-direction: column; }
}

/* ── Obras grid 2 columnas ───────────────────────────── */
.mb-obras-grid-pub {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 20px;
    margin-bottom: 16px;
}
.mb-obra-card-pub {
    background: #1a1a1a !important;
    border-radius: 8px !important;
    overflow: hidden !important;
    display: flex !important;
    flex-direction: column !important;
    border: 1px solid #2a2a2a !important;
}
.mb-obra-img-wrap {
    width: 100%;
    aspect-ratio: 2/3;
    overflow: hidden;
}
.mb-obra-img-pub {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.mb-obra-card-body {
    padding: 16px;
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.mb-obra-titulo {
    font-size: 18px !important;
    font-weight: bold !important;
    color: #ffffff !important;
    margin: 0 !important;
    line-height: 1.3 !important;
}
.mb-obra-subtitulo {
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-size: 13px;
    font-style: italic;
    font-weight: 300;
    color: rgba(240,236,227,.6);
    margin: -2px 0 4px;
    line-height: 1.3;
}
.mb-obra-sala-tag {
    font-size: 11px;
    color: var(--mb-gris-cla);
}
.mb-obra-precios { margin: 0; }
.mb-precio-tag {
    background: #EA2027 !important;
    color: #ffffff !important;
    padding: 3px 10px !important;
    border-radius: 20px !important;
    font-size: 12px !important;
    font-weight: bold !important;
    display: inline-block !important;
}
.mb-obra-fecha-inicio {
    font-size: 13px;
    font-weight: bold;
    color: var(--mb-blanco);
}
.mb-obra-sinopsis-txt {
    color: #bbbbbb !important;
    font-size: 12px !important;
    line-height: 1.5 !important;
    margin: 0 !important;
}
.mb-obra-creditos-txt {
    color: #888;
    font-size: 11px;
    line-height: 1.4;
    margin: 0;
    font-style: italic;
}
.mb-obra-produccion-txt {
    color: #888;
    font-size: 11px;
    margin: 0;
    font-style: italic;
}
.mb-fecha-selector {
    display: flex;
    flex-direction: column;
    gap: 8px;
    margin-top: 8px;
    padding-top: 12px;
    border-top: 1px solid #2a2a2a;
}
.mb-fecha-label {
    font-size: 12px;
    color: var(--mb-gris-cla);
    font-weight: bold;
}
.mb-select-fecha { width: 100%; }
.mb-pocos-boletos { color: #F39C12; font-size: 11px; font-weight: bold; }

@media (max-width: 600px) {
    .mb-obras-grid-pub { grid-template-columns: 1fr; gap: 16px; }
    .mb-obra-img-wrap { aspect-ratio: 3/2; }
    .mb-obra-card-body { padding: 14px; }
    .mb-obra-titulo { font-size: 16px; }
}

/* ── Admin obras grid ────────────────────────────────── */
.mb-obras-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: 20px;
}
.mb-obra-card {
    background: #1e1e1e;
    border: 1px solid #333;
    border-radius: 8px;
    overflow: hidden;
    display: flex;
    flex-direction: column;
}
.mb-obra-imagen {
    height: 140px;
    background-size: cover;
    background-position: center;
    background-color: #2a2a2a;
}
.mb-obra-imagen-placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 40px;
}
.mb-obra-info {
    padding: 16px;
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 6px;
}
.mb-obra-nombre {
    font-size: 16px;
    font-weight: bold;
    color: #fff;
}
.mb-obra-sala {
    font-size: 12px;
    color: #999;
}
.mb-obra-stats {
    display: flex;
    gap: 12px;
    font-size: 12px;
    color: #aaa;
    flex-wrap: wrap;
}
.mb-obra-sinopsis {
    font-size: 12px;
    color: #888;
    line-height: 1.5;
    margin-top: 4px;
}
.mb-obra-acciones {
    display: flex;
    gap: 8px;
    align-items: center;
    margin-top: 10px;
    flex-wrap: wrap;
}
.mb-pocos-boletos {
    color: #F39C12;
    font-size: 11px;
    font-weight: bold;
}

/* ── Tags clasificación / disciplina ────────────────── */
.mb-obra-tags-pub {
    display: flex;
    gap: 8px;
    margin-bottom: 12px;
    flex-wrap: wrap;
}
.mb-tag-clas {
    background: #C8A84B !important;
    color: #1a1a1a !important;
    padding: 3px 12px !important;
    border-radius: 20px !important;
    font-size: 12px !important;
    font-weight: bold !important;
    display: inline-block !important;
}
.mb-tag-disc {
    background: #6B3FA0 !important;
    color: #ffffff !important;
    padding: 3px 12px !important;
    border-radius: 20px !important;
    font-size: 12px !important;
    font-weight: bold !important;
    display: inline-block !important;
}
.mb-obra-fecha-inicio {
    font-size: 15px;
    font-weight: bold;
    color: var(--mb-blanco);
    margin-bottom: 10px;
}
.mb-obra-produccion-txt {
    color: #aaa;
    font-size: 13px;
    margin: 4px 0 0;
    font-style: italic;
}

/* ── Admin obra tags ─────────────────────────────────── */
.mb-obra-tags {
    display: flex;
    gap: 6px;
    margin-bottom: 6px;
    flex-wrap: wrap;
}

/* ── Fila para mapa custom (auto-ancho, centrado por mb-mapa) ─ */
.mb-fila-row {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 5px;
    margin-bottom: 6px;
}

/* Mesa layout */
.mb-mesa-wrap {
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
    margin: 4px 8px;
}
.mb-mesa-top, .mb-mesa-bottom {
    display: flex;
    gap: 4px;
}
.mb-mesa-centro {
    background: #333;
    border-radius: 4px;
    padding: 6px 16px;
    color: #999;
    font-size: 10px;
    min-width: 60px;
    text-align: center;
}
.mb-mesa-redonda-centro {
    border-radius: 50%;
    padding: 10px;
    min-width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
}
.mb-mesas-fila {
    display: flex;
    flex-wrap: wrap;
    gap: 16px;
    justify-content: center;
}
.mb-mesa-seat {
    width: 26px !important;
    height: 26px !important;
    font-size: 9px !important;
}
.mb-banca-seat {
    border-radius: 2px !important;
    width: 22px !important;
}

/* ── Mapa canvas absoluto (renderizado JS idéntico al diseñador) ── */

/* El .mb-mapa en modo canvas no necesita estirarse al ancho del padre */
.mb-mapa.mb-mapa-canvas-mode {
    position: relative;
    width: fit-content;
    min-width: unset;
    margin: 0 auto;
    align-items: flex-start;
    padding: 16px;
}

/* Contenedor de escala: mide el ancho disponible y clipea el canvas escalado */
.mb-mapa-canvas-wrap {
    width: 100%;
    overflow: hidden;
}

/* Canvas absoluto: mismo modelo que el diseñador */
.mb-mapa-canvas {
    position: relative;
    /* width y height vienen en inline style (calculados por JS) */
    /* transform:scale() aplicado por JS para responsive */
    transform-origin: top left;
}

/* Elemento de fila: position:absolute viene en inline style */
.mb-canvas-fila {
    line-height: 1;
}
.mb-canvas-row {
    display: flex;
    align-items: center;
    gap: 2px;
}

/* Asientos en canvas: 22×22px para coincidir con la grilla de 20px del diseñador */
.mb-mapa-canvas .mb-asiento {
    width: 22px;
    height: 22px;
    font-size: 7px;
    border-radius: 3px 3px 5px 5px;
}
.mb-mapa-canvas .mb-mesa-seat {
    width: 22px !important;
    height: 22px !important;
    font-size: 7px !important;
    border-radius: 50% !important;
}
.mb-mapa-canvas .mb-banca-seat {
    border-radius: 2px !important;
    width: 22px !important;
}

/* Escenario en canvas: position:absolute + ancho fijo desde inline style */
.mb-mapa-canvas .mb-escenario {
    box-sizing: border-box;
    text-align: center;
}

/* Pasillos decorativos: position:absolute con dimensiones en inline style */
.mb-pasillo-h {
    height: 20px;
    background: repeating-linear-gradient(90deg, #1a1a1a 0, #1a1a1a 8px, #222 8px, #222 16px);
    border: 1px dashed #333;
    border-radius: 2px;
    position: absolute;
}
.mb-pasillo-v {
    width: 20px;
    background: repeating-linear-gradient(180deg, #1a1a1a 0, #1a1a1a 8px, #222 8px, #222 16px);
    border: 1px dashed #333;
    border-radius: 2px;
    position: absolute;
}

/* ── Mapa SVG (renderizado directo, escala via viewBox) ────────── */

.mb-mapa.mb-mapa-svg-mode {
    width: 100%;
    max-width: 370px;
    min-width: 0;
    margin: 0 auto;
    padding: 12px 16px;
    box-sizing: border-box;
}

/* El SVG ocupa todo el ancho disponible y escala automáticamente */
.mb-mapa-svg {
    display: block;
    width: 100%;
    height: auto;
}

/* Asiento disponible: cursor pointer, transiciones suaves */
.mb-sv-disponible {
    cursor: pointer;
    transition: opacity 0.1s, filter 0.1s;
}
.mb-sv-disponible:hover {
    filter: brightness(1.25);
    opacity: 0.9;
}

/* Asiento seleccionado: amarillo dorado */
.mb-sv-seleccionado {
    cursor: pointer;
    filter: drop-shadow(0 0 3px rgba(255,215,0,.6));
}

/* Asiento vendido / bloqueado */
.mb-sv-vendido {
    cursor: not-allowed;
}

/* Label de fila: no interactivo */
.mb-sv-fila-label {
    pointer-events: none;
    user-select: none;
}

/* Escenario: no interactivo */
.mb-sv-escenario {
    pointer-events: none;
}
