:root{
  /* Superficie base (si no hay settings, el tema las sobreescribe igual) */
  --bg:#ffffff;
  --card:#ffffff;
  --text:#0f172a;
  --muted:#475569;

  /* Primario (se setea desde ui.theme.js) */
  --primary:#0b1020;
  --primary-rgb:14,165,255;
  --on-primary:#ffffff;            /* tinta sobre el primario */

  /* Navbar derivado (ui.theme.js decide la tinta correcta) */
  --nav-bg: var(--primary);
  --nav-ink: var(--on-primary);

  /* Tintes derivados (para “glass”, contador, etc.) */
  --tint-weak: 0.06;   /* fondo clarito */
  --tint-mid:  0.10;   /* un poco más marcado */
  --tint-line: 0.28;   /* bordes */
  --shadow:    0.20;

  /* Estados */
  --success:#16a34a;
  --danger:#ef4444;
  --warning:#f59e0b;
}

/* ====== Layout base ====== */
*{ box-sizing:border-box }
html{ scroll-behavior: smooth; }
body{
  background: var(--bg);
  color: var(--text);
  font-family:"Poppins",system-ui,-apple-system,Segoe UI,Roboto,"Helvetica Neue",Arial;
}

/* anclas con navbar sticky */
#inicio, #boletos, #faqs, #contacto{ scroll-margin-top: 84px; }

/* ====== NAVBAR ====== */
.navbar.navbar-themed{
  background: var(--nav-bg) !important;
  color: var(--nav-ink) !important;
  border-bottom: none;
  padding-top:.65rem; padding-bottom:.65rem;
  height: 100px;
}
/* ====== Brand logo en círculo ====== */
.brand-logo{
  width: 86px;
  height: 86px;
  border-radius: 999px;
  overflow: hidden;
  display: inline-flex;
  align-items: center;
  justify-content: center;

  background: rgba(255,255,255,.10);
  border: 1px solid rgba(var(--primary-rgb), .45);
  box-shadow:
    0 10px 26px rgba(0,0,0,.25),
    0 0 0 3px rgba(var(--primary-rgb), .12);
}

.brand-logo img{
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover; /* si tu logo es “cuadrado”, se ve llenito */
}

/* Si tu logo trae mucho margen blanco, usa contain para que no lo recorte */
.brand-logo.is-contain img{
  object-fit: contain;
  padding: 6px; /* ajusta si tu logo necesita aire */
}

/* Ajustes responsive: un poquito más grande en desktop */
@media (min-width: 992px){
  .brand-logo{ width: 50px; height: 50px; }
}

.navbar.navbar-themed .nav-link{
  color: var(--nav-ink) !important;
  opacity:.92; transition: opacity .2s;
}
.navbar.navbar-themed .nav-link:hover,
.navbar.navbar-themed .nav-link:focus{ opacity:1; text-decoration: underline; }
.navbar.navbar-themed .navbar-toggler{ border:none; }
.navbar.navbar-themed .navbar-toggler-icon{ filter: invert(1); }

/* Altura estable del navbar y ancla para centrado */
.navbar.navbar-themed { min-height: 56px; }
.navbar.navbar-themed .container { position: relative; }


/* Botón “Cuentas” que hereda la tinta del navbar */
.btn-accounts{
  --btn-ink: var(--nav-ink);
  color: var(--btn-ink) !important;
  border: 1px solid color-mix(in srgb, var(--btn-ink) 35%, transparent) !important;
  background: color-mix(in srgb, var(--btn-ink) 10%, transparent) !important;
}
.btn-accounts:hover{
  background: color-mix(in srgb, var(--btn-ink) 18%, transparent) !important;
}


/* Mobile: logo centrado absoluto, no se mueve al abrir el menú */
@media (max-width: 991.98px){
  .navbar-brand.brand-abs{
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%,-50%);
    margin: 0 !important;
    z-index: 2; /* arriba del colapso */
  }
  /* Botón cuentas (izq) y toggler (der) por encima del brand */
  .btn-accounts.btn-sm.d-lg-none,
  .navbar-toggler{ position: relative; z-index: 3; }
}

