:root{--bg:#0d0d0f;--bg2:#141417;--bg3:#1c1c21;--bg4:#242429;--border:rgba(255,255,255,0.07);--border2:rgba(255,255,255,0.13);--text:#f0f0f2;--text2:#8b8b99;--text3:#45454f;--accent:#6c63ff;--accent2:#8b84ff;--green:#22c55e;--amber:#f59e0b;--red:#ef4444;--blue:#3b82f6;--r:10px;--rl:14px}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;background:var(--bg);color:var(--text);min-height:100vh;font-size:14px;line-height:1.5}
a{color:inherit;text-decoration:none}

/* ── AUTH ── */
#auth-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:1rem}
.auth-card{background:var(--bg2);border:1px solid var(--border2);border-radius:var(--rl);padding:2rem;width:100%;max-width:400px}
.auth-logo{font-size:24px;font-weight:700;color:var(--accent2);margin-bottom:4px}
.auth-sub{color:var(--text2);font-size:13px;margin-bottom:1.5rem}
.tabs{display:flex;gap:4px;background:var(--bg3);border-radius:8px;padding:4px;margin-bottom:1.5rem}
.tab{flex:1;text-align:center;padding:7px;border-radius:6px;cursor:pointer;font-size:13px;color:var(--text2);transition:all .15s}
.tab.active{background:var(--bg2);color:var(--text)}
.err{color:var(--red);font-size:13px;margin-bottom:10px;display:none;padding:8px 12px;background:rgba(239,68,68,0.1);border-radius:8px}

/* ── LAYOUT ── */
#app{display:none}
.sidebar{position:fixed;left:0;top:0;bottom:0;width:220px;background:var(--bg2);border-right:1px solid var(--border);display:flex;flex-direction:column;z-index:10}
.sidebar-head{padding:1.25rem;border-bottom:1px solid var(--border)}
.sidebar-logo{font-size:18px;font-weight:700;color:var(--accent2)}
.sidebar-sub{font-size:11px;color:var(--text3);margin-top:2px}
.nav{flex:1;padding:.5rem 0;overflow-y:auto}
.nav-item{display:flex;align-items:center;gap:10px;padding:9px 1.25rem;cursor:pointer;color:var(--text2);font-size:13px;border-left:2px solid transparent;transition:all .12s;user-select:none}
.nav-item:hover{color:var(--text);background:var(--bg3)}
.nav-item.active{color:var(--text);border-left-color:var(--accent);background:rgba(108,99,255,.08)}
.nav-icon{width:18px;text-align:center;font-size:15px}
.nav-badge{margin-left:auto;background:var(--red);color:#fff;font-size:10px;padding:2px 6px;border-radius:10px;font-weight:600}
.sidebar-foot{padding:1rem 1.25rem;border-top:1px solid var(--border)}
.user-row{display:flex;align-items:center;gap:8px}
.avatar{width:30px;height:30px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;flex-shrink:0}
.user-info{overflow:hidden}
.user-name{font-size:13px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.user-role{font-size:11px;color:var(--text3)}
.btn-logout{margin-top:8px;width:100%;padding:7px;background:transparent;border:1px solid var(--border2);color:var(--text2);border-radius:7px;cursor:pointer;font-size:12px;transition:all .15s}
.btn-logout:hover{color:var(--text);background:var(--bg3)}
.main{margin-left:220px;padding:2rem;min-height:100vh}
.page{display:none}
.page.active{display:block}

/* ── TYPOGRAPHY ── */
.page-title{font-size:20px;font-weight:600;margin-bottom:3px}
.page-sub{color:var(--text2);font-size:13px;margin-bottom:1.5rem}
.section-label{font-size:11px;font-weight:600;color:var(--text2);text-transform:uppercase;letter-spacing:.07em;margin-bottom:10px}

/* ── COMPONENTS ── */
.topbar{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:1.5rem;gap:1rem}
.topbar-left .page-sub{margin-bottom:0}
.actions{display:flex;gap:8px;flex-shrink:0}

.btn{padding:8px 16px;border-radius:8px;cursor:pointer;font-size:13px;font-weight:500;border:none;transition:all .15s;display:inline-flex;align-items:center;gap:6px}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover{background:var(--accent2)}
.btn-ghost{background:transparent;border:1px solid var(--border2);color:var(--text)}
.btn-ghost:hover{background:var(--bg3)}
.btn-danger{background:rgba(239,68,68,.12);color:var(--red);border:1px solid rgba(239,68,68,.25)}
.btn-danger:hover{background:rgba(239,68,68,.2)}
.btn-sm{padding:5px 11px;font-size:12px;border-radius:7px;cursor:pointer;background:transparent;border:1px solid var(--border2);color:var(--text2);transition:all .15s}
.btn-sm:hover{color:var(--text);background:var(--bg3)}
.btn-sm.danger{color:var(--red);border-color:rgba(239,68,68,.3)}
.btn-sm.danger:hover{background:rgba(239,68,68,.1)}

.card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--rl);padding:1.25rem}
.card+.card{margin-top:10px}

.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:1.5rem}
.stat-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);padding:1rem}
.stat-label{font-size:12px;color:var(--text2);margin-bottom:6px}
.stat-value{font-size:22px;font-weight:600}
.stat-sub{font-size:11px;color:var(--text3);margin-top:3px}

