:root{--bg-primary: #0f1117;--bg-secondary: #1a1d27;--bg-tertiary: #242836;--bg-input: #1e2130;--text-primary: #e4e6eb;--text-secondary: #9ca3af;--text-muted: #6b7280;--accent: #6366f1;--accent-hover: #818cf8;--border: #2d3141;--success: #10b981;--warning: #f59e0b;--error: #ef4444;--confidence-exact: #10b981;--confidence-estimated: #f59e0b;--confidence-unavailable: #6b7280;font-family:Inter,system-ui,-apple-system,sans-serif;line-height:1.5;font-weight:400;color:var(--text-primary);background-color:var(--bg-primary);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{margin:0;padding:0;box-sizing:border-box}body{margin:0;min-height:100vh}#root{min-height:100vh;display:flex}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}:root{--hub-bg: #0B1215;--hub-bg2: #393E5B;--hub-bg3: #4B5477;--hub-text: #fafafa;--hub-muted: #9B9E9F;--hub-accent: #47A3FF;--hub-accent2: #00B39E;--hub-sep: #76797B}.login-root{position:relative;min-height:100vh;width:100%;display:flex;align-items:center;justify-content:center;background:var(--hub-bg);overflow:hidden}.login-glow{position:absolute;border-radius:50%;filter:blur(120px);pointer-events:none;opacity:.18}.login-glow--blue{width:600px;height:600px;background:var(--hub-accent);top:-200px;left:-150px}.login-glow--teal{width:500px;height:500px;background:var(--hub-accent2);bottom:-180px;right:-120px}.login-content{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;text-align:center;gap:0;padding:0 24px;max-width:360px;width:100%}.login-mark{margin-bottom:24px}.login-wordmark{display:flex;flex-direction:column;align-items:center;margin-bottom:12px;line-height:1;font-family:system-ui,-apple-system,sans-serif}.login-wordmark-hub{font-size:42px;font-weight:700;color:var(--hub-text);letter-spacing:-1px}.login-wordmark-product{font-size:13px;font-weight:500;color:var(--hub-accent);letter-spacing:3px;text-transform:uppercase;margin-top:4px}.login-tagline{font-size:14px;color:var(--hub-muted);line-height:1.6;margin-bottom:36px;margin-top:4px;max-width:260px}.login-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:13px 24px;border-radius:10px;border:none;background:var(--hub-accent);color:#fff;font-size:15px;font-weight:600;font-family:inherit;cursor:pointer;transition:opacity .15s,transform .15s;letter-spacing:.01em}.login-btn:hover:not(:disabled){opacity:.88;transform:translateY(-1px)}.login-btn:active:not(:disabled){transform:translateY(0);opacity:1}.login-btn:disabled{opacity:.5;cursor:not-allowed}.login-btn-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:login-spin .7s linear infinite;display:inline-block}@keyframes login-spin{to{transform:rotate(360deg)}}.login-footer{margin-top:24px;font-size:11px;color:var(--hub-sep);letter-spacing:.03em}.login-content:before{content:"";position:absolute;top:-40px;left:50%;transform:translate(-50%);width:1px;height:80px;background:linear-gradient(to bottom,transparent,var(--hub-sep),transparent);opacity:.4}.ds-view{padding:32px 40px;max-width:800px;margin:0 auto;color:var(--text-primary)}.ds-header{margin-bottom:28px}.ds-header-row{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:0}.ds-header h2{font-size:22px;font-weight:600;margin-bottom:6px;color:var(--text-primary)}.ds-header p{font-size:14px;color:var(--text-secondary);margin:0}.ds-test-btn{flex-shrink:0;padding:7px 14px;font-size:13px;font-weight:500;font-family:inherit;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:8px;color:var(--text-secondary);cursor:pointer;transition:all .15s;white-space:nowrap}.ds-test-btn:hover:not(:disabled){border-color:var(--accent);color:var(--text-primary)}.ds-test-btn--running,.ds-test-btn:disabled{opacity:.5;cursor:not-allowed}.ds-error{margin-top:10px;padding:8px 12px;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:6px;font-size:13px;color:#ef4444}.ds-list{display:flex;flex-direction:column;gap:12px}.ds-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;padding:18px 20px;transition:border-color .15s}.ds-card--connected{border-left:3px solid #10b981}.ds-card--phase2{border-left:3px solid #6366f1;opacity:.9}.ds-card--not-connected{border-left:3px solid #374151;opacity:.6}.ds-card-title-row{display:flex;align-items:center;gap:10px;margin-bottom:6px;flex-wrap:wrap}.ds-name{font-size:15px;font-weight:600;color:var(--text-primary)}.ds-type{font-size:11px;color:var(--text-muted);background:var(--bg-tertiary);padding:2px 8px;border-radius:10px}.ds-badges{display:flex;align-items:center;gap:6px;margin-left:auto}.ds-badge,.ds-test-badge{font-size:11px;font-weight:500;padding:2px 8px;border-radius:10px}.ds-test-badge--testing{background:#6366f11a;color:#818cf8}.ds-test-badge--ok{background:#10b9811f;color:#10b981}.ds-test-badge--error{background:#ef44441f;color:#ef4444;cursor:help}.ds-test-error{margin-top:10px;padding:8px 12px;background:#ef444414;border:1px solid rgba(239,68,68,.2);border-radius:6px;font-size:12px;color:#ef4444;line-height:1.5;word-break:break-word}.ds-badge--connected{background:#10b98126;color:#10b981}.ds-badge--phase2{background:#6366f126;color:#818cf8}.ds-badge--not-connected{background:#3741514d;color:var(--text-muted)}.ds-description{font-size:13px;color:var(--text-secondary);line-height:1.5;margin-bottom:0}.ds-meta{margin-top:14px;padding-top:14px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:6px}.ds-meta-row{display:flex;align-items:baseline;gap:10px;font-size:12px}.ds-meta-label{color:var(--text-muted);width:56px;flex-shrink:0;font-size:11px;text-transform:uppercase;letter-spacing:.4px}.ds-meta-value{color:var(--text-secondary);font-family:JetBrains Mono,Fira Code,monospace;font-size:12px}.ds-tables{margin-top:14px;padding-top:14px;border-top:1px solid var(--border)}.ds-tables-label{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.4px;margin-bottom:10px}.ds-table-row{padding:8px 0;border-bottom:1px solid var(--border)}.ds-table-row:last-child{border-bottom:none;padding-bottom:0}.ds-table-name{display:flex;align-items:center;gap:8px;margin-bottom:3px;flex-wrap:wrap}.ds-table-name code{font-family:JetBrains Mono,Fira Code,monospace;font-size:12px;color:var(--text-primary);background:var(--bg-tertiary);padding:1px 6px;border-radius:4px}.ds-table-badge{font-size:11px;color:#6366f1;background:#6366f11f;padding:1px 7px;border-radius:8px}.ds-table-desc{font-size:12px;color:var(--text-muted);line-height:1.4;padding-left:2px}@media(max-width:768px){.ds-view{padding:20px 16px}}.fb-view{padding:32px 40px;max-width:1200px;margin:0 auto;color:var(--text-primary)}.fb-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:28px;flex-wrap:wrap}.fb-header-left h2{font-size:22px;font-weight:600;margin-bottom:4px;color:var(--text-primary)}.fb-header-left p{font-size:14px;color:var(--text-secondary);margin:0}.fb-filters{display:flex;gap:6px}.fb-filter-btn{padding:5px 14px;font-size:13px;font-family:inherit;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:20px;color:var(--text-secondary);cursor:pointer;transition:all .15s}.fb-filter-btn:hover{color:var(--text-primary);border-color:var(--accent)}.fb-filter-btn--active{background:#6366f126;border-color:#6366f1;color:#818cf8}.fb-loading{text-align:center;padding:60px 0;color:var(--text-muted);font-size:14px}.fb-error{padding:10px 14px;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:8px;font-size:13px;color:#ef4444;margin-bottom:20px}.fb-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px}.fb-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;overflow:hidden;transition:border-color .15s,transform .15s}.fb-card:hover{border-color:#4b5563;transform:translateY(-1px)}.fb-thumb-wrap{position:relative;aspect-ratio:9 / 16;background:#0d0f18;cursor:pointer;overflow:hidden}.fb-thumb{width:100%;height:100%;object-fit:cover;display:block;transition:transform .2s}.fb-card:hover .fb-thumb{transform:scale(1.02)}.fb-thumb-empty{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:var(--text-muted);font-size:12px}.fb-thumb-overlay{position:absolute;inset:0;background:#0000;display:flex;align-items:center;justify-content:center;opacity:0;transition:background .2s,opacity .2s}.fb-thumb-wrap:hover .fb-thumb-overlay{background:#00000059;opacity:1}.fb-card-body{padding:12px 14px}.fb-card-badges{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:8px}.fb-card-text{font-size:13px;color:var(--text-secondary);line-height:1.5;margin:0 0 10px;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.fb-card-text--empty{color:var(--text-muted);font-style:italic}.fb-card-footer{display:flex;align-items:center;justify-content:space-between;gap:8px;font-size:11px}.fb-card-email{color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:120px}.fb-card-date{color:var(--text-muted);white-space:nowrap;flex-shrink:0}.fb-badge{font-size:10px;font-weight:500;padding:2px 7px;border-radius:10px;white-space:nowrap}.fb-badge--ios{background:#6366f126;color:#818cf8}.fb-badge--android{background:#10b98126;color:#34d399}.fb-badge--platform{text-transform:capitalize}.fb-badge--client{background:#f59e0b1f;color:#fbbf24;text-transform:capitalize}.fb-badge--version{background:var(--bg-tertiary);color:var(--text-muted)}.fb-badge--status.fb-badge--pending{background:#f59e0b1f;color:#fbbf24}.fb-badge--status.fb-badge--reviewed{background:#10b9811f;color:#10b981}.fb-pagination{display:flex;align-items:center;justify-content:center;gap:16px;margin-top:32px;padding-top:24px;border-top:1px solid var(--border)}.fb-page-btn{padding:7px 18px;font-size:13px;font-family:inherit;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:8px;color:var(--text-secondary);cursor:pointer;transition:all .15s}.fb-page-btn:hover:not(:disabled){border-color:var(--accent);color:var(--text-primary)}.fb-page-btn:disabled{opacity:.35;cursor:default}.fb-page-info{font-size:13px;color:var(--text-muted);min-width:60px;text-align:center}.lb-overlay{position:fixed;inset:0;background:#000000e6;z-index:1000;display:flex;align-items:center;justify-content:center}.lb-panel{position:relative;background:#1a1d27;border:1px solid #2d3141;border-radius:16px;overflow:hidden;display:flex;flex-direction:column;max-height:92vh;width:min(420px,92vw)}.lb-close{position:absolute;top:12px;right:12px;width:32px;height:32px;background:#0009;border:none;border-radius:50%;color:#e4e6eb;font-size:20px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:10;transition:background .15s}.lb-close:hover{background:#000000d9}.lb-image-wrap{flex:1;min-height:0;background:#0d0f18;display:flex;align-items:center;justify-content:center;overflow:hidden}.lb-image{max-width:100%;max-height:65vh;object-fit:contain;display:block}.lb-no-image{color:var(--text-muted);font-size:13px;padding:40px}.lb-details{padding:16px 18px;border-top:1px solid #2d3141}.lb-details-top{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}.lb-counter{font-size:11px;color:var(--text-muted);flex-shrink:0}.lb-badges{display:flex;flex-wrap:wrap;gap:5px;justify-content:flex-end}.lb-text{font-size:14px;color:var(--text-primary);line-height:1.55;margin:0 0 10px;white-space:pre-wrap}.lb-meta-row{display:flex;align-items:center;justify-content:space-between;font-size:12px;color:var(--text-muted);gap:8px}.lb-email{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lb-date{white-space:nowrap;flex-shrink:0}.lb-nav{position:fixed;top:50%;transform:translateY(-50%);width:48px;height:64px;background:#ffffff14;border:none;border-radius:10px;color:#e4e6eb;font-size:32px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s;z-index:1001}.lb-nav:hover{background:#ffffff24}.lb-nav--prev{left:16px}.lb-nav--next{right:16px}@media(max-width:768px){.fb-view{padding:20px 16px}.fb-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px}.lb-nav{display:none}}.team-view{padding:32px 40px;max-width:600px;margin:0 auto;color:var(--text-primary)}.team-header{margin-bottom:28px}.team-header h2{font-size:22px;font-weight:600;margin-bottom:4px;color:var(--text-primary)}.team-header p{font-size:14px;color:var(--text-secondary);margin:0}.team-list{display:flex;flex-direction:column;gap:10px;margin-bottom:28px}.team-card{display:flex;align-items:center;gap:14px;padding:14px 18px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;transition:border-color .15s}.team-card:hover{border-color:#4b5563}.team-avatar{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;color:#fff;flex-shrink:0;letter-spacing:.5px}.team-info{flex:1;min-width:0}.team-name{font-size:15px;font-weight:500;color:var(--text-primary);margin-bottom:2px}.team-email{font-size:13px;color:var(--text-secondary);font-family:JetBrains Mono,Fira Code,monospace}.team-role{font-size:11px;font-weight:500;padding:3px 10px;border-radius:10px;background:#6366f126;color:#818cf8;flex-shrink:0}.team-note{display:flex;align-items:flex-start;gap:8px;padding:12px 14px;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:8px;font-size:12px;color:var(--text-muted);line-height:1.55}.team-note code{font-family:JetBrains Mono,Fira Code,monospace;font-size:11px;background:#ffffff0f;padding:1px 5px;border-radius:3px}@media(max-width:768px){.team-view{padding:20px 16px}}.ha-view{padding:32px 40px;max-width:1100px;margin:0 auto;color:var(--text-primary)}.ha-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:24px;flex-wrap:wrap}.ha-header h2{font-size:22px;font-weight:600;margin-bottom:4px}.ha-header p{font-size:14px;color:var(--text-secondary);margin:0}.ha-search-wrap{position:relative;display:flex;align-items:center}.ha-search-icon{position:absolute;left:10px;color:var(--text-muted);pointer-events:none}.ha-search{padding:7px 32px 7px 30px;font-size:13px;font-family:inherit;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:8px;color:var(--text-primary);width:220px;outline:none;transition:border-color .15s}.ha-search:focus{border-color:var(--accent)}.ha-search::placeholder{color:var(--text-muted)}.ha-search-clear{position:absolute;right:8px;background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:16px;line-height:1;padding:0}.ha-search-clear:hover{color:var(--text-primary)}.ha-error{padding:14px 16px;background:#ef444414;border:1px solid rgba(239,68,68,.25);border-radius:10px;font-size:13px;color:var(--text-secondary);line-height:1.6}.ha-error strong{color:#ef4444}.ha-error ol{margin:8px 0 0 16px;padding:0}.ha-error li{margin-bottom:4px}.ha-error code{font-family:JetBrains Mono,monospace;font-size:11px;background:#ffffff0f;padding:1px 5px;border-radius:3px}.ha-table-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:12px}.ha-table{width:100%;border-collapse:collapse;font-size:13px}.ha-table thead tr{border-bottom:1px solid var(--border)}.ha-table th{padding:10px 14px;text-align:left;font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.4px;white-space:nowrap;background:var(--bg-secondary)}.ha-th-right,.ha-td-right{text-align:right}.ha-table tbody tr{border-bottom:1px solid var(--border);transition:background .1s}.ha-table tbody tr:last-child{border-bottom:none}.ha-table tbody tr:hover{background:var(--bg-tertiary)}.ha-row--blocked{opacity:.5}.ha-table td{padding:11px 14px;vertical-align:middle}.ha-td-user{display:flex;align-items:center;gap:10px}.ha-avatar-img{width:32px;height:32px;border-radius:50%;object-fit:cover;flex-shrink:0}.ha-avatar{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;color:#fff;flex-shrink:0}.ha-user-name{font-size:13px;font-weight:500;color:var(--text-primary);line-height:1.3}.ha-user-email{font-size:12px;color:var(--text-secondary);font-family:JetBrains Mono,monospace}.ha-blocked-badge{font-size:10px;font-weight:500;padding:2px 7px;border-radius:10px;background:#ef444426;color:#ef4444;margin-left:6px;flex-shrink:0}.ha-provider{font-size:11px;font-weight:500;padding:2px 8px;border-radius:8px}.ha-provider--auth0{background:var(--bg-tertiary);color:var(--text-muted)}.ha-provider--googleoauth2{background:#4285f426;color:#60a5fa}.ha-provider--apple{background:#ffffff14;color:var(--text-secondary)}.ha-td-date,.ha-td-right{color:var(--text-secondary);white-space:nowrap}.ha-td-location{white-space:nowrap;color:var(--text-secondary);font-size:13px}.ha-location-city{margin-right:5px}.ha-location-country{font-size:10px;font-weight:600;padding:1px 5px;border-radius:4px;background:var(--bg-tertiary);color:var(--text-muted);letter-spacing:.3px}.ha-location-ip{font-family:JetBrains Mono,monospace;font-size:11px;color:var(--text-muted)}.ha-loading{text-align:center;padding:40px;color:var(--text-muted);font-size:14px}.ha-pagination{display:flex;align-items:center;justify-content:center;gap:16px;margin-top:24px}.ha-page-btn{padding:7px 18px;font-size:13px;font-family:inherit;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:8px;color:var(--text-secondary);cursor:pointer;transition:all .15s}.ha-page-btn:hover:not(:disabled){border-color:var(--accent);color:var(--text-primary)}.ha-page-btn:disabled{opacity:.35;cursor:default}.ha-page-info{font-size:13px;color:var(--text-muted);min-width:100px;text-align:center}@media(max-width:768px){.ha-view{padding:20px 16px}.ha-search{width:180px}}.sms-view{padding:32px 40px;max-width:1000px;margin:0 auto;color:var(--text-primary)}.sms-header{margin-bottom:24px}.sms-header h2{font-size:22px;font-weight:600;margin-bottom:4px}.sms-header p{font-size:14px;color:var(--text-secondary);margin:0}.sms-loading{text-align:center;padding:40px;color:var(--text-muted);font-size:14px}.sms-error{padding:10px 14px;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:8px;font-size:13px;color:#ef4444}.sms-table-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:12px}.sms-table{width:100%;border-collapse:collapse;font-size:13px}.sms-table thead tr{border-bottom:1px solid var(--border)}.sms-table th{padding:10px 14px;text-align:left;font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.4px;white-space:nowrap;background:var(--bg-secondary)}.sms-th-right,.sms-td-right{text-align:right}.sms-table tbody tr{border-bottom:1px solid var(--border);transition:background .1s}.sms-table tbody tr:last-child{border-bottom:none}.sms-table tbody tr:hover{background:var(--bg-tertiary)}.sms-table td{padding:11px 14px;vertical-align:middle}.sms-td-num{color:var(--text-muted);font-size:12px;width:36px}.sms-td-hash code{font-family:JetBrains Mono,Fira Code,monospace;font-size:12px;color:var(--text-secondary)}.sms-td-communities{max-width:260px}.sms-community-tag{display:inline-block;font-size:11px;padding:2px 7px;border-radius:8px;background:#6366f11a;color:#818cf8;margin:2px 3px 2px 0;white-space:nowrap}.sms-td-locales{white-space:nowrap}.sms-locale-tag{display:inline-block;font-size:10px;font-weight:600;padding:2px 6px;border-radius:6px;background:var(--bg-tertiary);color:var(--text-muted);margin-right:3px;letter-spacing:.3px}.sms-td-date{color:var(--text-secondary);white-space:nowrap;font-size:12px}.sms-td-right{color:var(--text-secondary);font-variant-numeric:tabular-nums;white-space:nowrap}.sms-section{margin-bottom:28px}.sms-section-header{display:flex;align-items:center;gap:8px;margin-bottom:10px}.sms-section-title{font-size:13px;font-weight:600;color:var(--text-primary);text-transform:uppercase;letter-spacing:.5px}.sms-section-badge{font-size:11px;font-weight:600;padding:2px 7px;border-radius:10px;background:#eab30826;color:#fbbf24}.sms-section-badge--active{background:#22c55e1f;color:#4ade80}.sms-section-hint{font-size:12px;color:var(--text-muted)}.sms-td-phone{font-family:JetBrains Mono,Fira Code,monospace;font-size:13px;color:var(--text-primary);white-space:nowrap}.sms-row--opted-out{opacity:.5}.sms-opted-out-badge{font-size:10px;font-weight:500;padding:2px 7px;border-radius:10px;background:#ef44441f;color:#ef4444}@media(max-width:768px){.sms-view{padding:20px 16px}}.sidebar{position:fixed;top:0;left:0;bottom:0;width:48px;z-index:100;background:#1a1d27;border-right:1px solid #2d3141;display:flex;flex-direction:column;overflow:hidden;transition:width .25s ease}.sidebar.sidebar--open{width:260px}.sidebar-toggle-area{height:48px;min-height:48px;flex-shrink:0;display:flex;align-items:center;padding:0 8px;background:#1a1d27}.sidebar-toggle{display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:4px;background:transparent;border:none;border-radius:6px;cursor:pointer;color:#e4e6eb;flex-shrink:0}.sidebar-toggle:hover{background:#242836}.sidebar-body{flex:1;min-width:260px;display:flex;flex-direction:column;overflow:hidden;min-height:0;opacity:0;pointer-events:none;transition:opacity .15s ease}.sidebar.sidebar--open .sidebar-body{opacity:1;pointer-events:auto;transition:opacity .2s ease .1s}.sidebar-header{padding:16px 20px;border-bottom:1px solid #2d3141;background:#1a1d27}.sidebar-header h1{font-size:16px;font-weight:600;color:#e4e6eb}.sidebar-header .subtitle{font-size:11px;color:#6b7280;margin-top:2px}.logout-btn{margin-top:8px;padding:3px 8px;font-size:11px;color:#6b7280;background:none;border:1px solid #2d3141;border-radius:4px;cursor:pointer}.logout-btn:hover{color:#e4e6eb;border-color:#6b7280}.new-chat-btn{margin:12px 12px 0;padding:10px 16px;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:8px;color:var(--text-primary);font-size:13px;font-weight:500;cursor:pointer;transition:all .15s;text-align:left}.new-chat-btn:hover:not(:disabled){background:var(--accent);border-color:var(--accent);color:#fff}.new-chat-btn:disabled{opacity:.4;cursor:not-allowed}.conversation-list{flex:1;overflow-y:auto;padding:8px 8px 0;min-height:0}.conversation-item{position:relative;padding:10px 12px;border-radius:8px;cursor:pointer;transition:background .15s}.conversation-item:hover,.conversation-item.active{background:var(--bg-tertiary)}.conversation-item-title{font-size:13px;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding-right:20px}.conversation-item-date{font-size:11px;color:var(--text-muted);margin-top:2px}.conversation-item-delete{position:absolute;top:8px;right:8px;width:22px;height:22px;border:none;background:none;color:var(--text-muted);font-size:16px;line-height:1;border-radius:4px;cursor:pointer;opacity:0;transition:opacity .15s,background .15s;display:flex;align-items:center;justify-content:center}.conversation-item:hover .conversation-item-delete{opacity:1}.conversation-item-delete:hover{background:var(--border);color:var(--text-primary)}.sidebar-nav{padding:12px;flex-shrink:0}.sidebar-nav-item{display:flex;align-items:center;gap:8px;padding:8px 12px;border-radius:6px;color:var(--text-muted);font-size:13px;transition:background .15s}.sidebar-nav-item.active{background:var(--bg-tertiary);color:var(--text-primary);cursor:default}.sidebar-nav-item:not(.active){opacity:.5;cursor:default}.main{margin-left:48px;height:100vh;display:flex;flex-direction:column;overflow:hidden;transition:margin-left .25s ease}.app.sidebar-is-open .main{margin-left:260px}.chat-messages{flex:1;overflow-y:auto;padding:20px 0}.messages-container{max-width:800px;margin:0 auto;padding:0 20px}.message{margin-bottom:24px}.message-user{display:flex;justify-content:flex-end}.message-user .message-content{background:var(--accent);color:#fff;border-radius:16px 16px 4px;padding:10px 16px;max-width:70%;font-size:14px}.message-assistant .message-content{font-size:14px;line-height:1.6;color:var(--text-primary)}.message-assistant .message-content p{margin-bottom:8px}.message-assistant .message-content p:last-child{margin-bottom:0}.message-assistant .message-content code{background:var(--bg-tertiary);padding:2px 6px;border-radius:4px;font-size:13px;font-family:JetBrains Mono,Fira Code,monospace}.message-assistant .message-content pre{background:var(--bg-tertiary);border-radius:8px;padding:12px 16px;overflow-x:auto;margin:8px 0}.message-assistant .message-content pre code{background:none;padding:0}.message-assistant .message-content a{color:var(--accent-hover);text-decoration:underline}.message-assistant .message-content blockquote{border-left:3px solid var(--border);padding-left:12px;margin:8px 0;color:var(--text-secondary)}.message-assistant .message-content table{width:100%;border-collapse:collapse;margin:8px 0;font-size:13px}.message-assistant .message-content th,.message-assistant .message-content td{border:1px solid var(--border);padding:6px 12px;text-align:left}.message-assistant .message-content th{background:var(--bg-tertiary);font-weight:600;color:var(--text-secondary)}.message-assistant .message-content hr{border:none;border-top:1px solid var(--border);margin:12px 0}.message-assistant .message-content ul,.message-assistant .message-content ol{padding-left:20px;margin:8px 0}.message-assistant .message-content li{margin-bottom:4px}.tool-status{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--bg-tertiary);border-radius:8px;font-size:12px;color:var(--text-secondary);margin:8px 0}.tool-status .spinner{width:14px;height:14px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}.tool-status.complete .spinner{border-color:var(--success);border-top-color:var(--success);animation:none}.tool-status.error .spinner{border-color:var(--error);border-top-color:var(--error);animation:none}@keyframes spin{to{transform:rotate(360deg)}}.chat-input-area{border-top:1px solid var(--border);padding:16px 20px;flex-shrink:0}.chat-input-container{max-width:800px;margin:0 auto;display:flex;gap:8px}.chat-input{flex:1;background:var(--bg-input);border:1px solid var(--border);border-radius:12px;padding:12px 16px;color:var(--text-primary);font-size:14px;font-family:inherit;resize:none;outline:none;min-height:44px;max-height:200px}.chat-input:focus{border-color:var(--accent)}.chat-input::placeholder{color:var(--text-muted)}.chat-send-btn{background:var(--accent);color:#fff;border:none;border-radius:12px;padding:0 20px;font-size:14px;font-weight:500;cursor:pointer;transition:background .15s;white-space:nowrap}.chat-send-btn:hover:not(:disabled){background:var(--accent-hover)}.chat-send-btn:disabled{opacity:.5;cursor:not-allowed}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px;margin:12px 0}.kpi-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;padding:16px}.kpi-card.confidence-exact{border-left:3px solid var(--confidence-exact)}.kpi-card.confidence-estimated{border-left:3px solid var(--confidence-estimated)}.kpi-card.confidence-unavailable{border-left:3px solid var(--confidence-unavailable);opacity:.7}.kpi-label{font-size:12px;color:var(--text-secondary);font-weight:500;text-transform:uppercase;letter-spacing:.5px}.kpi-value{font-size:28px;font-weight:700;margin:4px 0;color:var(--text-primary)}.kpi-card.confidence-estimated .kpi-value{color:var(--confidence-estimated)}.kpi-card.confidence-unavailable .kpi-value{color:var(--confidence-unavailable)}.kpi-trend{display:flex;align-items:center;gap:4px;font-size:12px}.kpi-trend.up{color:var(--success)}.kpi-trend.down{color:var(--error)}.kpi-trend.flat{color:var(--text-muted)}.kpi-subtitle{font-size:11px;color:var(--text-muted);margin-top:4px}.kpi-confidence-badge{display:inline-block;font-size:10px;padding:2px 6px;border-radius:4px;margin-top:6px;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.kpi-confidence-badge.exact{background:#10b98126;color:var(--confidence-exact)}.kpi-confidence-badge.estimated{background:#f59e0b26;color:var(--confidence-estimated)}.kpi-confidence-badge.unavailable{background:#6b728026;color:var(--confidence-unavailable)}.chart-container{background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;padding:16px;margin:12px 0}.chart-title{font-size:14px;font-weight:600;margin-bottom:8px;color:var(--text-primary)}.chart-freshness{font-size:11px;color:var(--text-muted);margin-top:8px}.data-table-container{background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;overflow:hidden;margin:12px 0}.data-table-title{font-size:14px;font-weight:600;padding:12px 16px;border-bottom:1px solid var(--border)}.data-table{width:100%;border-collapse:collapse;font-size:13px}.data-table th{background:var(--bg-tertiary);padding:8px 16px;text-align:left;font-weight:600;color:var(--text-secondary);font-size:11px;text-transform:uppercase;letter-spacing:.5px}.data-table td{padding:8px 16px;border-top:1px solid var(--border);color:var(--text-primary)}.data-table tr:hover td{background:var(--bg-tertiary)}.welcome{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100%;text-align:center;padding:40px}.welcome h2{font-size:24px;font-weight:600;margin-bottom:8px}.welcome p{color:var(--text-secondary);font-size:14px;max-width:500px;margin-bottom:24px}.welcome-suggestions{display:flex;flex-direction:column;gap:8px;width:100%;max-width:500px}.welcome-suggestion{background:var(--bg-secondary);border:1px solid var(--border);border-radius:10px;padding:12px 16px;text-align:left;font-size:13px;color:var(--text-secondary);cursor:pointer;transition:all .15s}.welcome-suggestion:hover{border-color:var(--accent);color:var(--text-primary);background:var(--bg-tertiary)}.streaming-cursor:after{content:"";display:inline-block;width:2px;height:14px;background:var(--accent);margin-left:2px;vertical-align:text-bottom;animation:blink 1s step-end infinite}@keyframes blink{50%{opacity:0}}.chart-loading{display:flex;align-items:center;justify-content:center;height:300px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;color:var(--text-muted);font-size:13px;margin:12px 0}@media(max-width:768px){.messages-container{padding:0 12px}.chat-input-area{padding:12px}.welcome{padding:20px 12px}.welcome-suggestions{max-width:100%}.kpi-grid{grid-template-columns:1fr}.message-user .message-content{max-width:85%}}