/* Desktop: que el brand regrese al flujo normal */
@media (min-width: 992px){
  .navbar-brand.brand-abs{
    position: static;
    transform: none;
    margin-right: .5rem !important; /* opcional */
  }
}



/* ====== HERO / “glass” ====== */
.hero{ position:relative; overflow:hidden; border-bottom:1px solid rgba(0,0,0,.06) }

/* glass con tinte del primario */
.glass{
  background: linear-gradient(180deg,
    rgba(var(--primary-rgb), var(--tint-weak)),
    rgba(0,0,0,.01)
  );
  border: 1px solid rgba(var(--primary-rgb), var(--tint-line));
  backdrop-filter: blur(6px);
  border-radius: 18px;
}

/* ====== Botones ====== */
.btn-primary{
  background: var(--primary) !important;
  border: 1px solid rgba(0,0,0,.15) !important;
  color: var(--on-primary) !important;
  box-shadow: 0 10px 30px rgba(var(--primary-rgb), var(--shadow));
}
.btn-primary:hover{ filter: brightness(.96); }

/* Botón “Ver bases”: primario suave para que el texto contraste */
#btnBases{
  color: var(--primary) !important;
  background: rgba(var(--primary-rgb), var(--tint-mid)) !important;
  border-color: rgba(var(--primary-rgb), .35) !important;
}
#btnBases:hover{ background: rgba(var(--primary-rgb), calc(var(--tint-mid) + .06)) !important; }

/* Badge suave */
.badge-soft{
  background: rgba(var(--primary-rgb), var(--tint-mid));
  border:1px solid rgba(var(--primary-rgb), .30);
  color: var(--primary);
}

/* ====== Tickets ====== */
.ticket{
  user-select:none; display:flex; align-items:center; justify-content:center;
  height:56px; border-radius:14px; font-weight:600;
  border:1px dashed rgba(0,0,0,.18);
  background:rgba(0,0,0,.02);
  cursor:pointer; transition:.18s ease;
}
.ticket:hover{ transform: translateY(-2px); border-color:rgba(0,0,0,.35) }
.ticket.selected{
  background: rgba(var(--primary-rgb), .12);
  border-color: var(--primary);
  box-shadow: inset 0 0 0 1px rgba(var(--primary-rgb), .5);
  color:#0b1222;
}
.ticket.sold{
  background: rgba(239,68,68,.10);
  border-color: rgba(239,68,68,.55);
  color:#991b1b; cursor:not-allowed; text-decoration: line-through;
}

