@import"https://fonts.googleapis.com/css2?family=Syne:wght@400;600;700;800&family=DM+Sans:wght@300;400;500;600&family=JetBrains+Mono:wght@400;500&display=swap";:root{--bg: #F1F5F9;--surface: #FFFFFF;--surface-alt: #F8FAFC;--surface-hi: #EEF2F7;--border: #E2E8F0;--border-hi: #CBD5E1;--accent: #EA6C0A;--accent-dim: rgba(234,108,10,.08);--accent-glow: rgba(234,108,10,.2);--cyan: #0891B2;--cyan-dim: rgba(8,145,178,.08);--success: #059669;--success-dim: rgba(5,150,105,.08);--danger: #DC2626;--danger-dim: rgba(220,38,38,.08);--warning: #D97706;--warning-dim: rgba(217,119,6,.08);--text: #0F172A;--text-muted: #64748B;--text-dim: #475569;--font-sans: "DM Sans", -apple-system, sans-serif;--font-display: "Syne", sans-serif;--font-mono: "JetBrains Mono", monospace;--radius: 8px;--radius-sm: 4px;--radius-lg: 12px;--shadow: 0 1px 3px rgba(0,0,0,.08), 0 0 0 1px var(--border);--shadow-lg: 0 4px 24px rgba(0,0,0,.1)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{height:100%}body{min-height:100%;background:var(--bg);color:var(--text);font-family:var(--font-sans);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}#root{height:100%}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--border-hi);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.display{font-family:var(--font-display)}.mono{font-family:var(--font-mono);font-feature-settings:"tnum"}.text-muted{color:var(--text-muted)}.text-dim{color:var(--text-dim)}.text-accent{color:var(--accent)}.text-cyan{color:var(--cyan)}.text-success{color:var(--success)}.text-danger{color:var(--danger)}.text-sm{font-size:12px}.text-xs{font-size:11px}.fw-500{font-weight:500}.fw-600{font-weight:600}.app-shell{display:flex;height:100vh;overflow:hidden}.main-content{flex:1;overflow-y:auto;padding:20px 28px;background:var(--bg)}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--border)}.page-title{font-family:var(--font-display);font-size:18px;font-weight:700;color:var(--text);letter-spacing:-.02em}.page-title span{color:var(--accent)}.sidebar{width:228px;min-height:100vh;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0}.sidebar-brand{padding:20px 20px 16px;border-bottom:1px solid var(--border)}.sidebar-brand-name{font-family:var(--font-display);font-size:16px;font-weight:800;letter-spacing:-.02em;color:var(--text)}.sidebar-brand-name em{color:var(--accent);font-style:normal}.sidebar-brand-sub{font-size:10px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted);margin-top:2px}.sidebar-nav{flex:1;padding:10px 0;overflow-y:auto}.sidebar-section-label{padding:12px 20px 4px;font-size:10px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted)}.sidebar-link{display:flex;align-items:center;gap:10px;padding:9px 20px;font-size:13px;font-weight:400;color:var(--text-dim);text-decoration:none;border-left:2px solid transparent;transition:all .15s;cursor:pointer}.sidebar-link:hover{color:var(--text);background:var(--accent-dim);border-left-color:var(--border-hi)}.sidebar-link.active{color:var(--accent);background:var(--accent-dim);border-left-color:var(--accent);font-weight:500}.sidebar-link-icon{width:16px;height:16px;opacity:.7;flex-shrink:0}.sidebar-link.active .sidebar-link-icon{opacity:1}.sidebar-footer{padding:12px 16px;border-top:1px solid var(--border)}.sidebar-user{font-size:11px;color:var(--text-muted);margin-bottom:8px;padding:0 4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.btn{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;font-family:var(--font-sans);font-size:13px;font-weight:500;border-radius:var(--radius-sm);border:1px solid transparent;cursor:pointer;transition:all .15s;white-space:nowrap;text-decoration:none}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}.btn-primary:hover:not(:disabled){background:#ea6c0a;box-shadow:0 0 0 3px var(--accent-glow)}.btn-ghost{background:transparent;color:var(--text-dim);border-color:var(--border-hi)}.btn-ghost:hover:not(:disabled){color:var(--text);background:var(--surface-hi);border-color:var(--border-hi)}.btn-danger{background:transparent;color:var(--danger);border-color:#f871714d}.btn-danger:hover:not(:disabled){background:var(--danger-dim)}.btn-success{background:transparent;color:var(--success);border-color:#10b9814d}.btn-success:hover:not(:disabled){background:var(--success-dim)}.btn-sm{padding:4px 10px;font-size:12px}.btn-icon{padding:6px;line-height:1}.btn-logout{width:100%;padding:7px 12px;font-size:12px;font-weight:500;color:var(--text-muted);background:transparent;border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:all .15s;font-family:var(--font-sans);letter-spacing:.02em}.btn-logout:hover{color:var(--danger);border-color:#f8717166;background:var(--danger-dim)}.input,.select{padding:7px 11px;font-family:var(--font-sans);font-size:13px;color:var(--text);background:var(--surface-alt);border:1px solid var(--border);border-radius:var(--radius-sm);outline:none;transition:border-color .15s,box-shadow .15s;width:100%}.input::placeholder{color:var(--text-muted)}.input:focus,.select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}.input-sm{padding:4px 8px;font-size:12px}.select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2364748B' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:30px;cursor:pointer}.select option{background:var(--surface);color:var(--text)}.input-date{color-scheme:dark}.label{display:block;font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);margin-bottom:6px}.form-group{display:flex;flex-direction:column;gap:4px}.form-row{display:flex;gap:10px;align-items:flex-end;flex-wrap:wrap}.form-row .form-group{flex:1;min-width:100px}.filter-bar{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:20px;padding:12px 16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius)}.filter-bar .input,.filter-bar .select{width:auto}.table-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.data-table{width:100%;border-collapse:collapse;font-size:13px}.data-table thead{background:var(--surface-alt);border-bottom:1px solid var(--border)}.data-table thead th{padding:10px 14px;text-align:left;font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);white-space:nowrap}.data-table tbody tr{border-bottom:1px solid var(--border);transition:background .1s}.data-table tbody tr:last-child{border-bottom:none}.data-table tbody tr:hover{background:var(--surface-hi)}.data-table tbody td{padding:10px 14px;color:var(--text);vertical-align:middle}.data-table .td-mono{font-family:var(--font-mono);font-size:12px;color:var(--text-dim)}.data-table .td-muted{color:var(--text-dim)}.data-table .td-key{font-family:var(--font-mono);font-size:11px;color:var(--text-muted);letter-spacing:.04em}.data-table .td-name{font-weight:500;color:var(--text)}.data-table .td-accent{font-weight:600;color:var(--accent);font-family:var(--font-mono);font-size:13px}.data-table .td-actions{display:flex;gap:6px;align-items:center}.empty-state{padding:28px 16px;text-align:center;color:var(--text-muted);font-size:13px}.empty-state-icon{font-size:28px;margin-bottom:10px;opacity:.4}.badge{display:inline-flex;align-items:center;padding:3px 8px;font-size:11px;font-weight:600;letter-spacing:.04em;border-radius:20px;border:1px solid transparent;white-space:nowrap}.badge-success{background:var(--success-dim);color:var(--success);border-color:#10b98133}.badge-danger{background:var(--danger-dim);color:var(--danger);border-color:#f8717133}.badge-warning{background:var(--warning-dim);color:var(--warning);border-color:#fbbf2433}.badge-cyan{background:var(--cyan-dim);color:var(--cyan);border-color:#22d3ee33}.badge-accent{background:var(--accent-dim);color:var(--accent);border-color:#f9731633}.badge-muted{background:#64748b26;color:var(--text-dim);border-color:#64748b33}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px}.card-title{font-family:var(--font-display);font-size:14px;font-weight:600;color:var(--text);margin-bottom:16px}.alert{padding:14px 16px;border-radius:var(--radius);border:1px solid transparent;margin-bottom:20px;font-size:13px}.alert-success{background:var(--success-dim);border-color:#10b9814d;color:var(--success)}.alert-danger{background:var(--danger-dim);border-color:#f871714d;color:var(--danger)}.alert-accent{background:var(--accent-dim);border-color:#f973164d;color:var(--accent)}.alert-title{font-weight:600;margin-bottom:8px}.token-box{font-family:var(--font-mono);font-size:12px;padding:10px 12px;background:var(--surface-alt);border-radius:var(--radius-sm);word-break:break-all;color:var(--cyan);border:1px solid var(--border-hi);margin-bottom:10px}.tab-bar{display:flex;gap:2px;margin-bottom:20px;border-bottom:1px solid var(--border)}.tab-btn{padding:8px 18px;font-family:var(--font-sans);font-size:13px;font-weight:500;color:var(--text-muted);background:transparent;border:none;border-bottom:2px solid transparent;margin-bottom:-1px;cursor:pointer;transition:all .15s}.tab-btn:hover{color:var(--text)}.tab-btn.active{color:var(--accent);border-bottom-color:var(--accent)}.dot{display:inline-block;width:7px;height:7px;border-radius:50%;margin-right:5px}.dot-success{background:var(--success);box-shadow:0 0 4px var(--success)}.dot-danger{background:var(--danger)}.dot-muted{background:var(--text-muted)}.login-shell{min-height:100vh;background:var(--bg);display:flex;align-items:stretch}.login-left{flex:1;display:none;background:var(--surface-alt);border-right:1px solid var(--border);padding:60px;flex-direction:column;justify-content:space-between;position:relative;overflow:hidden}@media (min-width: 900px){.login-left{display:flex}}.login-grid-bg{position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(var(--border-hi) 1px,transparent 1px),linear-gradient(90deg,var(--border-hi) 1px,transparent 1px);background-size:48px 48px;opacity:.6}.login-left-brand{position:relative;z-index:1}.login-left-headline{font-family:var(--font-display);font-size:56px;font-weight:800;letter-spacing:-.04em;line-height:1;color:var(--text);position:relative;z-index:1}.login-left-headline span{color:var(--accent)}.login-left-sub{font-size:15px;color:var(--text-muted);margin-top:14px;line-height:1.6;max-width:360px;position:relative;z-index:1}.login-right{width:440px;flex-shrink:0;display:flex;align-items:center;justify-content:center;padding:48px 40px;background:var(--bg);border-left:1px solid var(--border)}@media (max-width: 899px){.login-right{width:100%;border-left:none}}.login-form-wrap{width:100%;max-width:340px}.login-title{font-family:var(--font-display);font-size:26px;font-weight:800;letter-spacing:-.03em;color:var(--text);margin-bottom:6px}.login-title span{color:var(--accent)}.login-sub{font-size:13px;color:var(--text-muted);margin-bottom:28px}.login-form .form-group{margin-bottom:16px}.login-input{width:100%;padding:10px 14px;font-family:var(--font-sans);font-size:14px;color:var(--text);background:var(--surface);border:1px solid var(--border-hi);border-radius:var(--radius);outline:none;transition:border-color .15s,box-shadow .15s}.login-input::placeholder{color:var(--text-muted)}.login-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}.login-btn{width:100%;padding:11px;font-family:var(--font-display);font-size:14px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:#fff;background:var(--accent);border:none;border-radius:var(--radius);cursor:pointer;transition:all .15s;margin-top:6px}.login-btn:hover:not(:disabled){background:#ea6c0a;box-shadow:0 0 0 3px var(--accent-glow)}.login-btn:disabled{opacity:.6;cursor:not-allowed}.login-toggle{text-align:center;font-size:12px;color:var(--text-muted);margin-top:18px}.login-toggle a{color:var(--accent);cursor:pointer;font-weight:500;text-decoration:none}.login-error{padding:10px 12px;background:var(--danger-dim);border:1px solid rgba(248,113,113,.3);border-radius:var(--radius-sm);font-size:13px;color:var(--danger);margin-bottom:16px}.inline-input{width:80px;padding:4px 7px;font-family:var(--font-mono);font-size:12px;color:var(--text);background:var(--surface-alt);border:1px solid var(--border);border-radius:var(--radius-sm);outline:none;transition:border-color .15s}.inline-input:focus{border-color:var(--accent)}.divider{border:none;border-top:1px solid var(--border);margin:20px 0}.gap-2{gap:8px}.gap-3{gap:12px}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.flex-wrap{flex-wrap:wrap}.flex-1{flex:1}.mb-4{margin-bottom:16px}.mb-5{margin-bottom:20px}.w-full{width:100%}.nowrap{white-space:nowrap}@keyframes spin{to{transform:rotate(360deg)}}.spinner{width:16px;height:16px;border:2px solid var(--border-hi);border-top-color:var(--accent);border-radius:50%;animation:spin .6s linear infinite}@keyframes fadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}.fade-in{animation:fadeIn .2s ease-out}
