:root{
  --bg:#f4f5f7; --card:#fff; --ink:#1d2330; --muted:#6b7280; --line:#e5e7eb;
  --noc:#6d4aff; --fx:#0ea5a4;
  --t-abs:#ea580c; --t-abs-bg:#fff1e8; --t-bue:#ca8a04; --t-bue-bg:#fefce0; --t-des:#2563eb; --t-des-bg:#eaf1ff;
  --t-baj:#a16207; --t-baj-bg:#fef3c7; --t-los:#991b1b; --t-los-bg:#fee2e2;
  --win:#16a34a; --warn:#d97706;
  --shadow:0 1px 3px rgba(16,24,40,.06),0 1px 2px rgba(16,24,40,.04);
}
*{box-sizing:border-box}
body{margin:0;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  background:var(--bg);color:var(--ink);font-size:13px;}
.hidden{display:none !important;}

/* ---- login ---- */
#loginScreen{position:fixed;inset:0;background:#eef0f3;display:flex;align-items:center;justify-content:center;z-index:50;}
.login-card{background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:0 8px 30px rgba(16,24,40,.12);
  padding:28px 26px;width:340px;}
.login-card h1{font-size:17px;margin:0 0 4px;}
.login-card p{color:var(--muted);margin:0 0 18px;font-size:12px;}
.login-card input{width:100%;padding:9px 11px;border:1px solid var(--line);border-radius:8px;font:inherit;margin-bottom:10px;}
.login-card button{width:100%;padding:9px;border-radius:8px;border:1px solid var(--ink);background:var(--ink);color:#fff;
  font:inherit;font-weight:600;cursor:pointer;}
