:root{--bg: #0f0a1e;--bg-elev: #15102a;--card: #1a1130;--card-alt: #211840;--border: rgba(255, 255, 255, .08);--border-strong: rgba(255, 255, 255, .14);--text: #ffffff;--text-sub: rgba(255, 255, 255, .65);--text-muted: rgba(255, 255, 255, .4);--text-faint: rgba(255, 255, 255, .25);--purple: #7c3aed;--purple-light: rgba(124, 58, 237, .18);--indigo: #6366f1;--green: #34d399;--green-bg: rgba(52, 211, 153, .12);--red: #f87171;--red-bg: rgba(248, 113, 113, .12);--amber: #fbbf24;--amber-bg: rgba(251, 191, 36, .12);--blue: #60a5fa;--blue-bg: rgba(96, 165, 250, .12);--sidebar: #120d22}*{box-sizing:border-box}html,body{margin:0;padding:0}body{font-family:Inter,Segoe UI,sans-serif;background:var(--bg);color:var(--text);font-size:14px;line-height:1.5;min-height:100vh}a{color:inherit;text-decoration:none}button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}.layout{display:grid;grid-template-columns:240px 1fr;min-height:100vh}.sidebar{background:var(--sidebar);border-right:1px solid var(--border);padding:22px 14px;position:sticky;top:0;height:100vh;display:flex;flex-direction:column;gap:4px}.sidebar__logo{display:flex;align-items:center;gap:10px;padding:4px 8px 18px;margin-bottom:8px;border-bottom:1px solid var(--border)}.sidebar__logo-icon{width:32px;height:32px;border-radius:9px;background:linear-gradient(135deg,#a78bfa,var(--indigo));display:flex;align-items:center;justify-content:center;box-shadow:0 4px 14px #6366f166}.sidebar__logo-text{font-size:14px;font-weight:800;letter-spacing:.04em}.sidebar__logo-sub{font-size:10px;color:var(--text-muted);font-weight:500;letter-spacing:.08em;text-transform:uppercase}.nav-link{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:9px;color:var(--text-sub);font-weight:500;font-size:13px;transition:background .15s,color .15s}.nav-link:hover{background:#ffffff0a;color:var(--text)}.nav-link.is-active{background:var(--purple-light);color:var(--text);font-weight:600}.nav-link svg{flex-shrink:0}.sidebar__footer{margin-top:auto;padding-top:14px;border-top:1px solid var(--border);display:flex;align-items:center;gap:10px}.avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--purple),var(--indigo));display:flex;align-items:center;justify-content:center;font-weight:700;font-size:12px}.sidebar__footer-name{font-size:12px;font-weight:600}.sidebar__footer-email{font-size:10px;color:var(--text-muted)}.main{padding:0;display:flex;flex-direction:column}.topbar{display:flex;align-items:center;gap:16px;padding:16px 28px;border-bottom:1px solid var(--border);background:var(--bg);position:sticky;top:0;z-index:5}.topbar__title{font-size:18px;font-weight:700}.topbar__sub{font-size:12px;color:var(--text-muted);margin-top:2px}.search{margin-left:auto;display:flex;align-items:center;gap:8px;background:var(--card);border:1px solid var(--border);border-radius:10px;padding:7px 10px;width:280px;transition:border-color .15s}.search:focus-within{border-color:#a78bfa80}.search input{background:none;border:none;outline:none;color:var(--text);font-size:13px;flex:1;font-family:inherit}.search input::placeholder{color:var(--text-faint)}.btn{padding:8px 14px;border-radius:10px;font-size:13px;font-weight:600;display:inline-flex;align-items:center;gap:6px;transition:filter .15s,background .15s}.btn--primary{background:linear-gradient(135deg,var(--purple),var(--indigo));color:#fff;box-shadow:0 3px 12px #6366f159}.btn--primary:hover{filter:brightness(1.1)}.btn--ghost{background:var(--card);border:1px solid var(--border);color:var(--text-sub)}.btn--ghost:hover{background:var(--card-alt);color:var(--text)}.btn--danger{background:var(--red-bg);color:var(--red);border:1px solid rgba(248,113,113,.3)}.btn--danger:hover{background:#f8717133}.btn--sm{padding:5px 10px;font-size:12px;border-radius:8px}.content{padding:24px 28px 60px;flex:1}.section-title{font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);margin:24px 0 12px}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:20px}.stat-card{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:16px 18px;display:flex;flex-direction:column;gap:4px;position:relative;overflow:hidden}.stat-card__label{font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted)}.stat-card__num{font-size:28px;font-weight:800;letter-spacing:-.02em;line-height:1.1}.stat-card__delta{font-size:11px;display:inline-flex;align-items:center;gap:4px;padding:2px 7px;border-radius:6px;font-weight:600;width:fit-content}.stat-card__delta--up{color:var(--green);background:var(--green-bg)}.stat-card__delta--down{color:var(--red);background:var(--red-bg)}.stat-card__delta--flat{color:var(--text-muted);background:#ffffff0a}.stat-card__icon{position:absolute;top:14px;right:14px;opacity:.25}.stat-card--accent{border-left:3px solid var(--purple)}.stat-card--accent .stat-card__num{color:#c4b5fd}.card{background:var(--card);border:1px solid var(--border);border-radius:14px;overflow:hidden}.card__header{display:flex;align-items:center;gap:12px;padding:14px 18px;border-bottom:1px solid var(--border)}.card__title{font-size:14px;font-weight:700}.card__sub{font-size:11px;color:var(--text-muted)}.card__actions{margin-left:auto;display:flex;gap:8px}.tabs{display:flex;gap:2px;border-bottom:1px solid var(--border);padding:0 18px}.tab{padding:11px 14px;font-size:13px;font-weight:600;color:var(--text-muted);border-bottom:2px solid transparent;transition:color .15s,border-color .15s}.tab.is-active{color:var(--text);border-bottom-color:var(--purple)}.tab:hover{color:var(--text-sub)}table{width:100%;border-collapse:collapse;font-size:13px}th{text-align:left;font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);padding:12px 18px;border-bottom:1px solid var(--border);background:#0000002e}td{padding:14px 18px;border-bottom:1px solid var(--border);color:var(--text-sub)}tr:last-child td{border-bottom:none}tr:hover td{background:#ffffff05}tbody a{color:var(--text);font-weight:600}tbody a:hover{color:#c4b5fd}td.num{font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:6px;font-size:10px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;border:1px solid transparent}.badge--free{background:#ffffff0d;color:var(--text-sub);border-color:var(--border)}.badge--pro{background:var(--purple-light);color:#c4b5fd;border-color:#a78bfa4d}.badge--enterprise,.badge--green{background:var(--green-bg);color:var(--green);border-color:#34d3994d}.badge--red{background:var(--red-bg);color:var(--red);border-color:#f871714d}.badge--amber{background:var(--amber-bg);color:var(--amber);border-color:#fbbf244d}.badge--blue{background:var(--blue-bg);color:var(--blue);border-color:#60a5fa4d}.filters{display:flex;align-items:center;gap:8px;padding:12px 18px;border-bottom:1px solid var(--border);flex-wrap:wrap}.chip{padding:5px 11px;border-radius:999px;font-size:12px;font-weight:600;background:var(--card-alt);color:var(--text-sub);border:1px solid var(--border);transition:background .15s,color .15s}.chip:hover{background:#ffffff0f;color:var(--text)}.chip.is-active{background:var(--purple);color:#fff;border-color:var(--purple)}.detail-grid{display:grid;grid-template-columns:320px 1fr;gap:20px;margin-top:4px}.detail-aside{display:flex;flex-direction:column;gap:16px}.profile-card{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:22px 18px;text-align:center}.profile-card__avatar{width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,var(--purple),var(--indigo));display:inline-flex;align-items:center;justify-content:center;font-size:22px;font-weight:800;margin-bottom:12px;box-shadow:0 8px 24px #6366f159}.profile-card__name{font-size:16px;font-weight:700}.profile-card__id{font-size:12px;color:var(--text-muted);margin-top:4px;font-feature-settings:"tnum"}.profile-list{display:flex;flex-direction:column}.profile-list__row{display:flex;justify-content:space-between;align-items:center;padding:11px 0;border-bottom:1px solid var(--border)}.profile-list__row:last-child{border-bottom:none}.profile-list__label{font-size:12px;color:var(--text-muted)}.profile-list__value{font-size:13px;font-weight:600;color:var(--text)}.action-block{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:16px 18px;display:flex;flex-direction:column;gap:10px}.action-block__title{font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted)}.action-block .btn{justify-content:center}.input,.select{width:100%;padding:9px 12px;background:var(--bg-elev);border:1px solid var(--border);border-radius:10px;color:var(--text);font-size:13px;outline:none;font-family:inherit;transition:border-color .15s}.input:focus,.select:focus{border-color:#a78bfa80}.select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23ffffff80' stroke-width='2.5'><polyline points='6 9 12 15 18 9'/></svg>");background-repeat:no-repeat;background-position:right 10px center;padding-right:30px}.label{font-size:11px;font-weight:600;color:var(--text-muted);letter-spacing:.04em;text-transform:uppercase;margin-bottom:4px;display:block}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:none;align-items:center;justify-content:center;z-index:100}.modal-backdrop.is-open{display:flex}.modal{width:380px;background:var(--card);border:1px solid var(--border-strong);border-radius:16px;padding:22px;box-shadow:0 20px 50px #00000080}.modal__title{font-size:16px;font-weight:700;margin-bottom:14px}.modal__row{margin-bottom:14px}.modal__actions{display:flex;gap:8px;justify-content:flex-end;margin-top:4px}.row{display:flex;align-items:center;gap:8px}.spacer{flex:1}.muted{color:var(--text-muted)}.tnum{font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.login-screen{min-height:100vh;display:grid;place-items:center;background:var(--bg);background:radial-gradient(circle at 25% 15%,rgba(167,139,250,.1),transparent 45%),radial-gradient(circle at 75% 85%,rgba(99,102,241,.08),transparent 45%),var(--bg);padding:24px}.login-card{background:var(--card);border:1px solid var(--border);border-radius:18px;padding:36px 36px 32px;width:440px;max-width:100%;box-shadow:0 30px 80px #00000080;position:relative}.login-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:18px;pointer-events:none;background:linear-gradient(135deg,rgba(167,139,250,.12),transparent 40%,transparent 70%,rgba(99,102,241,.08));opacity:.6}.login-card>*{position:relative;z-index:1}.login-brand{display:flex;align-items:center;gap:14px;padding-bottom:24px;margin-bottom:24px;border-bottom:1px solid var(--border)}.login-mark{width:48px;height:48px;border-radius:12px;background:linear-gradient(135deg,#a78bfa,var(--indigo));display:grid;place-items:center;color:#fff;box-shadow:0 8px 24px #6366f166}.login-title{font-size:18px;font-weight:800;letter-spacing:.01em}.login-sub{font-size:11px;color:var(--text-muted);margin-top:4px;letter-spacing:.06em;text-transform:uppercase;font-weight:500}.login-field{margin-bottom:16px}.login-field .label{margin-bottom:8px}.login-submit{width:100%;padding:12px;background:linear-gradient(135deg,var(--purple),var(--indigo));color:#fff;border:0;border-radius:10px;font:inherit;font-size:14px;font-weight:700;cursor:pointer;margin-top:8px;box-shadow:0 6px 20px #6366f166;transition:filter .15s,transform .05s}.login-submit:hover{filter:brightness(1.08)}.login-submit:active{transform:translateY(1px)}.login-submit:disabled{opacity:.6;cursor:default}.login-foot{margin-top:22px;padding-top:16px;border-top:1px solid var(--border);font-size:11px;color:var(--text-faint);display:flex;align-items:center;gap:6px;justify-content:center}.admin-remember{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text-sub);cursor:pointer;-webkit-user-select:none;user-select:none;margin:6px 0 14px}.admin-remember input[type=checkbox]{width:14px;height:14px;margin:0;cursor:pointer;accent-color:#a78bfa}.admin-remember:hover{color:var(--text)}.full-screen-loading{min-height:100vh;display:grid;place-items:center;color:var(--text-muted);background:var(--bg)}.logout-btn{background:transparent;border:0;color:var(--text-muted);cursor:pointer;padding:6px;border-radius:6px;display:grid;place-items:center}.logout-btn:hover{color:var(--red);background:var(--red-bg)}.row-actions{display:inline-flex;align-items:center;gap:6px}.row-action-btn{background:transparent;border:1px solid transparent;color:var(--text-muted);cursor:pointer;width:30px;height:30px;border-radius:8px;display:grid;place-items:center;transition:color .12s,background .12s,border-color .12s}.row-action-btn:hover{color:var(--text);background:var(--card-alt);border-color:var(--border)}.row-action-btn--danger:hover{color:var(--red);background:var(--red-bg);border-color:#f871714d}.row-action-btn:disabled{opacity:.5;cursor:default}.modal--lg{width:580px}.modal--xl{width:760px}.modal-backdrop.is-open-react{display:flex}.error-banner{background:var(--red-bg);border:1px solid rgba(248,113,113,.3);color:var(--red);padding:10px 14px;border-radius:10px;font-size:12px;margin-bottom:14px}.empty-state{display:flex;flex-direction:column;align-items:center;gap:14px;text-align:center;padding:64px 32px;color:var(--text-muted)}.empty-state__icon{width:64px;height:64px;border-radius:16px;background:var(--card-alt);border:1px solid var(--border);display:grid;place-items:center;color:var(--text-sub)}.empty-state__title{font-size:16px;font-weight:700;color:var(--text)}.empty-state__sub{font-size:13px;max-width:460px;line-height:1.6}.bar-chart{display:flex;align-items:flex-end;gap:14px;height:160px;padding:8px 22px 22px}.bar-chart__col{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px}.bar-chart__value{font-size:10px;color:var(--text-muted);height:14px;font-feature-settings:"tnum"}.bar-chart__bar{width:100%;background:linear-gradient(180deg,#a78bfa,var(--indigo));border-radius:6px 6px 0 0;transition:height .3s;min-height:2px}.bar-chart__day{font-size:11px;color:var(--text-muted)}.dist-list{padding:22px 22px 24px;display:flex;flex-direction:column;gap:14px}.dist-row__head{display:flex;justify-content:space-between;font-size:12px;margin-bottom:6px}.dist-row__bar-bg{height:8px;border-radius:4px;background:#ffffff0f;overflow:hidden}.dist-row__bar-fg{height:100%;transition:width .3s}.dist-summary{margin-top:8px;padding-top:14px;border-top:1px solid var(--border);font-size:12px;color:var(--text-muted);line-height:1.5}.table-empty{text-align:center;padding:30px;color:var(--text-muted)}.logs-box{background:var(--bg-elev);border:1px solid var(--border);border-radius:8px;padding:12px;font-family:JetBrains Mono,Consolas,monospace;font-size:11px;line-height:1.5;max-height:400px;overflow-y:auto;color:var(--text-sub);margin:0;white-space:pre-wrap}.logs-box .log-error{color:var(--red)}.logs-box .log-warn{color:var(--amber)}.logs-box .log-info{color:var(--text)}.logs-box .log-level{font-weight:700;opacity:.7}.info-banner{background:#34d3991a;border:1px solid rgba(52,211,153,.3);color:var(--green);padding:10px 14px;border-radius:8px;font-size:12px;margin-bottom:14px}.grid-2col{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:16px;align-items:start}@media (max-width: 980px){.grid-2col{grid-template-columns:1fr}}.toast{position:fixed;right:24px;bottom:24px;padding:11px 16px;border-radius:10px;font-size:13px;font-weight:600;box-shadow:0 8px 24px #00000080;z-index:200;border:1px solid var(--border);background:var(--card);color:var(--text);animation:toast-in .18s ease both}.toast--ok{border-color:#34d39966;color:var(--green);background:var(--green-bg)}.toast--err{border-color:#f8717166;color:var(--red);background:var(--red-bg)}@keyframes toast-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}.field{display:block;margin-bottom:14px}.field__label{display:block;font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);font-weight:600;margin-bottom:6px}.field__input{width:100%;padding:9px 12px;background:var(--bg-elev);border:1px solid var(--border);border-radius:8px;color:var(--text);font:inherit;font-size:13px}.field__input:focus{outline:none;border-color:#a78bfa80}