.badge{display:inline-flex;align-items:center;font-size:11px;padding:2px 8px;border-radius:5px;font-weight:500;white-space:nowrap}
.badge.green{background:rgba(34,197,94,.15);color:var(--green)}
.badge.amber{background:rgba(245,158,11,.15);color:var(--amber)}
.badge.red{background:rgba(239,68,68,.15);color:var(--red)}
.badge.blue{background:rgba(59,130,246,.15);color:var(--blue)}
.badge.purple{background:rgba(108,99,255,.15);color:var(--accent2)}

.alert-banner{background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.25);border-radius:var(--r);padding:10px 14px;font-size:13px;color:#fca5a5;margin-bottom:1rem;display:flex;align-items:center;gap:8px}
.warn-banner{background:rgba(245,158,11,.1);border:1px solid rgba(245,158,11,.25);border-radius:var(--r);padding:10px 14px;font-size:13px;color:#fcd34d;margin-bottom:1rem;display:flex;align-items:center;gap:8px}

/* ── FORMS ── */
.field{margin-bottom:14px}
.field label{display:block;font-size:12px;color:var(--text2);margin-bottom:6px;font-weight:500}
input,select,textarea{width:100%;padding:9px 12px;background:var(--bg3);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:13px;outline:none;transition:border-color .15s;font-family:inherit}
input:focus,select:focus,textarea:focus{border-color:var(--accent)}
select option{background:var(--bg3)}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}

/* ── MODAL ── */
.modal-bg{display:none;position:fixed;inset:0;background:rgba(0,0,0,.65);z-index:100;align-items:center;justify-content:center;padding:1rem}
.modal-bg.open{display:flex}
.modal{background:var(--bg2);border:1px solid var(--border2);border-radius:var(--rl);padding:1.5rem;width:100%;max-width:460px;max-height:90vh;overflow-y:auto}
.modal h2{font-size:17px;font-weight:600;margin-bottom:4px}
.modal-desc{font-size:13px;color:var(--text2);margin-bottom:1.25rem}
.modal-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:1.25rem;padding-top:1rem;border-top:1px solid var(--border)}

