:root{--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;--bg: #F5F6F8;--bg-elev: #FFFFFF;--bg-sunken: #F0F1F4;--bg-muted: #EAECF0;--fg: #101218;--fg-2: #1F232C;--fg-muted: #454B57;--fg-subtle: #6A707D;--fg-faint: #9AA0AB;--border: #E4E6EB;--border-strong: #CDD1D9;--border-faint: #EDEFF3;--accent: #2854A6;--accent-soft: #E5EDF8;--ok: #2A7F4F;--ok-soft: #E2F0E9;--warn: #9C5400;--warn-soft: #FBEFD9;--danger: #B5290E;--danger-soft: #FBE3DD;--info: #2854A6;--info-soft: #E5EDF8;--r-sm: 4px;--r-md: 6px;--r-lg: 10px;--r-xl: 14px;--shadow-1: 0 1px 2px rgba(16, 18, 24, .04), 0 1px 3px rgba(16, 18, 24, .06);--shadow-2: 0 2px 4px rgba(16, 18, 24, .06), 0 4px 12px rgba(16, 18, 24, .08);--shadow-3: 0 6px 12px rgba(16, 18, 24, .1), 0 16px 36px rgba(16, 18, 24, .14);--row-pad: 10px}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;height:100%;background:var(--bg);color:var(--fg);font-family:var(--font-sans);font-size:14px;line-height:1.45;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}button,input,select,textarea{font-family:inherit}.mono{font-family:var(--font-mono)}.tabular{font-variant-numeric:tabular-nums}.app-shell{height:100%;display:grid;grid-template-rows:auto 1fr}.topbar{display:flex;align-items:center;gap:18px;padding:0 24px;background:var(--bg-elev);border-bottom:1px solid var(--border);height:52px}.topbar .brand{display:flex;align-items:center;gap:10px;font-weight:600;font-size:14px;letter-spacing:-.01em}.brand-mark{width:26px;height:26px;border-radius:6px;background:var(--accent);color:#fff;display:grid;place-items:center;font-family:var(--font-mono);font-size:11px;font-weight:700;letter-spacing:-.04em}.topbar nav{display:flex;gap:4px;margin-left:12px}.topbar nav a{padding:6px 10px;border-radius:6px;color:var(--fg-muted);font-size:13px;cursor:pointer;text-decoration:none;transition:all .1s}.topbar nav a:hover{background:var(--bg-muted);color:var(--fg)}.topbar nav a.active{background:var(--bg-muted);color:var(--fg);font-weight:500}.topbar .spacer{flex:1}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 12px;border-radius:6px;border:1px solid transparent;background:transparent;color:var(--fg);font-size:13px;font-weight:500;cursor:pointer;transition:all .1s;white-space:nowrap}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-sm{padding:5px 9px;font-size:12.5px}.btn-lg{padding:11px 18px;font-size:14px}.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}.btn-primary:hover:not(:disabled){filter:brightness(.95)}.btn-secondary{background:var(--bg-elev);color:var(--fg);border-color:var(--border-strong)}.btn-secondary:hover:not(:disabled){background:var(--bg-muted)}.btn-ghost{background:transparent;color:var(--fg-muted);border:none}.btn-ghost:hover:not(:disabled){background:var(--bg-muted);color:var(--fg)}.btn-danger{background:transparent;color:var(--danger);border:1px solid transparent}.btn-danger:hover:not(:disabled){background:var(--danger-soft)}.input,.select{width:100%;padding:8px 10px;border:1px solid var(--border-strong);border-radius:6px;background:var(--bg-elev);color:var(--fg);font-size:13px;outline:none;transition:all .1s}.input:focus,.select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.label{display:block;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--fg-subtle);margin-bottom:5px}.card{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-1)}.card-header{padding:14px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:12px}.card-title{font-size:13px;font-weight:600;letter-spacing:-.01em}.card-subtitle{font-size:11.5px;color:var(--fg-subtle);margin-top:2px}.tbl{width:100%;border-collapse:collapse;font-size:13px}.tbl th{text-align:left;padding:10px 14px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--fg-subtle);background:var(--bg-sunken);border-bottom:1px solid var(--border);white-space:nowrap}.tbl td{padding:var(--row-pad) 14px;border-bottom:1px solid var(--border-faint);vertical-align:middle}.tbl tbody tr:hover{background:var(--bg-sunken)}.tbl tbody tr.inactive{opacity:.55}.badge{display:inline-flex;align-items:center;gap:4px;padding:2px 7px;border-radius:4px;background:var(--bg-muted);color:var(--fg-muted);font-family:var(--font-mono);font-size:10.5px;font-weight:500;letter-spacing:.02em}.badge-ok{background:var(--ok-soft);color:var(--ok)}.badge-warn{background:var(--warn-soft);color:var(--warn)}.badge-danger{background:var(--danger-soft);color:var(--danger)}.badge-admin{background:#fbe9d8;color:#9c5400}.dot{width:6px;height:6px;border-radius:50%;background:var(--fg-faint);flex-shrink:0}.avatar{width:28px;height:28px;border-radius:50%;background:var(--accent-soft);color:var(--accent);display:grid;place-items:center;font-family:var(--font-mono);font-size:11px;font-weight:600;flex-shrink:0}.avatar-lg{width:38px;height:38px;font-size:13px}.tile-icon{width:32px;height:32px;border-radius:6px;display:grid;place-items:center;color:#fff;font-family:var(--font-mono);font-size:11px;font-weight:700;letter-spacing:-.04em}.tile-icon.nb{background:#2854a6}.tile-icon.taas{background:#4a6585}.persona-badge{display:inline-flex;align-items:center;gap:8px;padding:5px 10px 5px 8px;background:var(--bg-sunken);border:1px solid var(--border-strong);border-radius:999px;font-size:12px}.kpi-label{font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.06em;color:var(--fg-subtle)}.kpi-value{font-size:26px;font-weight:600;letter-spacing:-.02em;font-variant-numeric:tabular-nums;margin-top:4px;line-height:1.1}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#10121873;display:grid;place-items:center;z-index:100;animation:fade-in .12s ease-out}.modal{background:var(--bg-elev);border-radius:var(--r-lg);box-shadow:var(--shadow-3);max-width:560px;width:calc(100% - 48px);max-height:calc(100vh - 48px);overflow:hidden;animation:pop-in .16s cubic-bezier(.2,.8,.2,1)}.drawer-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#10121859;z-index:100;animation:fade-in .12s ease-out}.drawer{position:fixed;top:0;right:0;bottom:0;width:520px;max-width:calc(100% - 48px);background:var(--bg-elev);border-left:1px solid var(--border);box-shadow:var(--shadow-3);z-index:101;display:flex;flex-direction:column;animation:slide-in .2s cubic-bezier(.2,.8,.2,1)}.toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%);background:var(--fg);color:var(--bg-elev);padding:10px 18px;border-radius:8px;font-size:13px;box-shadow:var(--shadow-3);z-index:200;animation:pop-in .16s cubic-bezier(.2,.8,.2,1)}.otp-row{display:flex;gap:8px;justify-content:center}.otp-cell{width:46px;height:56px;border:1px solid var(--border-strong);border-radius:8px;background:var(--bg-elev);text-align:center;font-family:var(--font-mono);font-size:22px;font-weight:600;color:var(--fg);outline:none;transition:all .12s}.otp-cell:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.otp-cell.filled{background:var(--bg-sunken)}.auth-stage{min-height:100vh;display:grid;place-items:center;background:linear-gradient(135deg,#f5f6f8,#e8ecf2);padding:24px}.auth-card{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--r-xl);box-shadow:var(--shadow-2);padding:36px 36px 32px;width:100%;max-width:400px}.filter-bar{display:flex;gap:10px;align-items:center;padding:14px 18px;border-bottom:1px solid var(--border);flex-wrap:wrap}.filter-bar .input,.filter-bar .select{width:auto;min-width:160px}.empty-state{padding:40px 18px!important;text-align:center;color:var(--fg-subtle);font-size:13px;border-bottom:none!important}.code-block{font-family:var(--font-mono);font-size:12px;background:var(--bg-sunken);color:var(--fg-2);padding:12px 14px;border-radius:6px;border:1px solid var(--border);white-space:pre-wrap;word-break:break-word;line-height:1.55}.divider{height:1px;background:var(--border);margin:8px 0}.scrollbar::-webkit-scrollbar{width:10px;height:10px}.scrollbar::-webkit-scrollbar-track{background:transparent}.scrollbar::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:999px;border:2px solid var(--bg)}.scrollbar::-webkit-scrollbar-thumb:hover{background:var(--fg-faint)}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes pop-in{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}@keyframes slide-in{0%{transform:translate(20px);opacity:0}to{transform:translate(0);opacity:1}}@keyframes fade-up{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.fade-up{animation:fade-up .2s cubic-bezier(.2,.8,.2,1) backwards}.pop{animation:pop-in .12s ease-out}