/* Leyenda */
.legend .dot{
  width:12px; height:12px; border-radius:999px; display:inline-block; margin-right:.45rem;
  border:1px solid rgba(0,0,0,.25);
}
.dot-available{ background:rgba(0,0,0,.06) }
.dot-selected{  background:rgba(var(--primary-rgb), .5); border-color:var(--primary) }
.dot-held{background:rgba(245,158,11,.5);border-color:#f59e0b;}
.dot-sold{ background:rgba(239,68,68,.5); border-color:#ef4444 }

/* ====== Títulos / textos ====== */
.section-title{
  font-weight:800; letter-spacing:.2px;
  background: linear-gradient(90deg, var(--text), rgba(var(--primary-rgb), .85));
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
.text-info{ color: var(--primary) !important; }
a{ color: var(--primary); }
a:hover{ color: var(--primary); filter:brightness(.92) }

/* ====== Countdown ====== */
.countdown .unit{
  min-width:80px; text-align:center; padding:.6rem 0;
  border:1px solid rgba(var(--primary-rgb), var(--tint-line));
  border-radius:12px;
  background: rgba(var(--primary-rgb), var(--tint-mid));
}
.countdown .unit .fw-bold{ color: var(--text); }

/* ====== Grid scroll ====== */
#gridWrapper { max-height: 500px; overflow-y: auto; padding-right: 6px; }
#gridWrapper::-webkit-scrollbar { width: 6px; }
#gridWrapper::-webkit-scrollbar-thumb { background: var(--primary); border-radius: 6px; }
#gridWrapper::-webkit-scrollbar-track { background: rgba(0,0,0,.05); }

/* ====== Form / Table ====== */
.form-check-input:checked{ background-color:var(--primary); border-color:var(--primary) }
.table-dark td, .table-dark th{ border-color:rgba(0,0,0,.06) }

/* ====== Footer ====== */
.footer{ border-top:1px solid rgba(0,0,0,.08); color:#334155; }

/* ====== Cuentas (modal) ====== */
.cuenta-card{
  border: 1px solid rgba(var(--primary-rgb), .22);
  border-radius: 16px; overflow: hidden;
  background: linear-gradient(180deg, rgba(var(--primary-rgb), var(--tint-weak)), rgba(0,0,0,.01));
}
.cuenta-card .cc-header{
  padding:.85rem 1rem;
  background: var(--primary);
  color: var(--on-primary);
  border-bottom: 1px solid rgba(0,0,0,.15);
}
.cuenta-card .cc-body{ padding:.85rem 1rem; }
.cuenta-row{ display:flex; align-items:center; justify-content:space-between; gap:.75rem; padding:.35rem 0; border-bottom:1px dashed rgba(0,0,0,.08) }
.cuenta-row:last-child{ border-bottom:none }
.cuenta-row .label{ color: var(--muted); font-size:.9rem }
.cuenta-row .value{ font-weight:600 }
.cuenta-row .btn-copy{ padding:.2rem .45rem; border-color: rgba(0,0,0,.25) }

/* ====== Responsive ====== */
@media (max-width: 576px) {
  .countdown .unit { min-width: 64px; padding:.45rem 0; }
  .countdown .unit .fs-3 { font-size: 1.5rem !important; }
  #inicio .display-5 { font-size: 1.9rem; }
  .cuenta-row { flex-wrap: wrap; }
  .cuenta-row .value-wrap { display:flex; align-items:center; gap:.5rem; width:100%; justify-content:space-between; }
}

/* ====== FAQ / Accordion (tema) ====== */
#faqs .section-title{
  /* Que se vea el color principal, sin truco raro de degradado */
  color: var(--primary);
  font-weight: 800;
  letter-spacing: .02em;
  text-shadow: 0 0 10px rgba(0,0,0,.25);
}

/* Card del acordeón con el tema */
.accordion.glass{
  border-radius: 18px;
  border: 1px solid rgba(var(--primary-rgb), .35);
  /* Menos humo, más color */
  background: linear-gradient(
    145deg,
    rgba(var(--primary-rgb), .20),
    rgba(var(--primary-rgb), .08)
  );
  backdrop-filter: blur(12px);
  overflow: hidden;
}

/* Ítems */
.accordion-item{
  border: 0;
  border-bottom: 1px solid rgba(0,0,0,.04);
  background: transparent;
}
.accordion-item:last-child{ border-bottom: 0; }

/* Botón del acordeón */
.accordion-button{
  gap: .35rem;
  background: transparent;
  color: var(--text);
  font-weight: 600;
  padding: 1rem 1.1rem;
  box-shadow: none !important;
  border-radius: 0 !important;
  transition: background .15s ease, color .15s ease;
}

/* Hover: un ligero baño del primario */
.accordion-button:hover,
.accordion-button:focus{
  background: rgba(var(--primary-rgb), .18);
  color: var(--text);
}

/* Abierto: que se note bien el estado activo */
.accordion-button:not(.collapsed){
  background: rgba(var(--primary-rgb), .22);
  color: var(--text);
  border-bottom: 1px solid rgba(0,0,0,.06);
}

/* Cuerpo */
.accordion-body{
  color: var(--muted);
  background: rgba(255,255,255,.06);
  padding: 1rem 1.1rem 1.25rem;
}

/* Links dentro de FAQ */
#faqs a{
  color: var(--primary);
  text-decoration: underline;
  text-decoration-color: rgba(var(--primary-rgb), .35);
}
#faqs a:hover{
  text-decoration-color: rgba(var(--primary-rgb), .9);
}

/* Iconito: si no trae color, usa el primario del tema */
#faqs .accordion-button i:not([class*="text-"]){
  color: var(--primary);
}


