*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--bg-body:#0d1117;--bg-card:#141822;--bg-hover:#1a2233;--bg-input:#0d1117;--border:#1f2d3d;--border-hi:#2a3f5a;--text:#dfe7ef;--text-sub:#8a9bb0;--text-mute:#4a5568;--blue:#7aa3ff;--blue-dim:#1e3a6e;--green:#4ade80;--green-dim:#14532d;--amber:#fbbf24;--amber-dim:#451a03;--red:#f87171;--red-dim:#450a0a;--purple:#c084fc;--radius:8px;--radius-sm:4px;--sidebar-w:200px;--topbar-h:52px;--font-mono:"JetBrains Mono",ui-monospace,SFMono-Regular,Menlo,monospace;--font-ui:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;--shadow:0 2px 12px rgba(0,0,0,.35)}body,html{height:100%}body{background:var(--bg-body);color:var(--text);font-family:var(--font-ui);font-size:14px;line-height:1.6;-webkit-font-smoothing:antialiased}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-hi);border-radius:3px}a{color:var(--blue);text-decoration:none}a:hover{text-decoration:underline}.shell{display:flex;height:100vh;overflow:hidden}.sidebar{width:var(--sidebar-w);background:var(--bg-card);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;overflow-y:auto}.sidebar-logo{padding:18px 16px 14px;border-bottom:1px solid var(--border)}.sidebar-logo .logo-name{font-size:1rem;font-weight:700;color:var(--blue);letter-spacing:-.02em}.sidebar-logo .logo-sub{font-size:.72rem;color:var(--text-mute);margin-top:1px}.sidebar-nav{flex:1 1;padding:8px 0}.nav-item{display:flex;align-items:center;gap:9px;padding:8px 16px;font-size:.83rem;font-weight:500;color:var(--text-sub);cursor:pointer;border-left:2px solid transparent;transition:background .12s,color .12s;text-decoration:none}.nav-item:hover{background:var(--bg-hover);color:var(--text);text-decoration:none}.nav-item.active{color:var(--blue);border-left-color:var(--blue);background:rgba(122,163,255,.06)}.nav-item .nav-icon{font-size:14px;width:18px;text-align:center}.sidebar-footer{padding:12px 16px;border-top:1px solid var(--border)}.btn-logout{width:100%;padding:6px 10px;background:transparent;border:1px solid var(--border-hi);color:var(--text-mute);border-radius:var(--radius-sm);font-size:.78rem;cursor:pointer;transition:color .12s,border-color .12s}.btn-logout:hover{color:var(--red);border-color:var(--red)}.page-area{flex:1 1;overflow-y:auto;display:flex;flex-direction:column}.page-main{flex:1 1;padding:24px 28px;max-width:1400px;width:100%;margin:0 auto}.page-title{font-size:1.35rem;font-weight:700;margin-bottom:4px;letter-spacing:-.02em}.page-subtitle{font-size:.82rem;color:var(--text-sub);margin-bottom:20px}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:18px 20px}.card+.card{margin-top:16px}.card-title{font-size:.78rem;font-weight:600;color:var(--text-sub);text-transform:uppercase;letter-spacing:.06em;margin-bottom:10px}.stat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));grid-gap:14px;gap:14px;margin-bottom:20px}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:16px 18px}.stat-card .stat-label{font-size:.72rem;font-weight:600;color:var(--text-sub);text-transform:uppercase;letter-spacing:.06em;margin-bottom:8px}.stat-card .stat-value{font-size:1.65rem;font-weight:700;line-height:1}.stat-card .stat-sub{font-size:.73rem;color:var(--text-sub);margin-top:6px}.tbl-wrap{overflow-x:auto;margin-top:14px}table.data-table{width:100%;border-collapse:collapse;font-size:.82rem}table.data-table th{padding:7px 10px;text-align:left;font-size:.7rem;font-weight:600;color:var(--text-sub);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border-hi);white-space:nowrap}table.data-table td{padding:7px 10px;border-bottom:1px solid var(--border);white-space:nowrap;vertical-align:middle}table.data-table tbody tr:hover td{background:var(--bg-hover)}table.data-table .mono{font-family:var(--font-mono);font-size:.78rem}table.data-table .mute{color:var(--text-sub);font-size:.73rem}.badge{display:inline-block;padding:2px 7px;border-radius:99px;font-size:.7rem;font-weight:600;letter-spacing:.03em;border:1px solid transparent}.badge-green{color:var(--green);border-color:var(--green);background:rgba(74,222,128,.08)}.badge-amber{color:var(--amber);border-color:var(--amber);background:rgba(251,191,36,.08)}.badge-red{color:var(--red);border-color:var(--red);background:hsla(0,91%,71%,.08)}.badge-blue{color:var(--blue);border-color:var(--blue);background:rgba(122,163,255,.08)}.badge-mute{color:var(--text-sub);border-color:var(--border-hi);background:transparent}.badge-purple{color:var(--purple);border-color:var(--purple);background:rgba(192,132,252,.08)}.btn{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:var(--radius-sm);font-size:.82rem;font-weight:600;cursor:pointer;border:1px solid transparent;transition:opacity .12s}.btn:disabled{opacity:.45;cursor:not-allowed}.btn-primary{background:var(--blue-dim);color:var(--blue);border-color:#2a4a8e}.btn-green{background:var(--green-dim);color:var(--green);border-color:#166534}.btn-red{background:var(--red-dim);color:var(--red);border-color:#7f1d1d}.btn-ghost{background:transparent;color:var(--text-sub);border-color:var(--border-hi)}.btn:not(:disabled):hover{opacity:.8}.inp{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);padding:5px 8px;font-size:.82rem;font-family:var(--font-mono);outline:none;width:100%;transition:border-color .12s}.inp:focus{border-color:var(--blue)}.alert{padding:8px 14px;border-radius:var(--radius-sm);font-size:.82rem;margin-bottom:14px}.alert-err{background:hsla(0,91%,71%,.08);border:1px solid var(--red);color:var(--red)}.alert-ok{background:rgba(74,222,128,.08);border:1px solid var(--green);color:var(--green)}.alert-info{background:rgba(122,163,255,.08);border:1px solid var(--blue);color:var(--blue)}.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:8px}.gap-3{gap:12px}.mt-1{margin-top:6px}.mt-2{margin-top:12px}.mt-3{margin-top:20px}.text-green{color:var(--green)}.text-red{color:var(--red)}.text-amber{color:var(--amber)}.text-blue{color:var(--blue)}.text-mute{color:var(--text-sub)}.text-right{text-align:right}.font-mono{font-family:var(--font-mono)}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}