:root{
  --bg:#f4f5f7;--sur:#fff;--sur2:#f8f9fa;--sur3:#eef0f3;--bg2:#f0f2f5;
  --ink:#1a1d23;--ink2:#3d4451;--ink3:#6b7280;--ink4:#9ca3af;
  --acc:#2563eb;--acc2:#1d4ed8;--acc-s:rgba(37,99,235,.1);
  --grn:#16a34a;--grn-s:rgba(22,163,74,.12);
  --amb:#d97706;--amb-s:rgba(217,119,6,.12);
  --red:#dc2626;--red-s:rgba(220,38,38,.12);
  --pur:#7c3aed;--pur-s:rgba(124,58,237,.12);
  --tl:#0891b2;--tl-s:rgba(8,145,178,.12);
  --bdr:#e5e7eb;--bdr2:#d1d5db;
  --sw:255px;--sm:58px;
  --r:8px;--r2:12px;--r3:16px;
  --sh:0 1px 3px rgba(0,0,0,.08),0 4px 16px rgba(0,0,0,.06);
  --sh2:0 8px 24px rgba(0,0,0,.12);
  --font:'Inter',sans-serif;--mono:'JetBrains Mono',monospace;
  --tr:.18s ease;
  --fs:15px;--fs-sm:13px;--fs-xs:12px;
}
*{margin:0;padding:0;box-sizing:border-box;}
html{font-size:var(--fs);}
body{font-family:var(--font);background:var(--bg);color:var(--ink);line-height:1.55;-webkit-font-smoothing:antialiased;}
::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--bdr2);border-radius:99px}

/* LOGIN */
#login-screen{
  position:fixed;inset:0;z-index:9999;overflow:auto;
  background:
    radial-gradient(circle at top left, rgba(29,78,216,.18), transparent 34%),
    linear-gradient(135deg, #eff6ff 0%, #f8fafc 46%, #eef8f7 100%);
}
#login-screen.gone{display:none}

.l-shell{
  min-height:100vh;
  display:grid;
  grid-template-columns:minmax(0, 1fr) minmax(420px, .66fr);
}

.l-hero{
  position:relative;
  min-height:100vh;
  padding:0;
  overflow:hidden;
  background:#dbe7f3;
}

.l-hero-image{
  display:block;
  width:100%;
  height:100%;
  object-fit:fill;
  object-position:center;
}

.l-pane{
  position:relative;
  min-height:100vh;
  display:grid;
  place-items:center;
  padding:80px 42px;
  overflow:hidden;
  background:
    radial-gradient(circle at 16% 16%, rgba(29,78,216,.08), transparent 20%),
    radial-gradient(circle at 84% 20%, rgba(15,118,110,.08), transparent 18%),
    radial-gradient(circle at 72% 82%, rgba(37,99,235,.05), transparent 18%),
    linear-gradient(180deg, #fbfdff 0%, #f8fafc 52%, #f3faf8 100%);
}
.l-pane::before{
  content:'';
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at 18% 26%, rgba(37,99,235,.08) 0 3px, transparent 3.5px),
    radial-gradient(circle at 24% 38%, rgba(37,99,235,.06) 0 2.5px, transparent 3px),
    radial-gradient(circle at 20% 50%, rgba(15,118,110,.08) 0 3px, transparent 3.5px),
    radial-gradient(circle at 82% 24%, rgba(15,118,110,.08) 0 3px, transparent 3.5px),
    radial-gradient(circle at 76% 36%, rgba(37,99,235,.06) 0 2.5px, transparent 3px),
    radial-gradient(circle at 80% 50%, rgba(15,118,110,.08) 0 3px, transparent 3.5px),
    linear-gradient(115deg, transparent 0 42%, rgba(37,99,235,.035) 42.4%, transparent 42.8%),
    linear-gradient(115deg, transparent 0 46%, rgba(15,118,110,.03) 46.4%, transparent 46.8%),
    linear-gradient(65deg, transparent 0 56%, rgba(37,99,235,.03) 56.4%, transparent 56.8%),
    linear-gradient(65deg, transparent 0 60%, rgba(15,118,110,.03) 60.4%, transparent 60.8%);
  opacity:1;
  pointer-events:none;
}
.l-pane::after{
  content:'';
  position:absolute;
  inset:24px;
  border-radius:32px;
  border:1px solid rgba(148,163,184,.12);
  background-image:
    linear-gradient(rgba(148,163,184,.08) 1px, transparent 1px),
    linear-gradient(90deg, rgba(148,163,184,.08) 1px, transparent 1px);
  background-size:32px 32px;
  mask-image:radial-gradient(circle at center, transparent 0 26%, black 56%, transparent 88%);
  opacity:.28;
  pointer-events:none;
}

