.notification-banner-container{z-index:9999;pointer-events:none;flex-direction:column;gap:8px;width:min(380px,100vw - 24px);display:flex;position:fixed;top:12px;left:50%;transform:translate(-50%)}.notification-banner{background:var(--surface);border:1px solid var(--border);cursor:pointer;pointer-events:auto;border-radius:12px;align-items:center;gap:10px;padding:12px 16px;animation:.3s ease-out forwards notif-slide-in;display:flex;box-shadow:0 4px 20px #0000004d}.notification-banner.slide-out{animation:.3s ease-in forwards notif-slide-out}.notification-dot{background:var(--success);border-radius:50%;flex-shrink:0;width:8px;height:8px}.notification-body{flex-direction:column;min-width:0;display:flex}.notification-title{white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.notification-text{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:12px;overflow:hidden}.notification-command{font-style:italic}@keyframes notif-slide-in{0%{opacity:0;transform:translateY(-100%)}to{opacity:1;transform:translateY(0)}}@keyframes notif-slide-out{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-100%)}}.session-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;touch-action:pan-y;align-items:center;gap:12px;margin-bottom:10px;padding:14px 16px;transition:background .15s;display:flex;position:relative}.session-card:active{background:var(--surface2)}.session-card--child{border-left:2px solid var(--border)}.status-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.status-dot--working{animation:1.5s ease-in-out infinite working-pulse}@keyframes working-pulse{0%,to{opacity:1;box-shadow:0 0 #f59e0b66}50%{opacity:.7;box-shadow:0 0 6px 2px #f59e0b4d}}.session-info{flex:1;min-width:0}.session-name{white-space:nowrap;text-overflow:ellipsis;font-size:15px;font-weight:500;overflow:hidden}.session-agent-message,.session-meta{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;margin-top:2px;font-size:12px;overflow:hidden}.unread-dot{background:var(--danger);border-radius:50%;flex-shrink:0;width:8px;height:8px;animation:2s infinite unread-pulse;box-shadow:0 0 4px #f8514999}@keyframes unread-pulse{0%,to{opacity:1}50%{opacity:.3}}.stop-btn{background:var(--danger);color:#fff;border-radius:var(--radius);cursor:pointer;border:none;flex-shrink:0;padding:6px 12px;font-size:12px}.stop-btn:active{opacity:.7}.delete-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:4px;flex-shrink:0;padding:2px 6px;font-size:16px}.delete-btn:hover{color:var(--danger);background:var(--surface2)}.history-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;opacity:.8;touch-action:pan-y;margin-bottom:8px;padding:12px 16px;transition:background .15s}.history-card:active{background:var(--surface2)}.history-card-inner{align-items:flex-start;gap:10px;display:flex}.history-card-info{flex:1;min-width:0}.history-title{white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:500;overflow:hidden}.history-subtitle{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;margin-top:3px;font-size:12px;overflow:hidden}.history-meta{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;margin-top:2px;font-size:11px;overflow:hidden}.modal-overlay{z-index:1000;background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-box{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);width:90%;max-width:420px;padding:24px}.modal-box h3{margin-bottom:16px;font-size:18px}.modal-box label{color:var(--text-muted);margin-top:12px;margin-bottom:6px;font-size:13px;display:block}.modal-box label:first-of-type{margin-top:0}.modal-box input,.modal-box select{background:var(--surface2);border:1px solid var(--border);width:100%;color:var(--text);border-radius:8px;outline:none;padding:9px 12px;font-size:14px}.modal-box input:focus,.modal-box select:focus{border-color:var(--accent)}.modal-actions{justify-content:flex-end;gap:8px;margin-top:20px;display:flex}.btn-create{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:8px 16px;font-size:14px;font-weight:600}.session-list-view{flex-direction:column;height:100dvh;display:flex}.app-header{background:var(--surface);border-bottom:1px solid var(--border);min-height:var(--header-h);flex-shrink:0;justify-content:space-between;align-items:center;padding:10px 16px;display:flex}.app-title{font-size:18px;font-weight:700}.header-actions{gap:8px;display:flex}.btn-new,.btn-settings{cursor:pointer;border:none;border-radius:8px;padding:6px 14px;font-size:13px;font-weight:600}.btn-new{background:var(--accent);color:#fff}.btn-settings{background:var(--surface2);color:var(--text-muted);border:1px solid var(--border);padding:4px 10px;font-size:16px}.settings-dropdown{position:relative}.settings-menu{background:var(--surface2);border:1px solid var(--border);z-index:100;border-radius:8px;min-width:120px;margin-top:4px;position:absolute;top:100%;right:0;overflow:hidden}.settings-menu button{width:100%;color:var(--text-muted);cursor:pointer;text-align:left;background:0 0;border:none;padding:8px 14px;font-size:13px;font-weight:600;display:block}.settings-menu button:hover{background:var(--surface);color:var(--text)}.session-cards{-webkit-overflow-scrolling:touch;flex:1;padding:12px 16px;overflow-y:auto}@media (width>=768px){.session-cards{width:100%;max-width:600px;margin:0 auto}}.history-divider{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;align-items:center;gap:10px;margin:16px 0 8px;font-size:12px;display:flex}.history-divider:after{content:"";border-top:1px solid var(--border);flex:1}.history-sentinel{height:1px}.xterm{cursor:text;-webkit-user-select:none;user-select:none;position:relative}.xterm.focus,.xterm:focus{outline:none}.xterm .xterm-helpers{z-index:5;position:absolute;top:0}.xterm .xterm-helper-textarea{opacity:0;z-index:-5;white-space:nowrap;resize:none;border:0;width:0;height:0;margin:0;padding:0;position:absolute;top:0;left:-9999em;overflow:hidden}.xterm .composition-view{color:#fff;white-space:nowrap;z-index:1;background:#000;display:none;position:absolute}.xterm .composition-view.active{display:block}.xterm .xterm-viewport{cursor:default;background-color:#000;position:absolute;inset:0;overflow-y:scroll}.xterm .xterm-screen{position:relative}.xterm .xterm-screen canvas{position:absolute;top:0;left:0}.xterm-char-measure-element{visibility:hidden;line-height:normal;display:inline-block;position:absolute;top:0;left:-9999em}.xterm.enable-mouse-events{cursor:default}.xterm.xterm-cursor-pointer,.xterm .xterm-cursor-pointer{cursor:pointer}.xterm.column-select.focus{cursor:crosshair}.xterm .xterm-accessibility:not(.debug),.xterm .xterm-message{z-index:10;color:#0000;pointer-events:none;position:absolute;inset:0}.xterm .xterm-accessibility-tree:not(.debug) ::selection{color:#0000}.xterm .xterm-accessibility-tree{-webkit-user-select:text;user-select:text;white-space:pre;font-family:monospace}.xterm .xterm-accessibility-tree>div{transform-origin:0;width:fit-content}.xterm .live-region{width:1px;height:1px;position:absolute;left:-9999px;overflow:hidden}.xterm-dim{opacity:1!important}.xterm-underline-1{text-decoration:underline}.xterm-underline-2{-webkit-text-decoration:underline double;text-decoration:underline double}.xterm-underline-3{-webkit-text-decoration:underline wavy;text-decoration:underline wavy}.xterm-underline-4{-webkit-text-decoration:underline dotted;text-decoration:underline dotted}.xterm-underline-5{-webkit-text-decoration:underline dashed;text-decoration:underline dashed}.xterm-overline{text-decoration:overline}.xterm-overline.xterm-underline-1{text-decoration:underline overline}.xterm-overline.xterm-underline-2{-webkit-text-decoration:overline double underline;text-decoration:overline double underline}.xterm-overline.xterm-underline-3{-webkit-text-decoration:overline wavy underline;text-decoration:overline wavy underline}.xterm-overline.xterm-underline-4{-webkit-text-decoration:overline dotted underline;text-decoration:overline dotted underline}.xterm-overline.xterm-underline-5{-webkit-text-decoration:overline dashed underline;text-decoration:overline dashed underline}.xterm-strikethrough{text-decoration:line-through}.xterm-screen .xterm-decoration-container .xterm-decoration{z-index:6;position:absolute}.xterm-screen .xterm-decoration-container .xterm-decoration.xterm-decoration-top-layer{z-index:7}.xterm-decoration-overview-ruler{z-index:8;pointer-events:none;position:absolute;top:0;right:0}.xterm-decoration-top{z-index:2;position:relative}.xterm .xterm-scrollable-element>.scrollbar{cursor:default}.xterm .xterm-scrollable-element>.scrollbar>.scra{cursor:pointer;font-size:11px!important}.xterm .xterm-scrollable-element>.visible{opacity:1;z-index:11;background:0 0;transition:opacity .1s linear}.xterm .xterm-scrollable-element>.invisible{opacity:0;pointer-events:none}.xterm .xterm-scrollable-element>.invisible.fade{transition:opacity .8s linear}.xterm .xterm-scrollable-element>.shadow{display:none;position:absolute}.xterm .xterm-scrollable-element>.shadow.top{width:100%;height:3px;box-shadow:var(--vscode-scrollbar-shadow,#000) 0 6px 6px -6px inset;display:block;top:0;left:3px}.xterm .xterm-scrollable-element>.shadow.left{width:3px;height:100%;box-shadow:var(--vscode-scrollbar-shadow,#000) 6px 0 6px -6px inset;display:block;top:3px;left:0}.xterm .xterm-scrollable-element>.shadow.top-left-corner{width:3px;height:3px;display:block;top:0;left:0}.xterm .xterm-scrollable-element>.shadow.top.left{box-shadow:var(--vscode-scrollbar-shadow,#000) 6px 0 6px -6px inset}.textarea-panel{background:var(--surface);flex-shrink:0;padding:6px 10px;position:relative}.textarea-panel.hidden{height:0;padding:0 10px;overflow:hidden}.textarea-panel .msg-input{box-sizing:border-box;background:var(--surface2);border:1px solid var(--border);width:100%;color:var(--text);resize:none;border-radius:20px;outline:none;min-height:38px;max-height:33vh;padding:8px 12px;font-family:inherit;font-size:15px;line-height:1.4;display:block}.textarea-panel .msg-input:focus{border-color:var(--accent)}.textarea-panel .msg-input.voice-active{min-height:80px;max-height:33vh}.clear-btn{background:var(--surface2);width:22px;height:22px;color:var(--text-muted);cursor:pointer;z-index:1;opacity:.7;border:none;border-radius:50%;justify-content:center;align-items:center;padding:0;display:flex;position:absolute;top:10px;right:16px}.clear-btn:hover{opacity:1;background:var(--border)}.action-bar{padding:8px 10px;padding-bottom:max(30px, env(safe-area-inset-bottom));background:var(--surface);border-top:1px solid var(--border);flex-shrink:0;align-items:center;gap:6px;display:flex}.action-bar .upload-btn{cursor:pointer;background:var(--surface2);width:38px;height:38px;color:var(--text-muted);border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:16px;display:flex}.action-bar .upload-btn.uploading{animation:1s infinite pulse-upload}.action-bar .mic-btn.wide,.action-bar .send-btn.wide{cursor:pointer;border:none;border-radius:19px;flex:1;justify-content:center;align-items:center;gap:6px;height:38px;font-size:14px;font-weight:600;display:flex}.action-bar .mic-btn.wide{background:var(--surface2);color:var(--text-muted)}.action-bar .mic-btn.wide.listening{background:var(--danger);color:#fff;animation:1.5s infinite mic-pulse}.action-bar .mic-btn.wide.polishing{opacity:.6}.action-bar .send-btn.wide{background:var(--accent);color:#fff}.action-bar .send-btn.wide:disabled,.action-bar .upload-btn:disabled,.action-bar .mic-btn.wide:disabled{opacity:.4;cursor:not-allowed}@keyframes mic-pulse{0%{box-shadow:0 0 #f8514980}70%{box-shadow:0 0 0 10px #f8514900}to{box-shadow:0 0 #f8514900}}@keyframes pulse-upload{0%,to{opacity:1}50%{opacity:.5}}.shortcut-bar{background:var(--surface);border-top:1px solid var(--border);-webkit-overflow-scrolling:touch;flex-shrink:0;gap:4px;padding:4px 8px;display:flex;overflow-x:auto}.shortcut-bar::-webkit-scrollbar{display:none}.shortcut-bar button{background:var(--surface2);color:var(--text-muted);border:1px solid var(--border);cursor:pointer;white-space:nowrap;border-radius:6px;flex-shrink:0;padding:5px 10px;font-size:12px;font-weight:500}.shortcut-bar button:active{background:var(--accent);color:#fff}.shortcut-bar .kb-btn{justify-content:center;align-items:center;margin-left:auto;padding:3px 8px;display:flex}.shortcut-bar .kb-btn svg{display:block}.terminal-view{flex-direction:column;height:100dvh;display:flex}.term-header{background:var(--surface);border-bottom:1px solid var(--border);min-height:var(--header-h);flex-shrink:0;align-items:center;gap:8px;padding:8px 12px;display:flex}.back-btn{color:var(--accent);cursor:pointer;background:0 0;border:none;padding:4px 8px;font-size:20px}.term-title{white-space:nowrap;text-overflow:ellipsis;flex:1;font-size:15px;font-weight:600;overflow:hidden}.mode-badge{background:var(--surface2);color:var(--text-muted);border:1px solid var(--border);border-radius:10px;padding:2px 8px;font-size:11px}.status-indicator{border-radius:50%;flex-shrink:0;width:8px;height:8px}.terminal-wrapper{flex:1;position:relative;overflow:hidden}.terminal-container{width:100%;height:100%}.terminal-container .xterm{height:100%}.terminal-container .xterm-viewport::-webkit-scrollbar{display:none;width:0!important}.terminal-container .xterm-viewport{scrollbar-width:none;overflow-y:auto!important}.terminal-container .xterm .xterm-scrollable-element>.scrollbar.vertical{width:3px!important}.terminal-container .xterm .xterm-scrollable-element>.scrollbar.vertical .slider{width:3px!important;left:0!important}.touch-overlay{z-index:10;touch-action:none;position:absolute;inset:0}@media (pointer:fine){.touch-overlay{pointer-events:none}}.select-overlay{background:var(--bg);color:var(--text);-webkit-overflow-scrolling:touch;white-space:pre-wrap;word-break:break-all;z-index:11;-webkit-user-select:text;user-select:text;padding:8px;font-family:Menlo,Monaco,Courier New,monospace;font-size:14px;line-height:1.2;position:absolute;inset:0;overflow:auto}.scroll-bottom-btn{background:var(--surface);border:1px solid var(--border);width:36px;height:36px;color:var(--text);cursor:pointer;z-index:20;opacity:.85;border-radius:50%;justify-content:center;align-items:center;font-size:18px;display:flex;position:absolute;bottom:8px;right:12px}.login-page{justify-content:center;align-items:center;height:100dvh;display:flex}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);width:90%;max-width:360px;padding:32px 28px}.login-card h1{text-align:center;margin-bottom:24px;font-size:22px;font-weight:600}.login-card label{color:var(--text-muted);margin-bottom:6px;font-size:13px;display:block}.login-card input{background:var(--surface2);border:1px solid var(--border);width:100%;color:var(--text);border-radius:8px;outline:none;margin-bottom:16px;padding:10px 12px;font-size:15px}.login-card input:focus{border-color:var(--accent)}.login-card button{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:8px;width:100%;margin-top:4px;padding:11px;font-size:15px;font-weight:600}.login-card button:active{opacity:.85}.setup-hint{text-align:center;color:var(--text-muted);background:var(--surface2);border-radius:8px;margin-bottom:16px;padding:8px;font-size:13px}.toggle-link{text-align:center;margin-top:16px;font-size:13px;display:block}.toggle-link a{color:var(--accent);text-decoration:none}.error-msg{color:var(--danger);text-align:center;margin-top:12px;font-size:13px}.oauth-divider{color:var(--text-muted);align-items:center;gap:12px;margin:20px 0 16px;font-size:13px;display:flex}.oauth-divider:before,.oauth-divider:after{content:"";border-top:1px solid var(--border);flex:1}.oauth-buttons{flex-direction:column;gap:8px;display:flex}.oauth-btn{cursor:pointer;border:1px solid var(--border);border-radius:8px;justify-content:center;align-items:center;gap:10px;width:100%;padding:10px;font-size:14px;font-weight:500;display:flex}.oauth-btn.google{color:#333;background:#fff}.oauth-btn.github{color:#fff;background:#24292e;border-color:#24292e}.oauth-btn:active{opacity:.85}.settings-page{flex-direction:column;height:100dvh;display:flex}.settings-header{background:var(--surface);border-bottom:1px solid var(--border);min-height:var(--header-h);align-items:center;gap:12px;padding:10px 16px;display:flex}.settings-header h2{font-size:18px}.settings-content{flex:1;width:100%;max-width:600px;margin:0 auto;padding:16px;overflow-y:auto}.settings-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:16px;padding:16px}.settings-section h3{color:var(--text);margin-bottom:12px;font-size:15px}.settings-section label{color:var(--text-muted);margin-top:8px;margin-bottom:4px;font-size:13px;display:block}.settings-section input,.settings-section select{background:var(--surface2);border:1px solid var(--border);width:100%;color:var(--text);border-radius:8px;outline:none;margin-bottom:4px;padding:8px 12px;font-size:14px}.settings-section input:focus,.settings-section select:focus{border-color:var(--accent)}.btn-primary{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:8px;margin-top:8px;padding:8px 16px;font-size:14px;font-weight:600}.btn-danger-sm{color:var(--danger);border:1px solid var(--danger);cursor:pointer;background:0 0;border-radius:6px;padding:4px 10px;font-size:12px}.success-msg{color:var(--success);margin-top:8px;font-size:13px}.error-msg{color:var(--danger);margin-top:8px;font-size:13px}.data-table{border-collapse:collapse;width:100%;margin-bottom:12px;font-size:13px}.data-table th{text-align:left;color:var(--text-muted);border-bottom:1px solid var(--border);padding:6px 8px;font-weight:500}.data-table td{border-bottom:1px solid var(--border);padding:6px 8px}.add-form{flex-wrap:wrap;gap:6px;margin-top:8px;display:flex}.add-form input,.add-form select{flex:1;min-width:100px;margin-bottom:0}.add-form button{flex-shrink:0}.hook-status{flex-direction:column;gap:4px;margin-bottom:10px;display:flex}.hook-row{align-items:center;gap:8px;font-size:13px;display:flex}.hook-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.hook-dot--ok{background:var(--success,#22c55e)}.hook-dot--missing{background:var(--danger,#ef4444)}.hook-dot--broken{background:var(--warning,#f59e0b)}.push-toggle{align-items:center;gap:10px;display:flex}.push-status{color:var(--text-muted);font-size:13px}.admin-page{flex-direction:column;height:100dvh;display:flex}.admin-header{background:var(--surface);border-bottom:1px solid var(--border);min-height:var(--header-h);align-items:center;gap:12px;padding:10px 16px;display:flex}.admin-header h2{flex:1;font-size:18px}.admin-ops{gap:8px;margin-left:auto;display:flex}.btn-warning{color:#fff;cursor:pointer;background:#e6a700;border:none;border-radius:8px;padding:6px 14px;font-size:13px}.btn-warning:disabled{opacity:.6;cursor:not-allowed}.btn-danger{color:#fff;cursor:pointer;background:#e53935;border:none;border-radius:8px;padding:6px 14px;font-size:13px}.op-msg{color:var(--text-muted);background:var(--surface);border-bottom:1px solid var(--border);text-align:center;padding:8px 16px;font-size:13px}.admin-tabs{background:var(--surface);border-bottom:1px solid var(--border);padding:0 16px;display:flex}.admin-tabs button{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;padding:10px 16px;font-size:14px}.admin-tabs button.active{color:var(--accent);border-bottom-color:var(--accent)}.admin-content{flex:1;width:100%;max-width:800px;margin:0 auto;padding:16px;overflow-y:auto}.tab-header{justify-content:flex-end;margin-bottom:12px;display:flex}.inline-form{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);flex-wrap:wrap;gap:6px;margin-bottom:12px;padding:12px;display:flex}.inline-form input,.inline-form select{background:var(--surface2);border:1px solid var(--border);min-width:100px;color:var(--text);border-radius:8px;outline:none;flex:1;padding:8px 12px;font-size:14px}.inline-form input:focus,.inline-form select:focus{border-color:var(--accent)}.btn-cancel{background:var(--surface2);color:var(--text-muted);border:1px solid var(--border);cursor:pointer;border-radius:8px;padding:8px 16px;font-size:14px}.role-badge{background:var(--surface2);color:var(--text-muted);border-radius:10px;padding:2px 8px;font-size:11px}.role-badge.admin{background:var(--accent);color:#fff}.field-badge{background:var(--accent);color:#fff;border-radius:8px;margin-right:3px;padding:1px 6px;font-size:10px;display:inline-block}.toggle-btn{border:1px solid var(--border);background:var(--surface2);color:var(--text-muted);cursor:pointer;border-radius:10px;padding:3px 10px;font-size:12px}.toggle-btn.active{background:var(--success);color:#fff;border-color:var(--success)}:root{--bg:#0d1117;--surface:#161b22;--surface2:#21262d;--border:#30363d;--text:#e6edf3;--text-muted:#8b949e;--accent:#58a6ff;--user-bg:#1f6feb;--success:#3fb950;--warning:#d29922;--danger:#f85149;--radius:12px;--header-h:48px}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);-webkit-text-size-adjust:100%;height:100dvh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;overflow:hidden}#root{height:100dvh;overflow:hidden}