/* ===== Footer teñido como las cards ===== */
.footer{
background: var(--nav-bg) !important;
border-top: 1px solid rgba(var(--primary-rgb), var(--tint-line));
color: var(--nav-ink) !important;
padding: 20px;
}

/* Enlaces dentro del footer: usan el primario */
.footer a{
  color: var(--nav-ink) !important;
  text-decoration: underline;
  text-decoration-color: rgba(var(--primary-rgb), .35);
}
.footer a:hover{
  text-decoration-color: rgba(var(--primary-rgb), .8);
}

/* (Opcional) tono aún más suave en pantallas muy oscuras: ya se regula con --tint-weak vía ui.theme */
/* Footer centrado + logo */
.footer .footer-brand { display:flex; flex-direction:column; align-items:center; justify-content:center; }
.footer-logo { height: 92px; width:auto; border-radius: 8px; opacity:.95 }
.footer-madeby { color: var(--primary); text-decoration: underline; text-decoration-color: rgba(var(--primary-rgb), .35); }
.footer-madeby:hover { text-decoration-color: rgba(var(--primary-rgb), .85); }

/* ======= PRELOADER ======= */
:root{
  --loader-bg: #0b0f1a;
}
.app-loading body { overflow: hidden; } /* evita scroll mientras carga */

#appLoader{
  position: fixed; inset: 0; z-index: 9999;
  display: grid; place-items: center;
  background:
    radial-gradient(60vmax 60vmax at 50% -10%, rgba(var(--primary-rgb), .18), transparent 70%),
    linear-gradient(180deg, rgba(var(--primary-rgb), .10), rgba(0,0,0,.65)),
    var(--loader-bg);
  color: var(--on-primary);
}
#appLoader .loader-card{
  padding: 1.25rem 1.5rem; border-radius: 16px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.18);
  backdrop-filter: blur(8px);
  text-align: center; min-width: 260px;
}
#appLoader .spinner{
  width: 46px; height: 46px; border-radius: 999px;
  border: 3px solid rgba(255,255,255,.28);
  border-top-color: var(--primary);
  animation: spin 1s linear infinite;
  margin: 0 auto .75rem;
}
#appLoader .brand-dot{
  width: 8px; height: 8px; border-radius: 999px;
  background: var(--primary); display: inline-block; margin-left: .35rem;
}
@keyframes spin { to { transform: rotate(360deg); } }

/* Evita “flicker”: oculta el contenido hasta que JS quite .app-loading */
.app-loading .app-root { visibility: hidden; }

/* Modal blanco solo para "Sobre la rifa" */
.swal2-popup.sw-plain {
  background: #ffffff !important;
  color: var(--text);
  border: 1px solid rgba(0,0,0,.08);
  box-shadow: 0 20px 60px rgba(0,0,0,.15);
  backdrop-filter: none;
}
.swal2-popup.sw-plain .swal2-title { color: var(--text); }
.swal2-popup.sw-plain .swal2-html-container { color: var(--muted); }
.swal2-popup.sw-plain .swal2-close { color: var(--muted); }

/* Tus botones siguen “temeados” por variables */
.swal2-styled.swal2-confirm {
  background: var(--primary) !important;
  border-color: var(--primary) !important;
  color: var(--on-primary) !important;
}
.swal2-styled.swal2-confirm:hover {
  filter: brightness(.96);
}