/* ── SERVICES LIST ── */
.svc-list{display:flex;flex-direction:column;gap:10px}
.svc-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--rl);padding:1.25rem;transition:border-color .15s}
.svc-card.alert{border-color:rgba(239,68,68,.4)}
.svc-card.warn{border-color:rgba(245,158,11,.3)}
.svc-header{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.svc-icon{width:36px;height:36px;border-radius:9px;background:var(--bg3);display:flex;align-items:center;justify-content:center;font-size:17px;flex-shrink:0}
.svc-name{font-size:14px;font-weight:500}
.svc-plan{font-size:12px;color:var(--text2)}
.svc-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.sstat{background:var(--bg3);border-radius:8px;padding:10px 12px}
.sstat-label{font-size:11px;color:var(--text2);margin-bottom:4px}
.sstat-val{font-size:15px;font-weight:500}
.sstat-val.red{color:var(--red)}
.sstat-val.amber{color:var(--amber)}
.sstat-val.green{color:var(--green)}
.progress{height:3px;background:rgba(255,255,255,.08);border-radius:2px;margin-top:6px;overflow:hidden}
.pbar{height:100%;border-radius:2px;transition:width .5s}
.pbar.green{background:var(--green)}
.pbar.amber{background:var(--amber)}
.pbar.red{background:var(--red)}
.svc-footer{display:flex;align-items:center;justify-content:space-between;margin-top:12px;padding-top:12px;border-top:1px solid var(--border);font-size:12px;color:var(--text2)}

/* ── TABLE ── */
.table-wrap{overflow-x:auto}
table{width:100%;border-collapse:collapse;font-size:13px}
th{text-align:left;padding:8px 12px;color:var(--text2);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--border)}
td{padding:10px 12px;border-bottom:1px solid var(--border);vertical-align:middle}
tr:last-child td{border-bottom:none}
tr:hover td{background:rgba(255,255,255,.02)}
.mono{font-family:'SF Mono',Menlo,monospace;font-size:12px;color:var(--text2)}

/* ── LOG ITEMS ── */
.log-item{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--border);font-size:12px}
.log-item:last-child{border-bottom:none}
.log-time{color:var(--text3);white-space:nowrap;margin-left:auto}

/* ── TOKEN ── */
.token-box{display:flex;gap:8px;align-items:center}
.token-val{flex:1;font-family:'SF Mono',Menlo,monospace;font-size:12px;background:var(--bg3);border:1px solid var(--border);border-radius:7px;padding:8px 12px;color:var(--text2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* ── CHART ── */
.chart-wrap{position:relative;height:180px;margin-top:12px}

/* ── EMPTY ── */
.empty{text-align:center;padding:3rem 1rem;color:var(--text2)}
.empty-icon{font-size:36px;margin-bottom:12px}
.empty-title{font-size:15px;font-weight:500;color:var(--text);margin-bottom:6px}

/* ── BUDGET BAR ── */
.budget-item{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--border)}
.budget-item:last-child{border-bottom:none}
.budget-name{width:100px;font-size:13px;font-weight:500;flex-shrink:0}
.budget-bar-wrap{flex:1;height:6px;background:var(--bg4);border-radius:3px;overflow:hidden}
.budget-bar{height:100%;border-radius:3px;transition:width .4s}
.budget-nums{font-size:12px;color:var(--text2);white-space:nowrap;width:120px;text-align:right}

/* ── TOGGLE ── */
.toggle{position:relative;width:34px;height:20px;flex-shrink:0}
.toggle input{opacity:0;width:0;height:0}
.toggle-track{position:absolute;inset:0;background:var(--bg4);border-radius:10px;transition:.2s;cursor:pointer}
.toggle input:checked+.toggle-track{background:var(--accent)}
.toggle-thumb{position:absolute;top:2px;left:2px;width:16px;height:16px;background:#fff;border-radius:50%;transition:.2s;pointer-events:none}
.toggle input:checked~.toggle-thumb{transform:translateX(14px)}

/* ── GRID 2COL ── */
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}

/* ── LOADER ── */
.loader{display:inline-block;width:16px;height:16px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .6s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.loading{display:flex;align-items:center;gap:10px;color:var(--text2);font-size:13px;padding:2rem 0}