.l-pane-inner{
  position:relative;
  z-index:1;
  width:100%;
  max-width:560px;
  display:flex;
  flex-direction:column;
  justify-content:center;
}
.l-pane-art{
  position:absolute;
  z-index:0;
  color:rgba(29,78,216,.14);
  filter:drop-shadow(0 16px 28px rgba(148,163,184,.12));
  pointer-events:none;
}
.l-pane-art i{display:block;}
.l-pane-art-dna-1{
  top:9%;
  left:8%;
  font-size:3.9rem;
  color:rgba(29,78,216,.14);
  transform:rotate(-14deg);
}
.l-pane-art-dna-2{
  right:8%;
  bottom:12%;
  font-size:4.6rem;
  color:rgba(15,118,110,.12);
  transform:rotate(18deg);
}
.l-pane-art-vial-1{
  top:21%;
  right:12%;
  font-size:2.6rem;
  color:rgba(29,78,216,.12);
  transform:rotate(14deg);
}
.l-pane-art-vial-2{
  left:10%;
  bottom:17%;
  font-size:3rem;
  color:rgba(15,118,110,.12);
  transform:rotate(-10deg);
}
.l-pane-art-flask{
  right:16%;
  top:58%;
  font-size:2.9rem;
  color:rgba(56,189,248,.11);
  transform:rotate(-8deg);
}