/* Lista de seleccionados con scroll */
.sel-list{
  max-height: 96px;           /* ajusta a gusto */
  overflow: auto;
  padding: 6px;
  border-radius: 10px;
  background: rgba(var(--primary-rgb), var(--tint-weak));
  border: 1px solid rgba(var(--primary-rgb), var(--tint-line));
}

/* Chips clicables */
.sel-chip{
  display: inline-block;
  margin: 2px 4px 2px 0;
  padding: 4px 8px;
  border-radius: 999px;
  font-weight: 700;
  font-size: .9rem;
  line-height: 1;
  cursor: pointer;
  user-select: none;
  font-variant-numeric: tabular-nums;
  background: rgba(var(--primary-rgb), .12);
  border: 1px solid var(--primary);
  color: var(--text);
}
.sel-chip:hover{
  background: rgba(var(--primary-rgb), .2);
  filter: brightness(.98);
}

/* panel del preview (dentro del Swal) */
#maqPanel {
  background: linear-gradient(180deg, rgba(0,0,0,.03), rgba(0,0,0,.06));
  border: 1px dashed rgba(0,0,0,.15) !important;
}
#maqPreview .btn { white-space: nowrap; }

/* Maquinita: panel blanco */
.swal2-popup #maqPanel{
  background:#fff !important;   /* el resto de estilos vienen inline */
}

/* Píldoras/chips primarios (usa tu variable --primary) */
.btn-outline-primary,
.ticket-pill{
  color: var(--primary) !important;
  border-color: var(--primary) !important;
  background: transparent !important;
}
.btn-outline-primary:hover,
.ticket-pill:hover{
  background: rgba(var(--primary-rgb), .12) !important;
}

/* Chip deshabilitado: gris suave */
.btn-chip-disabled{
  color: #9aa0a6 !important;
  border-color: rgba(0,0,0,.15) !important;
  cursor: not-allowed !important;
  pointer-events: none;
  background: rgba(0,0,0,.03) !important;
}

.promo-bar {
  background: linear-gradient(
    90deg,
    rgba(var(--primary-rgb), 0.18) 0%,
    rgba(var(--primary-rgb), 0.05) 100%
  );
  border-bottom: 1px solid rgba(var(--primary-rgb), 0.4);
  box-shadow: 0 10px 30px rgba(0,0,0,.4);
  backdrop-filter: blur(6px);
}

.promo-chip {
  background-color: var(--primary);
  color: var(--on-primary);
  border-radius: 999px;
  padding: 4px 10px;
  font-size: .8rem;
  font-weight: 600;
  box-shadow: 0 10px 30px rgba(var(--primary-rgb), var(--shadow));
  line-height: 1.2;
}

/* algo tipo */
.chip-free {
  display: inline-block;
  background: rgba(25,135,84,.12); /* verde bajito */
  color: #198754;
  border: 1px solid rgba(25,135,84,.4);
  border-radius: 6px;
  padding: 2px 6px;
  font-size: .8rem;
  font-weight: 600;
}

