*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--brand:#2563eb;--brand-light:#3b82f6;--brand-dark:#1d4ed8;--brand-muted:#eff6ff;--sidebar-bg:#0f172a;--sidebar-hover:#1e293b;--sidebar-active:#2563eb;--sidebar-text:#94a3b8;--sidebar-text-active:#fff;--sidebar-width:232px;--sidebar-width-collapsed:60px;--bg:#f1f5f9;--card:#fff;--border:#e2e8f0;--border-focus:#2563eb;--text:#0f172a;--text-2:#475569;--muted:#94a3b8;--green:#16a34a;--green-bg:#dcfce7;--green-text:#166534;--red:#dc2626;--red-bg:#fee2e2;--red-text:#991b1b;--yellow:#d97706;--yellow-bg:#fef3c7;--yellow-text:#92400e;--blue:#2563eb;--blue-bg:#dbeafe;--blue-text:#1e40af;--purple:#7c3aed;--purple-bg:#ede9fe;--purple-text:#5b21b6;--slate-bg:#f1f5f9;--slate-text:#475569;--r:8px;--r-lg:12px;--r-xl:16px;--shadow-sm:0 1px 2px 0 #0000000d;--shadow:0 1px 3px 0 #0000001a,0 1px 2px -1px #0000001a;--shadow-md:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a;--header-h:60px;--font:"Inter",system-ui,-apple-system,"Segoe UI",Roboto,sans-serif}html,body{height:100%}body{font-family:var(--font);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;font-size:14px;line-height:1.5}a{color:inherit;text-decoration:none}button,input,select{font-family:var(--font)}.app-shell{min-height:100vh;display:flex}.main-wrap{margin-left:var(--sidebar-width);flex-direction:column;flex:1;min-width:0;transition:margin-left .25s cubic-bezier(.4,0,.2,1);display:flex}.main-wrap.collapsed{margin-left:var(--sidebar-width-collapsed)}.sidebar{width:var(--sidebar-width);background:var(--sidebar-bg);z-index:50;flex-direction:column;transition:width .25s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;top:0;bottom:0;left:0;overflow:hidden auto}.sidebar.collapsed{width:var(--sidebar-width-collapsed)}.sb-logo{border-bottom:1px solid #ffffff12;align-items:center;gap:10px;min-width:0;padding:18px 14px 16px;display:flex;overflow:hidden}.sb-logo-icon{background:var(--brand);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:18px;display:flex}.sb-logo-name{color:#fff;white-space:nowrap;font-size:14px;font-weight:700;line-height:1.2}.sb-logo-sub{color:var(--sidebar-text);white-space:nowrap;margin-top:1px;font-size:10px}.sb-logo-text{opacity:1;width:auto;transition:opacity .2s,width .25s;overflow:hidden}.sidebar.collapsed .sb-logo-text{opacity:0;pointer-events:none;width:0}.sb-section{padding:14px 8px 4px}.sb-label{letter-spacing:.08em;text-transform:uppercase;color:var(--sidebar-text);white-space:nowrap;margin-bottom:4px;padding:0 8px;font-size:10px;font-weight:600;transition:opacity .2s,height .25s,margin .25s,padding .25s;overflow:hidden}.sidebar.collapsed .sb-label{opacity:0;pointer-events:none;height:0;margin:0;padding:0}.nav-item{color:var(--sidebar-text);cursor:pointer;text-align:left;white-space:nowrap;background:0 0;border:none;border-radius:7px;align-items:center;gap:9px;width:100%;padding:8px 10px;font-size:13px;font-weight:500;text-decoration:none;transition:background .12s,color .12s;display:flex;position:relative;overflow:hidden}.nav-item:hover{background:var(--sidebar-hover);color:#e2e8f0}.nav-item.active{background:var(--sidebar-active);color:#fff}.nav-item svg{opacity:.8;flex-shrink:0;width:16px;height:16px}.nav-item.active svg{opacity:1}.nav-item-label{opacity:1;transition:opacity .2s,width .25s;overflow:hidden}.sidebar.collapsed .nav-item-label{opacity:0;width:0}.nav-badge{color:#fff;background:#ffffff2e;border-radius:99px;margin-left:auto;padding:1px 6px;font-size:10px;font-weight:700}.sidebar.collapsed .nav-badge,.nav-item .sb-tooltip{display:none}.sidebar.collapsed .nav-item .sb-tooltip{color:#e2e8f0;white-space:nowrap;pointer-events:none;z-index:200;opacity:0;background:#1e293b;border-radius:7px;padding:5px 10px;font-size:12px;font-weight:500;transition:opacity .15s;display:block;position:absolute;top:50%;left:calc(100% + 8px);transform:translateY(-50%);box-shadow:0 4px 12px #00000040}.sidebar.collapsed .nav-item .sb-tooltip:before{content:"";border:5px solid #0000;border-right-color:#1e293b;position:absolute;top:50%;right:100%;transform:translateY(-50%)}.sidebar.collapsed .nav-item:hover .sb-tooltip{opacity:1}.sidebar.collapsed .nav-item{justify-content:center;padding:8px 0}.sidebar.collapsed .sb-section{padding:10px 8px 4px}.sb-toggle{width:24px;height:24px;color:var(--sidebar-text);cursor:pointer;background:#ffffff0f;border:1px solid #ffffff1f;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;margin-left:auto;transition:background .12s,color .12s;display:flex}.sb-toggle:hover{color:#e2e8f0;background:#ffffff24}.sidebar.collapsed .sb-toggle{margin-left:0}.sb-footer{border-top:1px solid #ffffff12;margin-top:auto;padding:10px 8px}.sb-user{border-radius:7px;align-items:center;gap:9px;padding:8px 10px;display:flex}.sb-avatar{background:var(--brand);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;font-size:12px;font-weight:700;display:flex}.sb-user-name{color:#e2e8f0;font-size:12px;font-weight:600}.sb-user-role{color:var(--sidebar-text);font-size:10px}.topbar{height:var(--header-h);background:var(--card);border-bottom:1px solid var(--border);z-index:40;align-items:center;gap:0;padding:0 24px;display:flex;position:sticky;top:0}.topbar-title{color:var(--text);margin-right:auto;font-size:15px;font-weight:700}.topbar-right{align-items:center;gap:10px;display:flex}.page-body{flex:1;padding:22px 24px}.tb-nav{align-items:center;gap:2px;margin-right:24px;display:flex}.tb-menu{position:relative}.tb-menu-btn{height:34px;color:var(--text-2);font-size:13px;font-weight:500;font-family:var(--font);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-radius:7px;align-items:center;gap:5px;padding:0 11px;transition:background .12s,color .12s;display:flex}.tb-menu-btn:hover{background:var(--bg);color:var(--text)}.tb-menu-btn.active{background:var(--brand-muted);color:var(--brand);font-weight:600}.tb-menu-btn svg{opacity:.7;flex-shrink:0;width:13px;height:13px;transition:transform .15s}.tb-menu-btn.active svg{opacity:1;transform:rotate(180deg)}.tb-dropdown{border:1px solid var(--border);z-index:200;background:#fff;border-radius:10px;min-width:220px;animation:.12s fadeDown;position:absolute;top:calc(100% + 6px);left:0;overflow:hidden;box-shadow:0 8px 30px #0000001f}@keyframes fadeDown{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.tb-dropdown-section{padding:6px}.tb-dropdown-section+.tb-dropdown-section{border-top:1px solid var(--border)}.tb-dropdown-label{text-transform:uppercase;letter-spacing:.07em;color:var(--muted);padding:6px 10px 4px;font-size:10px;font-weight:700}.tb-dropdown-item{color:var(--text-2);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:7px;align-items:center;gap:9px;width:100%;padding:8px 10px;font-size:13px;font-weight:500;text-decoration:none;transition:background .1s,color .1s;display:flex}.tb-dropdown-item:hover{background:var(--bg);color:var(--text)}.tb-dropdown-item.active{background:var(--brand-muted);color:var(--brand);font-weight:600}.tb-dropdown-item svg{opacity:.7;flex-shrink:0;width:15px;height:15px}.tb-dropdown-item.active svg{opacity:1}.tb-dropdown-divider{background:var(--border);height:1px;margin:4px 0}.card{background:var(--card);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-sm)}.card-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:10px;padding:14px 18px 12px;display:flex}.card-title{color:var(--text);font-size:13.5px;font-weight:700}.card-sub{color:var(--muted);margin-top:1px;font-size:11px}.card-body{padding:16px 18px}.kpi-grid{grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:14px;display:grid}.kpi-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);flex-direction:column;gap:8px;padding:16px 18px;transition:box-shadow .2s,transform .2s;display:flex}.kpi-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.kpi-top{justify-content:space-between;align-items:flex-start;display:flex}.kpi-icon{border-radius:var(--r);flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;font-size:17px;display:flex}.kpi-val{color:var(--text);font-size:24px;font-weight:800;line-height:1}.kpi-lbl{color:var(--muted);margin-top:1px;font-size:11.5px;font-weight:500}.kpi-trend{align-items:center;gap:3px;margin-top:2px;font-size:11.5px;font-weight:600;display:flex}.kpi-trend.up{color:var(--green)}.kpi-trend.down{color:var(--red)}.kpi-trend.neu{color:var(--muted)}.g2{grid-template-columns:1fr 1fr;gap:16px;display:grid}.g3{grid-template-columns:1fr 1fr 1fr;gap:16px;display:grid}.g64{grid-template-columns:6fr 4fr;gap:16px;display:grid}.g73{grid-template-columns:7fr 3fr;gap:16px;display:grid}.ph{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:18px;display:flex}.ph-title{color:var(--text);font-size:19px;font-weight:800}.ph-desc{color:var(--muted);margin-top:2px;font-size:12.5px}.ph-right{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.stack{flex-direction:column;gap:16px;display:flex}.row{align-items:center;gap:8px;display:flex}.row.w{flex-wrap:wrap}.spacer{flex:1}.table-wrap{overflow-x:auto}table{border-collapse:collapse;width:100%;font-size:13px}thead tr{border-bottom:1px solid var(--border)}th{text-align:left;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);white-space:nowrap;padding:9px 14px;font-size:10.5px;font-weight:600}td{vertical-align:middle;border-bottom:1px solid #f1f5f9;padding:11px 14px}tbody tr:last-child td{border-bottom:none}tbody tr:hover td{background:#fafbfc}.badge{white-space:nowrap;border-radius:99px;align-items:center;gap:3px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-flex}.b-green{background:var(--green-bg);color:var(--green-text)}.b-red{background:var(--red-bg);color:var(--red-text)}.b-yellow{background:var(--yellow-bg);color:var(--yellow-text)}.b-blue{background:var(--blue-bg);color:var(--blue-text)}.b-purple{background:var(--purple-bg);color:var(--purple-text)}.b-slate{background:var(--slate-bg);color:var(--slate-text)}.input,.select{border:1.5px solid var(--border);border-radius:var(--r);height:35px;font-size:13px;font-family:var(--font);color:var(--text);background:var(--card);outline:none;width:100%;padding:0 10px;transition:border-color .15s}.input::placeholder{color:var(--muted)}.input:focus,.select:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px #2563eb1a}.form-group{flex-direction:column;gap:4px;display:flex}.form-label{color:var(--text-2);font-size:11.5px;font-weight:600}.btn{border-radius:var(--r);height:35px;font-size:13px;font-weight:600;font-family:var(--font);cursor:pointer;white-space:nowrap;border:1.5px solid #0000;justify-content:center;align-items:center;gap:5px;padding:0 13px;text-decoration:none;transition:background .12s,box-shadow .12s,opacity .12s;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn svg{flex-shrink:0;width:14px;height:14px}.btn-primary{background:var(--brand);color:#fff;border-color:var(--brand)}.btn-primary:hover:not(:disabled){background:var(--brand-dark)}.btn-secondary{background:var(--card);color:var(--text);border-color:var(--border)}.btn-secondary:hover:not(:disabled){background:var(--bg)}.btn-danger{background:var(--red);color:#fff;border-color:var(--red)}.btn-danger:hover:not(:disabled){background:#b91c1c}.btn-ghost{color:var(--text-2);background:0 0;border-color:#0000}.btn-ghost:hover:not(:disabled){background:var(--bg);color:var(--text)}.btn-sm{height:29px;padding:0 9px;font-size:12px}.btn-sm svg{width:12px;height:12px}.modal-overlay{z-index:100;background:#00000073;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal{background:var(--card);border-radius:var(--r-xl);box-shadow:var(--shadow-lg);width:100%;max-width:460px;max-height:90vh;overflow-y:auto}.modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px 18px 12px;display:flex}.modal-title{font-size:14px;font-weight:700}.modal-body{flex-direction:column;gap:13px;padding:16px 18px;display:flex}.modal-footer{border-top:1px solid var(--border);justify-content:flex-end;gap:7px;padding:10px 18px 16px;display:flex}.search-wrap{position:relative}.search-wrap svg{width:14px;height:14px;color:var(--muted);pointer-events:none;position:absolute;top:50%;left:9px;transform:translateY(-50%)}.search-wrap .input{padding-left:30px}.avatar{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;font-size:11px;font-weight:700;display:flex}.av-blue{background:var(--blue-bg);color:var(--blue-text)}.av-green{background:var(--green-bg);color:var(--green-text)}.av-purple{background:var(--purple-bg);color:var(--purple-text)}.av-yellow{background:var(--yellow-bg);color:var(--yellow-text)}.av-slate{background:var(--slate-bg);color:var(--slate-text)}.empty{color:var(--muted);flex-direction:column;justify-content:center;align-items:center;gap:8px;padding:48px 24px;display:flex}.empty svg{opacity:.35;width:38px;height:38px}.empty p{font-size:14px;font-weight:500}.pager{border-top:1px solid var(--border);justify-content:space-between;align-items:center;padding:10px 18px;display:flex}.pager-info{color:var(--muted);font-size:12px}.pager-btns{gap:4px;display:flex}.alert{border-radius:var(--r);align-items:flex-start;gap:9px;padding:11px 13px;font-size:13px;display:flex}.alert svg{flex-shrink:0;width:15px;height:15px;margin-top:1px}.a-error{background:var(--red-bg);color:var(--red-text)}.a-success{background:var(--green-bg);color:var(--green-text)}.a-info{background:var(--blue-bg);color:var(--blue-text)}@keyframes spin{to{transform:rotate(360deg)}}.spinner{border:2.5px solid var(--border);border-top-color:var(--brand);border-radius:50%;flex-shrink:0;width:18px;height:18px;animation:.65s linear infinite spin}.loading-row{color:var(--muted);justify-content:center;align-items:center;gap:10px;padding:48px;font-size:13px;display:flex}.divider{background:var(--border);height:1px}.text-muted{color:var(--muted)}.text-2{color:var(--text-2)}.text-sm{font-size:12px}.text-xs{font-size:11px}.fw-700{font-weight:700}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.mono{font-family:SF Mono,Fira Code,monospace;font-size:12px}.mt-4{margin-top:4px}.mt-8{margin-top:8px}.mt-12{margin-top:12px}.mt-16{margin-top:16px}.mb-12{margin-bottom:12px}.mb-16{margin-bottom:16px}.gap-12{gap:12px}@media (max-width:1100px){.g3{grid-template-columns:1fr 1fr}.g64,.g73{grid-template-columns:1fr}}@media (max-width:800px){:root{--sidebar-width:0px;--sidebar-width-collapsed:0px}.sidebar{display:none}.main-wrap,.main-wrap.collapsed{margin-left:0}.g2{grid-template-columns:1fr}.kpi-grid{grid-template-columns:1fr 1fr}}@media (max-width:500px){.kpi-grid{grid-template-columns:1fr}.page-body{padding:14px}}
