.app,.sidebar,body{display:flex}.nav-item,.sidebar-logo{gap:10px;text-decoration:none}.logo-mark svg,.nav-item svg{width:16px;height:16px}.btn-sm,.nav-item,.sidebar-logo{text-decoration:none}#dlg-overlay.open,.modal-overlay.open{pointer-events:all;opacity:1}.bar,.btn-full,.btn-sm,.copy-btn,.dash-toggle,.dlg-key-copy,.nav-item,.session-item,.tab,.toggle,.user-pill{cursor:pointer}html{height:100%}body{font-size:14px;line-height:1.5;flex-direction:column;min-height:100vh}.app{height:100vh;overflow:hidden}.main,.sidebar{overflow-y:auto}.sidebar{width:240px;flex-shrink:0;background:var(--bg2);border-right:1px solid var(--border);flex-direction:column}.logo-mark,.sidebar-logo{align-items:center;display:flex}.sidebar-logo{padding:20px 20px 16px;border-bottom:1px solid var(--border)}.logo-mark{width:30px;height:30px;background:var(--accent);border-radius:7px;justify-content:center;flex-shrink:0}.logo-text{font-family:var(--font-display);font-size:18px;font-weight:700;color:var(--text)}.nav-badge,.sidebar-label{font-family:var(--font-mono)}.sidebar-section{padding:20px 12px 8px}.sidebar-label{font-size:10px;color:var(--text3);letter-spacing:.1em;text-transform:uppercase;padding:0 8px;margin-bottom:6px}.nav-item{display:flex;align-items:center;padding:9px 10px;border-radius:8px;color:var(--text2);font-size:13px;font-weight:400;border:none;background:0 0;width:100%;text-align:left;transition:background .15s,color .15s;margin-bottom:2px}#dlg-body,#dlg-title,.btn-full,.connected-state,.dlg-key-hint,.qr-area{text-align:center}.nav-item:hover{background:var(--surface);color:var(--text)}.nav-badge,.nav-item.active{background:var(--accent-dim);color:var(--accent)}.nav-item svg{flex-shrink:0;opacity:.7}.copy-btn svg,.toggle::after{width:14px;height:14px}.attention-banner,.user-pill{align-items:center;gap:10px;display:flex}.nav-item.active svg{opacity:1}.nav-badge{margin-left:auto;font-size:10px;padding:2px 7px;border-radius:100px}.avatar,.topbar-title{font-family:var(--font-display)}.nav-badge.attention{background:rgba(239,68,68,.15);color:#ef4444}.attention-banner{background:rgba(239,68,68,.08);border:1px solid rgba(239,68,68,.25);border-radius:10px;padding:12px 16px;margin-bottom:14px;font-size:13px;color:#fca5a5}.attention-banner svg{flex-shrink:0}.attention-banner.hidden{display:none}.sidebar-bottom{margin-top:auto;padding:16px 12px;border-top:1px solid var(--border)}.user-pill{padding:8px 10px;border-radius:8px;transition:background .15s}.user-pill:hover{background:var(--surface)}.avatar{width:30px;height:30px;border-radius:50%;background:var(--purple-dim);border:1px solid var(--purple);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:var(--purple);flex-shrink:0}.user-name{font-size:13px;font-weight:500;color:var(--text)}.user-plan{font-size:11px;color:var(--text3)}.main{flex:1;display:flex;flex-direction:column}.apikey-val,.card,.qr-frame{overflow:hidden}.topbar,.topbar-right{align-items:center;display:flex}.topbar{padding:0 32px;height:56px;border-bottom:1px solid var(--border);justify-content:space-between;background:var(--bg2);flex-shrink:0;position:sticky;top:0;z-index:10}.qr-frame,.toggle{position:relative}.topbar-title{font-size:16px;font-weight:600;color:var(--text)}.topbar-right{gap:12px}.btn-sm{padding:6px 14px;border-radius:7px;font-family:var(--font-body);font-size:13px;font-weight:500;transition:.15s;display:inline-flex;align-items:center;gap:6px}#dlg-body,#dlg-icon,#dlg-title,.page-hidden{display:none}.btn-outline{border:1px solid var(--border2);background:0 0;color:var(--text2)}.btn-accent,.dot-green{background:var(--accent)}.btn-outline:hover{border-color:var(--border3);color:var(--text)}.log-item:last-child,.session-item:last-child{border-bottom:none}.btn-accent{border:none;color:#000}.card-header,.session-item{border-bottom:1px solid var(--border)}.btn-accent:hover{background:var(--accent2)}.status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.dot-red{background:var(--red)}.dot-amber{background:var(--amber)}.card,.stat-card{background:var(--bg2)}.page{padding:28px 32px;flex:1}.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:24px}.stat-card{border:1px solid var(--border);border-radius:12px;padding:20px}.stat-label{font-size:11px;color:var(--text3);margin-bottom:8px;text-transform:uppercase;letter-spacing:.06em;font-family:var(--font-mono)}.grid-2,.grid-3{display:grid;gap:16px;margin-bottom:16px}#dlg-title,.card-title,.stat-val{font-family:var(--font-display)}.stat-val{font-size:28px;font-weight:800;color:var(--text);letter-spacing:-1px;line-height:1}.dlg-key-val,.log-text,.qr-hint{line-height:1.5}.stat-sub{font-size:12px;color:var(--text3);margin-top:6px}.copy-btn:hover,.stat-up{color:var(--accent)}.stat-down{color:var(--red)}.grid-2{grid-template-columns:1fr 1fr}.grid-3{grid-template-columns:2fr 1fr}.card{border:1px solid var(--border);border-radius:14px}#dlg-box,.session-msgs{background:var(--surface)}.card-header{padding:16px 20px;display:flex;align-items:center;justify-content:space-between}.session-icon,.session-item{align-items:center;display:flex}.card-title{font-size:14px;font-weight:600;color:var(--text)}.apikey-row,.chart-label,.connected-num,.input-field,.log-time,.qr-expire,.session-msgs,.session-num{font-family:var(--font-mono)}.qr-title,.session-name,.tab{font-weight:500}.card-sub{font-size:12px;color:var(--text3)}.card-body{padding:20px}.session-item{gap:14px;padding:14px 20px;transition:background .15s}.session-item:hover{background:var(--bg3)}.session-icon{width:38px;height:38px;border-radius:10px;justify-content:center;flex-shrink:0}.session-name{font-size:13px;color:var(--text);margin-bottom:2px}.session-num{font-size:11px;color:var(--text3)}.session-status{margin-left:auto;display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text2)}.session-msgs{font-size:11px;color:var(--text3);padding:3px 8px;border-radius:100px}.qr-area{display:flex;flex-direction:column;align-items:center;padding:28px 20px}.qr-frame{width:180px;height:180px;border:2px solid var(--border2);border-radius:14px;background:#fff;display:flex;align-items:center;justify-content:center;margin-bottom:16px}.qr-placeholder{display:flex;flex-direction:column;align-items:center;gap:8px;padding:20px}.qr-grid{display:grid;grid-template-columns:repeat(9,14px);grid-template-rows:repeat(9,14px);gap:1px}.qr-cell{border-radius:1px}.qr-title{font-size:13px;color:var(--text);margin-bottom:4px}.qr-hint{font-size:12px;color:var(--text3);max-width:200px}.qr-expire{font-size:11px;color:var(--amber);margin-top:12px}.apikey-row,.key-meta-item span{color:var(--text2)}.apikey-row{display:flex;align-items:center;gap:10px;background:var(--bg3);border:1px solid var(--border);border-radius:8px;padding:10px 14px;font-size:13px;margin-bottom:12px}.chart-label,.copy-btn,.key-meta-item{color:var(--text3)}.apikey-val{flex:1;text-overflow:ellipsis;white-space:nowrap}.copy-btn{background:0 0;border:none;padding:2px;transition:color .15s;flex-shrink:0}.bar-sent,.toggle.on{background:var(--accent)}.key-meta{display:flex;gap:16px}.key-meta-item{font-size:11px}.chart-area{height:160px;padding:16px 20px;display:flex;align-items:flex-end;gap:6px}.chart-footer,.chart-legend{display:flex;padding:0 20px 14px}.bar-group{flex:1;display:flex;align-items:flex-end;gap:2px}.bar{flex:1;border-radius:3px 3px 0 0;transition:opacity .15s;min-height:4px}.bar:hover{opacity:.8}.bar-recv{background:var(--purple)}.chart-footer{justify-content:space-between}.chart-label{font-size:10px}.chart-legend{align-items:center;gap:16px}.legend-item,.log-icon{display:flex;align-items:center}.legend-item{gap:6px;font-size:12px;color:var(--text2)}.legend-dot{width:8px;height:8px;border-radius:50%}.log-item{display:flex;align-items:flex-start;gap:12px;padding:10px 20px;border-bottom:1px solid var(--border);font-size:12px}.log-icon{width:24px;height:24px;border-radius:6px;justify-content:center;flex-shrink:0;margin-top:1px}.log-icon svg{width:12px;height:12px}.log-text{color:var(--text2)}.log-text strong{color:var(--text);font-weight:500}.log-time{margin-left:auto;font-size:10px;color:var(--text3);white-space:nowrap;padding-top:2px}.input-row{margin-bottom:14px}.input-label{font-size:12px;color:var(--text2);margin-bottom:6px;display:block}#dlg-icon.show,#dlg-overlay,.connected-icon,.dlg-key-row,.tabs,.toggle-row{display:flex}.input-field{width:100%;background:var(--bg3);border:1px solid var(--border2);border-radius:8px;padding:9px 12px;font-size:12px;color:var(--text);outline:0;transition:border-color .15s}.input-field:focus{border-color:var(--accent)}.input-field::placeholder{color:var(--text3)}.toggle-row{align-items:center;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--border)}.toggle-row:last-child{border-bottom:none}.toggle-label{font-size:13px;color:var(--text)}.toggle-desc{font-size:11px;color:var(--text3);margin-top:2px}.toggle{width:36px;height:20px;border-radius:100px;background:var(--surface2);border:none;transition:background .2s;flex-shrink:0}.toggle::after{content:'';position:absolute;top:3px;left:3px;border-radius:50%;background:#fff;transition:transform .2s}.toggle.on::after{transform:translateX(16px)}.connected-state{display:flex;flex-direction:column;align-items:center;padding:28px 20px}.connected-icon{width:56px;height:56px;border-radius:14px;background:var(--accent-dim);align-items:center;justify-content:center;margin-bottom:14px}.connected-icon svg{width:28px;height:28px}.connected-num{font-size:13px;color:var(--text2);margin-bottom:4px}#dlg-body,.tabs{margin-bottom:20px}.connected-since{font-size:11px;color:var(--text3)}.tabs{gap:2px;padding:4px;background:var(--bg3);border-radius:9px}.tab{flex:1;padding:7px 12px;border-radius:7px;font-size:12px;color:var(--text3);border:none;background:0 0;transition:.15s;font-family:var(--font-body)}.tab.active{background:var(--surface2);color:var(--text)}#dlg-overlay{position:fixed;inset:0;background:rgba(0,0,0,.65);backdrop-filter:blur(4px);align-items:center;justify-content:center;z-index:9000;opacity:0;pointer-events:none;transition:opacity .18s}#dlg-box{border:1px solid var(--border2);border-radius:16px;padding:28px 24px 22px;width:360px;max-width:calc(100vw - 40px);transform:translateY(10px) scale(.98);transition:transform .18s}#dlg-overlay.open #dlg-box{transform:none}#dlg-icon{width:44px;height:44px;border-radius:50%;margin:0 auto 14px;align-items:center;justify-content:center}#dlg-body.show,#dlg-title.show{display:block}#dlg-icon.error{background:rgba(239,68,68,.12)}#dlg-icon.warn{background:rgba(251,191,36,.12)}#dlg-icon.info{background:rgba(96,165,250,.12)}#dlg-title{font-size:16px;font-weight:700;color:var(--text);margin-bottom:8px}#dlg-body{font-size:13px;color:var(--text2);line-height:1.6}.dlg-key-row{align-items:center;gap:10px;background:var(--bg3);border:1px solid var(--border);border-radius:10px;padding:12px 14px;margin-bottom:8px}.copied-toast,.dlg-key-copy{border:1px solid var(--border2)}.dlg-key-val{flex:1;font-family:var(--font-mono);font-size:12px;color:var(--accent);word-break:break-all}.dlg-key-copy{background:0 0;border-radius:6px;color:var(--text3);padding:5px 7px;flex-shrink:0;transition:color .15s,border-color .15s;line-height:0}.copied-toast,.modal-overlay{position:fixed;align-items:center;opacity:0;pointer-events:none;display:flex}.dlg-key-copy:hover{color:var(--accent);border-color:var(--accent)}.skel-log-row:last-child,.skel-session-row:last-child{border-bottom:none}.dlg-key-hint{font-size:11px;color:var(--text3);margin-bottom:16px}#dlg-footer{display:flex;gap:10px;margin-top:8px}#dlg-footer .btn-full{padding:10px}.copied-toast{bottom:24px;right:24px;background:var(--surface2);border-radius:8px;padding:10px 16px;font-size:13px;color:var(--text);gap:8px;transform:translateY(8px);transition:.2s;z-index:1000}.copied-toast.show{opacity:1;transform:translateY(0)}.copied-toast svg{width:14px;height:14px;color:var(--accent)}.modal-overlay{inset:0;background:rgba(0,0,0,.7);justify-content:center;z-index:200;transition:opacity .2s}.modal{background:var(--bg2);border:1px solid var(--border2);border-radius:16px;width:420px;max-width:90vw;padding:28px;animation:.2s modalIn}.skel-log-row,.skel-session-row{border-bottom:1px solid var(--border)}@keyframes modalIn{from{transform:scale(.96) translateY(8px)}to{transform:scale(1) translateY(0)}}.modal-title{font-family:var(--font-display);font-size:18px;font-weight:700;margin-bottom:6px}.modal-step,.modal-sub{font-size:13px;color:var(--text2)}.modal-sub{margin-bottom:24px;line-height:1.5}.modal-qr{width:160px;height:160px;background:#fff;border-radius:12px;margin:0 auto 16px;display:flex;align-items:center;justify-content:center}.step-badge,.step-num-circle{background:var(--accent-dim)}.modal-step{display:flex;align-items:flex-start;gap:10px;margin-bottom:10px}.step-num-circle{width:20px;height:20px;border-radius:50%;color:var(--accent);font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px;font-family:var(--font-mono)}.modal-footer{display:flex;gap:10px;margin-top:24px}.btn-full{flex:1;padding:10px;border-radius:8px;font-family:var(--font-body);font-size:14px;font-weight:500}.modal-step-row,.step-badge{display:flex;align-items:center}.modal-step-row{gap:12px;padding:12px 16px;font-size:13px;color:var(--text2);line-height:1.4}.modal-step-row:first-child{border-radius:12px 12px 0 0}.modal-step-row:last-child{border-radius:0 0 12px 12px}.step-badge{width:22px;height:22px;border-radius:50%;color:var(--accent);font-size:10px;font-weight:700;justify-content:center;flex-shrink:0;font-family:var(--font-mono)}@media(max-width:992px){.sidebar{position:fixed;top:0;left:0;bottom:0;z-index:200;transform:translateX(-100%);transition:transform .3s cubic-bezier(.4,0,.2,1);width:280px}.sidebar.open{transform:translateX(0)}.sidebar-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:190;display:none}.sidebar-overlay.show{display:block}.topbar{padding:0 16px}.dash-toggle{display:flex!important}.page{padding:16px}.stats-row{grid-template-columns:repeat(2,1fr)}.grid-2,.grid-3{grid-template-columns:1fr}}@keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}.skel{display:block;border-radius:6px;background:linear-gradient(90deg,var(--surface) 25%,var(--surface2) 50%,var(--surface) 75%);background-size:200% 100%;animation:1.5s infinite shimmer}.stat-val .skel{height:32px;width:60%;margin-bottom:2px}.stat-sub .skel{height:12px;width:40%}.skel-session-row{display:flex;align-items:center;gap:12px;padding:14px 20px}.skel-avatar{width:38px;height:38px;border-radius:10px;flex-shrink:0}.skel-lines{flex:1;display:flex;flex-direction:column}.skel-log-row{display:flex;align-items:center;gap:12px;padding:12px 20px}.skel-icon{width:28px;height:28px;border-radius:8px;flex-shrink:0}@media(max-width:640px){.stats-row{grid-template-columns:repeat(2,1fr)}.stat-val{font-size:22px}.topbar-right .btn-sm:not(.btn-accent){display:none}}@media(max-width:480px){.stats-row{grid-template-columns:1fr}.page{padding:12px}}.dash-toggle{display:none;background:0 0;border:none;width:32px;height:32px;flex-direction:column;justify-content:center;gap:5px;padding:4px;color:var(--text);margin-right:12px}.dash-toggle span{display:block;width:100%;height:2px;background:var(--text)}