:root{--bg-base: #070a09;--bg-sunken: #050706;--surface-1: #0e1311;--surface-2: #131a17;--surface-3: #1a2420;--surface-hover: #1f2a25;--line: #1e2926;--line-strong: #2c3a35;--line-faint: #161e1b;--text: #e8efea;--text-soft: #a7b5ad;--text-dim: #6c7a72;--text-faint: #495450;--accent: #25d366;--accent-strong: #1ebe5a;--accent-soft: rgba(37, 211, 102, .12);--accent-line: rgba(37, 211, 102, .32);--accent-glow: rgba(37, 211, 102, .25);--success: #34d399;--success-soft: rgba(52, 211, 153, .12);--info: #38bdf8;--info-soft: rgba(56, 189, 248, .12);--warning: #fbbf24;--warning-soft: rgba(251, 191, 36, .12);--danger: #f87171;--danger-soft: rgba(248, 113, 113, .12);--neutral: #8b9a92;--neutral-soft: rgba(139, 154, 146, .12);--font-sans: "Inter", system-ui, -apple-system, sans-serif;--font-mono: "JetBrains Mono", ui-monospace, "Cascadia Code", monospace;--text-xs: .72rem;--text-sm: .82rem;--text-base: .92rem;--text-lg: 1.05rem;--text-xl: 1.35rem;--text-2xl: 1.85rem;--text-3xl: 2.6rem;--text-display: clamp(2.4rem, 1.2rem + 4vw, 3.6rem);--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.5rem;--space-6: 2rem;--space-8: 3rem;--radius-sm: 7px;--radius: 12px;--radius-lg: 18px;--radius-full: 999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .4);--shadow: 0 8px 24px -8px rgba(0, 0, 0, .6);--shadow-lg: 0 24px 60px -16px rgba(0, 0, 0, .75);--shadow-glow: 0 0 0 1px var(--accent-line), 0 8px 30px -6px var(--accent-glow);--ease: cubic-bezier(.16, 1, .3, 1);--dur-fast: .13s;--dur: .22s;--sidebar-w: 248px;--topbar-h: 60px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{font-family:var(--font-sans);font-size:var(--text-base);line-height:1.5;color:var(--text);background:var(--bg-base);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0;background:radial-gradient(900px 500px at 78% -8%,rgba(37,211,102,.07),transparent 60%),radial-gradient(700px 600px at 12% 110%,rgba(56,189,248,.05),transparent 55%)}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit;color:inherit}::selection{background:var(--accent-glow);color:#fff}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--line-strong);border-radius:999px;border:2px solid var(--bg-base)}::-webkit-scrollbar-thumb:hover{background:#3a4a44}.mono{font-family:var(--font-mono);font-feature-settings:"tnum" 1}.row{display:flex;align-items:center;gap:var(--space-3)}.row-between{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3)}.col{display:flex;flex-direction:column}.wrap{flex-wrap:wrap}.gap-2{gap:var(--space-2)}.gap-4{gap:var(--space-4)}.gap-5{gap:var(--space-5)}.grow{flex:1}.muted{color:var(--text-dim)}.soft{color:var(--text-soft)}.text-sm{font-size:var(--text-sm)}.text-xs{font-size:var(--text-xs)}.center{text-align:center}.spread{width:100%}.shell{display:grid;grid-template-columns:var(--sidebar-w) 1fr;min-height:100vh;position:relative;z-index:1}.sidebar{position:sticky;top:0;height:100vh;display:flex;flex-direction:column;background:linear-gradient(180deg,var(--surface-1),var(--bg-sunken));border-right:1px solid var(--line);padding:var(--space-4);gap:var(--space-2);overflow-y:auto}.brand{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-2) var(--space-5)}.brand-mark{width:38px;height:38px;border-radius:11px;display:grid;place-items:center;background:radial-gradient(circle at 30% 25%,var(--accent),var(--accent-strong));box-shadow:0 6px 18px -4px var(--accent-glow);color:#04130a;font-weight:800;font-size:1.1rem}.brand-name{font-weight:700;letter-spacing:-.02em;font-size:var(--text-lg);line-height:1.1}.brand-sub{font-size:var(--text-xs);color:var(--text-dim);letter-spacing:.08em;text-transform:uppercase}.nav-group-label{font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:var(--text-faint);padding:var(--space-4) var(--space-3) var(--space-2);font-weight:600}.nav-item{display:flex;align-items:center;gap:var(--space-3);padding:.6rem .75rem;border-radius:var(--radius-sm);color:var(--text-soft);font-size:var(--text-sm);font-weight:500;transition:background var(--dur-fast),color var(--dur-fast);position:relative}.nav-item:hover{background:var(--surface-2);color:var(--text)}.nav-item.active{background:var(--accent-soft);color:var(--accent)}.nav-item.active:before{content:"";position:absolute;left:-4px;top:20%;bottom:20%;width:3px;border-radius:999px;background:var(--accent)}.nav-icon{width:18px;height:18px;flex-shrink:0;stroke-width:1.8}.nav-badge{margin-left:auto;font-size:.66rem;font-weight:700;background:var(--danger);color:#1a0606;padding:1px 7px;border-radius:999px;font-family:var(--font-mono)}.main{display:flex;flex-direction:column;min-width:0}.topbar{height:var(--topbar-h);position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);padding:0 var(--space-6);background:#070a09b8;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}.page-title{font-size:var(--text-lg);font-weight:600;letter-spacing:-.01em}.content{padding:var(--space-6);max-width:1480px;width:100%;margin:0 auto;flex:1}.conn-pill{display:inline-flex;align-items:center;gap:var(--space-2);font-size:var(--text-xs);color:var(--text-soft);padding:4px 10px;border-radius:999px;border:1px solid var(--line);background:var(--surface-1)}.dot{width:8px;height:8px;border-radius:999px;background:var(--neutral)}.dot.live{background:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);animation:pulse 2s var(--ease) infinite}@keyframes pulse{0%,to{box-shadow:0 0 0 3px var(--accent-soft)}50%{box-shadow:0 0 0 6px transparent}}.user-chip{display:flex;align-items:center;gap:var(--space-3)}.avatar{width:34px;height:34px;border-radius:999px;display:grid;place-items:center;background:var(--surface-3);border:1px solid var(--line-strong);font-weight:700;font-size:var(--text-sm);color:var(--accent)}.card{background:var(--surface-1);border:1px solid var(--line);border-radius:var(--radius-lg);padding:var(--space-5)}.card.pad-0{padding:0}.card-head{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);margin-bottom:var(--space-4)}.card-title{font-size:var(--text-base);font-weight:600}.card-sub{font-size:var(--text-xs);color:var(--text-dim)}.grid{display:grid;gap:var(--space-5)}.grid-stats{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.span-2{grid-column:span 2}@media (max-width: 880px){.grid-2,.span-2{grid-template-columns:1fr;grid-column:auto}}.stat{background:linear-gradient(165deg,var(--surface-2),var(--surface-1));border:1px solid var(--line);border-radius:var(--radius-lg);padding:var(--space-5);display:flex;flex-direction:column;gap:var(--space-2);position:relative;overflow:hidden;transition:border-color var(--dur),transform var(--dur)}.stat:hover{border-color:var(--line-strong);transform:translateY(-2px)}.stat-label{font-size:var(--text-xs);color:var(--text-dim);text-transform:uppercase;letter-spacing:.06em;font-weight:600}.stat-value{font-size:var(--text-3xl);font-weight:700;letter-spacing:-.03em;font-family:var(--font-mono);line-height:1}.stat-foot{font-size:var(--text-xs);color:var(--text-dim)}.stat-accent{color:var(--accent)}.stat-icon{position:absolute;right:var(--space-4);top:var(--space-4);opacity:.18;width:40px;height:40px}.badge{display:inline-flex;align-items:center;gap:6px;font-size:var(--text-xs);font-weight:600;padding:3px 10px;border-radius:999px;border:1px solid transparent;white-space:nowrap}.badge:before{content:"";width:6px;height:6px;border-radius:999px;background:currentColor}.badge.no-dot:before{display:none}.tone-success{color:var(--success);background:var(--success-soft);border-color:#34d39933}.tone-info{color:var(--info);background:var(--info-soft);border-color:#38bdf833}.tone-warning{color:var(--warning);background:var(--warning-soft);border-color:#fbbf2433}.tone-danger{color:var(--danger);background:var(--danger-soft);border-color:#f8717133}.tone-neutral{color:var(--neutral);background:var(--neutral-soft);border-color:#8b9a9233}.tone-accent{color:var(--accent);background:var(--accent-soft);border-color:var(--accent-line)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:.55rem 1rem;border-radius:var(--radius-sm);border:1px solid var(--line-strong);background:var(--surface-2);color:var(--text);font-size:var(--text-sm);font-weight:600;cursor:pointer;transition:all var(--dur-fast);white-space:nowrap;-webkit-user-select:none;user-select:none}.btn:hover{background:var(--surface-hover);border-color:var(--line-strong)}.btn:active{transform:translateY(1px)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn svg{width:16px;height:16px}.btn-primary{background:linear-gradient(180deg,var(--accent),var(--accent-strong));border-color:transparent;color:#04130a;box-shadow:0 6px 18px -6px var(--accent-glow)}.btn-primary:hover{background:linear-gradient(180deg,#2ee070,var(--accent))}.btn-danger{color:var(--danger);border-color:#f871714d;background:var(--danger-soft)}.btn-danger:hover{background:#f8717133}.btn-ghost{background:transparent;border-color:transparent}.btn-ghost:hover{background:var(--surface-2)}.btn-sm{padding:.35rem .65rem;font-size:var(--text-xs)}.btn-icon{padding:.45rem}.btn-block{width:100%}.field{display:flex;flex-direction:column;gap:var(--space-2)}.label{font-size:var(--text-xs);font-weight:600;color:var(--text-soft);letter-spacing:.02em}.input,.select,.textarea{width:100%;background:var(--bg-sunken);border:1px solid var(--line-strong);border-radius:var(--radius-sm);padding:.6rem .8rem;font-size:var(--text-sm);transition:border-color var(--dur-fast),box-shadow var(--dur-fast)}.input:focus,.select:focus,.textarea:focus{outline:none;border-color:var(--accent-line);box-shadow:0 0 0 3px var(--accent-soft)}.input::placeholder,.textarea::placeholder{color:var(--text-faint)}.textarea{resize:vertical;min-height:92px;font-family:var(--font-mono)}.input-error{border-color:#f8717180}.hint{font-size:var(--text-xs);color:var(--text-dim)}.error-text{font-size:var(--text-xs);color:var(--danger)}.table-wrap{overflow-x:auto;border-radius:var(--radius-lg);border:1px solid var(--line)}table.tbl{width:100%;border-collapse:collapse;font-size:var(--text-sm)}.tbl thead th{text-align:left;font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.06em;color:var(--text-dim);font-weight:600;padding:var(--space-3) var(--space-4);background:var(--surface-1);border-bottom:1px solid var(--line);position:sticky;top:0}.tbl tbody td{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--line-faint);vertical-align:middle}.tbl tbody tr{background:var(--surface-1);transition:background var(--dur-fast)}.tbl tbody tr:hover{background:var(--surface-2)}.tbl tbody tr:last-child td{border-bottom:none}.tbl .num{font-family:var(--font-mono);text-align:right}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;background:#030504b3;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:grid;place-items:center;padding:var(--space-5);animation:fade var(--dur) var(--ease)}@keyframes fade{0%{opacity:0}}.modal{width:100%;max-width:520px;background:var(--surface-1);border:1px solid var(--line-strong);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);max-height:90vh;overflow-y:auto;animation:rise var(--dur) var(--ease)}.modal.wide{max-width:760px}@keyframes rise{0%{opacity:0;transform:translateY(12px) scale(.98)}}.modal-head{display:flex;align-items:center;justify-content:space-between;padding:var(--space-5);border-bottom:1px solid var(--line)}.modal-title{font-size:var(--text-lg);font-weight:600}.modal-body{padding:var(--space-5);display:flex;flex-direction:column;gap:var(--space-4)}.modal-foot{padding:var(--space-4) var(--space-5);border-top:1px solid var(--line);display:flex;justify-content:flex-end;gap:var(--space-3)}.toast-stack{position:fixed;bottom:var(--space-5);right:var(--space-5);z-index:200;display:flex;flex-direction:column;gap:var(--space-3);max-width:360px}.toast{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-4);background:var(--surface-3);border:1px solid var(--line-strong);border-left-width:3px;border-radius:var(--radius);box-shadow:var(--shadow-lg);animation:rise var(--dur) var(--ease);font-size:var(--text-sm)}.toast.t-success{border-left-color:var(--success)}.toast.t-error{border-left-color:var(--danger)}.toast.t-info{border-left-color:var(--info)}.tabs{display:flex;gap:var(--space-1);border-bottom:1px solid var(--line);margin-bottom:var(--space-5);overflow-x:auto}.tab{padding:.6rem .9rem;font-size:var(--text-sm);font-weight:600;color:var(--text-dim);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;white-space:nowrap;transition:color var(--dur-fast)}.tab:hover{color:var(--text-soft)}.tab.active{color:var(--accent);border-bottom-color:var(--accent)}.empty{display:flex;flex-direction:column;align-items:center;gap:var(--space-3);padding:var(--space-8) var(--space-5);text-align:center;color:var(--text-dim)}.empty svg{width:40px;height:40px;opacity:.4}.empty-title{color:var(--text-soft);font-weight:600}.spinner{width:18px;height:18px;border:2px solid var(--line-strong);border-top-color:var(--accent);border-radius:999px;animation:spin .7s linear infinite}.spinner.lg{width:32px;height:32px;border-width:3px}@keyframes spin{to{transform:rotate(360deg)}}.loading-wrap{display:grid;place-items:center;min-height:50vh}.skel{background:linear-gradient(90deg,var(--surface-1),var(--surface-2),var(--surface-1));background-size:200% 100%;animation:shimmer 1.4s ease infinite;border-radius:var(--radius-sm)}@keyframes shimmer{to{background-position:-200% 0}}.qr-frame{background:#fff;padding:var(--space-4);border-radius:var(--radius);width:264px;height:264px;display:grid;place-items:center;margin:0 auto;box-shadow:var(--shadow)}.qr-frame img,.qr-frame canvas{width:100%;height:100%}.qr-waiting{width:264px;height:264px;margin:0 auto;display:grid;place-items:center;border:1px dashed var(--line-strong);border-radius:var(--radius);gap:var(--space-3)}.pairing-code{font-family:var(--font-mono);font-size:var(--text-2xl);letter-spacing:.3em;font-weight:700;color:var(--accent);text-align:center;padding:var(--space-4);background:var(--bg-sunken);border:1px dashed var(--accent-line);border-radius:var(--radius)}.console{background:var(--bg-sunken);border:1px solid var(--line);border-radius:var(--radius);font-family:var(--font-mono);font-size:var(--text-xs);line-height:1.7;padding:var(--space-4);height:62vh;overflow-y:auto}.log-line{display:flex;gap:var(--space-3);padding:1px 0;white-space:pre-wrap;word-break:break-word}.log-time{color:var(--text-faint);flex-shrink:0}.log-lvl{flex-shrink:0;width:48px;font-weight:700}.log-mod{color:var(--info);flex-shrink:0}.lvl-INFO{color:var(--success)}.lvl-WARN{color:var(--warning)}.lvl-ERROR,.lvl-FATAL{color:var(--danger)}.lvl-DEBUG,.lvl-TRACE{color:var(--text-dim)}.bubble{max-width:72%;padding:.5rem .8rem;border-radius:var(--radius);font-size:var(--text-sm);margin-bottom:var(--space-2);width:fit-content}.bubble.out{background:var(--accent-soft);border:1px solid var(--accent-line);margin-left:auto;border-bottom-right-radius:4px}.bubble.in{background:var(--surface-2);border:1px solid var(--line);border-bottom-left-radius:4px}.bubble-meta{font-size:.65rem;color:var(--text-faint);margin-top:2px}.divider{height:1px;background:var(--line);margin:var(--space-4) 0}.kpi-bar{height:6px;border-radius:999px;background:var(--surface-3);overflow:hidden}.kpi-bar>span{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,var(--accent),var(--success));transition:width var(--dur) var(--ease)}.chip{font-size:var(--text-xs);padding:3px 9px;border-radius:999px;background:var(--surface-2);border:1px solid var(--line);color:var(--text-soft);cursor:pointer;transition:all var(--dur-fast)}.chip:hover{border-color:var(--line-strong)}.chip.active{background:var(--accent-soft);border-color:var(--accent-line);color:var(--accent)}.page-head{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-4);margin-bottom:var(--space-6);flex-wrap:wrap}.page-head h1{font-size:var(--text-2xl);font-weight:700;letter-spacing:-.02em}.page-head p{color:var(--text-dim);font-size:var(--text-sm);margin-top:2px}.toolbar{display:flex;gap:var(--space-3);align-items:center;flex-wrap:wrap}.login-screen{position:relative;z-index:1;min-height:100vh;display:grid;grid-template-columns:1.1fr 1fr}.login-aside{padding:clamp(2rem,5vw,5rem);display:flex;flex-direction:column;justify-content:center;gap:var(--space-5);background:linear-gradient(160deg,var(--surface-1),var(--bg-sunken));border-right:1px solid var(--line)}.login-headline{font-size:var(--text-display);font-weight:800;line-height:1.02;letter-spacing:-.03em}.accent-grad{background:linear-gradient(120deg,var(--accent),var(--info));-webkit-background-clip:text;background-clip:text;color:transparent}.login-lede{color:var(--text-soft);max-width:46ch;font-size:var(--text-lg)}.login-points{list-style:none;display:flex;flex-direction:column;gap:var(--space-3);margin-top:var(--space-2)}.login-points li{display:flex;align-items:center;gap:var(--space-3);color:var(--text-soft);font-size:var(--text-sm)}.login-panel{display:grid;place-items:center;padding:var(--space-6)}.login-card{width:100%;max-width:380px;display:flex;flex-direction:column;gap:var(--space-4);background:var(--surface-1);border:1px solid var(--line-strong);border-radius:var(--radius-lg);padding:var(--space-6);box-shadow:var(--shadow-lg)}@media (max-width: 860px){.login-screen{grid-template-columns:1fr}.login-aside{display:none}}@media (max-width: 760px){.shell{grid-template-columns:1fr}.sidebar{position:static;height:auto;flex-direction:row;overflow-x:auto;align-items:center;border-right:none;border-bottom:1px solid var(--line)}.nav-group-label,.brand-sub,.nav-item span{display:none}.content{padding:var(--space-4)}.grid-stats{grid-template-columns:repeat(2,1fr)}}.media-drop{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);text-align:center;padding:var(--space-6) var(--space-4);border:1.5px dashed var(--line-strong);border-radius:var(--radius);color:var(--text-dim);transition:border-color .2s,background .2s}.media-drop:hover{border-color:var(--accent);background:var(--surface-2)}.media-drop p{margin:0}.media-section{margin-top:var(--space-4)}.media-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(96px,1fr));gap:var(--space-3)}.media-item{position:relative;aspect-ratio:1}.media-thumb{width:100%;height:100%;object-fit:cover;border-radius:var(--radius-sm);border:1px solid var(--line);background:var(--surface-2);display:block}.media-thumb--ph{background:var(--surface-3);animation:pulse 1.4s ease-in-out infinite}.media-thumb--file{display:flex;align-items:center;justify-content:center;font-size:1.8rem}.media-del{position:absolute;top:4px;right:4px;display:grid;place-items:center;width:26px;height:26px;border:none;border-radius:var(--radius-sm);background:#0000008c;color:#fff;cursor:pointer;opacity:0;transition:opacity .15s}.media-item:hover .media-del{opacity:1}.media-del:hover{background:var(--danger)}@keyframes pulse{0%,to{opacity:.5}50%{opacity:.9}}
