/* INTEGRA360 · estilos */

/* ── COMPACT PRO TOKENS ─────────────────────────────── */
:root{
  /* Rail (sidebar) — Integra360 */
  --rail:#0D1B2A;--rail-sub:#122233;--rail-hover:#1a2e42;
  --rail-txt:#e2e8f0;--rail-muted:#64748B;--rail-bdr:#1e3247;

  /* Surface */
  --bg:#f8fafc;--srf:#ffffff;
  --bdr:#e2e8f0;--bdr2:#cbd5e1;

  /* Text */
  --txt:#0D1B2A;--txt2:#334155;--txt3:#64748B;

  /* Accent — Integra360 */
  --pri:#17B4A6;--pri-l:#e6faf8;--pri-d:#0e8f84;--pri-ln:#9ee8e3;
  --sec:#17B4A6;--sec-l:#e6faf8;
  --acc:#E2E8F0;

  /* Risk levels — Compact Pro */
  --r-i:#dc2626;   --r-i-bg:#fee2e2;   --r-i-txt:#991b1b;
  --r-ii:#ea580c;  --r-ii-bg:#ffedd5;  --r-ii-txt:#9a3412;
  --r-iii:#ca8a04; --r-iii-bg:#fef3c7; --r-iii-txt:#854d0e;
  --r-iv:#16a34a;  --r-iv-bg:#dcfce7;  --r-iv-txt:#166534;

  --radius:9px;--radius-sm:6px;--radius-lg:12px;
  --sh:0 1px 3px rgba(0,0,0,.06);
  --sh-md:0 4px 16px rgba(0,0,0,.08);
}

