@import"https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&family=JetBrains+Mono:wght@400;500&display=swap";:root{--bg: #0b0f1c;--panel: #ffffff;--surface: #f6f7fb;--surface-2: #eef0f7;--border: #e5e7ef;--text: #0f172a;--text-muted: #6b7280;--text-soft: #94a3b8;--brand: #6366f1;--brand-strong: #4f46e5;--brand-deep: #3730a3;--brand-soft: #eef2ff;--accent: #ec4899;--accent-soft: #fce7f3;--ok: #10b981;--ok-soft: #ecfdf5;--warn: #f59e0b;--warn-soft: #fffbeb;--bad: #ef4444;--bad-soft: #fef2f2;--shadow-1: 0 1px 2px rgba(15, 23, 42, .04), 0 1px 3px rgba(15, 23, 42, .06);--shadow-2: 0 8px 24px rgba(15, 23, 42, .08);--shadow-brand: 0 12px 28px rgba(99, 102, 241, .28);--radius-sm: 8px;--radius: 12px;--radius-lg: 16px}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;height:100%;font-family:Plus Jakarta Sans,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--surface);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:inherit;text-decoration:none}button{font-family:inherit;cursor:pointer}code,.mono{font-family:JetBrains Mono,ui-monospace,monospace}.shell{display:grid;grid-template-columns:260px 1fr;min-height:100vh}.sidebar{background:var(--bg);color:#d1d5db;padding:1.5rem 1rem;display:flex;flex-direction:column;gap:.25rem;position:sticky;top:0;height:100vh}.sidebar-brand{display:flex;align-items:center;gap:.7rem;padding:.5rem .6rem 1.25rem;border-bottom:1px solid rgba(255,255,255,.06);margin-bottom:.9rem}.sidebar-brand-mark{width:36px;height:36px;border-radius:10px;background:linear-gradient(135deg,var(--brand),var(--accent));display:grid;place-items:center;color:#fff;box-shadow:var(--shadow-brand)}.sidebar-brand-text{line-height:1.15}.sidebar-brand-text strong{color:#fff;font-weight:700;font-size:.95rem;display:block}.sidebar-brand-text small{color:#94a3b8;font-size:.72rem;letter-spacing:.04em;text-transform:uppercase}.nav-section{font-size:.7rem;color:#6b7280;letter-spacing:.08em;text-transform:uppercase;padding:.8rem .7rem .3rem}.nav-item{display:flex;align-items:center;gap:.7rem;padding:.55rem .7rem;border-radius:9px;color:#cbd5e1;font-size:.9rem;font-weight:500;transition:background .12s,color .12s}.nav-item:hover{background:#ffffff0d;color:#fff}.nav-item.active{background:linear-gradient(135deg,#6366f12e,#ec489914);color:#fff}.nav-item svg{width:18px;height:18px;opacity:.85}.sidebar-foot-version{margin-top:auto;padding-top:1rem;border-top:1px solid rgba(255,255,255,.06);color:#6b7280;font-size:.72rem;padding-left:.7rem}.sidebar-foot-version small{letter-spacing:.04em}.main-col{display:flex;flex-direction:column;min-height:100vh;min-width:0}.topbar{display:flex;align-items:center;justify-content:space-between;padding:.95rem 2.25rem;background:#fff;border-bottom:1px solid var(--border);position:sticky;top:0;z-index:20;box-shadow:0 1px #0f172a05}.topbar-date{color:var(--text-muted);font-size:.85rem;font-weight:500;display:flex;align-items:center;gap:.4rem}.topbar-right{display:flex;align-items:center;gap:1rem}.topbar-user{display:flex;align-items:center;gap:.65rem}.avatar{width:38px;height:38px;border-radius:50%;flex-shrink:0;background:linear-gradient(135deg,var(--brand),var(--accent));color:#fff;font-weight:700;display:grid;place-items:center;font-size:.88rem;box-shadow:0 4px 12px #6366f138}.user-meta{line-height:1.2;min-width:0;text-align:right}.user-meta strong{color:var(--text);font-size:.88rem;font-weight:700;display:block}.user-meta small{color:var(--text-muted);font-size:.72rem;display:block;letter-spacing:.02em}.logout-btn{display:inline-flex;align-items:center;gap:.45rem;background:transparent;color:var(--bad);border:none;padding:.5rem .85rem;border-radius:9px;font-weight:600;font-size:.85rem;transition:background .15s,color .15s}.logout-btn:hover{background:var(--bad-soft)}.logout-btn svg{width:16px;height:16px}.main{padding:2rem 2.25rem 3rem;overflow-x:hidden;flex:1}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}.page-title{font-size:1.6rem;font-weight:800;letter-spacing:-.02em;margin:0}.page-sub{color:var(--text-muted);margin:.3rem 0 0;font-size:.92rem}.card{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-1);overflow:hidden}.card-pad{padding:1.4rem 1.6rem}.card-head{padding:1.1rem 1.6rem;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:1rem;background:linear-gradient(180deg,#fcfcfe,#fff)}.card-head h3{margin:0;font-size:.98rem;font-weight:700;letter-spacing:-.01em;color:var(--text)}.stat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem;margin-bottom:1.5rem}.stat{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem 1.35rem;box-shadow:var(--shadow-1);position:relative;overflow:hidden;transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease}.stat:hover{transform:translateY(-2px);box-shadow:var(--shadow-2);border-color:#d8d9e3}.stat:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--brand),var(--accent));opacity:0;transition:opacity .15s}.stat:hover:before{opacity:1}.stat .label{font-size:.74rem;color:var(--text-muted);font-weight:700;text-transform:uppercase;letter-spacing:.06em;margin-bottom:.55rem;display:flex;align-items:center;gap:.35rem}.stat .value{font-size:1.8rem;font-weight:800;letter-spacing:-.025em;color:var(--text);line-height:1}.stat .hint{font-size:.78rem;color:var(--text-soft);margin-top:.55rem}.stat.accent{background:linear-gradient(135deg,#6366f1,#8b5cf6,#ec4899);border-color:transparent;color:#fff}.stat.accent:before{display:none}.stat.accent .label{color:#ffffffd9}.stat.accent .value{color:#fff}.stat.accent .hint{color:#ffffffb3}.stat.accent:hover{transform:translateY(-2px);box-shadow:var(--shadow-brand)}.table-wrap{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-1)}table.tbl{width:100%;border-collapse:separate;border-spacing:0;font-size:.9rem}table.tbl thead th{text-align:left;font-weight:600;color:var(--text-muted);font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;padding:.85rem 1.25rem;border-bottom:1px solid var(--border);background:var(--surface)}table.tbl tbody td{padding:.85rem 1.25rem;border-bottom:1px solid var(--border);color:var(--text)}table.tbl tbody tr:last-child td{border-bottom:0}table.tbl tbody tr:hover{background:var(--surface)}table.tbl tbody tr.clickable{cursor:pointer}.badge{display:inline-flex;align-items:center;gap:.3rem;padding:.2rem .55rem;border-radius:999px;font-size:.74rem;font-weight:600;background:var(--surface-2);color:var(--text-muted)}.badge.ok{background:var(--ok-soft);color:#047857}.badge.warn{background:var(--warn-soft);color:#92400e}.badge.bad{background:var(--bad-soft);color:#b91c1c}.badge.brand{background:var(--brand-soft);color:var(--brand-deep)}.badge.accent{background:var(--accent-soft);color:#9d174d}.badge .dot{width:6px;height:6px;border-radius:50%;background:currentColor;opacity:.65}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;background:linear-gradient(135deg,var(--brand),var(--brand-strong));color:#fff;border:none;padding:.7rem 1.1rem;font-weight:600;font-size:.9rem;border-radius:10px;box-shadow:var(--shadow-brand);transition:transform .1s,filter .15s,box-shadow .15s}.btn:hover{filter:brightness(1.05);box-shadow:0 16px 32px #6366f157}.btn:active{transform:translateY(1px)}.btn.ghost{background:var(--surface);color:var(--text);box-shadow:none;border:1px solid var(--border)}.btn.ghost:hover{background:var(--surface-2);filter:none;box-shadow:none}.btn:disabled{opacity:.6;cursor:not-allowed;filter:grayscale(.4)}.input-group{display:flex;flex-direction:column;gap:.35rem}.input-group label{font-size:.78rem;color:var(--text);font-weight:600;letter-spacing:.01em}.input{width:100%;border:1px solid var(--border);border-radius:10px;padding:.7rem .9rem;font-size:.9rem;background:#fff;transition:border-color .12s,box-shadow .12s;font-family:inherit}.input:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 4px #6366f124}.input-with-icon{position:relative}.input-with-icon .input{padding-left:2.4rem}.input-with-icon .icon{position:absolute;left:.85rem;top:50%;transform:translateY(-50%);color:var(--text-soft)}.alert-bad{display:flex;align-items:flex-start;gap:.6rem;background:var(--bad-soft);border:1px solid #fecaca;color:#991b1b;padding:.75rem .9rem;border-radius:10px;font-size:.85rem}.alert-ok{display:flex;align-items:flex-start;gap:.6rem;background:var(--ok-soft);border:1px solid #a7f3d0;color:#065f46;padding:.75rem .9rem;border-radius:10px;font-size:.85rem}.spin{animation:spin .8s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.filter-bar{display:flex;align-items:center;gap:.55rem;flex-wrap:wrap;background:#fff;border:1px solid var(--border);border-bottom:none;border-radius:14px 14px 0 0;padding:.85rem 1rem}.filter-bar .input{padding:.5rem .7rem;font-size:.85rem;max-width:240px}.filter-bar .input-with-icon .input{padding-left:2rem;max-width:none}.filter-bar .filter-grow{flex:1;min-width:200px}.filter-bar .btn{padding:.55rem .95rem;font-size:.85rem}.pagination{display:flex;align-items:center;justify-content:space-between;padding:.8rem 1.25rem;border-top:1px solid var(--border);background:var(--surface);font-size:.83rem;color:var(--text-muted);flex-wrap:wrap;gap:.6rem}.pagination .group{display:flex;gap:.3rem;align-items:center}.pagination .pg-btn{min-width:32px;height:32px;padding:0 .5rem;display:inline-flex;align-items:center;justify-content:center;background:#fff;border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:.83rem;font-weight:500;transition:background .12s,border-color .12s,color .12s}.pagination .pg-btn:not(:disabled):hover{background:var(--surface-2);border-color:#cbd5e1}.pagination .pg-btn.active{background:var(--brand);border-color:var(--brand);color:#fff}.pagination .pg-btn:disabled{opacity:.4;cursor:not-allowed}.pagination .pg-ellipsis{padding:0 .25rem;color:var(--text-soft)}.row{display:flex;gap:1rem;flex-wrap:wrap}.row.between{justify-content:space-between;align-items:center}.muted{color:var(--text-muted)}.empty{padding:3rem 1rem;text-align:center;color:var(--text-muted)}.empty h4{font-weight:700;color:var(--text);margin:0 0 .5rem}.code-block{background:var(--surface-2);padding:.75rem 1rem;border-radius:8px;font-size:.78rem;overflow-x:auto}.login-shell{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(0,1fr);min-height:100vh;background:var(--surface)}.login-brand{position:relative;overflow:hidden;padding:3rem 3.5rem;background:radial-gradient(1200px 600px at 10% 0%,rgba(236,72,153,.32),transparent 55%),radial-gradient(900px 600px at 95% 100%,rgba(99,102,241,.42),transparent 55%),linear-gradient(160deg,#0b1027,#1e1b4b 55%,#312e81);color:#fff;display:flex;flex-direction:column;justify-content:space-between}.login-brand:before{content:"";position:absolute;inset:0;background:radial-gradient(2px 2px at 20% 30%,rgba(255,255,255,.5) 50%,transparent 51%),radial-gradient(2px 2px at 70% 60%,rgba(255,255,255,.35) 50%,transparent 51%),radial-gradient(2px 2px at 85% 25%,rgba(255,255,255,.4) 50%,transparent 51%),radial-gradient(1px 1px at 40% 80%,rgba(255,255,255,.3) 50%,transparent 51%);opacity:.6;pointer-events:none}.login-brand>*{position:relative;z-index:1}.login-brand-top{display:flex;align-items:center;gap:.9rem}.login-brand-mark{width:52px;height:52px;border-radius:14px;background:linear-gradient(135deg,#fff,#e0e7ff);color:var(--brand-strong);display:grid;place-items:center;box-shadow:0 18px 36px #00000040}.login-brand-text strong{font-weight:700;font-size:1.05rem;display:block;letter-spacing:-.005em;color:#fff}.login-brand-text small{display:block;font-size:.75rem;color:#fff9;margin-top:2px;letter-spacing:.04em;text-transform:uppercase}.login-hero{max-width:520px}.login-eyebrow{display:inline-flex;align-items:center;gap:.4rem;padding:.35rem .8rem;border:1px solid rgba(255,255,255,.2);border-radius:999px;background:#ffffff0f;color:#c7d2fe;font-size:.72rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;margin-bottom:1.25rem}.login-headline{font-size:2.6rem;line-height:1.1;font-weight:800;letter-spacing:-.025em;margin:0 0 1rem;color:#fff}.login-headline span{background:linear-gradient(135deg,#fcd34d,#f472b6);-webkit-background-clip:text;background-clip:text;color:transparent}.login-lede{font-size:1.02rem;color:#ffffffc7;line-height:1.6;margin:0 0 2rem}.login-features{list-style:none;padding:0;margin:0;display:grid;gap:.7rem}.login-features li{display:flex;align-items:flex-start;gap:.75rem;color:#ffffffd9;font-size:.92rem}.login-features li>span.dot{margin-top:.4rem;width:8px;height:8px;border-radius:50%;background:linear-gradient(135deg,#fcd34d,#f472b6);flex-shrink:0}.login-foot{color:#ffffff73;font-size:.78rem;letter-spacing:.02em}.login-form-panel{display:flex;align-items:center;justify-content:center;padding:3rem 2rem;background:var(--panel)}.login-form-wrap{width:100%;max-width:400px;animation:fadeInUp .5s cubic-bezier(.16,1,.3,1)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.login-form-title{font-size:1.75rem;font-weight:800;letter-spacing:-.02em;margin:0 0 .4rem;color:var(--text)}.login-form-sub{color:var(--text-muted);margin:0 0 2rem;font-size:.92rem;line-height:1.5}.login-form .input-group+.input-group{margin-top:.9rem}.login-form .btn{width:100%;margin-top:1.2rem;padding:.85rem;font-size:.95rem}.login-form-foot{text-align:center;color:var(--text-soft);font-size:.78rem;margin-top:1.5rem}@media(max-width:980px){.shell{grid-template-columns:1fr}.sidebar{position:relative;height:auto}.login-shell{grid-template-columns:1fr}.login-brand{padding:2rem 1.5rem 1.5rem}.login-headline{font-size:1.85rem}.login-features,.login-foot{display:none}.login-form-panel{padding:2rem 1.25rem 3rem}}