.login-card button:hover{opacity:.9;}
.login-err{color:#b91c1c;font-size:12px;min-height:16px;margin-bottom:6px;}

/* ---- header ---- */
header{background:var(--card);border-bottom:1px solid var(--line);padding:14px 22px;
  display:flex;align-items:center;gap:12px;flex-wrap:wrap;position:sticky;top:0;z-index:20;}
header h1{font-size:16px;margin:0;font-weight:700;}
header .sub{color:var(--muted);font-size:12px;}
.spacer{flex:1}
button,.btn{font:inherit;cursor:pointer;border:1px solid var(--line);background:#fff;
  padding:7px 12px;border-radius:8px;color:var(--ink);}
button:hover{background:#f0f1f3}
button:disabled{opacity:.5;cursor:not-allowed;}
.btn-primary{background:var(--ink);color:#fff;border-color:var(--ink);}
.btn-primary:hover{opacity:.9;background:var(--ink);}
button.danger:hover{background:#fee2e2;color:#b91c1c;border-color:#fecaca;}
.role-badge{padding:3px 9px;border-radius:999px;font-size:11px;font-weight:700;}
.role-admin{background:#dcfce7;color:#15803d;}
.role-consulta{background:#e0e7ff;color:#4338ca;}

main{padding:18px 22px;max-width:none;margin:0;}
.kpis{display:grid;grid-template-columns:repeat(8,1fr);gap:10px;margin-bottom:16px;}
.kpi{background:var(--card);border:1px solid var(--line);border-radius:10px;padding:11px 13px;box-shadow:var(--shadow);}
.kpi .label{color:var(--muted);font-size:10.5px;text-transform:uppercase;letter-spacing:.03em;}
.kpi .value{font-size:19px;font-weight:700;margin-top:4px;}
.kpi .value small{font-size:12px;color:var(--muted);font-weight:500;}
.panel{background:var(--card);border:1px solid var(--line);border-radius:10px;box-shadow:var(--shadow);margin-bottom:16px;}
.filters{padding:12px 14px;display:flex;gap:10px;flex-wrap:wrap;align-items:flex-end;}
.field{display:flex;flex-direction:column;gap:3px;}
.field label{font-size:10px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);}
select,input[type=text],input[type=number]{font:inherit;padding:6px 8px;border:1px solid var(--line);
  border-radius:7px;background:#fff;min-width:115px;}
input[type=text]{min-width:190px;}
input[type=number]{width:78px;min-width:0;}
.chkwrap{display:flex;align-items:center;gap:6px;padding:7px 0;}
.crit{padding:0 14px 14px;border-top:1px dashed var(--line);margin-top:2px;}
.crit summary{cursor:pointer;padding:10px 0;font-weight:600;font-size:12px;}
.crit-grid{display:grid;grid-template-columns:175px 140px 140px 140px;gap:9px 16px;align-items:center;}
.crit-grid .h{font-size:10px;text-transform:uppercase;color:var(--muted);letter-spacing:.03em;line-height:1.3;}
.crit-grid input[type=number]{width:120px;}
.crit-grid label.muted{display:flex;align-items:center;gap:6px;}
.crit-grid .h-sec{grid-column:1 / -1;font-size:11px;font-weight:600;padding:8px 0 2px;border-top:1px dashed var(--line);margin-top:4px;color:var(--ink);}
.crit-grid .h-sec-w{color:var(--win);border-color:transparent;margin-top:0;padding-top:0;}
.crit-grid .h-sec-l{color:var(--t-los);}
.crit-note{margin-top:12px;color:var(--muted);max-width:680px;font-size:11.5px;}

table{width:100%;border-collapse:collapse;}
thead th{position:sticky;top:0;background:#fafafa;text-align:left;padding:8px 10px;font-size:11px;
  text-transform:uppercase;letter-spacing:.03em;color:var(--muted);border-bottom:1px solid var(--line);
  cursor:pointer;white-space:nowrap;user-select:none;}
thead th:hover{color:var(--ink);}
thead th.num{text-align:right;}
thead th .arr{opacity:.5;font-size:9px;}
tbody td{padding:8px 10px;border-bottom:1px solid #f1f2f4;white-space:nowrap;}
tbody td.num{text-align:right;font-variant-numeric:tabular-nums;}
tbody tr{cursor:pointer;}
tbody tr:hover{background:#f7f8fa;}
.tablewrap{max-height:60vh;overflow:auto;border-radius:0 0 10px 10px;}
.concepto{font-weight:600;max-width:260px;overflow:hidden;text-overflow:ellipsis;}
.badge{display:inline-block;padding:2px 7px;border-radius:999px;font-size:10px;font-weight:700;
  letter-spacing:.02em;vertical-align:middle;}
.b-noc{background:#efeaff;color:var(--noc);}
.b-fx{background:#dcfbfa;color:#0c7a79;}
.tier-absoluto{background:var(--t-abs-bg);color:var(--t-abs);}
.tier-bueno{background:var(--t-bue-bg);color:var(--t-bue);}
.tier-destacable{background:var(--t-des-bg);color:var(--t-des);}
.tier-bajo{background:var(--t-baj-bg);color:var(--t-baj);}
.tier-loser{background:var(--t-los-bg);color:var(--t-los);}
.tier-manual{outline:1.5px dashed currentColor;outline-offset:1px;}
.tag{display:inline-block;padding:2px 6px;border-radius:6px;background:#f0f1f3;color:var(--muted);
  font-size:10px;margin-right:3px;}
.drv-yes{color:#15803d;font-weight:700;}
.drv-no{color:#cbd0d6;}
.estado-active{color:#16a34a;font-weight:600;}
.estado-not_delivering,.estado-inactive,.estado-rejected,.estado-archived{color:var(--muted);}
.muted{color:var(--muted);}
.empty{padding:40px;text-align:center;color:var(--muted);}
.count{font-size:12px;color:var(--muted);padding:10px 14px;display:flex;gap:14px;flex-wrap:wrap;}

/* ---- drawer ---- */
.drawer-bg{position:fixed;inset:0;background:rgba(16,24,40,.35);z-index:30;display:none;}
.drawer{position:fixed;top:0;right:0;height:100%;width:640px;max-width:96vw;background:#fff;
  box-shadow:-4px 0 24px rgba(16,24,40,.18);z-index:31;transform:translateX(100%);
  transition:transform .18s ease;overflow-y:auto;}
.drawer.open{transform:translateX(0);}
.drawer-bg.open{display:block;}
.drawer .dh{padding:16px 18px;border-bottom:1px solid var(--line);}
.drawer .dh .close{float:right;border:none;background:none;font-size:20px;line-height:1;padding:0;color:var(--muted);}
.drawer .dh h2{margin:0 0 6px;font-size:15px;}
.drawer .body{padding:16px 18px;}
.drawer .camp{font-size:11px;color:var(--muted);word-break:break-word;margin-bottom:12px;}
.mgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin:14px 0;}
.mgrid .m{background:#fafafa;border:1px solid var(--line);border-radius:8px;padding:8px 10px;}
.mgrid .m .l{font-size:10px;color:var(--muted);text-transform:uppercase;}
.mgrid .m .v{font-size:15px;font-weight:700;margin-top:2px;}
.block{border:1px solid var(--line);border-radius:8px;padding:10px 12px;margin-bottom:10px;}
.block .bl-l{font-size:10px;text-transform:uppercase;color:var(--muted);letter-spacing:.04em;margin-bottom:6px;}
.links a{display:block;padding:9px 12px;border:1px solid var(--line);border-radius:8px;margin-bottom:8px;
  text-decoration:none;color:var(--ink);font-weight:600;}
.links a:hover{background:#f7f8fa;}
.links a small{display:block;font-weight:400;color:var(--muted);font-size:11px;}
.drive-row{display:flex;gap:6px;}
.drive-row input{flex:1;min-width:0;}
.note{font-size:11px;color:#92600c;background:#fff7ed;border:1px solid #fed7aa;border-radius:8px;
  padding:8px 10px;margin-top:10px;}
.note.grey{color:var(--muted);background:#f7f8fa;border-color:var(--line);}
.set-by{font-size:10px;color:var(--muted);margin-top:4px;}

/* ---- modal genérico (reporte de importación) ---- */
.modal-bg{position:fixed;inset:0;background:rgba(16,24,40,.4);z-index:40;display:none;align-items:center;justify-content:center;}
.modal-bg.open{display:flex;}
.modal{background:#fff;border-radius:12px;max-width:560px;width:92vw;max-height:80vh;overflow:auto;padding:20px 22px;
  box-shadow:0 12px 40px rgba(16,24,40,.2);}
.modal h3{margin:0 0 10px;font-size:15px;}
.modal table{font-size:12px;margin-top:8px;}
.modal td{padding:3px 8px;border-bottom:1px solid #f1f2f4;}
.modal .ok{color:#15803d;font-weight:700;}
.modal .actions{margin-top:16px;text-align:right;}
.toast{position:fixed;bottom:20px;left:50%;transform:translateX(-50%);background:var(--ink);color:#fff;
  padding:10px 16px;border-radius:8px;font-size:12px;z-index:60;opacity:0;transition:opacity .2s;}
.toast.show{opacity:1;}
@media(max-width:1200px){.kpis{grid-template-columns:repeat(4,1fr);}}

/* ---- view tabs ---- */
.viewtabs{display:flex;gap:4px;background:#eef0f3;border-radius:9px;padding:3px;}
.vt{border:none;background:transparent;padding:6px 12px;border-radius:7px;font-size:12px;font-weight:600;color:var(--muted);}
.vt:hover{background:#e3e5e9;}
.vt.active{background:#fff;color:var(--ink);box-shadow:var(--shadow);}

/* ---- confirmación de winner (drawer) ---- */
.confirm-box{border:1.5px solid var(--noc);border-radius:10px;padding:12px 14px;margin-bottom:12px;background:#faf9ff;}
.confirm-box .bl-l{color:var(--noc);}
.suggest-row{display:flex;gap:8px;margin:8px 0;flex-wrap:wrap;}
.suggest{flex:1;min-width:130px;background:#fff;border:1px solid var(--line);border-radius:8px;padding:7px 9px;}
.suggest .sl{font-size:9.5px;text-transform:uppercase;color:var(--muted);letter-spacing:.03em;}
.suggest .sv{font-size:12px;font-weight:700;margin-top:2px;}
.nivel-pick{display:flex;gap:6px;margin:8px 0;}
.nivel-pick label{flex:1;border:1px solid var(--line);border-radius:8px;padding:7px 6px;text-align:center;cursor:pointer;
  font-size:11px;font-weight:600;background:#fff;}
.nivel-pick input{display:none;}
.nivel-pick input:checked+span{display:block;}
.nivel-pick label:has(input:checked){border-color:var(--noc);background:#f0ecff;box-shadow:0 0 0 1px var(--noc) inset;}
textarea.nota{width:100%;border:1px solid var(--line);border-radius:8px;padding:8px 10px;font:inherit;font-size:12px;
  resize:vertical;min-height:62px;margin:6px 0;}
.btn-confirm{width:100%;background:var(--noc);color:#fff;border-color:var(--noc);font-weight:700;padding:9px;}
.btn-confirm:hover{opacity:.92;background:var(--noc);}
.confirmed-pill{display:inline-block;font-size:10px;font-weight:700;color:var(--win);background:#dcfce7;
  border-radius:999px;padding:2px 7px;}
.mini-confirm{font-size:10.5px;font-weight:700;padding:3px 9px;border-radius:7px;
  background:var(--noc);color:#fff;border:1px solid var(--noc);}
.mini-confirm:hover{opacity:.88;background:var(--noc);}
.in-hist{font-size:11px;color:var(--win);background:#f0fdf4;border:1px solid #bbf7d0;border-radius:8px;
  padding:8px 10px;margin-bottom:10px;}
.recu{display:inline-block;font-size:10px;font-weight:700;color:#7c3aed;background:#f3e8ff;border-radius:999px;padding:2px 7px;}
.ad-frame{width:100%;border:1px solid var(--line);border-radius:8px;background:#fafafa;display:block;}
iframe.ad-frame{height:640px;}
img.ad-frame, video.ad-frame{height:auto;max-height:720px;object-fit:contain;}
.ad-frame-note{font-size:10.5px;color:var(--muted);margin-top:5px;}
.ad-frame-loading{width:100%;height:480px;border:1px solid var(--line);border-radius:8px;background:#fafafa;
  display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:12px;}

/* ---- vista administrador (con sub-pestañas) ---- */
.subtabs{display:flex;gap:3px;background:#eef0f3;border-radius:9px;padding:3px;width:max-content;margin-bottom:14px;}
.st{border:none;background:transparent;padding:6px 14px;border-radius:7px;font-size:12px;font-weight:600;color:var(--muted);cursor:pointer;}
.st:hover{background:#e3e5e9;color:var(--ink);}
.st.active{background:#fff;color:var(--ink);box-shadow:var(--shadow);}
.subview{display:block;}
.admin-panel{padding:14px 18px;max-width:780px;}
.ayuda-panel{padding:18px 22px;max-width:1200px;}
.admin-h{font-size:14px;margin:0 0 10px;display:flex;align-items:center;flex-wrap:wrap;gap:4px;}
.admin-field{margin-bottom:14px;}
.admin-field:last-child{margin-bottom:0;}
.admin-field label{font-size:12px;font-weight:600;display:block;margin-bottom:3px;}
.admin-hint{font-size:11.5px;color:var(--muted);margin:0 0 8px;line-height:1.4;}
.cfg-status{font-size:10px;font-weight:700;padding:2px 7px;border-radius:999px;margin-left:6px;}
.cfg-set{background:#dcfce7;color:#15803d;}
.cfg-unset{background:#f0f1f3;color:var(--muted);}
.admin-actions{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:8px;}
.cmp-row{display:flex;align-items:center;gap:10px;padding:7px 10px;border:1px solid var(--line);border-radius:8px;margin-bottom:6px;font-size:12px;}
.cmp-name{font-weight:600;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.cmp-edit,.cmp-save,.cmp-cancel{font-size:11px;padding:4px 10px;}
.cmp-input{flex:1;min-width:0;padding:5px 8px;border:1px solid var(--line);border-radius:6px;font:inherit;}

/* ---- sección de ayuda ---- */
.ayuda .group-title{font-size:10.5px;text-transform:uppercase;color:var(--muted);letter-spacing:.05em;margin:18px 0 8px;font-weight:700;border-top:1px solid var(--line);padding-top:14px;}
.ayuda .group-title:first-of-type{border-top:none;padding-top:4px;margin-top:8px;}
.ayuda ol{margin:0;padding-left:0;list-style:none;counter-reset:step;}
.ayuda ol li{position:relative;padding:10px 12px 10px 44px;margin-bottom:6px;background:#fafafa;border:1px solid var(--line);border-radius:8px;font-size:12px;line-height:1.5;counter-increment:step;}
.ayuda ol li::before{content:counter(step);position:absolute;left:10px;top:10px;width:24px;height:24px;border-radius:50%;background:var(--ink);color:#fff;font-weight:700;font-size:11px;display:flex;align-items:center;justify-content:center;}
.ayuda ol li strong{display:block;color:var(--ink);font-size:13px;margin-bottom:3px;}
.ayuda ol li em{font-style:normal;background:#eef0f3;padding:1px 5px;border-radius:4px;font-size:11.5px;}
.ayuda .concepts{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:10px;}
.ayuda .concept{background:#fafafa;border:1px solid var(--line);border-radius:8px;padding:10px 12px;font-size:11.5px;line-height:1.45;}
.ayuda .concept strong{display:block;color:var(--ink);margin-bottom:3px;font-size:12px;}
.anal-no{color:var(--warn);font-weight:600;}
.anal-si{color:var(--win);font-weight:600;}
.w-danger{font-size:11px;color:#b91c1c;background:none;border:1px solid #fecaca;}
.w-danger:hover{background:#fee2e2;}
.periodos-list{font-size:11px;color:var(--muted);}
