:root{--bg:#f6f7fb;--fg:#111827;--card:#fff;--line:#d8deea;--muted:#667085;--primary:#2563eb;--danger:#dc2626;--ok:#16a34a}html[data-theme=dark]{--bg:#0b1220;--fg:#e5e7eb;--card:#111827;--line:#263244;--muted:#9ca3af;--primary:#60a5fa}*{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--fg);font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif}.top{height:58px;position:fixed;inset:0 0 auto 0;background:var(--card);border-bottom:1px solid var(--line);display:grid;grid-template-columns:auto auto 1fr auto auto auto;gap:10px;align-items:center;padding:0 14px;z-index:3}.hamb{display:none}.side{position:fixed;top:58px;bottom:0;left:0;width:240px;background:var(--card);border-right:1px solid var(--line);padding:14px;overflow:auto}.side a{display:block;color:var(--fg);text-decoration:none;padding:11px;border-radius:10px;margin-bottom:4px}.side a:hover{background:var(--bg)}.main{margin-left:240px;padding:82px 24px 24px}.card{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:18px;margin-bottom:16px;box-shadow:0 8px 30px #0001}.grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px}.grid2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.metric{font-size:26px;font-weight:800}.muted{color:var(--muted);font-size:13px}.btn,button{background:var(--primary);color:white;border:0;border-radius:10px;padding:10px 14px;text-decoration:none;display:inline-block;cursor:pointer}.btn.small{padding:7px 10px;font-size:13px}.icon-btn{width:38px;height:38px;padding:0;border-radius:999px;font-size:20px;line-height:1}.mobile-logout{display:none}.inline{display:inline}.inline button{vertical-align:middle}.welcome{font-size:34px;font-weight:900;letter-spacing:-.03em;margin:0 0 6px}.user-name{font-weight:700}.btn.danger{background:var(--danger)}.btn.gray{background:#64748b}.form{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.field label{display:block;font-weight:650;margin-bottom:5px}.field input,.field select,.field textarea,input,select{width:100%;padding:11px;border:1px solid var(--line);border-radius:10px;background:var(--bg);color:var(--fg)}.help{font-size:12px;color:var(--muted);margin-top:4px}.table-wrap{overflow:auto;max-height:65vh;border:1px solid var(--line);border-radius:12px}table{border-collapse:collapse;width:100%;min-width:850px;background:var(--card)}th,td{padding:10px;border-bottom:1px solid var(--line);text-align:left}th{position:sticky;top:0;background:var(--card);z-index:1}.alert{padding:12px;border-radius:12px;margin-bottom:14px}.alert-ok{background:#dcfce7;color:#166534}.alert-error{background:#fee2e2;color:#991b1b}.alert-info{background:#dbeafe;color:#1e40af}.login{max-width:420px;margin:8vh auto}.badge{padding:4px 8px;border-radius:20px;background:var(--bg)}canvas{width:100%;max-height:280px}@media(max-width:850px){.hamb{display:block}.side{transform:translateX(-105%);transition:.2s;z-index:2}.open .side{transform:none}.main{margin-left:0;padding:78px 12px}.grid,.grid2,.form{grid-template-columns:1fr}.top{grid-template-columns:auto auto 1fr auto}.user-name,.logout-top{display:none}.mobile-logout{display:block}.welcome{font-size:27px}}
/* Tablas profesionales: scroll, altura controlada y paginación visual */
.table-card{display:flex;flex-direction:column;max-height:calc(100vh - 170px)}
.table-toolbar{display:flex;gap:10px;align-items:center;justify-content:space-between;flex-wrap:wrap;margin-bottom:10px}
.table-toolbar input[data-search]{max-width:360px}
.table-wrap{overflow:auto;max-height:460px;min-height:120px;border:1px solid var(--line);border-radius:12px;overscroll-behavior:contain}
.table-wrap table{margin:0}
th{position:sticky;top:0;background:var(--card);z-index:1;box-shadow:0 1px 0 var(--line)}
td{vertical-align:top}
td:last-child{white-space:nowrap}
.table-pager{display:flex;gap:8px;align-items:center;justify-content:flex-end;flex-wrap:wrap;margin-top:10px;color:var(--muted);font-size:13px}
.table-pager button{padding:7px 10px;font-size:13px}
.table-pager button:disabled{opacity:.45;cursor:not-allowed}
.table-count{color:var(--muted);font-size:13px;margin-top:6px}
@media(max-width:850px){.table-card{max-height:calc(100vh - 145px)}.table-wrap{max-height:52vh}.table-toolbar{display:block}.table-toolbar input[data-search]{max-width:none;margin-bottom:8px}th,td{padding:9px 8px}.table-pager{justify-content:center}.welcome{font-size:27px}}

/* Corrección móvil: Salir no debe aparecer independiente en barra superior */
@media (max-width:850px){
  header.top .logout-top,
  .top .logout-top,
  a.logout-top{
    display:none!important;
    visibility:hidden!important;
    width:0!important;
    height:0!important;
    padding:0!important;
    margin:0!important;
    overflow:hidden!important;
  }
  .side .mobile-logout{display:block!important}
}
@media (min-width:851px){
  .side .mobile-logout{display:none!important}
}


/* Popup informativo para reglas por monto de venta */
.popup-overlay{position:fixed;inset:0;background:rgba(0,0,0,.55);display:flex;align-items:center;justify-content:center;z-index:99;padding:18px}
.popup-box{position:relative;width:min(560px,100%);background:var(--card);color:var(--fg);border:1px solid var(--line);border-radius:22px;padding:30px;text-align:center;box-shadow:0 24px 80px rgba(0,0,0,.35)}
.popup-title{font-size:18px;font-weight:800;margin-bottom:12px;color:var(--muted)}
.popup-text{font-size:34px;line-height:1.12;font-weight:950;margin:10px 0 24px;letter-spacing:-.03em}
.popup-close{position:absolute;right:14px;top:12px;background:transparent;color:var(--fg);font-size:30px;line-height:1;padding:0 8px}
.popup-ok{border-color:var(--ok)}
.popup-warning{border-color:#f59e0b}
.popup-error{border-color:var(--danger)}
@media(max-width:850px){.popup-box{padding:26px 18px}.popup-text{font-size:28px}}


/* Ajuste solicitado: usuario operativo sin menú hamburguesa; tema y salir visibles en extremos */
body.role-operador .side{display:none!important}
body.role-operador .main{margin-left:0}
body.role-operador .top{grid-template-columns:auto 1fr auto auto auto}
body.role-operador .hamb{display:none!important}
@media(max-width:850px){
  body.role-operador .top{grid-template-columns:auto 1fr auto;gap:8px}
  body.role-operador .theme-form{justify-self:end}
  body.role-operador .logout-top{
    display:inline-block!important;visibility:visible!important;width:auto!important;height:auto!important;
    padding:7px 10px!important;margin:0!important;overflow:visible!important
  }
  body.role-operador .user-name{display:none!important}
  body.role-operador .main{padding:78px 12px 18px}
}

/* Mensaje por condición: ventana flotante tipo software PHP + respaldo junto al saludo */
.welcome-row{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-bottom:6px}
.welcome-alert{font-size:22px;font-weight:950;color:#b91c1c;background:#fee2e2;border:2px solid #ef4444;border-radius:14px;padding:9px 14px;box-shadow:0 8px 24px rgba(220,38,38,.18)}
.welcome-alert-ok{color:#166534;background:#dcfce7;border-color:#22c55e}
.welcome-alert-warning{color:#92400e;background:#fef3c7;border-color:#f59e0b}
.toast-popup{position:fixed;right:22px;top:76px;z-index:120;width:min(430px,calc(100% - 30px));background:var(--card);color:var(--fg);border:2px solid var(--primary);border-left-width:10px;border-radius:16px;padding:18px 46px 18px 18px;box-shadow:0 20px 70px rgba(0,0,0,.32);animation:toastIn .25s ease-out}
.toast-title{font-size:14px;font-weight:800;color:var(--muted);margin-bottom:5px}
.toast-text{font-size:27px;line-height:1.12;font-weight:950;color:#b91c1c}
.toast-close{position:absolute;right:10px;top:7px;background:transparent;color:var(--fg);font-size:28px;line-height:1;padding:0 8px}
.toast-ok{border-color:var(--ok)}.toast-ok .toast-text{color:#166534}
.toast-warning{border-color:#f59e0b}.toast-warning .toast-text{color:#92400e}
.toast-error{border-color:var(--danger)}.toast-error .toast-text{color:#b91c1c}
.toast-hide{opacity:0;transform:translateY(-8px);transition:.45s}
@keyframes toastIn{from{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:none}}
@media(max-width:850px){
  .welcome-row{align-items:flex-start}
  .welcome-alert{font-size:18px;width:100%}
  .toast-popup{left:12px;right:12px;top:68px;width:auto}
  .toast-text{font-size:23px}
}

.alerta-ventas{display:inline-block;margin-left:12px;padding:10px 14px;background:#fee2e2;color:#dc2626;border-left:6px solid #dc2626;border-radius:8px;font-size:22px;font-weight:800;box-shadow:0 2px 8px rgba(0,0,0,.15)}



/* Ajuste final: solo popup, sin mensaje fijo junto al usuario */
.welcome-alert,.alerta-ventas{display:none!important}

/* Botón salir como icono compacto */
.logout-top.icon-btn{
  width:38px!important;
  height:38px!important;
  padding:0!important;
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  border-radius:999px!important;
  font-size:20px!important;
  line-height:1!important;
}
@media(max-width:850px){
  body.role-operador .logout-top.icon-btn{
    width:38px!important;
    height:38px!important;
    padding:0!important;
    display:inline-flex!important;
    align-items:center!important;
    justify-content:center!important;
  }
}


/* Ajuste operativo: encabezado limpio y salida al pie */
body.role-operador .top{
  grid-template-columns:auto 1fr auto!important;
}
body.role-operador .top .user-name,
body.role-operador .top .logout-top,
body.role-operador .hamb{
  display:none!important;
}
body.role-operador .theme-form{
  justify-self:end;
}
.operador-footer{
  margin-top:26px;
  padding:18px 0 8px;
  display:flex;
  justify-content:center;
  border-top:1px solid var(--line);
}
.operador-logout{
  min-width:180px;
  text-align:center;
  font-size:16px;
  font-weight:800;
  background:var(--danger);
}
@media(max-width:850px){
  body.role-operador .top{
    grid-template-columns:auto 1fr auto!important;
    gap:8px;
  }
  body.role-operador .main{
    padding-bottom:22px;
  }
  .operador-footer{
    position:static;
    margin-top:22px;
    padding-bottom:14px;
  }
  .operador-logout{
    width:100%;
    max-width:320px;
  }
}


/* Ajuste final solicitado: sin botón Salir en encabezado de escritorio; queda el tema en encabezado */
header.top .logout-top,
.top .logout-top{
  display:none!important;
}
.side .logout-menu{
  display:block!important;
  margin-top:12px;
  border-top:1px solid var(--line);
  padding-top:14px;
  font-weight:800;
}
body.role-operador .top{
  grid-template-columns:auto 1fr auto!important;
}

.bonus-card{border-left:5px solid var(--primary)}
.bonus-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.bonus-item{display:flex;justify-content:space-between;gap:12px;align-items:center;border:1px solid var(--line);border-radius:12px;padding:12px;background:var(--bg)}
.bonus-amount{font-size:22px;font-weight:900;color:var(--primary);white-space:nowrap}
.toast-global{right:18px}
.toast-global:nth-of-type(2){bottom:150px}
.toast-global:nth-of-type(3){bottom:280px}
@media(max-width:850px){.bonus-grid{grid-template-columns:1fr}.bonus-item{align-items:flex-start}.bonus-amount{font-size:20px}}


/* PWA y bonus */
.install-app{background:#0f766e}
.operador-footer{display:flex;gap:10px;justify-content:center;align-items:center;flex-wrap:wrap;padding:18px 10px 24px}
.bonus-card .bonus-item{border:1px solid var(--line);border-radius:14px;padding:12px;background:var(--bg)}
.bonus-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.bonus-amount{font-size:24px;font-weight:900;margin-top:8px}
@media(max-width:850px){.bonus-grid{grid-template-columns:1fr}.operador-footer .btn{width:100%;max-width:280px;text-align:center}}

/* Corrección confidencialidad bonus operativo y PWA */
body.role-operador .bonus-grid{grid-template-columns:1fr}
body.role-operador .bonus-own{width:100%}
body.role-operador .operador-footer{
  display:flex;
  flex-direction:column;
  align-items:stretch;
  gap:10px;
  width:100%;
  margin-top:22px;
  padding:18px 0 24px;
}
body.role-operador .operador-footer .install-app,
body.role-operador .operador-footer .operador-logout{
  width:100%;
  max-width:none;
  text-align:center;
  display:block;
}
body.role-operador .operador-footer .install-app{
  font-size:18px;
  font-weight:800;
  padding:14px 16px;
  order:1;
}
body.role-operador .operador-footer .operador-logout{
  order:2;
}