/* ── MODO OSCURO ────────────────────────────────────── */
[data-theme="dark"]{
  --bg:#111827;--srf:#1f2937;
  --bdr:#374151;--bdr2:#4b5563;
  --txt:#f1f5f9;--txt2:#cbd5e1;--txt3:#94a3b8;
  --pri-l:#0f2e2c;--pri-ln:#0e4f4a;
  --sec-l:#0f2e2c;
  --acc:#1f2937;
  --sh:0 1px 3px rgba(0,0,0,.3);
  --sh-md:0 4px 16px rgba(0,0,0,.4);
}
[data-theme="dark"] body{ background:var(--bg); }
[data-theme="dark"] .hdr{ background:var(--srf);border-color:var(--bdr); }
[data-theme="dark"] .card{ background:var(--srf);border-color:var(--bdr); }
[data-theme="dark"] .panel{ background:var(--bg); }
[data-theme="dark"] input,[data-theme="dark"] select,[data-theme="dark"] textarea{
  background:var(--srf)!important;color:var(--txt)!important;border-color:var(--bdr2)!important;
}
[data-theme="dark"] .tbl-wrap table{ background:var(--srf); }
[data-theme="dark"] tbody tr:nth-child(odd){ background:#243044; }
[data-theme="dark"] tbody tr:hover{ background:#2d3e55!important; }
[data-theme="dark"] thead tr{ background:#1a2537!important; }
[data-theme="dark"] .badge-cnt{ background:var(--srf);border-color:var(--bdr);color:var(--txt2); }
[data-theme="dark"] .drw-bg{ background:rgba(0,0,0,.6); }
[data-theme="dark"] .drw{ background:var(--srf); }
[data-theme="dark"] #usr-modal > div{ background:var(--srf); }
[data-theme="dark"] .auth-box{ background:var(--srf); }
*, *::before, *::after{ transition:background-color .2s ease, border-color .2s ease, color .15s ease; }

/* ── RESET ──────────────────────────────────────────── */
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Inter',sans-serif;background:var(--bg);color:var(--txt);font-size:13px;line-height:1.45;min-height:100vh;-webkit-font-smoothing:antialiased}
.app{display:flex;flex-direction:column;min-height:100vh}

/* ── TOPBAR ─────────────────────────────────────────── */
.hdr{background:#fff;border-bottom:1px solid var(--bdr);padding:0 20px;height:48px;display:flex;align-items:center;gap:12px;position:sticky;top:0;z-index:200}
.hdr-logo{display:none}
.hdr-title{font-size:13px;font-weight:500;color:var(--txt2)}
.hdr-sep{color:var(--bdr2);font-size:13px;margin:0 2px}
.hdr-crumb{font-size:13px;font-weight:600;color:var(--txt)}
.hdr-sub{display:none}
.hdr-right{margin-left:auto;display:flex;gap:8px;align-items:center}
.badge-cnt{background:var(--bg);border:1px solid var(--bdr);color:var(--txt2);padding:2px 10px;border-radius:20px;font-size:11px;font-weight:500;font-family:'JetBrains Mono',monospace}
.btn-exp{background:#fff;border:1px solid var(--bdr2);color:var(--txt2);padding:0 12px;height:30px;border-radius:6px;font-size:12px;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:6px;transition:all .15s;font-family:'Inter',sans-serif}
.btn-exp:hover{border-color:var(--txt3);color:var(--txt)}
.btn-nuevo{background:var(--rail);border:none;color:#fff;padding:0 14px;height:30px;border-radius:6px;font-size:12px;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:6px;transition:background .15s;font-family:'Inter',sans-serif}
.btn-nuevo:hover{background:#2a221c}

/* ── LAYOUT ─────────────────────────────────────────── */
.main{display:flex;flex:1;overflow:hidden;height:calc(100vh - 48px)}
.sidebar{width:208px;background:var(--rail);border-right:1px solid var(--rail-bdr);flex-shrink:0;display:flex;flex-direction:column;overflow:hidden}
.sidebar-head{padding:14px 14px 10px;border-bottom:1px solid var(--rail-bdr)}
.sidebar-logo{display:flex;align-items:center;gap:8px}
.logo-sq{width:26px;height:26px;background:var(--pri);border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:#fff;flex-shrink:0;letter-spacing:-0.5px}
.logo-txt{display:flex;flex-direction:column}
.logo-name{font-size:13px;font-weight:600;color:var(--rail-txt);line-height:1.2}
.logo-sub{font-size:10.5px;color:var(--rail-muted);line-height:1.2}
.sidebar-search{margin-top:10px;display:flex;align-items:center;gap:7px;background:var(--rail-sub);border:1px solid var(--rail-bdr);border-radius:6px;padding:6px 10px;cursor:pointer}
.sidebar-search svg{opacity:.45;flex-shrink:0}
.sidebar-search span{font-size:12px;color:var(--rail-muted);flex:1}
.sidebar-search kbd{background:var(--rail-bdr);color:var(--rail-muted);font-family:'JetBrains Mono',monospace;font-size:10px;padding:1px 5px;border-radius:3px}
.sidebar-nav{flex:1;padding:8px 0;overflow-y:auto}
.nav-lbl{padding:10px 14px 4px;font-size:10px;font-weight:600;color:var(--rail-muted);text-transform:uppercase;letter-spacing:.08em}
.nav-item{display:flex;align-items:center;gap:9px;padding:8px 14px;cursor:pointer;font-size:12.5px;font-weight:500;color:var(--rail-muted);transition:all .12s;border-left:2px solid transparent;position:relative;margin:1px 0}
.nav-item:hover{background:var(--rail-hover);color:var(--rail-txt)}
.nav-item.active{background:var(--rail-hover);color:var(--rail-txt);border-left-color:var(--pri)}
.nav-item .ni{font-size:14px;opacity:.7;width:16px;text-align:center}
.nav-item.active .ni{opacity:1}
.nav-div{height:1px;background:var(--rail-bdr);margin:6px 14px}
.sidebar-footer{padding:12px 14px;border-top:1px solid var(--rail-bdr)}
.sf-label{font-size:10px;font-weight:600;color:var(--rail-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px}
.sf-number{font-size:18px;font-weight:600;font-family:'JetBrains Mono',monospace;color:var(--rail-txt);line-height:1;margin-bottom:6px}
.sf-bar{height:4px;background:var(--rail-bdr);border-radius:2px;overflow:hidden}
.sf-fill{height:100%;background:var(--pri);border-radius:2px;transition:width .4s}
.sf-desc{font-size:10.5px;color:var(--rail-muted);margin-top:4px}

.content{flex:1;overflow-y:auto;padding:20px 24px}
.panel{display:none}.panel.active{display:block}

/* ── CARDS ──────────────────────────────────────────── */
.card{background:var(--srf);border:1px solid var(--bdr);border-radius:var(--radius);padding:16px 18px;margin-bottom:14px}
.card-ttl{font-size:10.5px;font-weight:600;color:var(--txt3);display:flex;align-items:center;gap:8px;margin-bottom:14px;text-transform:uppercase;letter-spacing:.04em}

/* ── STEPPER ─────────────────────────────────────────── */
.stepper{display:flex;align-items:center;margin-bottom:20px;padding:0 4px;gap:0}
.stp{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;position:relative;padding-bottom:4px}
.stp::after{content:'';position:absolute;top:10px;left:calc(50% + 14px);right:calc(-50% + 14px);height:1px;background:var(--bdr2)}
.stp:last-child::after{display:none}
.sn{width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:600;border:1.5px solid var(--bdr2);background:#fff;color:var(--txt3);z-index:1;font-family:'JetBrains Mono',monospace;transition:all .15s}
.stp-lbl{font-size:10px;color:var(--txt3);font-weight:500;white-space:nowrap}
.stp.done .sn{background:var(--sec);border-color:var(--sec);color:#fff}
.stp.done .sn::before{content:'✓'}
.stp.done .stp-lbl{color:var(--sec)}
.stp.active .sn{background:var(--pri);border-color:var(--pri);color:#fff}
.stp.active .stp-lbl{color:var(--pri);font-weight:600}
.stp.active::after,.stp.done::after{background:var(--sec)}
.stp.done{cursor:pointer}
.stp.done:hover .sn{opacity:.8;transform:scale(1.1)}
.stp.done:hover .stp-lbl{opacity:.8}

/* ── GRIDS ──────────────────────────────────────────── */
.g2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.g3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}

/* ── FIELDS ─────────────────────────────────────────── */
.fld{display:flex;flex-direction:column;gap:4px;margin-bottom:12px}
.fld label{font-size:10.5px;font-weight:600;color:var(--txt2);text-transform:uppercase;letter-spacing:.04em}
.fld input,.fld select,.fld textarea{font-family:'Inter',sans-serif;font-size:12.5px;padding:7px 10px;border:1px solid var(--bdr2);border-radius:var(--radius-sm);background:#fff;color:var(--txt);outline:none;transition:border-color .15s,box-shadow .15s;width:100%}
.fld input:focus,.fld select:focus,.fld textarea:focus{border-color:var(--pri);box-shadow:0 0 0 3px rgba(160,0,88,.08)}
.fld textarea{min-height:68px;resize:vertical}
select:disabled,input:disabled{opacity:.4;cursor:not-allowed;background:var(--bg)}

/* ── ALERTS ─────────────────────────────────────────── */
.alert{border-radius:var(--radius-sm);padding:9px 12px;font-size:12px;margin-bottom:12px;border:1px solid}
.alert-pri{background:var(--pri-l);border-color:var(--pri-ln);color:#6b0039}
.alert-sec{background:var(--sec-l);border-color:#8dd9a8;color:#065f46}

/* ── CHIPS (multi-cargo) ────────────────────────────── */
.chip-box{border:1px solid var(--bdr2);border-radius:var(--radius-sm);background:#fff;min-height:38px;padding:5px 8px;cursor:text;transition:border-color .15s;display:flex;flex-wrap:wrap;gap:4px;align-items:flex-start;position:relative}
.chip-box.focused{border-color:var(--pri);box-shadow:0 0 0 3px rgba(160,0,88,.08)}
.chip{background:var(--pri-l);color:var(--pri);border:1px solid var(--pri-ln);border-radius:4px;padding:2px 8px;font-size:11.5px;font-weight:500;display:flex;align-items:center;gap:4px;white-space:nowrap}
.chip .rm{cursor:pointer;font-size:13px;line-height:1;opacity:.6}
.chip .rm:hover{opacity:1}
.chip-input{border:none;outline:none;font-size:12.5px;font-family:'Inter',sans-serif;color:var(--txt);background:transparent;min-width:120px;flex:1;padding:2px 4px}
.ms-drop{position:absolute;top:100%;left:-1px;right:-1px;background:#fff;border:1px solid var(--bdr2);border-top:none;border-radius:0 0 var(--radius-sm) var(--radius-sm);max-height:200px;overflow-y:auto;z-index:50;box-shadow:var(--sh-md);display:none}
.ms-drop.open{display:block}
.ms-opt{padding:7px 11px;font-size:12.5px;cursor:pointer;color:var(--txt);transition:background .1s}
.ms-opt:hover,.ms-opt.hl{background:var(--pri-l);color:var(--pri)}
.ms-opt.sel{background:var(--sec-l);color:var(--sec)}
.ms-opt.sel::after{content:' ✓';float:right;opacity:.7}
.ms-empty{padding:10px 12px;font-size:12px;color:var(--txt3);text-align:center}

/* ── SUGGESTION CHIPS ───────────────────────────────── */
.sug-row{display:flex;flex-wrap:wrap;gap:5px;margin-top:6px}
.sug-chip{background:var(--bg);border:1px solid var(--bdr2);border-radius:4px;padding:3px 9px;font-size:11px;color:var(--txt2);cursor:pointer;transition:all .12s}
.sug-chip:hover{background:var(--pri-l);border-color:var(--pri-ln);color:var(--pri)}
.sug-chip.added{background:var(--sec-l);border-color:#8dd9a8;color:var(--sec)}
.sug-lbl{font-size:10.5px;color:var(--txt3);margin-bottom:4px;font-weight:500}

/* ── OPT CARDS (ND/NE/NC) ──────────────────────────── */
.opt-grid{display:grid;grid-template-columns:1fr 1fr;gap:7px}
.opt-card{border:1px solid var(--bdr2);border-radius:var(--radius-sm);padding:9px 11px;cursor:pointer;transition:all .12s;background:#fff;display:flex;align-items:flex-start;gap:8px}
.opt-card:hover{border-color:var(--pri);background:var(--pri-l)}
.opt-card.sel{border-color:var(--pri);background:var(--pri-l)}
.opt-card .ol{font-size:12px;font-weight:600;color:var(--txt);flex:1}
.opt-card.sel .ol{color:var(--pri)}
.opt-card .od{font-size:10.5px;color:var(--txt3);margin-top:2px;font-weight:400}
.opt-card .ov{font-family:'JetBrains Mono',monospace;font-size:13px;font-weight:600;color:var(--txt3);margin-top:2px}
.opt-card.sel .ov{color:var(--pri)}

/* ── RESULT BOX ─────────────────────────────────────── */
.res-box{border-radius:var(--radius);padding:14px 16px;border:1px solid;margin-top:12px}
.calc-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:10px}
.calc-v{text-align:center;min-width:44px}
.calc-v .v{font-size:20px;font-weight:600;font-family:'JetBrains Mono',monospace}
.calc-v .l{font-size:9.5px;color:var(--txt3);text-transform:uppercase;letter-spacing:.04em}
.calc-op{font-size:16px;color:var(--txt3)}

/* ── BUTTONS ─────────────────────────────────────────── */
.btn-row{display:flex;gap:8px;justify-content:flex-end;margin-top:16px;padding-top:14px;border-top:1px solid var(--bdr)}
.btn{font-family:'Inter',sans-serif;font-size:12.5px;font-weight:500;padding:0 14px;height:30px;border-radius:6px;cursor:pointer;transition:all .12s;border:1px solid var(--bdr2);background:#fff;color:var(--txt);display:inline-flex;align-items:center;gap:6px}
.btn:hover{background:var(--bg);border-color:var(--bdr)}
.btn:disabled{opacity:.4;cursor:not-allowed}
.btn-pri{background:var(--rail);color:#fff;border-color:var(--rail)}
.btn-pri:hover{background:#2a221c;border-color:#2a221c}
.btn-suc{background:var(--sec);color:#fff;border-color:var(--sec)}
.btn-suc:hover{background:#0a8a42;border-color:#0a8a42}

/* ── TABLE ──────────────────────────────────────────── */
.tbl-wrap{overflow-x:auto;border-radius:var(--radius);border:1px solid var(--bdr)}
table{width:100%;border-collapse:collapse;font-size:12px;min-width:1000px}
thead tr{background:#f1f5f9;border-bottom:1px solid var(--bdr)}
th{padding:9px 8px;color:var(--txt3);font-weight:600;text-align:left;white-space:nowrap;font-size:10px;letter-spacing:.04em;text-transform:uppercase}
tbody tr{border-bottom:1px solid var(--bdr);transition:background .1s}
tbody tr:hover{background:#faf7f2}
td{padding:8px;vertical-align:middle}
.td-m{font-family:'JetBrains Mono',monospace;font-size:11px;font-weight:500;text-align:center}

/* ── BADGES ─────────────────────────────────────────── */
.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:600}
.badge-I{background:var(--r-i-bg);color:var(--r-i-txt)}
.badge-II{background:var(--r-ii-bg);color:var(--r-ii-txt)}
.badge-III{background:var(--r-iii-bg);color:var(--r-iii-txt)}
.badge-IV{background:var(--r-iv-bg);color:var(--r-iv-txt)}
.badge-sm{background:var(--bg);color:var(--txt3);font-size:10px;padding:1px 6px;border-radius:3px;border:1px solid var(--bdr)}

/* ── STATS / BARS ────────────────────────────────────── */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:10px;margin-bottom:14px}
.stat-card{background:var(--srf);border:1px solid var(--bdr);border-radius:var(--radius);padding:14px 16px}
.bar-row{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.bar-lbl{font-size:12px;min-width:200px;color:var(--txt2)}
.bar-track{flex:1;background:var(--bg);border-radius:2px;height:6px;overflow:hidden}
.bar-fill{height:100%;border-radius:2px;transition:width .4s}

/* ── FILTER BAR ─────────────────────────────────────── */
.fil-bar{background:var(--srf);border:1px solid var(--bdr);border-radius:var(--radius);padding:12px 16px;margin-bottom:14px;display:grid;grid-template-columns:1fr 1fr 1fr auto;gap:10px;align-items:end}
.empty-st{text-align:center;padding:60px 20px;color:var(--txt3)}
.empty-st .ei{font-size:40px;margin-bottom:12px}

/* ── PREVIEW ─────────────────────────────────────────── */
.preview{border-radius:var(--radius-sm);padding:12px 14px;margin:10px 0;border:1px solid}
.preview-g{display:grid;grid-template-columns:1fr 1fr;gap:5px 14px;font-size:11.5px}

/* ── STEP 3 — LAYOUT 2 COLUMNAS ────────────────────── */
.step3-grid{display:grid;grid-template-columns:1fr 280px;gap:14px;align-items:start}
.live-panel-wrap{position:sticky;top:20px}
.live-panel-wrap .card{margin-bottom:0}
.live-nr{font-size:52px;font-weight:700;font-family:'JetBrains Mono',monospace;line-height:1;text-align:center;margin:8px 0 4px}
.live-eq{display:flex;align-items:center;justify-content:center;gap:6px;font-size:13px;margin:10px 0 6px;flex-wrap:wrap}
.live-eq .v{font-family:'JetBrains Mono',monospace;font-size:15px;font-weight:700}
.live-eq .op{color:var(--txt3);font-size:12px}
.live-lbl{font-size:9px;color:var(--txt3);text-transform:uppercase;letter-spacing:.05em;text-align:center;display:block}
@media(max-width:860px){.step3-grid{grid-template-columns:1fr}.live-panel-wrap{position:static}}
/* ── SEGUIMIENTOS THREAD ────────────────────────────── */
.seg-thread{display:flex;flex-direction:column}
.seg-entry{display:flex;gap:12px;padding:12px 0;border-bottom:1px solid var(--bdr)}
.seg-entry:last-child{border-bottom:none}
.seg-line{display:flex;flex-direction:column;align-items:center;flex-shrink:0;width:9px}
.seg-dot{width:9px;height:9px;border-radius:50%;background:var(--pri);margin-top:4px}
.seg-connector{width:1px;flex:1;background:var(--bdr2);margin-top:4px}
.seg-content{flex:1;min-width:0}
.seg-meta{font-size:10.5px;color:var(--txt3);margin-bottom:5px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.seg-user{font-weight:600;color:var(--txt2)}
.seg-date{font-family:'JetBrains Mono',monospace}
.seg-tag{background:var(--pri-l);color:var(--pri);border:1px solid var(--pri-ln);border-radius:3px;padding:1px 6px;font-size:9.5px;font-weight:600}
.seg-obs{font-size:12.5px;color:var(--txt);line-height:1.55;white-space:pre-wrap}
.seg-empty{color:var(--txt3);font-size:12px;padding:16px 0;text-align:center}
.seg-add-btn{background:var(--bg);border:1px dashed var(--bdr2);color:var(--txt2);padding:0 12px;height:28px;border-radius:5px;font-size:11.5px;font-weight:500;cursor:pointer;transition:all .15s;font-family:'Inter',sans-serif;display:inline-flex;align-items:center;gap:5px}
.seg-add-btn:hover{border-color:var(--pri);color:var(--pri);background:var(--pri-l)}
.seg-form{background:var(--bg);border:1px solid var(--bdr2);border-radius:var(--radius-sm);padding:12px;margin-top:10px}
.seg-form textarea{width:100%;border:1px solid var(--bdr2);border-radius:var(--radius-sm);padding:8px 10px;font-size:12.5px;font-family:'Inter',sans-serif;resize:vertical;min-height:72px;outline:none;color:var(--txt)}
.seg-form textarea:focus{border-color:var(--pri);box-shadow:0 0 0 3px rgba(160,0,88,.07)}
.seg-form-row{display:flex;gap:8px;margin-top:8px;justify-content:flex-end}
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-thumb{background:var(--bdr2);border-radius:3px}
::-webkit-scrollbar-track{background:transparent}

/* ── OBS TEMPLATE ───────────────────────────────────── */
.obs-tpl{font-size:11px;color:var(--pri);cursor:pointer;text-decoration:underline;margin-top:4px;display:inline-block}

/* ── USER PILL ──────────────────────────────────────── */
#user-badge{display:flex;align-items:center;gap:7px;background:var(--bg);border:1px solid var(--bdr);border-radius:20px;padding:3px 8px 3px 4px;cursor:pointer;transition:border-color .15s,background .15s,box-shadow .15s;outline:none}
#user-badge:hover{background:var(--srf);border-color:var(--pri-ln);box-shadow:0 1px 3px rgba(13,27,42,.07)}
#user-badge:focus-visible{border-color:var(--pri);box-shadow:0 0 0 3px var(--pri-l)}
#user-badge[aria-expanded="true"]{background:var(--srf);border-color:var(--pri-ln)}
#user-badge[aria-expanded="true"] #user-chevron{transform:rotate(180deg)}
#user-avatar{width:22px;height:22px;background:var(--pri);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:#fff}
#user-name{font-size:12px;font-weight:500;color:var(--txt2)}
/* ── USER DROPDOWN MENU ─────────────────────────────── */
#user-menu{position:absolute;top:calc(100% + 8px);right:0;min-width:212px;background:var(--srf);border:1px solid var(--bdr);border-radius:11px;box-shadow:0 12px 34px rgba(13,27,42,.16),0 2px 6px rgba(13,27,42,.06);padding:6px;z-index:200;opacity:0;visibility:hidden;transform:translateY(-6px);transition:opacity .15s,transform .15s,visibility .15s}
#user-menu.open{opacity:1;visibility:visible;transform:translateY(0)}
#user-menu button{display:flex;align-items:center;gap:10px;width:100%;background:transparent;border:none;text-align:left;padding:9px 11px;border-radius:7px;font-family:'Inter',sans-serif;font-size:13px;font-weight:500;color:var(--txt);cursor:pointer;transition:background .12s}
#user-menu button:hover{background:var(--pri-l);color:var(--pri-d)}
#user-menu button .um-ic{width:18px;text-align:center;font-size:13px;color:var(--txt3);flex-shrink:0}
#user-menu button:hover .um-ic{color:var(--pri-d)}
#user-menu button.um-danger{color:#b91c1c}
#user-menu button.um-danger .um-ic{color:#dc2626}
#user-menu button.um-danger:hover{background:#fef2f2;color:#991b1b}
#user-menu .um-sep{height:1px;background:var(--bdr);margin:5px 6px}
/* role pill shown in header when tweak enabled */
#hdr-role-pill{display:none;font-size:9.5px;font-weight:700;letter-spacing:.03em;padding:2px 7px;border-radius:4px;color:#fff;background:var(--pri);white-space:nowrap}

/* ── FILTER CHIPS ────────────────────────────────────── */
.fil-chips{display:flex;align-items:center;gap:6px;flex-wrap:wrap;padding:12px 0;margin-bottom:12px;border-bottom:1px solid var(--bdr)}
.cf{position:relative;display:inline-flex;align-items:center;gap:5px;padding:5px 10px;border:1px solid var(--bdr2);border-radius:6px;font-size:12px;color:var(--txt2);cursor:pointer;background:#fff;user-select:none;transition:all .12s;white-space:nowrap}
.cf:hover{border-color:var(--txt3);color:var(--txt)}
.cf.active{background:var(--pri-l);border-color:var(--pri-ln);color:var(--pri)}
.cf .cf-lbl{font-size:10.5px;color:var(--txt3);font-weight:500}
.cf.active .cf-lbl{color:var(--pri);opacity:.7}
.cf .cf-val{font-weight:600}
.cf .cf-arr{font-size:10px;opacity:.5;margin-left:2px}
.cf-drop{position:absolute;top:calc(100% + 4px);left:0;min-width:210px;background:#fff;border:1px solid var(--bdr2);border-radius:8px;box-shadow:0 8px 24px rgba(0,0,0,.1);z-index:300;display:none;overflow:hidden}
.cf-drop.open{display:block}
.cf-opt{padding:8px 12px;font-size:12.5px;cursor:pointer;color:var(--txt);transition:background .1s;display:flex;align-items:center;gap:8px}
.cf-opt:hover{background:var(--bg)}
.cf-opt.sel{background:var(--pri-l);color:var(--pri);font-weight:500}
.cf-opt.sel::after{content:'✓';margin-left:auto;font-size:11px}
.fil-search-wrap{display:flex;align-items:center;gap:6px;padding:5px 10px;border:1px solid var(--bdr2);border-radius:6px;background:#fff;margin-left:auto}
.fil-search-wrap svg{opacity:.35;flex-shrink:0}
.fil-search-wrap input{border:none;outline:none;font-size:12px;color:var(--txt);font-family:'Inter',sans-serif;width:150px;background:transparent}
.cf-clear{background:transparent;border:none;font-size:11.5px;color:var(--txt3);cursor:pointer;padding:4px 8px;border-radius:4px;transition:all .12s;font-family:'Inter',sans-serif}
.cf-clear:hover{background:var(--bg);color:var(--txt)}

/* ── DRAWER ──────────────────────────────────────────── */
.drw-overlay{position:fixed;inset:0;background:rgba(21,17,14,.35);z-index:400;opacity:0;pointer-events:none;transition:opacity .22s}
.drw-overlay.open{opacity:1;pointer-events:all}
.drw{position:fixed;top:0;right:0;width:560px;height:100vh;background:#fff;border-left:1px solid var(--bdr);z-index:401;transform:translateX(100%);transition:transform .25s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column}
.drw.open{transform:translateX(0)}
.drw-hdr{padding:0 20px;height:52px;display:flex;align-items:center;gap:12px;border-bottom:1px solid var(--bdr);flex-shrink:0;background:#fff}
.drw-nr{font-family:'JetBrains Mono',monospace;font-size:24px;font-weight:700;line-height:1}
.drw-body{flex:1;overflow-y:auto;padding:20px}
.drw-sec{margin-bottom:18px}
.drw-sec-ttl{font-size:10px;font-weight:600;color:var(--txt3);text-transform:uppercase;letter-spacing:.06em;margin-bottom:10px;padding-bottom:6px;border-bottom:1px solid var(--bdr)}
.drw-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px 20px}
.drw-field{display:flex;flex-direction:column;gap:2px;padding:6px 0}
.drw-field .df-l{font-size:10px;font-weight:600;color:var(--txt3);text-transform:uppercase;letter-spacing:.04em}
.drw-field .df-v{font-size:12.5px;color:var(--txt);line-height:1.4}
.drw-field.full{grid-column:1/-1}
.drw-close{width:28px;height:28px;border:1px solid var(--bdr2);border-radius:6px;background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;color:var(--txt3);transition:all .12s;margin-left:auto;flex-shrink:0}
.drw-close:hover{background:var(--bg);color:var(--txt)}
.drw-footer{padding:14px 20px;border-top:1px solid var(--bdr);display:flex;gap:8px;align-items:center;flex-shrink:0;background:#fff}
.drw-del-confirm{padding:14px 20px;border-top:1px solid var(--bdr);background:#fff9f9;flex-shrink:0}
.drw-del-confirm p{font-size:12.5px;color:var(--txt2);margin-bottom:8px}
.drw-del-confirm strong{color:#dc2626}
.drw-del-confirm input{width:100%;padding:7px 10px;border:1.5px solid #fca5a5;border-radius:6px;font-size:13px;font-family:'Inter',sans-serif;outline:none;margin-bottom:8px;transition:border-color .15s}
.drw-del-confirm input:focus{border-color:#dc2626}
.btn-danger{background:#fff;border:1px solid #fca5a5;color:#dc2626;padding:0 14px;height:30px;border-radius:6px;font-size:12px;font-weight:500;cursor:pointer;font-family:'Inter',sans-serif;transition:all .12s}
.btn-danger:hover{background:#fee2e2;border-color:#dc2626}
.btn-danger:disabled{opacity:.4;cursor:not-allowed}
.btn-danger-solid{background:#dc2626;border:none;color:#fff;padding:0 14px;height:30px;border-radius:6px;font-size:12px;font-weight:500;cursor:pointer;font-family:'Inter',sans-serif;transition:all .12s}
.btn-danger-solid:hover{background:#b91c1c}
.btn-danger-solid:disabled{opacity:.4;cursor:not-allowed}
.btn-edit{background:#fff;border:1px solid var(--bdr2);color:var(--txt);padding:0 14px;height:30px;border-radius:6px;font-size:12px;font-weight:500;cursor:pointer;font-family:'Inter',sans-serif;transition:all .12s}
.btn-edit:hover{background:var(--bg);border-color:var(--txt3)}
tbody tr.clickable{cursor:pointer}

/* ── SEARCH PANEL ───────────────────────────────────── */
.sp-overlay{position:fixed;inset:0;background:rgba(13,27,42,.4);z-index:600;opacity:0;pointer-events:none;transition:opacity .18s}
.sp-overlay.open{opacity:1;pointer-events:all}
.sp-box{position:fixed;top:72px;left:50%;transform:translateX(-50%);width:min(640px,92vw);background:#fff;border:1px solid var(--bdr2);border-radius:var(--radius-lg);z-index:601;box-shadow:0 20px 48px rgba(0,0,0,.16);overflow:hidden;display:flex;flex-direction:column;max-height:calc(100vh - 120px)}
.sp-hdr{display:flex;align-items:center;gap:10px;padding:12px 16px;border-bottom:1px solid var(--bdr)}
.sp-hdr svg{opacity:.4;flex-shrink:0}
.sp-input{flex:1;border:none;outline:none;font-size:14px;font-family:'Inter',sans-serif;color:var(--txt);background:transparent}
.sp-input::placeholder{color:var(--txt3)}
.sp-kbd{font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--txt3);background:var(--bg);border:1px solid var(--bdr2);border-radius:3px;padding:1px 6px;white-space:nowrap;flex-shrink:0}
.sp-results{overflow-y:auto;max-height:420px}
.sp-group-lbl{font-size:9.5px;font-weight:600;color:var(--txt3);text-transform:uppercase;letter-spacing:.07em;padding:10px 16px 4px}
.sp-item{display:flex;align-items:center;gap:12px;padding:9px 16px;cursor:pointer;border-bottom:1px solid var(--bdr);transition:background .1s}
.sp-item:hover,.sp-item.sp-sel{background:var(--pri-l)}
.sp-item:last-child{border-bottom:none}
.sp-nr{font-family:'JetBrains Mono',monospace;font-size:13px;font-weight:700;min-width:36px;text-align:center}
.sp-main{flex:1;min-width:0}
.sp-title{font-size:12.5px;font-weight:500;color:var(--txt);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sp-sub{font-size:11px;color:var(--txt3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:1px}
.sp-empty{padding:32px 16px;text-align:center;color:var(--txt3);font-size:13px}
.sp-footer{padding:8px 16px;border-top:1px solid var(--bdr);display:flex;gap:12px;align-items:center;background:var(--bg)}
.sp-hint{font-size:10.5px;color:var(--txt3);display:flex;align-items:center;gap:4px}

/* ── RESPONSIVE ─────────────────────────────────────── */
@media(max-width:800px){
  .main{flex-direction:column;height:auto}
  .sidebar{width:100%;flex-direction:row;overflow-x:auto;padding:4px 8px}
  .sidebar-head,.sidebar-footer,.nav-lbl,.nav-div{display:none}
  .sidebar-nav{display:flex;flex-direction:row;padding:0;gap:2px}
  .nav-item{padding:8px 12px;border-left:none;border-bottom:2px solid transparent;white-space:nowrap;flex-shrink:0;font-size:12px}
  .nav-item.active{border-left:none;border-bottom-color:var(--pri)}
  .g2,.g3{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:repeat(3,1fr)}
  .fil-chips{flex-wrap:wrap}
  .opt-grid{grid-template-columns:1fr}
  .drw{width:100vw}
}


/* ===== Bloque 2: pantalla de login + panel de Tweaks ===== */

.auth-btn-pri{width:100%;padding:11px;background:var(--pri);color:#fff;border:none;border-radius:var(--radius-sm);font-size:14px;font-weight:600;cursor:pointer;transition:background .15s;margin-top:4px}
.auth-btn-pri:hover{background:var(--pri-d)}
.auth-btn-sec{width:100%;padding:11px;background:var(--sec);color:#fff;border:none;border-radius:var(--radius-sm);font-size:14px;font-weight:600;cursor:pointer;transition:background .15s;margin-top:4px}
.auth-btn-sec:hover{background:#0a8a42}
.auth-btn-ghost{width:100%;padding:10px;background:transparent;color:var(--txt2);border:1px solid var(--bdr2);border-radius:var(--radius-sm);font-size:13px;font-weight:500;cursor:pointer;transition:all .15s}
.auth-btn-ghost:hover{background:var(--bg)}
.auth-err{background:#fff0f0;border:1px solid #fca5a5;border-radius:var(--radius-sm);padding:10px 12px;font-size:12px;color:#b91c1c;margin-bottom:12px}
.auth-ok{background:var(--sec-l);border:1px solid #8dd9a8;border-radius:var(--radius-sm);padding:10px 12px;font-size:12px;color:#065f46;margin-bottom:12px}

/* ── TWEAKS PANEL ───────────────────────────────────── */
#tweaks-panel{position:fixed;right:18px;bottom:18px;width:288px;background:var(--srf);border:1px solid var(--bdr);border-radius:14px;box-shadow:0 18px 48px rgba(13,27,42,.22),0 3px 10px rgba(13,27,42,.08);z-index:4000;font-family:'Inter',sans-serif;opacity:0;visibility:hidden;transform:translateY(10px) scale(.98);transform-origin:bottom right;transition:opacity .18s,transform .18s,visibility .18s}
#tweaks-panel.open{opacity:1;visibility:visible;transform:translateY(0) scale(1)}
#tweaks-panel .tw-head{display:flex;align-items:center;justify-content:space-between;padding:13px 16px;background:var(--navy,#0D1B2A);border-radius:14px 14px 0 0}
#tweaks-panel .tw-ttl{display:flex;align-items:center;gap:8px;color:#fff;font-size:13.5px;font-weight:700;letter-spacing:.01em}
#tweaks-panel .tw-ttl svg{color:var(--pri)}
#tweaks-panel .tw-x{background:rgba(255,255,255,.1);border:none;color:#cbd5e1;width:24px;height:24px;border-radius:6px;cursor:pointer;font-size:12px;display:flex;align-items:center;justify-content:center;transition:background .12s}
#tweaks-panel .tw-x:hover{background:rgba(255,255,255,.2);color:#fff}
#tweaks-panel .tw-body{padding:6px 16px 16px}
#tweaks-panel .tw-grp{padding:13px 0;border-bottom:1px solid var(--bdr)}
#tweaks-panel .tw-grp:last-child{border-bottom:none}
#tweaks-panel .tw-lbl{display:block;font-size:12px;font-weight:600;color:var(--txt);margin-bottom:9px}
#tweaks-panel .tw-hint{font-weight:400;color:var(--txt3);font-size:10.5px}
#tweaks-panel .tw-desc{font-size:11px;color:var(--txt3);margin-top:8px;line-height:1.45}
#tweaks-panel .tw-seg{display:flex;gap:5px;background:var(--bg);border:1px solid var(--bdr);border-radius:9px;padding:4px}
#tweaks-panel .tw-seg-btn{flex:1;border:none;background:transparent;padding:7px 8px;border-radius:6px;font-family:'Inter',sans-serif;font-size:11.5px;font-weight:600;color:var(--txt2);cursor:pointer;transition:all .14s}
#tweaks-panel .tw-seg-btn:hover{color:var(--txt)}
#tweaks-panel .tw-seg-btn.on{background:var(--pri);color:#fff;box-shadow:0 1px 3px rgba(13,27,42,.18)}
#tweaks-panel .tw-sw-row{display:flex;gap:9px}
#tweaks-panel .tw-sw{width:30px;height:30px;border-radius:50%;border:2px solid transparent;cursor:pointer;outline:2px solid transparent;outline-offset:2px;transition:outline-color .14s,transform .1s}
#tweaks-panel .tw-sw:hover{transform:scale(1.08)}
#tweaks-panel .tw-sw.on{outline-color:var(--txt);box-shadow:inset 0 0 0 2px #fff}
#tweaks-panel .tw-row{display:flex;align-items:center;justify-content:space-between;gap:12px;cursor:pointer}
#tweaks-panel .tw-switch{position:relative;width:40px;height:23px;border-radius:12px;border:none;background:var(--bdr2);cursor:pointer;transition:background .16s;flex-shrink:0;padding:0}
#tweaks-panel .tw-switch.on{background:var(--pri)}
#tweaks-panel .tw-knob{position:absolute;top:3px;left:3px;width:17px;height:17px;border-radius:50%;background:#fff;box-shadow:0 1px 3px rgba(0,0,0,.25);transition:left .16s}
#tweaks-panel .tw-switch.on .tw-knob{left:20px}