.l-mini-brand{
  display:flex;align-items:center;gap:12px;
  margin-bottom:-20px;
  color:#0f172a;
  font-weight:700;font-size:1.12rem;letter-spacing:-.02em;
}
.l-mini-ico{
  width:46px;height:46px;border-radius:15px;
  background:linear-gradient(135deg,#1d4ed8,#0f766e);
  display:flex;align-items:center;justify-content:center;
  color:#fff;
  box-shadow:0 14px 28px rgba(29,78,216,.18);
}

.lcard{
  background:rgba(255,255,255,.9);
  border:1px solid rgba(229,231,235,.92);
  border-radius:30px;
  padding:38px;
  box-shadow:0 32px 78px rgba(15,23,42,.12);
  backdrop-filter:blur(14px);
  margin-top: -65px;  /* adjust this value until it looks right */
}

.lcard-head{
  margin-bottom:30px;
}
.lcard-head h3{
  font-size:2.15rem;
  line-height:1.08;
  font-weight:700;
  letter-spacing:-.04em;
  color:#111827;
}
.lcard-head p{
  margin-top:10px;
  color:#6b7280;
  font-size:1rem;
}

.lf{margin-bottom:18px;}
.lf label{
  display:block;
  font-size:.83rem;
  font-weight:600;
  color:#374151;
  margin-bottom:9px;
}
.lf input{
  width:100%;
  padding:16px 17px;
  background:#fff;
  border:1px solid #e5e7eb;
  border-radius:14px;
  color:#111827;
  font-size:1rem;
  font-family:var(--font);
  transition:var(--tr);
}
.lf input:focus{
  outline:none;
  border-color:#1d4ed8;
  box-shadow:0 0 0 4px rgba(29,78,216,.08);
}
.lf input::placeholder{color:#9ca3af;}

.pw-wrap{position:relative;}
.pw-wrap input{padding-right:50px;}
.pw-eye{
  position:absolute;right:14px;top:50%;transform:translateY(-50%);
  width:32px;height:32px;border:none;border-radius:10px;
  background:transparent;color:#64748b;cursor:pointer;font-size:1rem;transition:var(--tr);
}
.pw-eye:hover{background:#f8fafc;color:#0f172a;}

.lrem{
  display:flex;align-items:center;gap:10px;
  font-size:.94rem;color:#4b5563;cursor:pointer;
  margin:8px 0 26px;
}
.lrem input[type=checkbox]{width:auto;cursor:pointer;accent-color:#1d4ed8;}

.lbtn{
  width:100%;
  padding:16px 20px;
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  background:linear-gradient(135deg,#0f172a,#1d4ed8);
  color:#fff;border:none;border-radius:14px;
  font-size:1rem;font-weight:700;cursor:pointer;font-family:var(--font);
  transition:var(--tr);letter-spacing:.01em;
  box-shadow:0 18px 32px rgba(15,23,42,.16);
  position:relative;overflow:hidden;
}
.lbtn::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(255,255,255,.12),transparent);
  opacity:0;transition:opacity .2s;
}
.lbtn:hover:not(:disabled){
  transform:translateY(-1px);
  box-shadow:0 24px 42px rgba(29,78,216,.24);
}
.lbtn:hover:not(:disabled)::before{opacity:1;}
.lbtn:disabled{opacity:.4;cursor:not-allowed;transform:none;}

.lerr{
  display:none;margin-top:14px;padding:12px 14px;
  background:#fef2f2;border:1px solid #fecaca;
  border-radius:12px;color:#dc2626;font-size:.88rem;
}
.lerr.on{display:flex;align-items:center;gap:8px;}

.l-note{
  display:flex;align-items:center;gap:10px;
  margin-top:18px;
  color:#6b7280;
  font-size:.88rem;
}
.l-note i{color:#0f766e;}

@media(max-width:1100px){
  .l-shell{grid-template-columns:minmax(0, .94fr) minmax(380px, .8fr);}
  .l-pane{padding:18px 30px;}
  .l-pane-inner{max-width:520px;}
  .l-pane-art-dna-1{left:4%;font-size:3.2rem;}
  .l-pane-art-dna-2{right:4%;font-size:3.8rem;}
  .lcard{padding:34px;}
}

@media(max-width:860px){
  #login-screen{background:#f8fafc;}
  .l-shell{grid-template-columns:1fr;}
  .l-hero{
    min-height:240px;
  }
  .l-pane{
    min-height:auto;
    padding:22px 16px 28px;
  }
  .l-pane::after{inset:16px;}
  .l-pane-inner{
    max-width:560px;
    min-height:auto;
  }
  .l-pane-art{display:none;}
}

@media(max-width:520px){
  .l-hero{min-height:180px;}
  .l-pane{padding:18px 12px 24px;}
  .lcard{padding:24px 18px;border-radius:22px;}
  .lcard-head h3{font-size:1.7rem;}
  .l-mini-brand{margin-bottom:18px;}
}
.cdot{width:8px;height:8px;border-radius:50%;background:#475569;flex-shrink:0;transition:background .3s;}
.cdot.live{background:#22c55e;}.cdot.pulse{background:#f59e0b;animation:blink 1s infinite;}.cdot.dead{background:#ef4444;}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}
/* APP */
#app{display:none;height:100vh;overflow:hidden;}
#app.on{display:flex;}

/* SIDEBAR */
.sid{width:var(--sw);min-width:var(--sw);background:var(--ink);display:flex;flex-direction:column;
  height:100vh;transition:var(--tr);position:relative;flex-shrink:0;border-right:1px solid rgba(255,255,255,.05);}
.sid.mini{width:var(--sm);min-width:var(--sm);}
.sid-brand{display:flex;align-items:center;gap:12px;padding:18px 16px;border-bottom:1px solid rgba(255,255,255,.07);min-height:64px;overflow:hidden;}
.sid-ico{width:32px;height:32px;background:linear-gradient(135deg,var(--acc),#38bdf8);border-radius:8px;
  display:flex;align-items:center;justify-content:center;font-size:.95rem;color:#fff;flex-shrink:0;}
.sid-txt{overflow:hidden;white-space:nowrap;}
.sid-txt h2{font-size:1rem;font-weight:700;color:#f1f5f9;}
.sid-txt span{font-size:.72rem;color:#475569;}
.sid-tgl{position:absolute;top:18px;right:-11px;width:22px;height:22px;background:var(--acc);border:none;
  border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;
  color:#fff;font-size:.65rem;z-index:10;box-shadow:0 2px 8px rgba(0,0,0,.3);transition:var(--tr);}
.sid-tgl:hover{background:var(--acc2);}
.sid-nav{flex:1;overflow-y:auto;padding:8px 0;}
.nav-sec{font-size:.68rem;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:#374151;padding:14px 16px 4px;}
.navi{display:flex;align-items:center;gap:12px;padding:10px 16px;cursor:pointer;color:#9ca3af;
  font-size:.92rem;font-weight:500;border-left:3px solid transparent;white-space:nowrap;transition:var(--tr);}
.navi:hover{color:#e5e7eb;background:rgba(255,255,255,.05);}
.navi.act{color:#fff;background:rgba(37,99,235,.2);border-left-color:var(--acc);}
.navi i{width:17px;text-align:center;font-size:.9rem;flex-shrink:0;}
.navi span{overflow:hidden;}
.sid-foot{padding:12px 14px;border-top:1px solid rgba(255,255,255,.07);display:flex;align-items:center;gap:10px;overflow:hidden;}
.u-av{width:32px;height:32px;background:linear-gradient(135deg,var(--acc),var(--pur));border-radius:50%;
  display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.88rem;color:#fff;flex-shrink:0;}
.u-info{overflow:hidden;flex:1;white-space:nowrap;}
.u-info strong{font-size:.88rem;display:block;color:#f1f5f9;}
.u-info small{color:#4b5563;font-size:.73rem;}
.u-out{background:none;border:none;color:#4b5563;cursor:pointer;padding:5px;border-radius:6px;transition:var(--tr);flex-shrink:0;}
.u-out:hover{color:#ef4444;background:rgba(239,68,68,.1);}
.sid.mini .sid-txt,.sid.mini .nav-sec,.sid.mini .u-info,.sid.mini .navi span{display:none;}
.sid.mini .navi{justify-content:center;padding:11px;}

/* MAIN */
.main{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0;}
.topbar{height:64px;background:var(--sur);border-bottom:1px solid var(--bdr);display:flex;align-items:center;padding:0 26px;gap:14px;flex-shrink:0;}
.tb-left{flex:1;}
.tb-left h1{font-size:1.15rem;font-weight:700;color:var(--ink);}
.tb-left p{font-size:.8rem;color:var(--ink3);}
.tb-right{display:flex;align-items:center;gap:9px;}
.conn-pill{display:flex;align-items:center;gap:6px;padding:6px 12px;border:1px solid var(--bdr);border-radius:99px;font-size:.8rem;color:var(--ink3);}
.icon-btn{width:34px;height:34px;display:flex;align-items:center;justify-content:center;
  background:none;border:1px solid var(--bdr);border-radius:var(--r);cursor:pointer;color:var(--ink3);font-size:.9rem;transition:var(--tr);}
.icon-btn:hover{background:var(--sur2);}
.spin{animation:spin .7s linear infinite;}
@keyframes spin{to{transform:rotate(360deg)}}

/* CONTENT */
.ca{flex:1;overflow-y:auto;padding:24px;}
.page{display:none;}.page.act{display:block;}

/* STAT CARDS */
.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(185px,1fr));gap:16px;margin-bottom:24px;}
.sc{background:var(--sur);border:1px solid var(--bdr);border-radius:var(--r2);padding:20px;
  cursor:pointer;transition:var(--tr);position:relative;overflow:hidden;}
.sc::after{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--acc);}
.sc.gn::after{background:var(--grn);}.sc.am::after{background:var(--amb);}
.sc.re::after{background:var(--red);}.sc.pu::after{background:var(--pur);}
.sc:hover{transform:translateY(-2px);box-shadow:var(--sh2);}
.sc-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;}
.sc-ico{width:38px;height:38px;border-radius:var(--r);display:flex;align-items:center;justify-content:center;font-size:1rem;}
.sc .sc-ico{background:var(--acc-s);color:var(--acc);}
.sc.gn .sc-ico{background:var(--grn-s);color:var(--grn);}
.sc.am .sc-ico{background:var(--amb-s);color:var(--amb);}
.sc.re .sc-ico{background:var(--red-s);color:var(--red);}
.sc.pu .sc-ico{background:var(--pur-s);color:var(--pur);}
.sc-val{font-size:2rem;font-weight:700;letter-spacing:-.03em;color:var(--ink);line-height:1;}
.sc-lbl{font-size:.8rem;color:var(--ink3);margin-top:4px;}

/* TOOLBAR */
.tbar{background:var(--sur);border:1px solid var(--bdr);border-radius:var(--r2);
  padding:12px 16px;display:flex;flex-wrap:wrap;gap:9px;align-items:center;margin-bottom:16px;}
.sbox{flex:1;min-width:180px;display:flex;align-items:center;gap:8px;
  background:var(--sur2);border:1px solid var(--bdr);border-radius:var(--r);padding:0 12px;}
.sbox i{color:var(--ink4);font-size:.86rem;}
.sbox input{border:none;background:none;padding:9px 0;font-size:.93rem;width:100%;outline:none;color:var(--ink);font-family:var(--font);}
.flt{padding:9px 11px;border:1px solid var(--bdr);border-radius:var(--r);font-size:.88rem;
  background:var(--sur2);cursor:pointer;outline:none;color:var(--ink);font-family:var(--font);transition:var(--tr);}
.flt:focus{border-color:var(--acc);box-shadow:0 0 0 2px rgba(37,99,235,.1);}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:6px;padding:9px 16px;border:none;border-radius:var(--r);
  font-size:.88rem;font-weight:600;cursor:pointer;transition:var(--tr);white-space:nowrap;font-family:var(--font);}
.btn:disabled{opacity:.5;cursor:not-allowed;}
.bp{background:var(--acc);color:#fff;}.bp:hover:not(:disabled){background:var(--acc2);}
.bg{background:var(--grn);color:#fff;}.bg:hover:not(:disabled){background:#15803d;}
.br{background:var(--red);color:#fff;}.br:hover:not(:disabled){background:#b91c1c;}
.bw{background:var(--amb);color:#fff;}.bw:hover:not(:disabled){background:#b45309;}
.bi{background:var(--tl);color:#fff;}.bi:hover:not(:disabled){background:#0e7490;}
.bo{background:transparent;color:var(--ink3);border:1px solid var(--bdr);}.bo:hover:not(:disabled){background:var(--sur2);color:var(--ink);}
.bsm{padding:7px 11px;font-size:.82rem;}.bico{padding:7px 9px;aspect-ratio:1;}

/* TABLE */
.twrap{background:var(--sur);border:1px solid var(--bdr);border-radius:var(--r2);overflow:hidden;}
.tscroll{overflow-x:auto;}
table{width:100%;border-collapse:collapse;}
thead th{background:var(--sur2);padding:11px 14px;text-align:left;font-size:.76rem;font-weight:700;
  text-transform:uppercase;letter-spacing:.6px;color:var(--ink3);border-bottom:1px solid var(--bdr);white-space:nowrap;}
tbody td{padding:12px 14px;border-bottom:1px solid var(--bdr);font-size:.92rem;vertical-align:middle;}
tbody tr:last-child td{border-bottom:none;}
tbody tr:hover td{background:#f8faff;}
.tfooter{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;
  border-top:1px solid var(--bdr);background:var(--sur2);font-size:.82rem;color:var(--ink3);}
.pager{display:flex;gap:4px;}
.pbtn{padding:5px 10px;border:1px solid var(--bdr);border-radius:5px;background:var(--sur);
  cursor:pointer;font-size:.8rem;font-family:var(--font);transition:var(--tr);color:var(--ink3);}
.pbtn:hover{background:var(--sur2);}.pbtn.act{background:var(--acc);color:#fff;border-color:var(--acc);}
.pbtn:disabled{opacity:.4;cursor:not-allowed;}

/* BADGE */
.bdg{padding:3px 10px;border-radius:99px;font-size:.76rem;font-weight:600;white-space:nowrap;}
.b-ok{background:var(--grn-s);color:var(--grn);}
.b-low{background:var(--amb-s);color:var(--amb);}
.b-red{background:var(--red-s);color:var(--red);}
.b-acc{background:var(--acc-s);color:var(--acc);}
.b-pur{background:var(--pur-s);color:var(--pur);}
.b-grey{background:var(--sur3);color:var(--ink3);}
.b-tl{background:var(--tl-s);color:var(--tl);}

/* MODAL */
.mo{position:fixed;inset:0;background:rgba(0,0,0,0);display:none;align-items:center;
  justify-content:center;z-index:4000;padding:20px;backdrop-filter:blur(0);
  transition:background .22s ease,backdrop-filter .22s ease;}
.mo.open{display:flex;background:rgba(0,0,0,.48);backdrop-filter:blur(4px);}
.md{background:var(--sur);border-radius:var(--r3);width:100%;max-height:92vh;overflow-y:auto;
  box-shadow:0 24px 64px rgba(0,0,0,.22);
  transform:translateY(16px) scale(.97);opacity:0;
  transition:transform .16s cubic-bezier(.34,1.4,.64,1),opacity .14s ease;}
.mo.open .md{transform:none;opacity:1;}
.md.closing{transform:translateY(8px) scale(.98);opacity:0;}
.md-sm{max-width:450px}.md-md{max-width:650px}.md-lg{max-width:870px}.md-xl{max-width:1080px}
.mhd{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--bdr);}
.mhd h3{font-size:1.05rem;font-weight:700;}
.mcl{background:none;border:none;font-size:1.3rem;cursor:pointer;color:var(--ink3);padding:3px;
  border-radius:5px;line-height:1;transition:var(--tr);}
.mcl:hover{color:var(--red);background:var(--red-s);}
.mbd{padding:24px;}
.mft{display:flex;justify-content:flex-end;gap:9px;padding:16px 24px;border-top:1px solid var(--bdr);
  background:var(--sur2);border-radius:0 0 var(--r3) var(--r3);}

/* FORM */
.fg{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:16px;}
.ffl{grid-column:1/-1;}
.ff{display:flex;flex-direction:column;gap:6px;}
.ff label{font-size:.82rem;font-weight:600;color:var(--ink2);}
.ff input,.ff select,.ff textarea{padding:10px 12px;border:1.5px solid var(--bdr);border-radius:var(--r);
  font-size:.92rem;color:var(--ink);background:var(--sur);font-family:var(--font);transition:var(--tr);}
.ff input:focus,.ff select:focus,.ff textarea:focus{outline:none;border-color:var(--acc);box-shadow:0 0 0 3px rgba(37,99,235,.1);}
.ff textarea{resize:vertical;min-height:76px;}
.ff input[readonly]{background:var(--sur2);color:var(--ink3);}
.fsec{font-size:.78rem;font-weight:700;color:var(--ink3);text-transform:uppercase;letter-spacing:.8px;
  padding:14px 0 8px;border-bottom:1px solid var(--bdr);margin-bottom:14px;margin-top:4px;}

/* TABS */
.tabs{display:flex;gap:2px;border-bottom:2px solid var(--bdr);margin-bottom:20px;}
.tabb{padding:9px 16px;background:none;border:none;font-size:.9rem;font-weight:600;color:var(--ink3);
  border-bottom:2px solid transparent;margin-bottom:-2px;cursor:pointer;transition:var(--tr);
  border-radius:6px 6px 0 0;font-family:var(--font);}
.tabb:hover{color:var(--ink);background:var(--sur2);}
.tabb.act{color:var(--acc);border-bottom-color:var(--acc);background:var(--acc-s);}
.tabp{display:none;}.tabp.act{display:block;}

/* PANEL */
.panel{background:var(--sur);border:1px solid var(--bdr);border-radius:var(--r2);padding:22px;margin-bottom:20px;}
.ptitle{font-size:.95rem;font-weight:700;color:var(--ink);margin-bottom:16px;display:flex;align-items:center;gap:8px;}
.ptitle i{color:var(--acc);}

/* ORDER ITEM TABLE */
.oit{width:100%;border-collapse:collapse;font-size:.88rem;}
.oit th{background:var(--sur2);padding:8px 10px;text-align:left;font-size:.74rem;font-weight:700;
  text-transform:uppercase;letter-spacing:.5px;color:var(--ink3);border-bottom:1px solid var(--bdr);}
.oit td{padding:7px 9px;border-top:1px solid var(--bdr);}
.oit tr:hover td{background:var(--sur2);}
.oit input,.oit select{padding:6px 8px;border:1.5px solid var(--bdr);border-radius:5px;
  font-size:.87rem;font-family:var(--font);background:var(--sur);color:var(--ink);transition:var(--tr);}
.oit input:focus,.oit select:focus{outline:none;border-color:var(--acc);}
.oit .nc{font-family:var(--mono);font-size:.86rem;font-weight:500;}
.oit .q-ord{background:#eff6ff!important;}
.oit .q-rcv{background:#f0fdf4!important;}
.oit .q-bo{background:#fffbeb!important;}
.oit .q-pnd{color:var(--acc);font-weight:700;}
.oit tfoot td{background:var(--sur2);font-weight:700;border-top:2px solid var(--bdr2);}

/* FILL BAR */
.fbar{height:5px;background:var(--sur3);border-radius:99px;overflow:hidden;margin-top:4px;}
.fbar-i{height:100%;border-radius:99px;background:var(--grn);transition:width .4s;}
.fbar-i.p{background:var(--amb);}.fbar-i.n{background:var(--red);}

/* ALERT */
.alert{display:flex;align-items:flex-start;gap:11px;padding:12px 14px;border-radius:var(--r);
  border:1px solid var(--bdr);margin-bottom:10px;font-size:.9rem;}
.alert.aw{background:rgba(217,119,6,.07);border-color:rgba(217,119,6,.25);}
.alert.ad{background:rgba(220,38,38,.07);border-color:rgba(220,38,38,.25);}
.alert.ai{background:var(--acc-s);border-color:rgba(37,99,235,.2);}
.alert.aw i{color:var(--amb);margin-top:2px;}
.alert.ad i{color:var(--red);margin-top:2px;}
.alert.ai i{color:var(--acc);margin-top:2px;}

/* TOAST */
#tw{position:fixed;top:18px;right:18px;z-index:9998;display:flex;flex-direction:column;gap:7px;}
/* CONTEXT MENU */
#ctx-menu{position:fixed;z-index:9000;background:var(--sur);border:1px solid var(--bdr);border-radius:var(--r2);box-shadow:var(--sh2);min-width:180px;overflow:hidden;display:none;animation:ctxIn [...]
@keyframes ctxIn{from{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}
#ctx-menu.open{display:block;}
.ctx-item{display:flex;align-items:center;gap:10px;padding:9px 16px;font-size:.9rem;cursor:pointer;color:var(--ink2);transition:var(--tr);}
.ctx-item:hover{background:var(--sur2);}
.ctx-item.danger{color:var(--red);}
.ctx-item.danger:hover{background:var(--red-s);}
.ctx-item i{width:15px;text-align:center;font-size:.85rem;opacity:.7;}
.ctx-sep{height:1px;background:var(--bdr);margin:3px 0;}

.toast{display:flex;align-items:center;gap:9px;padding:13px 16px;border-radius:var(--r2);
  background:var(--ink2);box-shadow:var(--sh2);min-width:260px;max-width:370px;
  animation:tIn .18s ease;border-left:4px solid var(--acc);}
.toast.tok{border-left-color:var(--grn);}.toast.tok i{color:#4ade80;}
.toast.terr{border-left-color:var(--red);}.toast.terr i{color:#f87171;}
.toast.twrn{border-left-color:var(--amb);}.toast.twrn i{color:#fbbf24;}
.toast i{font-size:.95rem;}
.toast span{flex:1;font-size:.87rem;font-weight:500;color:#f1f5f9;}
.tx{background:none;border:none;color:#4b5563;cursor:pointer;font-size:.9rem;}
@keyframes tIn{from{opacity:0;transform:translateX(14px)}to{opacity:1;transform:none}}
.toast.out{animation:tOut .18s ease forwards;}
@keyframes tOut{to{opacity:0;transform:translateX(14px)}}

/* CONFIRM */
.cf-ico{font-size:2.6rem;text-align:center;margin-bottom:12px;}
.cf-title{font-size:1.08rem;font-weight:700;text-align:center;margin-bottom:8px;}
.cf-msg{text-align:center;color:var(--ink3);font-size:.9rem;}


/* LOADING */
#load-overlay{position:fixed;inset:0;background:rgba(15,23,42,.45);backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);
  z-index:4000;display:none;align-items:center;justify-content:center;flex-direction:column;gap:16px;
  opacity:0;transition:opacity .2s ease;}
#load-overlay.on{display:flex;opacity:1;}
.load-card{background:#fff;border-radius:14px;padding:28px 36px;display:flex;flex-direction:column;
  align-items:center;gap:14px;box-shadow:0 20px 60px rgba(0,0,0,.25);}
.load-spinner{width:38px;height:38px;border:3px solid #e2e8f0;border-top-color:var(--acc);
  border-radius:50%;animation:spin .65s linear infinite;}
.load-msg{font-size:.92rem;color:var(--ink2);font-weight:600;letter-spacing:-.01em;}
/* SKELETON */
.skel{background:linear-gradient(90deg,var(--sur2) 25%,var(--bdr) 50%,var(--sur2) 75%);
  background-size:200% 100%;animation:shimmer 1.4s infinite;border-radius:4px;display:inline-block;}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
/* SKELETONS */
.skel{background:linear-gradient(90deg,var(--sur3) 25%,var(--sur2) 50%,var(--sur3) 75%);
  background-size:200% 100%;animation:shimmer 1.4s infinite;border-radius:4px;}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
/* NAV TRANSITIONS */
.navi{transition:background .15s ease,color .15s ease,border-color .15s ease;}
/* TABLE ROW FADE-IN */
tbody tr{animation:rowIn .2s ease both;}
@keyframes rowIn{from{opacity:0;transform:translateX(-4px)}to{opacity:1;transform:none}}
tbody tr:nth-child(1){animation-delay:.02s}
tbody tr:nth-child(2){animation-delay:.04s}
tbody tr:nth-child(3){animation-delay:.06s}
tbody tr:nth-child(4){animation-delay:.08s}
tbody tr:nth-child(5){animation-delay:.10s}
tbody tr:nth-child(6){animation-delay:.12s}
tbody tr:nth-child(7){animation-delay:.14s}
tbody tr:nth-child(8){animation-delay:.16s}
/* BUTTON PRESS */
.btn:active:not(:disabled){transform:scale(.97);}
.btn{transition:background .14s ease,box-shadow .14s ease,transform .1s ease,opacity .14s ease;}
/* SMOOTH TRANSITIONS */
.page{display:none;animation:pgIn .12s ease;}
.page.act{display:block;}
@keyframes pgIn{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}
.panel{animation:panelIn .25s ease both;}
@keyframes panelIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.panel:nth-child(2){animation-delay:.06s}
.panel:nth-child(3){animation-delay:.12s}
.panel:nth-child(4){animation-delay:.18s}
.sc{transition:transform .15s ease,box-shadow .15s ease;}
.sc:hover{transform:translateY(-3px);}
.btn-loading{position:relative;pointer-events:none;opacity:.75;}
.btn-loading .fa-save,.btn-loading .fa-trash,.btn-loading .fa-check,
.btn-loading .fa-plus,.btn-loading .fa-edit{display:none;}
.btn-loading::after{content:'';display:inline-block;width:12px;height:12px;
  border:2px solid rgba(255,255,255,.4);border-top-color:#fff;
  border-radius:50%;animation:spin .6s linear infinite;margin-left:4px;vertical-align:middle;}
.skel-row td{padding:10px 12px!important;}
.skel-cell{height:14px;border-radius:3px;}
/* TOAST improvements */
#tw{position:fixed;bottom:24px;right:24px;z-index:9999;display:flex;flex-direction:column;gap:8px;pointer-events:none;}
.t{padding:11px 18px;border-radius:8px;font-size:.88rem;font-weight:500;
  box-shadow:0 4px 16px rgba(0,0,0,.18);pointer-events:auto;
  animation:slideUp .25s ease forwards;display:flex;align-items:center;gap:8px;min-width:200px;}
@keyframes slideUp{from{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}
.t.out{animation:slideDown .25s ease forwards;}
@keyframes slideDown{from{transform:translateY(0);opacity:1}to{transform:translateY(20px);opacity:0}}
/* PRINT */
@media print{
  .sid,.topbar,.tbar,.mft,.icon-btn,.btn,.conn-pill,#tw{display:none!important;}
  .main{overflow:visible!important;}.ca{overflow:visible!important;padding:0!important;}
  .page{display:block!important;}
  .page:not(.act){display:none!important;}
  body{background:#fff!important;}
  .twrap{box-shadow:none!important;border:1px solid #ccc!important;}
  .panel{box-shadow:none!important;border:1px solid #ccc!important;}
  @page{margin:1.5cm;}
}
@media(max-width:768px){.sid{position:fixed;z-index:500;transform:translateX(-100%);}.stat-grid{grid-template-columns:1fr 1fr;}.ca{padding:14px;}.topbar{padding:0 14px;}}
