:root {
  --bg0: #090c12; --bg1: #0f1420; --bg2: #151c2b; --bg3: #1c2335; --bg4: #222c42;
  --bd: #2a3650; --bd2: #344160;
  --a: #f0a500; --ad: #f0a50018; --ag: #f0a50028;
  --b: #4a9eff; --bdb: #4a9eff18;
  --g: #2dd4a0; --gd: #2dd4a018;
  --r: #ff5c5c; --rd: #ff5c5c18;
  --p: #a78bfa; --pd: #a78bfa18;
  --t1: #e2e8f5; --t2: #8896b5; --t3: #4a5772;
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html,body { height: 100%; overflow: hidden; }
body { font-family: 'Space Grotesk', sans-serif; background: var(--bg0); color: var(--t1); font-size: 13.5px; line-height: 1.5; }
button { font-family: inherit; cursor: pointer; }

.shell { display: flex; height: 100vh; overflow: hidden; }

/* Sidebar */
.sb { width: 228px; min-width: 228px; background: var(--bg1); border-right: 1px solid var(--bd); display: flex; flex-direction: column; flex-shrink: 0; }
.sb-nav { flex: 1; overflow-y: auto; padding: 8px 0; }
.sb-logo { padding: 20px 18px 18px; border-bottom: 1px solid var(--bd); display: flex; align-items: center; gap: 11px; }
.lg { width: 36px; height: 36px; background: var(--ad); border: 1px solid var(--a); border-radius: 9px; display: flex; align-items: center; justify-content: center; font-size: 18px; color: var(--a); }
.logo-txt { font-size: 16px; font-weight: 700; }
.logo-sub { font-size: 10px; color: var(--a); letter-spacing: 1px; text-transform: uppercase; }
.lbl { font-size: 10px; color: var(--t3); letter-spacing: 1.2px; text-transform: uppercase; font-weight: 600; padding: 6px 18px 2px; }
.ni { display: flex; align-items: center; gap: 9px; padding: 8px 14px 8px 18px; cursor: pointer; color: var(--t2); border-left: 3px solid transparent; transition: .18s; font-size: 13px; user-select: none; }
.ni:hover { background: #ffffff05; color: var(--t1); }
.ni.on { background: var(--ad); color: var(--a); border-left-color: var(--a); font-weight: 600; }
.ni .ic { font-size: 15px; width: 20px; text-align: center; flex-shrink: 0; }
.ni .bd { margin-left: auto; background: var(--r); color: #fff; font-size: 10px; font-weight: 700; padding: 1px 5px; border-radius: 10px; min-width: 16px; text-align: center; }
.sb-ft { padding: 14px 18px; border-top: 1px solid var(--bd); }
.uc { display: flex; align-items: center; gap: 9px; padding: 8px 10px; background: var(--bg2); border: 1px solid var(--bd); border-radius: 8px; }
.ua { width: 32px; height: 32px; background: var(--ad); border: 1.5px solid var(--a); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 13px; font-weight: 700; color: var(--a); }
.un { font-size: 12.5px; font-weight: 600; }
.ur { font-size: 10.5px; color: var(--t3); font-weight: 400; }

/* Main */
.main { flex: 1; display: flex; flex-direction: column; overflow: hidden; min-width: 0; }
.topbar { height: 54px; background: var(--bg1); border-bottom: 1px solid var(--bd); display: flex; align-items: center; padding: 0 22px; gap: 12px; flex-shrink: 0; }
.tbc { font-size: 13px; color: var(--t2); }
.tbc span { color: var(--t1); font-weight: 600; }
.tbg { margin-left: auto; display: flex; align-items: center; gap: 8px; }
.tsrch { background: var(--bg4); border: 1px solid var(--bd); border-radius: 6px; padding: 6px 12px; width: 240px; display: flex; align-items: center; gap: 7px; transition: .2s; }
.tsrch:focus-within { border-color: var(--a); box-shadow: 0 0 0 3px var(--ag); }
.tsrch input { background: none; border: none; outline: none; color: var(--t1); font-size: 12.5px; width: 100%; font-family: inherit; }
.tsrch input::placeholder { color: var(--t3); }
.tbtn { width: 33px; height: 33px; border-radius: 6px; border: 1px solid var(--bd); background: transparent; color: var(--t2); font-size: 15px; transition: .18s; cursor: pointer; display: flex; align-items: center; justify-content: center; }
.tbtn:hover { background: var(--bg2); }
.ndot { position: absolute; top: 5px; right: 5px; width: 6px; height: 6px; background: var(--r); border-radius: 50%; border: 1.5px solid var(--bg1); }
.tt { font-family: 'JetBrains Mono', monospace; font-size: 11.5px; color: var(--t3); }

.page { flex: 1; overflow-y: auto; padding: 22px; }

/* Dashboard Header */
.dh { display: flex; align-items: flex-start; justify-content: space-between; margin-bottom: 22px; }
.dh h1 { font-size: 22px; font-weight: 700; }
.dh p { color: var(--t2); margin-top: 4px; font-size: 12.5px; }
.da { display: flex; gap: 7px; }
.ba { padding: 7px 16px; border-radius: 8px; font-size: 12.5px; font-weight: 500; cursor: pointer; border: 1px solid transparent; display: inline-flex; align-items: center; gap: 5px; transition: .18s; }
.bap { background: var(--a); color: #000; border-color: var(--a); }
.bap:hover { background: #ffb820; box-shadow: 0 4px 16px var(--ag); }
.bo { background: transparent; color: var(--t2); border-color: var(--bd); }
.bo:hover { background: var(--bg2); color: var(--t1); }
.bgr { background: var(--g); color: #000; border-color: var(--g); }

/* Stats Cards */
.sg2 { display: grid; grid-template-columns: repeat(auto-fit, minmax(190px, 1fr)); gap: 14px; margin-bottom: 22px; }
.sc { background: var(--bg2); border: 1px solid var(--bd); border-radius: 12px; padding: 18px; position: relative; overflow: hidden; transition: .2s; }
.sc::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 2px; border-radius: 12px 12px 0 0; }
.sc.a::before { background: var(--a); }
.sc.b::before { background: var(--b); }
.sc.g::before { background: var(--g); }
.sc.r::before { background: var(--r); }
.sc.p::before { background: var(--p); }
.sc:hover { border-color: var(--bd2); transform: translateY(-1px); box-shadow: 0 4px 24px #0006; }
.si { width: 38px; height: 38px; border-radius: 9px; display: flex; align-items: center; justify-content: center; font-size: 17px; margin-bottom: 12px; }
.sa { background: var(--ad); }
.sb { background: var(--bdb); }
.sg { background: var(--gd); }
.sr { background: var(--rd); }
.sp { background: var(--pd); }
.sv { font-size: 26px; font-weight: 700; font-family: 'JetBrains Mono', monospace; margin-bottom: 3px; letter-spacing: -1px; }
.sl { color: var(--t2); font-size: 12px; margin-bottom: 10px; }
.st { font-size: 11.5px; font-weight: 500; display: flex; align-items: center; gap: 3px; }
.st.up { color: var(--g); }
.st.dn { color: var(--r); }
.st.warn { color: var(--a); }

/* Bottom Stats */
.mr { display: flex; gap: 14px; margin-bottom: 22px; flex-wrap: wrap; }
.mb { background: var(--bg2); border: 1px solid var(--bd); border-radius: 8px; padding: 14px 18px; flex: 1; min-width: 130px; position: relative; overflow: hidden; }
.mb::after { content: ''; position: absolute; bottom: 0; left: 0; right: 0; height: 2px; }
.mb.g::after { background: var(--g); }
.mb.b::after { background: var(--b); }
.mb.a::after { background: var(--a); }
.mb.r::after { background: var(--r); }
.mb .ml { font-size: 10.5px; color: var(--t3); margin-bottom: 5px; text-transform: uppercase; letter-spacing: .5px; font-weight: 600; }
.mb .mv { font-size: 20px; font-weight: 700; font-family: 'JetBrains Mono', monospace; }

/* Cards */
.crow { display: grid; grid-template-columns: 2fr 1fr; gap: 14px; margin-bottom: 22px; }
.card { background: var(--bg2); border: 1px solid var(--bd); border-radius: 12px; overflow: hidden; }
.ch { padding: 14px 18px; border-bottom: 1px solid var(--bd); display: flex; align-items: center; justify-content: space-between; }
.ch h3 { font-size: 13.5px; font-weight: 600; display: flex; align-items: center; gap: 7px; }
.cb { padding: 18px; }

/* Bar Chart */
.bar-chart { display: flex; align-items: flex-end; gap: 6px; height: 150px; padding-top: 8px; }
.bi { flex: 1; display: flex; flex-direction: column; align-items: center; gap: 5px; height: 100%; justify-content: flex-end; }
.bw { flex: 1; width: 100%; display: flex; align-items: flex-end; }
.bar { width: 100%; border-radius: 3px 3px 0 0; transition: .15s; cursor: pointer; position: relative; min-height: 2px; display: flex; align-items: flex-end; }
.bar.i { background: linear-gradient(180deg, var(--g), #2dd4a040); }
.bar.o { background: linear-gradient(180deg, var(--b), #4a9eff40); }
.bar:hover { filter: brightness(1.2); }
.bar .bv { position: absolute; top: -18px; left: 50%; transform: translateX(-50%); font-size: 10.5px; font-weight: 600; font-family: 'JetBrains Mono', monospace; color: var(--t2); opacity: 0; transition: .15s; white-space: nowrap; pointer-events: none; }
.bar:hover .bv { opacity: 1; }
.bl { font-size: 10.5px; color: var(--t3); }

/* Donut Chart */
.dnut { display: flex; align-items: center; gap: 18px; }
.dc { width: 96px; height: 96px; flex-shrink: 0; }
.dc svg { transform: rotate(-90deg); }
.dl { flex: 1; }
.li { display: flex; align-items: center; gap: 7px; padding: 3px 0; }
.ld { width: 9px; height: 9px; border-radius: 2.5px; flex-shrink: 0; }
.ll { font-size: 12px; color: var(--t2); flex: 1; }
.lv { font-family: 'JetBrains Mono', monospace; font-size: 12px; font-weight: 600; }

/* Filter Bar */
.ftb { display: flex; gap: 8px; margin-bottom: 14px; flex-wrap: wrap; align-items: center; }
.fsbox { flex: 1; min-width: 180px; position: relative; }
.fsbox input { width: 100%; background: var(--bg2); border: 1px solid var(--bd); border-radius: 8px; padding: 7px 11px 7px 30px; font-size: 12.5px; color: var(--t1); outline: none; transition: .2s; }
.fsbox input:focus { border-color: var(--a); box-shadow: 0 0 0 3px var(--ag); }
.fsbox .si2 { position: absolute; left: 9px; top: 50%; transform: translateY(-50%); color: var(--t3); font-size: 13px; }
.fsel { background: var(--bg2); border: 1px solid var(--bd); border-radius: 8px; padding: 7px 28px 7px 10px; font-size: 12px; color: var(--t2); cursor: pointer; outline: none; appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='7'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%234a5572' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 9px center; padding-right: 28px; }
.fsel:focus { border-color: var(--a); }
.fsel option { background: var(--bg2); }
.tw { overflow-x: auto; }

/* Table */
.tbl { width: 100%; border-collapse: collapse; font-size: 12.5px; }
.tbl th { text-align: left; padding: 9px 14px; background: var(--bg3); color: var(--t3); font-size: 10.5px; font-weight: 600; letter-spacing: .5px; text-transform: uppercase; border-bottom: 1px solid var(--bd); cursor: pointer; user-select: none; white-space: nowrap; }
.tbl th:hover { color: var(--t1); }
.tbl td { padding: 10px 14px; border-bottom: 1px solid var(--bd); color: var(--t2); white-space: nowrap; }
.tbl tbody tr:last-child td { border-bottom: none; }
.tbl tbody tr { transition: .15s; }
.tbl tbody tr:hover { background: #ffffff03; }
.tbl .ca { text-align: right; white-space: nowrap; }
.mono { font-family: 'JetBrains Mono', monospace; font-size: 11.5px; }

/* Badges */
.bdg { background: var(--gd); color: var(--g); padding: 2px 7px; border-radius: 4px; font-size: 10.5px; font-weight: 600; display: inline-flex; align-items: center; gap: 3px; }
.bdg.bg-g { background: var(--gd); color: var(--g); }
.bdg.bg-a { background: var(--ad); color: var(--a); }
.bdg.bg-r { background: var(--rd); color: var(--r); }
.bdg.bg-b { background: var(--bdb); color: var(--b); }
.bdg.bg-p { background: var(--pd); color: var(--p); }
.bdg.bg-gy { background: var(--bg3); color: var(--t2); }

/* Buttons */
.abtn { width: 26px; height: 26px; border-radius: 6px; border: 1px solid var(--bd); background: transparent; color: var(--t3); cursor: pointer; font-size: 12.5px; transition: .15s; display: inline-flex; align-items: center; justify-content: center; }
.abtn:hover { background: var(--bg3); color: var(--t1); border-color: var(--bd2); }
.abtn.d:hover { background: var(--rd); color: var(--r); border-color: var(--r); }
.abtn.e:hover { background: var(--gd); color: var(--g); border-color: var(--g); }
.abtn.i:hover { background: var(--bdb); color: var(--b); border-color: var(--b); }

/* Page Header */
.ph { display: flex; align-items: center; justify-content: space-between; margin-bottom: 18px; }
.ph h2 { font-size: 17px; font-weight: 700; }
.ph p { color: var(--t2); margin-top: 2px; font-size: 12px; }

/* Tabs */
.tabs { display: flex; border-bottom: 1px solid var(--bd); margin-bottom: 18px; gap: 0; }
.tab { padding: 9px 18px; font-family: inherit; font-size: 12.5px; font-weight: 500; color: var(--t2); background: none; border: none; border-bottom: 2px solid transparent; cursor: pointer; transition: .18s; margin-bottom: -1px; display: flex; align-items: center; gap: 5px; }
.tab:hover { color: var(--t1); }
.tab.on { color: var(--a); border-bottom-color: var(--a); font-weight: 600; }
.tc { display: none; }
.tc.on { display: block; }

/* Form Sections */
.fsec { background: var(--bg2); border: 1px solid var(--bd); border-radius: 12px; margin-bottom: 16px; overflow: hidden; }
.fsh { padding: 12px 18px; background: var(--bg3); border-bottom: 1px solid var(--bd); font-size: 12.5px; font-weight: 600; display: flex; align-items: center; gap: 7px; }
.fg { display: grid; grid-template-columns: repeat(auto-fit, minmax(210px, 1fr)); gap: 14px 20px; padding: 16px 18px; }
.ff { display: flex; flex-direction: column; gap: 5px; }
.ff label { font-size: 11.5px; font-weight: 600; color: var(--t2); letter-spacing: .3px; }
.ff label .rq { color: var(--r); margin-left: 2px; }
.ffi, .fs, .fta { background: var(--bg4); border: 1px solid var(--bd); border-radius: 8px; padding: 8px 11px; font-family: inherit; font-size: 12.5px; color: var(--t1); outline: none; transition: .2s; width: 100%; }
.ffi:focus, .fs:focus, .fta:focus { border-color: var(--a); box-shadow: 0 0 0 3px var(--ag); }
.ffi::placeholder, .fta::placeholder { color: var(--t3); }
.fs { cursor: pointer; appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='7'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%234a5572' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 10px center; padding-right: 28px; }
.fsel option { background: var(--bg2); }
.fta { resize: vertical; min-height: 72px; }

/* Modal */
.mo { position: fixed; inset: 0; background: #0009; backdrop-filter: blur(4px); z-index: 1000; display: flex; align-items: center; justify-content: center; padding: 18px; opacity: 0; pointer-events: none; transition: opacity .2s; }
.mo.open { opacity: 1; pointer-events: all; }
.mdl { background: var(--bg2); border: 1px solid var(--bd2); border-radius: 12px; width: 100%; max-width: 860px; max-height: 90vh; overflow: hidden; box-shadow: 0 8px 48px #0009; transform: scale(.95) translateY(10px); transition: transform .2s; display: flex; flex-direction: column; }
.mo.open .mdl { transform: scale(1) translateY(0); }
.mh { padding: 16px 22px; border-bottom: 1px solid var(--bd); display: flex; align-items: center; justify-content: space-between; flex-shrink: 0; }
.mh h2 { font-size: 15px; font-weight: 600; display: flex; gap: 8px; }
.mcl { width: 28px; height: 28px; border-radius: 6px; border: 1px solid var(--bd); background: transparent; color: var(--t2); cursor: pointer; display: flex; align-items: center; justify-content: center; transition: .15s; }
.mcl:hover { background: var(--bg3); color: var(--t1); }
.mc { padding: 22px; overflow-y: auto; flex: 1; }
.mf { padding: 14px 22px; border-top: 1px solid var(--bd); display: flex; gap: 7px; justify-content: flex-end; flex-shrink: 0; }

/* Toast */
.toast-container { position: fixed; bottom: 20px; right: 20px; z-index: 9999; display: flex; flex-direction: column; gap: 7px; pointer-events: none; }
.toast { background: var(--bg3); border: 1px solid var(--bd2); border-radius: 8px; padding: 11px 14px; display: flex; align-items: center; gap: 9px; font-size: 12.5px; box-shadow: 0 4px 24px #0006; pointer-events: auto; min-width: 270px; max-width: 370px; animation: ti .3s cubic-bezier(.34, 1.56, .64, 1); }
.toast.ok { border-left: 3px solid var(--g); }
.toast.er { border-left: 3px solid var(--r); }
.toast.wr { border-left: 3px solid var(--a); }
.toast.if { border-left: 3px solid var(--b); }
@keyframes ti { from { opacity: 0; transform: translateX(18px); } to { opacity: 1; transform: translateX(0); } }
.toast .ti { font-size: 14px; }

/* Alert List */
.alist { display: flex; flex-direction: column; gap: 8px; }
.aitem { padding: 12px 14px; background: var(--bg3); border: 1px solid var(--bd); border-radius: 8px; display: flex; gap: 12px; transition: .15s; cursor: pointer; }
.aitem:hover { border-color: var(--bd2); }
.aitem .ico { width: 34px; height: 34px; border-radius: 8px; display: flex; align-items: center; justify-content: center; font-size: 16px; flex-shrink: 0; }
.aitem.cri .ico { background: var(--rd); }
.aitem .txt { flex: 1; }
.aitem .ait { font-size: 13px; font-weight: 600; margin-bottom: 3px; }
.aitem .aim { font-size: 11.5px; color: var(--t2); }
.aitem .aie { font-size: 10.5px; color: var(--t3); margin-top: 3px; }
.actbtn { padding: 4px 10px; border-radius: 6px; font-size: 11px; font-weight: 600; cursor: pointer; border: 1px solid; transition: .15s; white-space: nowrap; background: transparent; }
.actbtn.rbtn { border-color: var(--r); color: var(--r); }
.actbtn.rbtn:hover { background: var(--rd); }
.actbtn.abtn { border-color: var(--a); color: var(--a); }
.actbtn.abtn:hover { background: var(--ad); }

/* Scrollbar */
::-webkit-scrollbar { width: 6px; }
::-webkit-scrollbar-track { background: var(--bg0); }
::-webkit-scrollbar-thumb { background: var(--bd); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: var(--t3); }

/* Print */
@media print { body > * { visibility: hidden !important; }
  #pa, #pa > * { visibility: visible !important; }
  #pa { position: absolute; left: 0; top: 0; width: 100%; } }

/* Mobile */
@media (max-width: 960px) {
  .shell { flex-direction: row; }
  .sb { width: 72px; min-width: 72px; }
  .sb-logo { padding: 14px 10px; justify-content: center; }
  .sb-logo .lt, .sb-logo .ls { display: none; }
  .lbl { display: none; }
  .ni { padding: 10px; justify-content: center; border-left-width: 0; border-radius: 8px; margin: 4px 8px; }
  .ni .ic { font-size: 14px; width: auto; }
  .ni.on { border-left-width: 0; }
  .ni .bd { display: none; }
  .sb-ft { display: none; }
  .topbar { padding: 0 12px; gap: 8px; }
  .tsrch { width: 160px; padding: 6px 10px; }
  .page { padding: 14px; }
  .dh { flex-direction: column; gap: 10px; align-items: flex-start; }
  .da { flex-wrap: wrap; }
  .sg2 { grid-template-columns: 1fr; }
  .mr { flex-direction: column; }
  .crow { grid-template-columns: 1fr; }
  .tbl th, .tbl td { padding: 8px 10px; font-size: 11.5px; }
  .ph { flex-direction: column; align-items: flex-start; gap: 8px; }
  .tabs { overflow-x: auto; }
  .tab { white-space: nowrap; }
  .fg { grid-template-columns: 1fr; }
  .mdl { max-width: 100%; max-height: 100%; border-radius: 10px; }
}

@media (max-width: 640px) {
  .sb { width: 60px; min-width: 60px; }
  .lg { width: 30px; height: 30px; font-size: 14px; }
  .tsrch { width: 120px; }
  .tbtn { width: 30px; height: 30px; font-size: 13px; }
  .sv { font-size: 22px; }
  .mb .mv { font-size: 18px; }
  .toast-container { right: 12px; left: 12px; }
  .toast { min-width: 0; width: 100%; }
}