:root{
  /* Hereda tu tema; si faltan vars, usa estos fallbacks */
  --nx-bg: var(--card, rgba(15,23,51,0.85));
  --nx-txt: var(--txt, #fff);
  --nx-muted: var(--muted, #9fb0d6);
  --nx-primary: var(--primary, #0ea5ff);
  --nx-stroke: var(--stroke, #2b3a6a66);
}

.nx-mobile-nav{
  position: fixed;
  left: 0; right: 0; bottom: 0;
  z-index: 1035;
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  padding: 8px 6px calc(8px + env(safe-area-inset-bottom, 0));
  background: var(--nx-bg);
  color: var(--nx-txt);
  border-top: 1px solid var(--nx-stroke);
  backdrop-filter: saturate(140%) blur(10px);
}

.nx-mobile-nav .mn-item{
  position: relative;
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  gap: 2px;
  padding: 6px 4px;
  text-decoration: none;
  color: var(--nx-muted);
  font-size: 11px;
  line-height: 1;
  user-select: none;
  border-radius: 10px;
  transition: color .2s ease, background .2s ease;
}

.nx-mobile-nav .mn-item i{ font-size: 20px; line-height: 1; }

.nx-mobile-nav .mn-item.active,
.nx-mobile-nav .mn-item:active{
  color: var(--nx-primary);
  background: color-mix(in srgb, var(--nx-primary) 10%, transparent);
}

.nx-mobile-nav .mn-badge{
  position: absolute;
  top: 2px; right: 18%;
  min-width: 18px; height: 18px;
  padding: 0 4px;
  border-radius: 14px;
  background: var(--nx-primary);
  color: white;
  font-weight: 700;
  font-size: 11px;
  display: none;
  align-items: center; justify-content: center;
}
.nx-mobile-nav .mn-badge.show{ display: inline-flex; }

/* Deja espacio para que el nav no tape el contenido en móvil */
@media (max-width: 991.98px){
  body{ padding-bottom: calc(64px + env(safe-area-inset-bottom, 0)); }
}

/* ===== NAV fijo y brand centrado sin que baje (mobile) ===== */
:root{ --nav-h: 56px; } /* alto de la barra en mobile */

.navbar.navbar-themed { min-height: var(--nav-h); }
.navbar.navbar-themed .container { position: relative; }

/* Brand centrado absoluto en mobile */
@media (max-width: 991.98px){
  /* El contenedor NO cambia de altura al abrir el menú */
  .navbar.navbar-themed .container{
    height: var(--nav-h);
  }

  /* Logo al centro, fijo */
  .navbar-brand.brand-abs{
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%,-50%);
    margin: 0 !important;
    z-index: 2;
  }

  /* Botón Cuentas (izq) y Toggler (der) por encima del brand */
  .btn-accounts.btn-sm.d-lg-none,
  .navbar-toggler{ position: relative; z-index: 3; }

  /* El menú colapsado cuelga ABSOLUTO debajo del navbar, no empuja la altura */
  .navbar.navbar-themed .collapse.navbar-collapse,
  .navbar.navbar-themed .collapsing{
    position: absolute;
    top: 100%;           /* justo debajo de la barra */
    left: 0; right: 0;
    background: var(--nav-bg);
    color: var(--nav-ink);
    border-top: 1px solid color-mix(in srgb, var(--nav-ink) 25%, transparent);
    padding: 12px 16px;
    box-shadow: 0 10px 30px rgba(0,0,0,.25);
  }

  /* Links legibles en el dropdown */
  .navbar.navbar-themed .collapse .nav-link{
    color: var(--nav-ink) !important;
    opacity: .95;
    padding: 10px 8px;
  }
}

/* Premio en modal */
.nx-prize-img{
  width: 92px; height: 92px;
  object-fit: cover; border-radius: 14px;
  border: 1px solid rgba(var(--primary-rgb), var(--tint-line));
  box-shadow: 0 8px 24px rgba(var(--primary-rgb), var(--shadow));
}

/* Lista de boletos con altura fija dentro del modal */
.nx-ticket-list{
  max-height: 110px;
  overflow: auto;
  padding: 6px;
  border-radius: 10px;
  background: rgba(var(--primary-rgb), var(--tint-weak));
  border: 1px solid rgba(var(--primary-rgb), var(--tint-line));
}

/* Tarjetas de método de pago */
.nx-pay-grid{
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 10px;
}
.nx-pay-card{
  display: block; margin: 0; cursor: pointer; user-select: none;
}
.nx-pay-card input[type="radio"]{ display: none; }
.nx-pay-inner{
  border: 1px solid rgba(var(--primary-rgb), var(--tint-line));
  background: linear-gradient(180deg,
    rgba(var(--primary-rgb), var(--tint-weak)),
    rgba(0,0,0,.01)
  );
  border-radius: 12px; padding: 10px 12px;
  transition: transform .12s ease, box-shadow .12s ease, border-color .12s ease;
}
.nx-pay-card:hover .nx-pay-inner{
  transform: translateY(-2px);
  box-shadow: 0 10px 30px rgba(var(--primary-rgb), var(--shadow));
}
.nx-pay-card input[type="radio"]:checked + .nx-pay-inner{
  border-color: var(--primary);
  box-shadow: inset 0 0 0 1px var(--primary);
}
.nx-pay-logo{
  width: 26px; height: 26px; border-radius: 6px; object-fit: contain;
  background: #fff;
  border: 1px solid rgba(0,0,0,.08);
}

/* Botón flotante de WhatsApp */
.whatsapp-float {
  position: fixed;
  right: 16px;
  bottom: 100px;
  z-index: 1040;

  width: 56px;
  height: 56px;
  border-radius: 14px;

  background: radial-gradient(circle at 30% 30%, #25D366 0%, #128C7E 60%);
  box-shadow:
    0 20px 40px rgba(0,0,0,.8),
    0 0 20px rgba(14,165,255,.4);

  border: 1px solid rgba(255,255,255,.2);

  display: flex;
  align-items: center;
  justify-content: center;

  text-decoration: none;
  transition: all .18s ease-in-out;
}

/* Icono de WhatsApp dentro */
.whatsapp-float i {
  font-size: 1.5rem;
  color: #fff;
  filter: drop-shadow(0 0 6px rgba(0,0,0,.7));
}

/* Hover (desktop) */
.whatsapp-float:hover {
  transform: translateY(-2px) scale(1.03);
  box-shadow:
    0 28px 50px rgba(0,0,0,.9),
    0 0 28px rgba(39,224,255,.55);
}

@media (max-width: 768px) {
  #resumen {
    position: relative;
    overflow: hidden; /* por si el glass tiene bordes redondeados */
  }

  #resumen .resumen-bg-mobile {
    position: absolute;
    inset: 0;
    background: #ffffff;      /* aquí el blanco sólido */
    z-index: 0;
    border-radius: inherit;   /* respeta el radio del glass */
  }

  /* Todo lo demás del resumen por encima del fondo blanco */
  #resumen > *:not(.resumen-bg-mobile) {
    position: relative;
    z-index: 1;
  }
}

/* Card de acciones rápidas */
.quick-actions-card{
  width: 100%;
  border-radius: 18px;
  background: var(--nav-bg) !important;
  border: 1px solid rgba(0,0,0,.06);
}

/* Títulos con color del nav */
.quick-actions-title,
.quick-actions-subtitle{
  color: var(--nav-ink) !important;
}

/* Botones de acción rápida */
.qa-btn{
  flex: 1 1 0;
  border: none;
  background: transparent;
  padding: 10px 6px;
  border-radius: 14px;
  cursor: pointer;
  transition: transform .08s ease, box-shadow .12s ease, background .12s ease;
}

.qa-btn:hover{
  transform: translateY(-1px);
  box-shadow: 0 6px 16px rgba(15,23,42,.15);
}

/* Icon container */
.qa-icon{
  width: 48px;
  height: 48px;
  border-radius: 16px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 1.3rem;
}

/* Label */
.qa-label{
  margin-top: 6px;
  font-size: .8rem;
  font-weight: 600;
  color: var(--nav-ink) !important;
}

/* Variantes de color (manteniendo tu tema) */
.qa-btn-primary .qa-icon{
  background: #ffffff;
  color: var(--primary);
}

.qa-btn-danger .qa-icon{
  background: #fee2e2;
  color: #b91c1c;
}

.qa-btn-warning .qa-icon{
  background: #fef3c7;
  color: #b45309;
}

/* En pantallas grandes que se sienta más “barra” */
@media (min-width: 992px){
  .quick-actions-card{
    padding: 14px 22px;
  }
  .quick-actions-card .text-center{
    margin-bottom: 12px;
  }
  .qa-btn{
    padding: 12px 10px;
  }
}

#gridWrapper.ventas-cerradas .ticket {
  pointer-events: none;
  opacity: 0.75;
  cursor: default;
}
