*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.\!visible{visibility:visible!important}.visible{visibility:visible}.collapse{visibility:collapse}.absolute{position:absolute}.relative{position:relative}.sticky{position:sticky}.block{display:block}.inline-block{display:inline-block}.inline{display:inline}.flex{display:flex}.table{display:table}.grid{display:grid}.contents{display:contents}.hidden{display:none}.border-collapse{border-collapse:collapse}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.resize{resize:both}.border{border-width:1px}.uppercase{text-transform:uppercase}.italic{font-style:italic}.tabular-nums{--tw-numeric-spacing: tabular-nums;font-variant-numeric:var(--tw-ordinal) var(--tw-slashed-zero) var(--tw-numeric-figure) var(--tw-numeric-spacing) var(--tw-numeric-fraction)}.\!filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)!important}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh;background:var(--bg-base, #000);color:var(--text-primary, #e0e0e0)}#root{height:100vh}.ai-panel{width:340px;min-width:280px;display:flex;flex-direction:column;background:var(--bg-surface);border-left:1px solid var(--border-default);overflow:hidden;flex-shrink:0}.ai-fab{position:fixed;bottom:24px;right:24px;width:48px;height:48px;border-radius:50%;background:var(--accent);border:none;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px #dc26264d;z-index:200;transition:all .2s}.ai-fab:hover{background:var(--accent-hover);box-shadow:0 6px 24px #dc262666;transform:scale(1.05)}.ai-panel-header{display:flex;align-items:center;gap:8px;padding:10px 12px;border-bottom:1px solid var(--border-default);background:var(--bg-surface);flex-shrink:0;flex-wrap:nowrap;overflow:hidden;min-height:42px}.ai-panel-title{font-size:13px;font-weight:600;color:var(--text-primary);letter-spacing:-.2px;white-space:nowrap;flex-shrink:1;overflow:hidden;text-overflow:ellipsis;min-width:0}.ai-panel-model-badge{font-size:10px;font-family:var(--font-mono);color:var(--accent);background:var(--accent-bg);border:1px solid var(--accent-bg-subtle);border-radius:5px;padding:2px 6px;letter-spacing:.2px;white-space:nowrap;flex-shrink:0}.ai-panel-header-actions{margin-left:auto;display:flex;gap:3px;flex-shrink:0}.ai-panel-action-btn{background:none;border:1px solid transparent;border-radius:6px;color:var(--text-faint);font-size:10px;padding:4px 7px;cursor:pointer;white-space:nowrap;flex-shrink:0;transition:all .15s}.ai-panel-action-btn:hover{background:var(--bg-hover);color:var(--text-secondary);border-color:var(--border-strong)}.ai-panel-action-btn.active{border-color:var(--accent);color:var(--accent);background:var(--accent-bg)}.ai-panel-ctx{display:flex;flex-wrap:wrap;gap:4px;padding:8px 12px;border-bottom:1px solid var(--border-subtle);flex-shrink:0;min-height:32px;align-items:center}.ai-ctx-pill{font-size:10px;background:var(--accent-bg);border:1px solid var(--accent-bg-subtle);color:var(--accent);border-radius:5px;padding:2px 8px;font-family:var(--font-mono);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:150px}.ai-ctx-none{font-size:11px;color:var(--text-faint);font-style:italic}.ai-panel-messages{flex:1;overflow-y:auto;padding:14px;display:flex;flex-direction:column;gap:14px}.ai-panel-empty{margin:auto;text-align:center;display:flex;flex-direction:column;align-items:center;gap:14px;padding:32px 12px}.ai-empty-icon{font-size:28px;color:var(--text-ghost)}.ai-empty-text{font-size:12px;color:var(--text-muted);line-height:1.7;max-width:240px}.ai-suggestions{display:flex;flex-direction:column;gap:6px;width:100%;margin-top:4px}.ai-suggestion{background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:8px;color:var(--text-muted);font-size:11px;padding:8px 12px;text-align:left;cursor:pointer;line-height:1.5;transition:all .15s}.ai-suggestion:hover{background:var(--accent-bg);border-color:var(--accent-bg-subtle);color:var(--accent)}.ai-msg{display:flex;flex-direction:column;gap:6px}.ai-msg-user{align-items:flex-end}.ai-msg-assistant{align-items:flex-start}.ai-msg-bubble{max-width:94%;padding:10px 14px;border-radius:12px;font-size:12px;line-height:1.6}.ai-msg-user .ai-msg-bubble{background:var(--accent-bg);border:1px solid var(--accent-bg-subtle);color:var(--text-primary);border-bottom-right-radius:4px}.ai-msg-assistant .ai-msg-bubble{background:var(--bg-elevated);border:1px solid var(--border-default);color:var(--text-secondary);border-bottom-left-radius:4px}.ai-md{display:flex;flex-direction:column;gap:4px}.ai-md-heading{color:var(--text-primary);font-size:12px;font-weight:700;margin:6px 0 2px}.ai-md-p{margin:0}.ai-md-gap{height:4px}.ai-md-list{margin:2px 0 2px 16px;padding:0}.ai-md-list li{margin:2px 0}.ai-inline-code{font-family:var(--font-mono);font-size:11px;background:var(--bg-hover);border:1px solid var(--border-strong);border-radius:4px;padding:1px 5px;color:var(--accent-light)}.ai-md-table{border-collapse:collapse;font-size:11px;font-family:var(--font-mono);width:100%;margin:4px 0;overflow-x:auto;display:block}.ai-md-table th{background:var(--bg-surface);color:var(--text-muted);font-weight:600;padding:5px 8px;text-align:left;border:1px solid var(--border-default);white-space:nowrap}.ai-md-table td{padding:4px 8px;color:var(--text-secondary);border:1px solid var(--border-default);white-space:nowrap}.ai-md-table tr:hover td{background:var(--bg-hover)}.ai-thinking{display:flex;gap:5px;padding:10px 2px;align-items:center}.ai-thinking span{width:6px;height:6px;border-radius:50%;background:var(--accent);animation:ai-pulse 1.2s ease-in-out infinite;display:inline-block}.ai-thinking span:nth-child(2){animation-delay:.2s}.ai-thinking span:nth-child(3){animation-delay:.4s}@keyframes ai-pulse{0%,to{opacity:.2;transform:scale(.8)}50%{opacity:1;transform:scale(1.1)}}.ai-result-wrap{display:flex;flex-direction:column;gap:4px}.ai-result-note{font-size:10px;color:var(--text-faint)}.ai-result-scroll{overflow-x:auto;max-height:200px;overflow-y:auto;border:1px solid var(--border-default);border-radius:6px}.ai-result-table{border-collapse:collapse;font-size:10px;font-family:var(--font-mono);white-space:nowrap;width:100%}.ai-result-table th{background:var(--bg-surface);color:var(--text-muted);font-weight:600;padding:5px 8px;text-align:left;border-bottom:1px solid var(--border-default);position:sticky;top:0}.ai-result-table td{padding:4px 8px;color:var(--text-secondary);border-bottom:1px solid var(--border-subtle)}.ai-result-table tr:last-child td{border-bottom:none}.ai-result-table tr:hover td{background:var(--bg-hover)}.ai-null{color:var(--text-faint);font-style:italic}.ai-result-empty{font-size:11px;color:var(--text-muted)}.ai-streaming-bar{display:flex;align-items:center;gap:8px;padding:6px 2px 8px;border-bottom:1px solid var(--border-subtle);margin-bottom:8px}.ai-streaming-dot{width:6px;height:6px;border-radius:50%;background:var(--accent);animation:ai-pulse 1s ease-in-out infinite;flex-shrink:0}.ai-streaming-label{font-size:11px;color:var(--text-muted);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ai-stop-btn{display:flex;align-items:center;gap:5px;background:var(--accent-bg);border:1px solid var(--accent-bg-subtle);border-radius:6px;color:var(--accent);font-size:11px;padding:4px 10px;cursor:pointer;flex-shrink:0;transition:all .15s}.ai-stop-btn:hover{background:var(--accent-bg-subtle);color:var(--error)}.ai-stop-icon{width:8px;height:8px;background:currentColor;border-radius:2px;flex-shrink:0}.ai-panel-footer{padding:10px 12px 12px;border-top:1px solid var(--border-default);background:var(--bg-surface);flex-shrink:0;display:flex;flex-direction:column;gap:6px}.ai-input-wrap{display:flex;gap:6px;align-items:center}.ai-input{flex:1;background:var(--bg-input);border:1px solid var(--border-strong);border-radius:10px;color:var(--text-primary);font-size:12px;line-height:1.5;padding:8px 12px;resize:none;font-family:inherit;outline:none;height:36px;overflow-y:hidden;transition:border-color .15s}.ai-input:focus{border-color:var(--accent)}.ai-input::-moz-placeholder{color:var(--text-faint)}.ai-input::placeholder{color:var(--text-faint)}.ai-input:disabled{opacity:.4;cursor:not-allowed}.ai-effort-btn{width:36px;height:36px;background:var(--bg-elevated);border:1px solid var(--border-strong);border-radius:10px;color:var(--text-faint);font-size:11px;font-weight:600;font-family:var(--font-mono);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s}.ai-effort-btn:hover{border-color:var(--text-ghost);color:var(--text-secondary)}.ai-effort-btn.quick{background:var(--success-bg);border-color:var(--success);color:var(--success)}.ai-effort-btn.medium{background:var(--warning-bg);border-color:var(--warning);color:var(--warning)}.ai-effort-btn.deep{background:var(--accent-bg);border-color:var(--accent);color:var(--accent);box-shadow:0 0 8px #dc262626}.ai-send-btn{width:36px;height:36px;background:var(--accent);border:none;border-radius:10px;color:#fff;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s}.ai-send-btn:hover:not(:disabled){background:var(--accent-hover)}.ai-send-btn:disabled{background:var(--bg-elevated);color:var(--text-ghost);cursor:not-allowed}.ai-send-spinner{width:14px;height:14px;border:2px solid rgba(255,255,255,.15);border-top-color:#fff;border-radius:50%;animation:ai-spin .7s linear infinite;display:inline-block}@keyframes ai-spin{to{transform:rotate(360deg)}}.ai-input-hint{font-size:10px;color:var(--text-ghost);text-align:right}.ai-history-panel{flex:1;overflow-y:auto;display:flex;flex-direction:column;padding:10px;gap:4px}.ai-history-header{font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-faint);padding:4px 4px 8px}.ai-history-empty{font-size:12px;color:var(--text-faint);text-align:center;padding:24px 0;font-style:italic}.ai-history-row{position:relative;padding:10px 32px 10px 12px;border:1px solid var(--border-default);border-radius:8px;cursor:pointer;transition:all .12s;background:var(--bg-elevated)}.ai-history-row:hover{background:var(--bg-hover);border-color:var(--border-strong)}.ai-history-title{font-size:12px;color:var(--text-primary);line-height:1.4;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}.ai-history-meta{display:flex;gap:10px;margin-top:4px;font-size:10px;color:var(--text-faint);font-family:var(--font-mono)}.ai-history-del{position:absolute;top:50%;right:8px;transform:translateY(-50%);background:none;border:none;color:var(--text-ghost);font-size:10px;cursor:pointer;padding:4px 5px;border-radius:4px;line-height:1;transition:all .12s}.ai-history-del:hover{color:var(--error);background:var(--error-bg)}.ai-ctx-bar{display:flex;align-items:center;gap:8px;padding:4px 0 2px}.ai-ctx-track{flex:1;height:3px;background:var(--bg-hover);border-radius:2px;overflow:visible;position:relative}.ai-ctx-fill{height:100%;border-radius:2px;transition:width .4s ease,background .4s}.ai-ctx-tokens{font-size:10px;font-family:var(--font-mono);color:var(--text-faint);white-space:nowrap;flex-shrink:0}.rca-actions{display:flex;align-items:center;gap:4px;margin-top:8px;padding-top:8px;border-top:1px solid var(--border-default)}.rca-btn{background:none;border:1px solid var(--border-strong);border-radius:5px;color:var(--text-faint);font-size:11px;padding:3px 8px;cursor:pointer;transition:all .15s}.rca-btn:hover:not(:disabled){color:var(--text-secondary);border-color:var(--text-ghost)}.rca-btn:disabled{cursor:default;opacity:.4}.rca-btn.rated-good{color:var(--success);border-color:var(--success);background:var(--success-bg);opacity:1}.rca-btn.rated-bad{color:var(--error);border-color:var(--error);background:var(--error-bg);opacity:1}.rca-export{margin-left:4px}.rca-saved{font-size:10px;color:var(--text-faint);margin-left:4px}.ai-block{border-radius:8px;border:1px solid var(--border-default);overflow:hidden;margin:3px 0;transition:border-color .15s}.ai-block--thinking{border-color:#8b5cf640;background:#8b5cf60a}.ai-block--tool.ai-block--done{border-color:color-mix(in srgb,var(--tool-color, #3b82f6) 25%,transparent);background:color-mix(in srgb,var(--tool-color, #3b82f6) 4%,transparent)}.ai-block--tool.ai-block--running{border-color:var(--border-strong);background:var(--bg-elevated)}.ai-block--tool.ai-block--error{border-color:#ef44444d;background:#ef44440a}.ai-block-header{width:100%;display:flex;align-items:center;gap:8px;padding:8px 12px;text-align:left;background:none;border:none;cursor:pointer;color:inherit;font:inherit;transition:background .1s}.ai-block-header:hover{background:#8080800f}.ai-block-icon{font-size:11px;flex-shrink:0}.ai-block-label{font-size:11px;font-weight:500;color:var(--text-primary);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ai-block-meta{font-size:10px;font-family:var(--font-mono);color:var(--text-faint);margin-right:2px}.ai-block-chevron{font-size:9px;color:var(--text-faint);flex-shrink:0}.ai-block-dots{display:flex;gap:3px;align-items:center;margin-right:2px}.ai-block-dot{width:4px;height:4px;border-radius:50%;background:#8b5cf6;animation:ai-pulse .8s ease-in-out infinite}.ai-block-body{border-top:1px solid var(--border-default);padding:10px 12px;display:flex;flex-direction:column;gap:8px}.ai-block-content{font-size:11px;color:var(--text-muted);font-family:var(--font-mono);line-height:1.6;white-space:pre-wrap}.ai-tool-index{font-size:9px;font-family:var(--font-mono);color:var(--text-faint);background:var(--bg-elevated);border-radius:4px;padding:1px 5px;flex-shrink:0}.ai-tool-status{display:flex;align-items:center;gap:6px;flex-shrink:0}.ai-tool-running{display:flex;align-items:center;gap:5px;font-size:10px;color:var(--text-faint)}.ai-tool-spinner{width:7px;height:7px;border-radius:50%;border:1.5px solid var(--border-strong);border-top-color:var(--warning);animation:ai-spin .7s linear infinite;flex-shrink:0}.ai-tool-badge{font-size:10px;font-family:var(--font-mono);padding:2px 7px;border-radius:5px;border:1px solid}.ai-tool-badge--error{color:var(--error);border-color:var(--error);background:var(--error-bg)}.ai-tool-sql-label{font-size:9px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-faint);margin-bottom:4px}.ai-tool-sql{font-size:10px;color:var(--info);background:var(--bg-base);border:1px solid var(--border-default);border-radius:6px;padding:8px 10px;overflow-x:auto;white-space:pre;font-family:var(--font-mono);line-height:1.6;margin:0}.ai-tool-error{font-size:11px;color:var(--error);background:var(--error-bg);border:1px solid rgba(239,68,68,.2);border-radius:6px;padding:8px 10px;line-height:1.5}.ai-thinking-status{display:flex;align-items:center;gap:8px;padding:4px 4px 8px;font-size:11px;color:var(--text-muted)}.ai-thinking-status-dot{width:6px;height:6px;border-radius:50%;background:var(--warning);animation:ai-pulse 1s ease-in-out infinite;flex-shrink:0}:root,[data-theme=dark]{--bg-base: #000;--bg-surface: #0a0a0a;--bg-elevated: #111;--bg-overlay: #050505;--bg-hover: #1a1a1a;--bg-selected: #2a1010;--bg-input: #111;--border-default: #1a1a1a;--border-strong: #2a2a2a;--border-subtle: #111;--border-faint: #0d0d0d;--text-primary: #e0e0e0;--text-secondary: #ccc;--text-tertiary: #aaa;--text-muted: #888;--text-faint: #666;--text-ghost: #555;--text-dim: #444;--text-placeholder: #333;--accent: #dc2626;--accent-hover: #b91c1c;--accent-bg: #2a1010;--accent-bg-subtle: #1a0808;--accent-light: #f87171;--accent-dark: #6b1313;--success: #22c55e;--success-bg: #052e16;--warning: #f59e0b;--warning-bg: #1a1508;--error: #ef4444;--error-bg: #1a0505;--info: #3b82f6;--info-bg: #0c1a3a;--text-xs: 11px;--text-sm: 13px;--text-base: 14px;--text-md: 15px;--text-lg: 16px;--text-xl: 20px;--text-2xl: 24px;--font-mono: "Consolas", "Monaco", "Courier New", monospace;--space-xs: 4px;--space-sm: 8px;--space-md: 12px;--space-lg: 16px;--space-xl: 24px;--space-2xl: 32px;--radius-sm: 4px;--radius-md: 6px;--radius-lg: 8px;--radius-xl: 12px;--shadow-sm: 0 1px 3px rgba(0,0,0,.3);--shadow-md: 0 4px 12px rgba(0,0,0,.4);--shadow-lg: 0 8px 32px rgba(0,0,0,.5);--sidebar-width: 300px;--ai-panel-width: 340px;color-scheme:dark}[data-theme=light]{--bg-base: #fafafa;--bg-surface: #ffffff;--bg-elevated: #f4f4f5;--bg-overlay: #f0f0f2;--bg-hover: rgba(0,0,0,.03);--bg-selected: #fef2f2;--bg-input: #ffffff;--border-default: #e4e4e7;--border-strong: #d4d4d8;--border-subtle: #f4f4f5;--border-faint: #fafafa;--text-primary: #18181b;--text-secondary: #27272a;--text-tertiary: #3f3f46;--text-muted: #71717a;--text-faint: #a1a1aa;--text-ghost: #d4d4d8;--text-dim: #d4d4d8;--text-placeholder: #a1a1aa;--accent: #dc2626;--accent-hover: #b91c1c;--accent-bg: #fef2f2;--accent-bg-subtle: #fff5f5;--accent-light: #f87171;--accent-dark: #991b1b;--success: #16a34a;--success-bg: #f0fdf4;--warning: #d97706;--warning-bg: #fffbeb;--error: #dc2626;--error-bg: #fef2f2;--info: #2563eb;--info-bg: #eff6ff;--shadow-sm: 0 1px 3px rgba(0,0,0,.06);--shadow-md: 0 4px 12px rgba(0,0,0,.08);--shadow-lg: 0 8px 32px rgba(0,0,0,.1);color-scheme:light}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg-base);color:var(--text-primary);font-size:var(--text-base)}.theme-toggle-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:1px solid var(--border-strong);border-radius:var(--radius-sm);background:none;color:var(--text-muted);cursor:pointer;flex-shrink:0;transition:border-color .15s,color .15s,background .15s}.theme-toggle-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--bg-hover)}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #dc262626}button:focus-visible{outline:2px solid var(--accent);outline-offset:2px}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:var(--radius-sm)}::-webkit-scrollbar-thumb:hover{background:var(--text-dim)}.app{display:grid;grid-template-columns:300px 1fr 340px;height:100vh;overflow:hidden;transition:grid-template-columns .15s ease}.app.sidebar-collapsed{grid-template-columns:0px 1fr 340px}.app.ai-collapsed{grid-template-columns:300px 1fr 0px}.app.sidebar-collapsed.ai-collapsed{grid-template-columns:0px 1fr 0px}.app.chat-expanded{grid-template-columns:300px 0 1fr}.app.chat-expanded.sidebar-collapsed{grid-template-columns:0px 0 1fr}.app.chat-expanded .workspace{overflow:hidden;min-width:0;padding:0}.app.chat-expanded .ai-panel{width:100%;min-width:0;border-left:1px solid var(--border-default)}.sidebar{background:var(--bg-surface);border-right:1px solid var(--border-default);display:flex;flex-direction:column;overflow:hidden;min-width:0}.sidebar-header{padding:14px 16px;border-bottom:1px solid var(--border-default);display:flex;align-items:center;gap:8px;flex-shrink:0}.sidebar-header h1{font-size:16px;font-weight:600;color:var(--accent)}.sidebar-toggle{background:transparent;border:1px solid transparent;color:var(--text-faint);font-size:16px;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:6px;cursor:pointer;line-height:1;flex-shrink:0;margin-left:auto;transition:all .15s}.sidebar-toggle:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--border-strong)}.sidebar-expand-btn{position:absolute;left:0;top:50%;transform:translateY(-50%);z-index:50;background:var(--bg-surface);border:1px solid var(--border-strong);border-left:none;color:var(--text-faint);font-size:14px;width:20px;height:44px;display:flex;align-items:center;justify-content:center;cursor:pointer;border-radius:0 6px 6px 0;transition:all .15s}.sidebar-expand-btn:hover{border-color:var(--text-ghost);color:var(--text-primary);background:var(--bg-elevated)}.file-selector{padding:12px 14px;border-bottom:1px solid var(--border-default)}.file-selector select{width:100%;padding:8px 10px;background:var(--bg-input);color:var(--text-primary);border:1px solid var(--border-strong);border-radius:8px;font-size:13px;cursor:pointer;-webkit-appearance:auto;-moz-appearance:auto;appearance:auto;transition:border-color .15s}.file-selector select:focus{outline:none;border-color:var(--accent)}.file-selector-status{font-size:12px;color:var(--text-ghost)}.file-selector-status.error{color:var(--accent)}.file-meta{margin-top:6px;font-size:10px;color:var(--text-faint);font-family:var(--font-mono)}.kpi-tree{flex:1;overflow-y:auto;display:flex;flex-direction:column}.tree-filter{margin:10px 14px 6px;padding:8px 12px;background:var(--bg-input);color:var(--text-primary);border:1px solid var(--border-strong);border-radius:8px;font-size:12px;transition:border-color .15s}.tree-filter::-moz-placeholder{color:var(--text-faint)}.tree-filter::placeholder{color:var(--text-faint)}.tree-filter:focus{outline:none;border-color:var(--accent)}.tree-root{list-style:none;flex:1;overflow-y:auto;padding:4px 0 20px}.tree-root ul{list-style:none}.tree-branch{display:flex;align-items:center;gap:6px;padding:5px 10px;cursor:pointer;font-size:12px;font-weight:500;-webkit-user-select:none;-moz-user-select:none;user-select:none;color:var(--text-secondary);border-radius:6px;margin:1px 6px;transition:background .1s}.tree-branch:hover{background:var(--bg-hover)}.tree-leaf{display:flex;align-items:center;gap:6px;padding:5px 12px;cursor:pointer;font-size:12px;color:var(--text-tertiary);-webkit-user-select:none;-moz-user-select:none;user-select:none;border-radius:6px;margin:1px 6px;transition:all .1s}.tree-leaf:hover{background:var(--bg-hover);color:var(--text-primary)}.tree-leaf.selected{background:var(--accent-bg);color:var(--accent-light)}.tree-leaf.dragging{opacity:.5}.tree-icon{flex-shrink:0;font-size:13px}.tree-icon.folder{color:var(--text-muted)}.tree-icon.table-icon{color:var(--accent)}.tree-icon.metric{color:var(--text-faint);font-size:11px}.tree-count{margin-left:auto;font-size:10px;color:var(--text-faint);background:var(--bg-elevated);padding:1px 7px;border-radius:10px;font-weight:500}.col-type{margin-left:auto;font-size:9px;color:var(--text-faint);font-family:var(--font-mono);text-transform:uppercase}.tree-signal-entry{display:flex;align-items:center;gap:6px;padding:5px 10px;cursor:pointer;font-size:12px;-webkit-user-select:none;-moz-user-select:none;user-select:none;color:var(--text-tertiary);border-radius:6px;margin:1px 6px;transition:all .1s}.tree-signal-entry:hover{background:var(--bg-hover);color:var(--text-primary)}.tree-signal-entry.selected{background:var(--accent-bg);color:var(--accent-light)}.sig-tree-badge{margin-left:auto;font-size:9px;font-weight:600;letter-spacing:.5px;padding:2px 6px;border-radius:4px;border:1px solid;flex-shrink:0}.sig-tree-badge.signal{color:var(--success);border-color:var(--success);background:var(--success-bg)}.sig-tree-badge.event{color:var(--info);border-color:var(--info);background:var(--info-bg)}.tree-leaf.kpi-empty,.tree-table.kpi-empty{opacity:.25;cursor:default}.tree-leaf.kpi-empty:hover,.tree-table.kpi-empty:hover{background:transparent;color:inherit}.tree-summary-status{padding:4px 14px 6px;font-size:10px}.status-loading{color:var(--text-faint);font-style:italic}.status-ready{color:var(--text-faint)}.tree-table{display:flex;align-items:center;gap:6px;padding:5px 10px;cursor:pointer;font-size:12px;font-weight:500;-webkit-user-select:none;-moz-user-select:none;user-select:none;color:var(--accent-light);border-radius:6px;margin:1px 6px;transition:background .1s}.tree-table:hover{background:var(--bg-hover)}.tree-table.selected{background:var(--accent-bg)}.table-label{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.btn-select-all{display:none}.workspace{display:flex;flex-direction:column;overflow:hidden;background:var(--bg-base);position:relative;min-width:0}.workspace.empty{display:flex;align-items:center;justify-content:center}.placeholder{text-align:center;color:var(--text-faint);max-width:320px}.placeholder h2{font-size:18px;margin-bottom:8px;color:var(--text-muted);font-weight:600}.placeholder p{font-size:13px;line-height:1.6}.tab-bar{display:flex;background:var(--bg-surface);border-bottom:1px solid var(--border-default);overflow-x:auto;min-height:38px;align-items:stretch;gap:1px}.tab-bar:empty:after{content:"Double-click a KPI to open a tab";color:var(--text-faint);font-size:12px;padding:10px 16px}.tab{display:flex;align-items:center;gap:6px;padding:0 14px;cursor:pointer;border-bottom:2px solid transparent;font-size:12px;font-weight:500;color:var(--text-muted);white-space:nowrap;flex-shrink:0;transition:all .15s}.tab:hover{color:var(--text-secondary);background:var(--bg-hover)}.tab.active{color:var(--text-primary);border-bottom-color:var(--accent);background:var(--bg-elevated)}.tab-close{display:flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:4px;border:none;background:transparent;color:var(--text-ghost);font-size:13px;cursor:pointer;line-height:1;transition:all .1s}.tab-close:hover{background:var(--accent);color:#fff}.tab-kpi-count{font-size:10px;color:var(--accent);background:var(--accent-bg);padding:1px 5px;border-radius:6px;font-weight:600}.tab-bar-theme-toggle{margin-left:auto;background:none;border:1px solid transparent;border-radius:6px;color:var(--text-faint);cursor:pointer;padding:6px 8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s}.tab-bar-theme-toggle:hover{color:var(--text-primary);background:var(--bg-hover);border-color:var(--border-strong)}.tab-panel{display:flex;flex-direction:column;flex:1;overflow:hidden}.tab-panel-toolbar{display:flex;align-items:center;justify-content:space-between;padding:8px 16px;border-bottom:1px solid var(--border-default);background:var(--bg-surface);gap:12px;flex-wrap:wrap;min-height:40px}.toolbar-left{display:flex;align-items:center;gap:10px}.toolbar-left h3{font-size:13px;font-weight:600;color:var(--accent);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:300px}.toolbar-right{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.selected-cols{font-size:11px;color:var(--text-faint)}.view-toggle{display:flex;gap:2px;background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:8px;padding:2px}.view-toggle button{display:flex;align-items:center;gap:4px;padding:5px 12px;background:transparent;border:none;color:var(--text-faint);font-size:11px;font-weight:500;cursor:pointer;border-radius:6px;transition:all .15s}.view-toggle button.active{background:var(--bg-surface);color:var(--text-primary);box-shadow:var(--shadow-sm)}.view-toggle button:hover:not(.active){color:var(--text-secondary)}.range-indicator{display:flex;align-items:center;gap:6px;background:var(--bg-hover);border:1px solid var(--border-strong);border-radius:4px;padding:3px 6px 3px 10px;font-size:11px;font-family:monospace;color:var(--text-tertiary)}.range-reset{background:transparent;border:none;color:var(--text-ghost);font-size:14px;line-height:1;cursor:pointer;padding:0 2px;border-radius:2px}.range-reset:hover{color:var(--text-primary);background:var(--accent)}.time-range{display:flex;align-items:center;gap:8px;font-size:11px}.time-range label{display:flex;align-items:center;gap:4px;color:var(--text-faint);font-weight:500}.time-range input{padding:4px 8px;background:var(--bg-input);color:var(--text-primary);border:1px solid var(--border-strong);border-radius:6px;font-size:11px;transition:border-color .15s}.time-range input:focus{outline:none;border-color:var(--accent)}.btn-reset{padding:4px 10px;background:var(--bg-elevated);color:var(--text-secondary);border:1px solid var(--border-strong);border-radius:6px;font-size:11px;cursor:pointer;transition:all .15s}.btn-reset:hover{background:var(--accent);color:#fff;border-color:var(--accent)}.kpi-chip-bar{display:flex;flex-wrap:wrap;gap:4px;padding:6px 14px;background:var(--bg-surface);border-bottom:1px solid var(--border-default);align-items:center}.kpi-chip-tag{display:inline-flex;align-items:center;gap:4px;background:var(--bg-elevated);border:1px solid var(--border-strong);border-radius:6px;padding:3px 6px 3px 10px;font-size:11px;color:var(--text-tertiary);transition:border-color .1s}.kpi-chip-tag:hover{border-color:var(--text-ghost)}.kpi-chip-name{max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.kpi-chip-remove{display:flex;align-items:center;justify-content:center;background:transparent;border:none;color:var(--text-ghost);font-size:13px;line-height:1;cursor:pointer;padding:1px;border-radius:3px;transition:all .1s}.kpi-chip-remove:hover{color:#fff;background:var(--accent)}.workspace-content{flex:1;overflow:hidden;display:flex;flex-direction:column;min-height:0}.loading,.error,.no-data,.chart-empty,.table-empty{display:flex;align-items:center;justify-content:center;flex:1;min-height:120px;color:var(--text-ghost);font-size:14px}.error{color:var(--accent)}.chart-view{flex:1;display:flex;flex-direction:column;min-height:0;overflow:hidden;width:100%}.chart-track{flex:1;display:flex;flex-direction:column;min-height:60px;border-bottom:1px solid var(--border-subtle)}.cat-track{flex:1;min-height:60px}.chart-track-body{flex:1;min-height:0}.chart-track-label{display:flex;align-items:center;gap:8px;font-size:10px;font-weight:600;padding:6px 14px 0;letter-spacing:.3px;flex-shrink:0;text-transform:uppercase}.chart-ref-btn{font-size:9px;padding:2px 7px;background:transparent;border:1px solid var(--border-strong);color:var(--text-faint);border-radius:4px;cursor:pointer;letter-spacing:.3px;line-height:1.4;transition:all .1s;text-transform:none}.chart-ref-btn:hover{border-color:var(--text-ghost);color:var(--text-secondary)}.chart-ref-btn.active{background:var(--bg-elevated);font-weight:700;color:var(--text-primary)}.cat-strip-title{font-size:10px;color:var(--text-ghost);padding:4px 12px 0;font-weight:500;flex-shrink:0}.table-view{flex:1;display:flex;flex-direction:column;min-height:0;overflow:hidden}.table-scroll{flex:1;overflow:auto}.table-scroll table{width:100%;border-collapse:collapse;font-size:12px}.table-scroll thead{position:sticky;top:0;z-index:1}.table-scroll th{background:var(--bg-surface);color:var(--text-muted);padding:10px 14px;text-align:left;font-weight:500;border-bottom:1px solid var(--border-strong);white-space:nowrap}.table-scroll td{padding:8px 14px;border-bottom:1px solid var(--border-subtle);white-space:nowrap}.table-scroll tr:nth-child(2n){background:var(--bg-overlay)}.table-scroll tr:hover{background:var(--bg-hover)}.table-scroll tr.row-pinned{background:#dc262614!important}.table-footer{padding:8px 12px;font-size:12px;color:var(--text-ghost);border-top:1px solid var(--border-default)}.split-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;flex:1;overflow:hidden;background:var(--border-default)}.split-cell{position:relative;overflow:hidden;display:flex;flex-direction:column;background:var(--bg-base);min-width:0;min-height:0;cursor:pointer;outline:2px solid transparent;outline-offset:-2px;transition:outline-color .15s}.split-cell.active{cursor:default}.split-cell-close{position:absolute;top:8px;right:10px;z-index:10;background:var(--bg-surface);border:1px solid var(--border-strong);color:var(--text-faint);font-size:13px;line-height:1;width:22px;height:22px;display:flex;align-items:center;justify-content:center;border-radius:6px;cursor:pointer;transition:all .1s;opacity:0}.split-cell:hover .split-cell-close{opacity:1}.split-cell-close:hover{background:var(--accent);color:#fff;border-color:var(--accent)}.drop-overlay{position:absolute;top:36px;right:0;bottom:0;left:0;display:flex;z-index:100;pointer-events:none}.drop-overlay.active{pointer-events:all}.drop-zone{flex:1;display:flex;align-items:center;justify-content:center;border:2px dashed var(--border-strong);margin:8px;border-radius:8px;color:var(--text-placeholder);font-size:14px;font-weight:500;transition:all .15s}.drop-zone.hover{border-color:var(--accent);background:#dc262614;color:var(--accent)}.context-menu{position:fixed;background:var(--bg-surface);border:1px solid var(--border-strong);border-radius:6px;z-index:1000;min-width:180px;padding:4px 0;box-shadow:0 8px 24px #0009}.context-menu-item{padding:8px 16px;cursor:pointer;font-size:13px;color:var(--text-secondary);display:flex;align-items:center;gap:8px}.context-menu-item:hover{background:var(--bg-hover);color:var(--accent)}.context-menu-separator{height:1px;background:var(--border-default);margin:4px 0}.context-menu-item .pin-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.pin-bar{display:flex;gap:4px;padding:5px 16px;background:var(--bg-surface);border-bottom:1px solid var(--border-default);flex-wrap:wrap;align-items:center}.pin-chip{display:flex;align-items:center;gap:5px;padding:3px 10px;border-radius:6px;font-size:11px;cursor:pointer;border:1px solid var(--border-strong);color:var(--text-secondary);background:var(--bg-elevated);transition:border-color .1s}.pin-chip:hover{border-color:var(--accent)}.pin-chip .pin-dot{width:7px;height:7px;border-radius:50%}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-base)}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-ghost)}.view-type-badge{font-size:10px;font-weight:600;letter-spacing:.5px;padding:3px 8px;border-radius:5px;border:1px solid}.view-type-badge.signaling{color:var(--success);border-color:var(--success);background:var(--success-bg)}.view-type-badge.event-log{color:var(--info);border-color:var(--info);background:var(--info-bg)}.sig-empty{display:flex;align-items:center;justify-content:center;height:200px;color:var(--text-ghost);font-size:14px}.sig-container{display:flex;flex-direction:column;height:100%;min-height:0}.sig-toolbar{display:flex;align-items:center;gap:12px;padding:8px 12px;background:var(--bg-overlay);border-bottom:1px solid var(--border-default);flex-wrap:wrap;flex-shrink:0}.sig-search{padding:5px 10px;background:var(--bg-hover);color:var(--text-primary);border:1px solid var(--border-strong);border-radius:4px;font-size:12px;width:200px}.sig-search:focus{outline:none;border-color:var(--accent)}.sig-filters{display:flex;align-items:center;gap:4px}.sig-filters label{font-size:11px;color:var(--text-ghost);margin-right:2px}.sig-filter-btn{padding:4px 10px;background:var(--bg-hover);border:1px solid var(--border-strong);color:var(--text-muted);font-size:11px;cursor:pointer;border-radius:3px}.sig-filter-btn.active{background:var(--border-strong);color:var(--text-primary);border-color:var(--text-dim)}.sig-filter-btn.ul.active{color:var(--success);border-color:var(--success)}.sig-filter-btn.dl.active{color:var(--info);border-color:var(--info)}.sig-proto-select{padding:4px 8px;background:var(--bg-hover);color:var(--text-primary);border:1px solid var(--border-strong);border-radius:3px;font-size:11px;cursor:pointer}.sig-proto-select:focus{outline:none;border-color:var(--accent)}.sig-count{font-size:11px;color:var(--text-ghost);margin-left:auto}.sig-body{display:flex;flex-direction:column;flex:1;overflow:hidden;min-height:0}.sig-list{flex:1;overflow-y:auto;min-height:0}.sig-row{display:flex;align-items:center;gap:8px;padding:5px 12px;cursor:pointer;border-bottom:1px solid var(--border-subtle);font-size:13px;-webkit-user-select:none;-moz-user-select:none;user-select:none}.sig-row:hover{background:var(--bg-elevated)}.sig-row.sig-row-selected{background:var(--accent-bg)}.sig-ts{font-family:var(--font-mono);font-size:11px;color:var(--text-muted);flex-shrink:0;width:90px}.sig-dir{font-size:11px;font-weight:600;flex-shrink:0;width:40px}.sig-ul{color:var(--success)}.sig-dl{color:var(--info)}.sig-proto{font-size:10px;font-weight:700;padding:1px 6px;border-radius:3px;flex-shrink:0;font-family:monospace;letter-spacing:.3px}.sig-channel{font-size:11px;color:var(--text-tertiary);flex-shrink:0}.sig-name{font-size:12px;color:var(--text-secondary);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sig-detail{font-size:11px;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:200px}.sig-detail-pane{flex-shrink:0;height:320px;border-top:2px solid var(--border-strong);overflow:hidden;background:var(--bg-overlay);display:flex;flex-direction:column}.sig-detail-panel{display:flex;flex-direction:row;gap:0;height:100%;overflow:hidden}.sig-detail-meta{width:280px;flex-shrink:0;border-right:1px solid var(--border-default);overflow-y:auto;padding:12px}.sig-detail-decoded{flex:1;overflow:auto;padding:10px 14px;min-width:0}.sig-detail-header{display:flex;align-items:center;gap:10px;padding-left:8px;border-left:3px solid var(--accent);margin-bottom:12px}.sig-detail-title{font-size:13px;font-weight:600;color:var(--text-primary);flex:1}.sig-detail-ts{font-size:11px;color:var(--text-muted);font-family:var(--font-mono)}.sig-detail-grid{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}.sig-detail-row{display:flex;gap:8px;font-size:12px}.sig-detail-key{color:var(--text-muted);width:80px;flex-shrink:0;font-size:11px}.sig-detail-val{color:var(--text-secondary);word-break:break-all}.sig-hex-section{margin-top:8px}.sig-hex-label{font-size:10px;text-transform:uppercase;color:var(--text-muted);letter-spacing:.5px;margin-bottom:6px;font-weight:500}.sig-hex{font-family:var(--font-mono);font-size:11px;color:var(--text-tertiary);background:var(--bg-surface);border:1px solid var(--border-default);border-radius:3px;padding:8px 10px;white-space:pre;overflow-x:auto;line-height:1.6}.sig-decode-section{margin-top:10px}.sig-decode-label{font-size:10px;text-transform:uppercase;color:var(--text-dim);letter-spacing:.5px;margin-bottom:6px}.sig-decode-loading{font-size:11px;color:var(--text-ghost);font-style:italic;padding:6px 0}.sig-decode-text{font-family:monospace;font-size:11px;color:#a0c8a0;background:#050f05;border:1px solid #0f2a0f;border-radius:3px;padding:8px 10px;white-space:pre;overflow-x:auto;line-height:1.6;margin:0;max-height:400px;overflow-y:auto}.sig-decode-error{font-size:11px;color:var(--accent);padding:4px 0;font-style:italic}.sig-decode-progress{font-size:10px;color:var(--text-ghost);margin-left:auto;font-style:italic}.sig-decode-done{font-size:10px;color:#2a6a2a;margin-left:auto}.json-tree{font-family:monospace;font-size:12px;line-height:1.7;color:var(--text-secondary)}.json-tree-node{padding-left:16px}.json-tree-toggle{display:inline-flex;align-items:center;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;gap:4px;color:var(--text-secondary)}.json-tree-toggle:hover{color:var(--text-primary)}.json-tree-arrow{font-size:9px;color:var(--text-ghost);width:10px;display:inline-block}.json-tree-key{color:#7ec8e3}.json-tree-str{color:#a0c878}.json-tree-num{color:#e0a878}.json-tree-bool{color:#c878e0}.json-tree-null{color:var(--text-ghost)}.json-tree-bracket{color:var(--text-faint)}.sig-detail-section-label{font-size:10px;text-transform:uppercase;color:var(--text-placeholder);letter-spacing:.5px;margin-bottom:6px;margin-top:10px}.sig-detail-section-label:first-child{margin-top:0}.sig-decoded-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;gap:10px}.sig-ie-search{font-size:11px;padding:3px 8px;background:var(--bg-elevated);border:1px solid var(--border-strong);border-radius:3px;color:var(--text-secondary);width:160px}.sig-ie-search:focus{outline:none;border-color:var(--accent)}.json-tree-match{background:#3a2500;color:var(--warning);border-radius:2px}.json-tree-key-match{color:var(--warning)}.sig-proc-container{width:100%;overflow-x:auto}.sig-proc-header{display:flex;gap:0;background:var(--bg-surface);border-bottom:1px solid var(--border-strong);position:sticky;top:0}.sig-proc-header span{padding:8px 12px;font-size:11px;color:var(--text-ghost);font-weight:500;flex:1;white-space:nowrap}.sig-proc-rows{display:flex;flex-direction:column}.sig-proc-row{display:flex;border-bottom:1px solid var(--border-subtle)}.sig-proc-row:hover{background:var(--bg-elevated)}.sig-proc-cell{padding:6px 12px;font-size:12px;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sig-result-badge{font-size:11px;font-weight:600;padding:1px 8px;border-radius:3px;border:1px solid}.sig-kpi-strip{border-bottom:1px solid var(--border-default);background:var(--bg-overlay);padding:6px 12px 4px;flex-shrink:0}.sig-kpi-strip-label{font-size:9px;text-transform:uppercase;letter-spacing:.5px;color:var(--text-dim);margin-bottom:2px}.evlog-container{display:flex;flex-direction:column;height:100%;min-height:0}.evlog-toolbar{display:flex;align-items:center;gap:12px;padding:8px 12px;background:var(--bg-overlay);border-bottom:1px solid var(--border-default);flex-shrink:0;flex-wrap:wrap}.evlog-tech-btn{padding:4px 12px;background:var(--bg-hover);border:1px solid var(--border-strong);color:var(--text-muted);font-size:12px;font-weight:600;cursor:pointer;border-radius:3px;transition:border-color .15s,color .15s}.evlog-tech-btn:hover{background:#222}.evlog-list{flex:1;overflow-y:auto;font-size:13px}.evlog-row{display:flex;align-items:center;gap:8px;padding:5px 12px;border-bottom:1px solid var(--border-subtle)}.evlog-row:hover{background:var(--bg-elevated)}.evlog-ts{font-family:monospace;font-size:11px;color:var(--text-ghost);flex-shrink:0;width:90px}.evlog-tech-badge{font-size:10px;font-weight:700;padding:1px 6px;border-radius:3px;border:1px solid;flex-shrink:0;font-family:monospace;letter-spacing:.3px;min-width:46px;text-align:center}.evlog-event{color:var(--text-secondary);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.hp{min-height:100vh;background:var(--hp-bg);color:var(--hp-text);display:flex;flex-direction:column}:root,[data-theme=dark]{--hp-bg: #09090b;--hp-surface: #111114;--hp-elevated: #18181b;--hp-border: #27272a;--hp-border-subtle: #1e1e22;--hp-text: #e4e4e7;--hp-text-secondary: #a1a1aa;--hp-text-muted: #71717a;--hp-text-faint: #52525b;--hp-text-ghost: #3f3f46;--hp-accent: #dc2626;--hp-accent-hover: #ef4444;--hp-hover: rgba(255,255,255,.04);--hp-card-shadow: 0 1px 3px rgba(0,0,0,.3), 0 1px 2px rgba(0,0,0,.2);--hp-modal-overlay: rgba(0,0,0,.7);--hp-input-bg: #18181b;--hp-input-border: #27272a;--hp-input-focus: #3b82f6;--hp-checkbox-accent: #dc2626}[data-theme=light]{--hp-bg: #fafafa;--hp-surface: #ffffff;--hp-elevated: #f4f4f5;--hp-border: #e4e4e7;--hp-border-subtle: #f4f4f5;--hp-text: #18181b;--hp-text-secondary: #3f3f46;--hp-text-muted: #71717a;--hp-text-faint: #a1a1aa;--hp-text-ghost: #d4d4d8;--hp-accent: #dc2626;--hp-accent-hover: #b91c1c;--hp-hover: rgba(0,0,0,.03);--hp-card-shadow: 0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.04);--hp-modal-overlay: rgba(0,0,0,.4);--hp-input-bg: #ffffff;--hp-input-border: #e4e4e7;--hp-input-focus: #3b82f6;--hp-checkbox-accent: #dc2626}.hp-nav{display:flex;align-items:center;justify-content:space-between;padding:0 24px;height:56px;background:var(--hp-surface);border-bottom:1px solid var(--hp-border);flex-shrink:0;position:sticky;top:0;z-index:100}.hp-nav-left{display:flex;align-items:center;gap:12px}.hp-nav-brand{font-size:15px;font-weight:700;color:var(--hp-accent);letter-spacing:-.3px}.hp-nav-right{display:flex;align-items:center;gap:6px}.hp-nav-btn{display:flex;align-items:center;gap:5px;background:none;border:1px solid transparent;border-radius:6px;color:var(--hp-text-muted);font-size:12px;padding:6px 10px;cursor:pointer;transition:all .15s}.hp-nav-btn:hover{background:var(--hp-hover);color:var(--hp-text);border-color:var(--hp-border)}.hp-nav-btn--logout:hover{color:var(--hp-accent);border-color:#dc26264d;background:#dc26260f}.hp-nav-divider{width:1px;height:20px;background:var(--hp-border);margin:0 6px}.hp-nav-user{display:flex;align-items:center;gap:8px}.hp-nav-avatar{width:28px;height:28px;border-radius:50%;background:var(--hp-elevated);border:1px solid var(--hp-border);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;color:var(--hp-text-secondary)}.hp-nav-username{font-size:13px;color:var(--hp-text-secondary);font-weight:500}.hp-content{flex:1;max-width:960px;width:100%;margin:0 auto;padding:32px 32px 64px;display:flex;flex-direction:column;gap:20px;overflow-y:auto}.hp-header{display:flex;align-items:center;justify-content:space-between}.hp-title{font-size:22px;font-weight:700;color:var(--hp-text);margin:0;letter-spacing:-.3px}.hp-subtitle{font-size:13px;color:var(--hp-text-muted);margin:4px 0 0}.hp-header-actions{display:flex;gap:8px}.hp-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.hp-stat-card{background:var(--hp-surface);border:1px solid var(--hp-border);border-radius:10px;padding:16px;transition:border-color .15s}.hp-stat-card:hover{border-color:var(--hp-text-ghost)}.hp-stat-value{font-size:24px;font-weight:700;color:var(--hp-text);line-height:1;margin-bottom:4px}.hp-stat-label{font-size:11px;color:var(--hp-text-muted);text-transform:uppercase;letter-spacing:.5px;font-weight:500}.hp-stat-card--qcom .hp-stat-value{color:#ef4444}.hp-stat-card--logcat .hp-stat-value{color:#3b82f6}.hp-stat-card--pcap .hp-stat-value{color:#22c55e}.hp-upload-row{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.hp-upload-card{display:flex;align-items:center;gap:12px;background:var(--hp-surface);border:1px dashed var(--hp-border);border-radius:10px;padding:16px 18px;cursor:pointer;transition:all .15s;text-align:left}.hp-upload-card:hover{border-style:solid;border-color:var(--hp-text-ghost);background:var(--hp-hover)}.hp-upload-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.hp-upload-label{font-size:13px;font-weight:600;margin-bottom:2px}.hp-upload-hint{font-size:11px;color:var(--hp-text-muted)}.hp-upload-active{background:var(--hp-surface);border:1px solid var(--hp-border);border-radius:10px;overflow:hidden}.hp-upload-naming{display:flex;flex-direction:column;align-items:center;gap:12px;padding:28px 24px}.hp-upload-naming-icon{color:var(--hp-text-muted)}.hp-upload-naming-info{text-align:center}.hp-upload-naming-title{font-size:15px;font-weight:600;color:var(--hp-text);margin-bottom:4px}.hp-upload-naming-file{font-size:12px;color:var(--hp-text-muted)}.hp-upload-naming-size{margin-left:8px;opacity:.7}.hp-upload-naming-btns{display:flex;gap:8px;margin-top:4px}.hp-upload-progress-card{display:flex;align-items:center;gap:16px;padding:20px 24px}.hp-upload-progress-card--success{background:#22c55e0a}.hp-upload-progress-card--error{background:#ef44440a}.hp-upload-progress-info{flex:1;min-width:0}.hp-upload-progress-title{font-size:13px;font-weight:600;color:var(--hp-text);margin-bottom:6px}.hp-progress-bar{width:100%;height:4px;background:var(--hp-elevated);border-radius:2px;overflow:hidden;margin-bottom:4px}.hp-progress-fill{height:100%;background:linear-gradient(90deg,#8b5cf6,#a78bfa);border-radius:2px;transition:width .5s ease}.hp-input{width:100%;max-width:320px;background:var(--hp-input-bg);border:1px solid var(--hp-input-border);border-radius:8px;color:var(--hp-text);font-size:13px;padding:10px 14px;outline:none;transition:border-color .15s,box-shadow .15s}.hp-input:focus{border-color:var(--hp-input-focus);box-shadow:0 0 0 3px #3b82f626}.hp-toolbar{display:flex;align-items:center;gap:12px}.hp-search{position:relative;flex:1;max-width:280px}.hp-search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--hp-text-faint);pointer-events:none}.hp-search-input{width:100%;background:var(--hp-surface);border:1px solid var(--hp-border);border-radius:8px;color:var(--hp-text);font-size:12px;padding:8px 30px 8px 32px;outline:none;transition:border-color .15s}.hp-search-input:focus{border-color:var(--hp-text-muted)}.hp-search-input::-moz-placeholder{color:var(--hp-text-faint)}.hp-search-input::placeholder{color:var(--hp-text-faint)}.hp-search-clear{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--hp-text-faint);cursor:pointer;padding:2px;display:flex}.hp-search-clear:hover{color:var(--hp-text-secondary)}.hp-filter-tabs{display:flex;gap:2px;background:var(--hp-surface);border:1px solid var(--hp-border);border-radius:8px;padding:3px}.hp-filter-tab{background:none;border:none;border-radius:6px;color:var(--hp-text-muted);font-size:11px;font-weight:500;padding:5px 12px;cursor:pointer;transition:all .15s}.hp-filter-tab:hover{color:var(--hp-text-secondary)}.hp-filter-tab--active{background:var(--hp-elevated);color:var(--hp-text)}.hp-check-all{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--hp-text-muted);cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;margin-left:auto}.hp-check-all input{accent-color:var(--hp-checkbox-accent);cursor:pointer}.hp-selection-bar{display:flex;align-items:center;justify-content:space-between;background:var(--hp-surface);border:1px solid var(--hp-accent);border-radius:10px;padding:12px 16px;animation:hp-slide-in .2s ease}@keyframes hp-slide-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.hp-selection-count{font-size:13px;font-weight:500;color:var(--hp-text-secondary)}.hp-file-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px}.hp-file-card{background:var(--hp-surface);border:1px solid var(--hp-border);border-radius:10px;padding:16px;cursor:pointer;transition:all .15s;display:flex;flex-direction:column;gap:12px}.hp-file-card:hover{border-color:var(--hp-text-ghost);box-shadow:var(--hp-card-shadow)}.hp-file-card--selected{border-color:var(--hp-accent);background:#dc262608}.hp-file-card-top{display:flex;align-items:center;gap:8px}.hp-file-check{accent-color:var(--hp-checkbox-accent);cursor:pointer;flex-shrink:0;margin:0}.hp-file-type-badge{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;padding:3px 8px;border-radius:5px;border:1px solid}.hp-file-actions{display:flex;gap:2px;margin-left:auto;opacity:0;transition:opacity .15s}.hp-file-card:hover .hp-file-actions{opacity:1}.hp-file-action-btn{background:none;border:none;color:var(--hp-text-faint);cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center;transition:all .1s}.hp-file-action-btn:hover{color:var(--hp-text-secondary);background:var(--hp-hover)}.hp-file-action-btn--danger:hover{color:var(--hp-accent);background:#dc26260f}.hp-file-card-body{flex:1;min-width:0}.hp-file-name{font-size:13px;font-weight:600;color:var(--hp-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.4}.hp-file-shared-badge{display:inline-flex;align-items:center;gap:4px;font-size:10px;color:#8b5cf6;background:#8b5cf614;padding:2px 6px;border-radius:4px;margin-top:4px}.hp-file-card-footer{display:flex;align-items:center;justify-content:space-between}.hp-file-meta{display:flex;gap:6px}.hp-file-meta-item{font-size:10px;color:var(--hp-text-faint);background:var(--hp-elevated);padding:2px 6px;border-radius:4px;font-family:var(--font-mono);text-transform:uppercase}.hp-file-date{font-size:11px;color:var(--hp-text-faint)}.hp-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:48px 24px;color:var(--hp-text-muted);font-size:13px}.hp-job-history{background:var(--hp-surface);border:1px solid var(--hp-border);border-radius:10px;padding:16px;max-height:300px;overflow-y:auto}.hp-job-history-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.hp-job-history-header h3{margin:0;font-size:14px;font-weight:600;color:var(--hp-text)}.hp-job-item{display:flex;align-items:center;gap:8px;padding:8px 0;border-bottom:1px solid var(--hp-border-subtle);font-size:12px}.hp-job-name{flex:1;color:var(--hp-text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.hp-job-status{font-weight:500;flex-shrink:0}.hp-job-status--complete{color:#22c55e}.hp-job-status--failed{color:#ef4444}.hp-job-status--pending,.hp-job-status--starting,.hp-job-status--extracting,.hp-job-status--identifying,.hp-job-status--parsing,.hp-job-status--modeling,.hp-job-status--importing{color:#f59e0b}.hp-job-error{color:#ef4444;cursor:help;display:flex;flex-shrink:0}.hp-job-date{color:var(--hp-text-faint);flex-shrink:0}.hp-btn{display:inline-flex;align-items:center;gap:6px;border:none;border-radius:8px;font-size:13px;font-weight:500;padding:8px 16px;cursor:pointer;transition:all .15s;white-space:nowrap}.hp-btn--sm{font-size:12px;padding:6px 12px;border-radius:6px}.hp-btn--primary{background:var(--hp-accent);color:#fff}.hp-btn--primary:hover{background:var(--hp-accent-hover)}.hp-btn--primary:disabled{opacity:.5;cursor:not-allowed}.hp-btn--ghost{background:none;border:1px solid var(--hp-border);color:var(--hp-text-muted)}.hp-btn--ghost:hover{background:var(--hp-hover);color:var(--hp-text);border-color:var(--hp-text-ghost)}.hp-btn--danger-ghost{background:none;border:1px solid rgba(239,68,68,.3);color:#ef4444}.hp-btn--danger-ghost:hover{background:#ef44440f}.hp-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--hp-modal-overlay);display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.hp-modal{background:var(--hp-surface);border:1px solid var(--hp-border);border-radius:12px;width:400px;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 16px 64px #0000004d}.hp-modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--hp-border);font-size:14px;font-weight:600;color:var(--hp-text)}.hp-modal-close{background:none;border:none;color:var(--hp-text-faint);cursor:pointer;padding:4px;border-radius:4px;display:flex;transition:all .1s}.hp-modal-close:hover{color:var(--hp-text-secondary);background:var(--hp-hover)}.hp-modal-body{padding:20px;display:flex;flex-direction:column;gap:12px}.hp-modal-label{font-size:11px;font-weight:600;color:var(--hp-text-muted);letter-spacing:.5px;text-transform:uppercase}.hp-modal-hint{font-size:12px;color:var(--hp-text-faint);line-height:1.5}.hp-modal-footer{display:flex;justify-content:flex-end;gap:8px;padding:14px 20px;border-top:1px solid var(--hp-border)}.hp-status{font-size:12px;padding:6px 10px;border-radius:6px;display:flex;align-items:center;gap:6px}.hp-status--info{color:#3b82f6;background:#3b82f614}.hp-status--success{color:#22c55e;background:#22c55e14}.hp-status--error{color:#ef4444;background:#ef444414}.hp-status--warning{color:#f59e0b;background:#f59e0b14}.hp-share-info{font-size:13px;color:var(--hp-text-muted)}.hp-permission-badge{display:inline-block;margin-left:8px;font-size:11px;background:#3b82f614;color:#8b8bdb;padding:2px 8px;border-radius:4px}.hp-permission-badge--analyze{background:#22c55e14;color:#6dc96d}.hp-share-form{display:flex;gap:8px;align-items:center}.hp-select{flex:1;background:var(--hp-input-bg);color:var(--hp-text-secondary);border:1px solid var(--hp-input-border);border-radius:6px;padding:8px 10px;font-size:12px;outline:none}.hp-select--sm{flex:none;padding:6px 8px}.hp-select--xs{padding:2px 6px;font-size:11px;flex:none}.hp-form-error{font-size:12px;color:#ef4444}.hp-share-legend{font-size:11px;color:var(--hp-text-faint);line-height:1.5}.hp-share-legend strong{color:var(--hp-text-muted)}.hp-share-legend-sep{margin:0 8px}.hp-muted-text{font-size:12px;color:var(--hp-text-faint)}.hp-share-list-title{font-size:11px;color:var(--hp-text-muted);margin-bottom:6px}.hp-share-item{display:flex;align-items:center;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--hp-border-subtle);font-size:13px}.hp-share-username{color:var(--hp-text-secondary)}.hp-share-controls{display:flex;gap:8px;align-items:center}.hp-share-remove{background:none;border:none;color:#ef4444;cursor:pointer;display:flex;padding:2px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spin-icon{animation:spin 1.2s linear infinite}.back-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:0 6px 0 0;line-height:1;display:flex;align-items:center}.back-btn:hover{color:var(--accent)}.settings-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.settings-modal{background:var(--bg-surface);border:1px solid var(--border-strong);border-radius:var(--radius-xl);width:380px;display:flex;flex-direction:column;overflow:hidden;box-shadow:var(--shadow-lg)}.settings-modal-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border-default);font-size:13px;font-weight:600;color:var(--text-primary)}.settings-close{background:none;border:none;color:var(--text-faint);font-size:18px;cursor:pointer;line-height:1;padding:0 2px}.settings-close:hover{color:var(--accent)}.settings-modal-body{padding:20px 16px 16px;display:flex;flex-direction:column;gap:8px}.settings-label{font-size:11px;font-weight:600;color:var(--text-muted);letter-spacing:.5px;text-transform:uppercase}.settings-input{background:var(--bg-overlay);border:1px solid var(--border-strong);border-radius:6px;color:var(--text-primary);font-size:13px;font-family:monospace;padding:9px 12px;outline:none;width:100%;box-sizing:border-box}.settings-input:focus{border-color:var(--accent)}.settings-hint{font-size:11px;color:var(--text-dim);line-height:1.5}.settings-modal-footer{display:flex;justify-content:flex-end;gap:8px;padding:12px 16px;border-top:1px solid var(--border-default)}.settings-cancel{background:none;border:1px solid var(--border-strong);border-radius:6px;color:var(--text-faint);font-size:12px;padding:6px 14px;cursor:pointer}.settings-cancel:hover{background:var(--bg-hover);color:var(--text-tertiary)}.settings-save{background:var(--accent);border:none;border-radius:6px;color:var(--text-primary);font-size:12px;font-weight:600;padding:6px 16px;cursor:pointer}.settings-save:hover{background:var(--accent-hover)}.settings-save:disabled{background:var(--accent-dark);cursor:not-allowed;opacity:.7}.settings-input.valid{border-color:var(--success)}.settings-input.invalid{border-color:var(--error)}.settings-status{font-size:12px;padding:5px 0}.settings-status.validating{color:var(--text-muted)}.settings-status.valid{color:var(--success)}.settings-status.invalid{color:var(--error)}.settings-key-set{color:var(--success)}.lp{display:flex;height:100vh;overflow:hidden;transition:background .3s,color .3s}.lp--dark{background:#09090b;color:#e4e4e7}.lp--light{background:#fafafa;color:#18181b}.lp-theme-toggle{position:absolute;top:20px;right:24px;z-index:10;background:none;border:1px solid transparent;border-radius:8px;padding:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:border-color .2s,background .2s;color:#71717a}.lp--dark .lp-theme-toggle:hover{border-color:currentColor;background:#18181b}.lp--light .lp-theme-toggle:hover{border-color:#d4d4d8;background:#e4e4e7}.lp-brand{flex:1;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:48px 40px;position:relative}.lp--dark .lp-brand{background:#111114}.lp--light .lp-brand{background:#f0f0f2}.lp-brand-content{max-width:420px;width:100%}.lp-brand-title{font-size:32px;font-weight:800;margin:0 0 8px;letter-spacing:-.5px}.lp--dark .lp-brand-title{color:#fafafa}.lp--light .lp-brand-title{color:#18181b}.lp-brand-tagline{font-size:16px;margin:0 0 32px;font-weight:400}.lp--dark .lp-brand-tagline{color:#a1a1aa}.lp--light .lp-brand-tagline{color:#71717a}.lp-brand-divider{width:48px;height:3px;border-radius:3px;margin-bottom:32px}.lp--dark .lp-brand-divider,.lp--light .lp-brand-divider{background:#dc2626}.lp-features{display:flex;flex-direction:column;gap:20px}.lp-feature{display:flex;gap:14px;align-items:flex-start}.lp-feature-icon{flex-shrink:0;width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center}.lp--dark .lp-feature-icon{background:#1e1e22;color:#dc2626}.lp--light .lp-feature-icon{background:#fee2e2;color:#dc2626}.lp-feature-title{font-size:13px;font-weight:600;margin-bottom:2px}.lp--dark .lp-feature-title{color:#e4e4e7}.lp--light .lp-feature-title{color:#18181b}.lp-feature-desc{font-size:12px;line-height:1.5}.lp--dark .lp-feature-desc{color:#71717a}.lp--light .lp-feature-desc{color:#a1a1aa}.lp-brand-copy{position:absolute;bottom:24px;font-size:11px}.lp--dark .lp-brand-copy{color:#3f3f46}.lp--light .lp-brand-copy{color:#a1a1aa}.lp-form-panel{flex:1;display:flex;align-items:center;justify-content:center;padding:48px 40px}.lp-form-wrap{width:100%;max-width:380px}.lp-form-header{margin-bottom:32px}.lp-form-brand{font-size:20px;font-weight:800;letter-spacing:-.3px;margin-bottom:20px;color:#dc2626}.lp-form-title{font-size:24px;font-weight:700;margin:0 0 8px;letter-spacing:-.3px}.lp--dark .lp-form-title{color:#fafafa}.lp--light .lp-form-title{color:#18181b}.lp-form-sub{font-size:14px;margin:0}.lp--dark .lp-form-sub{color:#71717a}.lp--light .lp-form-sub{color:#a1a1aa}.lp-form{display:flex;flex-direction:column;gap:20px}.lp-label{display:flex;flex-direction:column;gap:6px}.lp-label>span{font-size:13px;font-weight:500}.lp--dark .lp-label>span{color:#a1a1aa}.lp--light .lp-label>span{color:#52525b}.lp-input-wrap{position:relative}.lp-input-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);pointer-events:none}.lp--dark .lp-input-icon{color:#52525b}.lp--light .lp-input-icon{color:#a1a1aa}.lp-input{width:100%;box-sizing:border-box;padding:11px 12px 11px 40px;border-radius:8px;font-size:14px;outline:none;transition:border-color .15s,box-shadow .15s}.lp--dark .lp-input{background:#18181b;border:1px solid #27272a;color:#e4e4e7}.lp--dark .lp-input::-moz-placeholder{color:#52525b}.lp--dark .lp-input::placeholder{color:#52525b}.lp--light .lp-input{background:#fff;border:1px solid #e4e4e7;color:#18181b}.lp--light .lp-input::-moz-placeholder{color:#a1a1aa}.lp--light .lp-input::placeholder{color:#a1a1aa}.lp-input:focus{border-color:#dc2626;box-shadow:0 0 0 3px #dc262626}.lp-btn{width:100%;padding:12px 0;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;letter-spacing:.3px;transition:background .15s,transform .1s;display:flex;align-items:center;justify-content:center;gap:8px;background:#dc2626;color:#fff;margin-top:4px}.lp-btn:hover{background:#b91c1c}.lp-btn:active{transform:scale(.98)}.lp-btn:disabled{background:#6b1313;cursor:not-allowed;opacity:.7;transform:none}.lp-spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:lp-spin .6s linear infinite}@keyframes lp-spin{to{transform:rotate(360deg)}}.lp-error{border-radius:8px;padding:10px 14px;font-size:13px;text-align:center}.lp--dark .lp-error{background:#1c0505;border:1px solid #3b0a0a;color:#ef4444}.lp--light .lp-error{background:#fef2f2;border:1px solid #fecaca;color:#dc2626}.lp-form-footer{margin-top:28px;text-align:center}.lp-form-footer p{font-size:12px;margin:4px 0;line-height:1.5}.lp--dark .lp-form-footer p{color:#3f3f46}.lp--light .lp-form-footer p{color:#a1a1aa}@media (max-width: 900px){.lp{flex-direction:column;overflow-y:auto}.lp-brand{padding:32px 24px 24px}.lp-brand-content{max-width:100%}.lp-features{display:none}.lp-brand-copy{position:static;margin-top:16px}.lp-brand-divider{display:none}.lp-form-panel{padding:24px}}.login-label{display:flex;flex-direction:column;gap:5px;font-size:11px;font-weight:600;color:#888;letter-spacing:.5px;text-transform:uppercase}.login-input{background:var(--bg-input);border:1px solid var(--border-strong);border-radius:6px;color:var(--text-primary);font-size:14px;padding:10px 12px;outline:none;width:100%;box-sizing:border-box}.login-input:focus{border-color:#dc2626}.login-btn{background:#dc2626;color:#fff;border:none;border-radius:6px;padding:10px 0;font-size:14px;font-weight:600;cursor:pointer;margin-top:4px;letter-spacing:.3px}.login-btn:hover{background:#b91c1c}.login-btn:disabled{background:#6b1313;cursor:not-allowed;opacity:.7}.login-error{border-radius:6px;padding:8px 12px;font-size:12px;text-align:center;background:var(--error-bg);color:var(--error);border:1px solid var(--accent-bg-subtle)}.app-loading{display:flex;align-items:center;justify-content:center;height:100vh;background:var(--bg-base);color:var(--text-ghost);font-size:14px;gap:10px}.home-topbar{display:flex;align-items:center;justify-content:space-between;padding:8px 16px;background:var(--bg-surface);border-bottom:1px solid var(--border-default);position:absolute;top:0;left:0;right:0;height:42px;z-index:100}.home-topbar-left{display:flex;align-items:center;gap:12px}.home-topbar-brand{font-size:14px;font-weight:700;color:var(--accent);letter-spacing:.5px}.home-topbar-right{display:flex;align-items:center;gap:10px}.home-topbar-user{font-size:12px;color:var(--text-muted)}.home-topbar-btn{background:none;border:1px solid var(--border-strong);border-radius:5px;color:var(--text-muted);font-size:11px;padding:4px 10px;cursor:pointer}.home-topbar-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.home-topbar-logout:hover{border-color:var(--accent);color:var(--accent)}.admin-page{height:100vh;background:var(--bg-base);color:var(--text-primary);overflow:hidden;display:flex;flex-direction:column}.admin-content{flex:1;overflow-y:auto;padding:32px;max-width:800px;margin:0 auto;width:100%}.admin-section-title{font-size:14px;font-weight:600;color:var(--text-tertiary);margin-bottom:12px;letter-spacing:.3px}.admin-create-form{display:flex;gap:10px;align-items:flex-end}.admin-create-form .login-input{flex:1;font-size:13px;padding:8px 10px}.admin-create-form select.login-input{flex:0 0 100px}.admin-create-form .login-btn{flex:0 0 auto;padding:8px 16px;font-size:12px;margin-top:0}.admin-table{width:100%;border-collapse:collapse;font-size:13px}.admin-table th{text-align:left;font-size:10px;font-weight:600;color:var(--text-faint);text-transform:uppercase;letter-spacing:.5px;padding:8px 10px;border-bottom:1px solid var(--border-default)}.admin-table td{padding:8px 10px;border-bottom:1px solid var(--border-subtle);color:var(--text-secondary)}.admin-table tr:hover{background:var(--bg-surface)}.admin-role-badge{font-size:10px;padding:2px 8px;border-radius:3px;font-weight:600;text-transform:uppercase;letter-spacing:.3px}.admin-role-badge.admin{background:var(--accent-bg);color:var(--accent);border:1px solid var(--accent-bg-subtle)}.admin-role-badge.user{background:var(--success-bg);color:var(--success);border:1px solid var(--success-bg)}.admin-action-btn{background:none;border:1px solid var(--border-strong);border-radius:4px;color:var(--text-muted);font-size:11px;padding:3px 10px;cursor:pointer;margin-right:4px}.admin-action-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.admin-action-btn.save{border-color:var(--success);color:var(--success)}.admin-action-btn.delete:hover{border-color:var(--accent);color:var(--accent)}.admin-edit-input{background:var(--bg-input);border:1px solid var(--border-strong);border-radius:4px;color:var(--text-primary);font-size:12px;padding:4px 8px;outline:none;width:100%}.admin-edit-input:focus{border-color:var(--accent)}
