:root{--bg: #0f1729;--bg-elev: #16203a;--bg-elev-2: #1e2a47;--panel: #141d33;--border: #283555;--border-soft: #1f2a45;--text: #e6ecf7;--text-dim: #9fb0cf;--text-faint: #6c7da0;--primary: #4f8cff;--primary-hover: #6aa0ff;--primary-dim: #2b4d8f;--success: #2fbf71;--warn: #f5a623;--danger: #ef4d61;--danger-hover: #ff647a;--radius: 10px;--radius-sm: 6px;--shadow: 0 8px 30px rgba(0, 0, 0, .35);--font: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;--mono: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:var(--bg);color:var(--text);font-family:var(--font);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}a{color:var(--primary);text-decoration:none}a:hover{color:var(--primary-hover)}h1,h2,h3{margin:0 0 .4em;font-weight:650}h1{font-size:1.5rem}h2{font-size:1.15rem}.app-shell{display:grid;grid-template-columns:232px 1fr;min-height:100vh}.sidebar{background:var(--bg-elev);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:16px 12px;gap:4px;position:sticky;top:0;height:100vh;overflow-y:auto}.brand{display:flex;align-items:center;gap:10px;padding:8px 10px 16px;font-weight:700;font-size:1.05rem;letter-spacing:.3px}.brand .dot{width:10px;height:10px;border-radius:50%;background:var(--primary);box-shadow:0 0 12px var(--primary)}.nav-link{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:var(--radius-sm);color:var(--text-dim);font-weight:500;transition:background .12s,color .12s}.nav-link:hover{background:var(--bg-elev-2);color:var(--text)}.nav-link.active{background:var(--primary-dim);color:#fff}.nav-section{margin-top:14px;padding:0 12px;font-size:.68rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-faint)}.sidebar-footer{margin-top:auto;border-top:1px solid var(--border);padding-top:12px;font-size:.8rem;color:var(--text-dim)}.main{display:flex;flex-direction:column;min-width:0}.topbar{display:flex;align-items:center;justify-content:space-between;padding:14px 28px;border-bottom:1px solid var(--border);background:#141d3399;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);position:sticky;top:0;z-index:10}.content{padding:24px 28px 64px;max-width:1320px;width:100%}.page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:20px;flex-wrap:wrap}.page-header .subtitle{color:var(--text-dim);margin-top:2px}.card{background:var(--panel);border:1px solid var(--border-soft);border-radius:var(--radius);padding:18px 20px}.card+.card{margin-top:16px}.card-title{font-size:.95rem;font-weight:650;margin-bottom:12px;color:var(--text)}.grid{display:grid;gap:16px}.grid.cols-2{grid-template-columns:repeat(2,1fr)}.grid.cols-3{grid-template-columns:repeat(3,1fr)}.grid.cols-4{grid-template-columns:repeat(4,1fr)}@media (max-width: 1000px){.grid.cols-3,.grid.cols-4{grid-template-columns:repeat(2,1fr)}}@media (max-width: 640px){.grid.cols-2,.grid.cols-3,.grid.cols-4,.app-shell{grid-template-columns:1fr}.sidebar{position:static;height:auto}}.stat{background:var(--panel);border:1px solid var(--border-soft);border-radius:var(--radius);padding:16px 18px}.stat .label{color:var(--text-faint);font-size:.75rem;text-transform:uppercase;letter-spacing:.05em}.stat .value{font-size:1.7rem;font-weight:700;margin-top:6px}.stat .hint{color:var(--text-dim);font-size:.8rem;margin-top:4px}.btn{display:inline-flex;align-items:center;gap:7px;border:1px solid var(--border);background:var(--bg-elev-2);color:var(--text);padding:8px 14px;border-radius:var(--radius-sm);font-size:.85rem;font-weight:550;cursor:pointer;transition:background .12s,border-color .12s,opacity .12s;white-space:nowrap}.btn:hover:not(:disabled){background:#25355c}.btn:disabled{opacity:.5;cursor:not-allowed}.btn.primary{background:var(--primary);border-color:var(--primary);color:#fff}.btn.primary:hover:not(:disabled){background:var(--primary-hover)}.btn.danger{background:transparent;border-color:var(--danger);color:var(--danger-hover)}.btn.danger:hover:not(:disabled){background:#ef4d611f}.btn.ghost{background:transparent;border-color:transparent}.btn.ghost:hover:not(:disabled){background:var(--bg-elev-2)}.btn.sm{padding:5px 10px;font-size:.78rem}.btn-row{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.field{margin-bottom:14px}.field label{display:block;font-size:.8rem;color:var(--text-dim);margin-bottom:5px;font-weight:550}.field .req{color:var(--danger);margin-left:3px}.field .help{font-size:.74rem;color:var(--text-faint);margin-top:4px}.field .err{font-size:.76rem;color:var(--danger-hover);margin-top:4px}.input,.select,textarea.input{width:100%;background:var(--bg);border:1px solid var(--border);color:var(--text);border-radius:var(--radius-sm);padding:9px 11px;font-size:.86rem;font-family:inherit}.input:focus,.select:focus,textarea.input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px #4f8cff40}.input.invalid{border-color:var(--danger)}.checkbox-row{display:flex;align-items:center;gap:9px}.checkbox-row input{width:16px;height:16px;accent-color:var(--primary)}.field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}.table-wrap{border:1px solid var(--border-soft);border-radius:var(--radius);overflow:hidden;background:var(--panel)}table.data{width:100%;border-collapse:collapse;font-size:.85rem}table.data th{text-align:left;padding:11px 14px;background:var(--bg-elev);color:var(--text-faint);font-weight:600;font-size:.74rem;text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--border);white-space:nowrap}table.data th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}table.data th.sortable:hover{color:var(--text)}table.data td{padding:11px 14px;border-bottom:1px solid var(--border-soft);vertical-align:middle}table.data tr:last-child td{border-bottom:none}table.data tbody tr.clickable{cursor:pointer}table.data tbody tr.clickable:hover{background:var(--bg-elev)}.table-toolbar{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:12px}.table-toolbar .spacer{flex:1}.search-input{min-width:220px}.pagination{display:flex;align-items:center;gap:12px;padding:12px 14px;border-top:1px solid var(--border);color:var(--text-dim);font-size:.82rem}.pagination .spacer{flex:1}.mono{font-family:var(--mono);font-size:.82em}.dim{color:var(--text-dim)}.faint{color:var(--text-faint)}.nowrap{white-space:nowrap}.right{text-align:right}.badge{display:inline-flex;align-items:center;gap:5px;padding:2px 9px;border-radius:999px;font-size:.72rem;font-weight:600;letter-spacing:.02em;border:1px solid transparent}.badge .b-dot{width:7px;height:7px;border-radius:50%;background:currentColor}.badge.green{color:var(--success);background:#2fbf711f}.badge.amber{color:var(--warn);background:#f5a62321}.badge.red{color:var(--danger-hover);background:#ef4d6121}.badge.blue{color:var(--primary-hover);background:#4f8cff21}.badge.gray{color:var(--text-dim);background:#9fb0cf1f}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0509129e;display:flex;align-items:flex-start;justify-content:center;padding:60px 16px;z-index:100;overflow-y:auto}.modal{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);width:100%;max-width:520px}.modal.wide{max-width:760px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}.modal-header h2{margin:0;font-size:1.05rem}.modal-body{padding:20px}.modal-footer{display:flex;justify-content:flex-end;gap:10px;padding:14px 20px;border-top:1px solid var(--border)}.modal-close{background:none;border:none;color:var(--text-faint);font-size:1.4rem;cursor:pointer;line-height:1}.modal-close:hover{color:var(--text)}.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(1200px 600px at 50% -10%,#1b2c52 0%,transparent 70%),var(--bg);padding:24px}.login-card{width:100%;max-width:400px;background:var(--bg-elev);border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow);padding:32px 30px}.login-card .brand{justify-content:center;font-size:1.25rem;padding-top:0}.login-card .sub{text-align:center;color:var(--text-dim);margin-bottom:22px}.alert{border-radius:var(--radius-sm);padding:11px 14px;font-size:.84rem;margin-bottom:14px;border:1px solid transparent}.alert.error{color:var(--danger-hover);background:#ef4d611a;border-color:#ef4d614d}.alert.info{color:var(--text-dim);background:var(--bg-elev-2);border-color:var(--border)}.alert.warn{color:var(--warn);background:#f5a6231a;border-color:#f5a6234d}.empty,.loading-block{text-align:center;padding:48px 20px;color:var(--text-faint)}.spinner{width:26px;height:26px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 12px}.full-spinner{min-height:60vh;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text-dim)}@keyframes spin{to{transform:rotate(360deg)}}.pulse{animation:pulse 1.6s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.toast-stack{position:fixed;bottom:20px;right:20px;display:flex;flex-direction:column;gap:10px;z-index:200}.toast{background:var(--bg-elev-2);border:1px solid var(--border);border-left-width:4px;border-radius:var(--radius-sm);padding:12px 16px;min-width:260px;max-width:380px;box-shadow:var(--shadow);font-size:.85rem}.toast.success{border-left-color:var(--success)}.toast.error{border-left-color:var(--danger)}.toast.info{border-left-color:var(--primary)}.row{display:flex;gap:12px;align-items:center}.between{justify-content:space-between}.wrap{flex-wrap:wrap}.kv{display:grid;grid-template-columns:160px 1fr;gap:8px 16px;font-size:.86rem}.kv dt{color:var(--text-faint)}.kv dd{margin:0}.tag-pill{display:inline-block;background:var(--bg-elev-2);border:1px solid var(--border);border-radius:999px;padding:2px 10px;font-size:.76rem;margin:0 4px 4px 0}.breadcrumb{color:var(--text-faint);font-size:.82rem;margin-bottom:4px}.breadcrumb a{color:var(--text-dim)}.color-swatch{width:18px;height:18px;border-radius:4px;border:1px solid var(--border);display:inline-block;vertical-align:middle}.live-pill{display:inline-flex;align-items:center;gap:6px;font-size:.78rem}.live-pill .b-dot{width:8px;height:8px;border-radius:50%;background:var(--success);box-shadow:0 0 8px var(--success);animation:pulse 1.6s ease-in-out infinite}.live-pill.off .b-dot{background:var(--text-faint);box-shadow:none;animation:none}
