*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#fdf5f7;--bg-elevated:#fff;--accent:#e91e7a;--accent-soft:#e91e7a1a;--accent-hover:#e91e7a29;--highlight:#ff6b9d;--text:#1a1a1a;--text-2:#666;--text-3:#999;--border:#f0dce2;--border-strong:#e0bcc6;--user-bubble:#e91e7a;--user-text:#fff;--ai-bubble:#fff;--input-bg:#fff;--surface:#fff;--shadow-sm:0 1px 2px #0000000d;--shadow:0 2px 8px #00000014;--shadow-lg:0 8px 32px #0000001f;--glass:#fdf5f7cc;--glass-border:#f0dce299;--topbar-h:56px;--sidebar-w:280px;--max-chat-w:800px;--radius:14px;--radius-sm:10px;--radius-xs:6px;--font:-apple-system, BlinkMacSystemFont, "SF Pro Text", "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--font-mono:"SF Mono", "Fira Code", "Cascadia Code", Consolas, monospace;--transition:.2s cubic-bezier(.4, 0, .2, 1)}[data-theme=dark]{--bg:#080808;--bg-elevated:#141414;--accent:#ffe99d;--accent-soft:#ffe99d1a;--accent-hover:#ffe99d2e;--highlight:#ffb800;--text:#ececec;--text-2:#999;--text-3:#666;--border:#222;--border-strong:#333;--user-bubble:#ffe99d;--user-text:#080808;--ai-bubble:#141414;--input-bg:#141414;--surface:#141414;--shadow-sm:0 1px 2px #0000004d;--shadow:0 2px 8px #0006;--shadow-lg:0 8px 32px #0009;--glass:#0e0e0ed9;--glass-border:#2229}@media (prefers-color-scheme:dark){:root:not([data-theme=light]){--bg:#080808;--bg-elevated:#141414;--accent:#ffe99d;--accent-soft:#ffe99d1a;--accent-hover:#ffe99d2e;--highlight:#ffb800;--text:#ececec;--text-2:#999;--text-3:#666;--border:#222;--border-strong:#333;--user-bubble:#ffe99d;--user-text:#080808;--ai-bubble:#141414;--input-bg:#141414;--surface:#141414;--shadow-sm:0 1px 2px #0000004d;--shadow:0 2px 8px #0006;--shadow-lg:0 8px 32px #0009;--glass:#0e0e0ed9;--glass-border:#2229}}html,body{height:100%;font-family:var(--font);color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background-color var(--transition), color var(--transition);font-size:15px;line-height:1.55;overflow:hidden}.hidden{display:none!important}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-3)}*{scrollbar-width:thin;scrollbar-color:var(--border-strong) transparent}#app{flex-direction:column;height:100dvh;display:flex;position:relative;overflow:hidden}#topbar{height:var(--topbar-h);background:var(--glass);-webkit-backdrop-filter:blur(20px)saturate(180%);border-bottom:1px solid var(--glass-border);z-index:30;transition:background-color var(--transition), border-color var(--transition);flex-shrink:0;justify-content:space-between;align-items:center;gap:8px;padding:0 12px;display:flex}.topbar-left,.topbar-center,.topbar-right{align-items:center;gap:8px;display:flex}.topbar-left{flex-shrink:0}.topbar-center{flex:1;justify-content:center;gap:6px;min-width:0}.topbar-right{flex-shrink:0}.topbar-left h1{letter-spacing:-.3px;color:var(--text);white-space:nowrap;font-size:17px;font-weight:700}.icon-btn{width:38px;height:38px;color:var(--text-2);cursor:pointer;transition:background-color var(--transition), color var(--transition), transform .1s;-webkit-tap-highlight-color:transparent;background:0 0;border:none;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.icon-btn:hover{background:var(--accent-soft);color:var(--accent)}.icon-btn:active{transform:scale(.92)}.icon-btn.active{color:var(--accent);background:var(--accent-soft)}.pill{background:var(--bg-elevated);border:1px solid var(--border);height:34px;font-family:var(--font);color:var(--text);cursor:pointer;white-space:nowrap;max-width:180px;transition:border-color var(--transition), background-color var(--transition), box-shadow var(--transition);-webkit-tap-highlight-color:transparent;border-radius:17px;align-items:center;gap:5px;padding:0 12px;font-size:13px;font-weight:500;display:inline-flex;overflow:hidden}.pill:hover{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-soft)}.pill:active{transform:scale(.97)}.pill.active{border-color:var(--accent);background:var(--accent-soft)}.pill-muted{color:var(--text-2)}.pill-arrow{opacity:.5;flex-shrink:0;margin-left:2px}#pill-scene-icon{font-size:15px;line-height:1}#pill-scene-label{text-overflow:ellipsis;overflow:hidden}.status-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px;display:inline-block}.status-dot.disconnected{background:var(--text-3)}.status-dot.connecting{background:#f59e0b;animation:1.2s ease-in-out infinite pulse-dot}.status-dot.connected{background:#22c55e;box-shadow:0 0 6px #22c55e66}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.4)}}#device-bar{background:var(--bg-elevated);border-bottom:1px solid var(--border);transition:background-color var(--transition), border-color var(--transition);flex-shrink:0;align-items:center;gap:16px;padding:8px 16px;animation:.25s ease-out slide-down;display:flex}@keyframes slide-down{0%{opacity:0;transform:translateY(-100%)}to{opacity:1;transform:translateY(0)}}.channel{flex:1;align-items:center;gap:8px;min-width:0;display:flex}.channel-label{color:var(--accent);background:var(--accent-soft);border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;width:18px;height:18px;font-size:12px;font-weight:600;display:flex}.strength-bar{background:var(--border);min-width:50px;height:6px;transition:background-color var(--transition);border-radius:3px;flex:1;position:relative}.strength-cap{pointer-events:none;background:#ff3b30;border-radius:1px;width:2px;position:absolute;top:-2px;bottom:-2px;left:25%;transform:translate(-1px);box-shadow:0 0 2px #ff3b3099}.strength-fill{background:linear-gradient(90deg, var(--accent) 0%, var(--highlight) 50%, #ff3b30 100%);background-size:200% 100%;border-radius:3px;width:0%;height:100%;transition:width .3s}.strength-value{font-variant-numeric:tabular-nums;text-align:right;min-width:22px;color:var(--text-2);font-size:12px;font-weight:600}.battery{color:var(--text-3);white-space:nowrap;flex-shrink:0;align-items:center;gap:4px;font-size:12px;display:flex}.wave-indicator{background:var(--accent);border-radius:50%;flex-shrink:0;width:6px;height:6px;animation:.8s ease-in-out infinite pulse-dot}#layout{flex:1;display:flex;position:relative;overflow:hidden}#sidebar{width:var(--sidebar-w);background:var(--bg-elevated);border-right:1px solid var(--border);transition:margin-left var(--transition), background-color var(--transition), border-color var(--transition);z-index:20;flex-direction:column;flex-shrink:0;display:flex;overflow:hidden}#sidebar.sidebar-closed{margin-left:calc(-1 * var(--sidebar-w))}.sidebar-header{flex-shrink:0;justify-content:space-between;align-items:center;padding:16px;display:flex}.sidebar-header h2{color:var(--text);font-size:15px;font-weight:600}.sidebar-list{flex:1;padding:0 8px 8px;overflow-y:auto}#sidebar-overlay{z-index:19;-webkit-backdrop-filter:blur(2px);transition:opacity var(--transition);background:#0006;position:absolute;inset:0}.history-item{border-radius:var(--radius-sm);cursor:pointer;transition:background-color var(--transition);align-items:center;gap:10px;margin-bottom:2px;padding:10px 12px;display:flex}.history-item:hover,.history-item.active{background:var(--accent-soft)}.history-item-info{flex:1;min-width:0}.history-item-title{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:13.5px;font-weight:500;overflow:hidden}.history-item-date{color:var(--text-3);margin-top:1px;font-size:11px}.history-item-del{width:28px;height:28px;color:var(--text-3);border-radius:var(--radius-xs);cursor:pointer;opacity:0;transition:opacity var(--transition), background-color var(--transition), color var(--transition);background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;display:flex}.history-item:hover .history-item-del{opacity:1}.history-item-del:hover{color:#ff3b30;background:#ff3b301f}.history-empty{text-align:center;color:var(--text-3);padding:40px 16px;font-size:13px}#main{flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}#chat-container{scroll-behavior:smooth;flex:1;padding:20px 16px;overflow:hidden auto}#messages{max-width:var(--max-chat-w);flex-direction:column;justify-content:flex-end;gap:10px;min-height:100%;margin:0 auto;display:flex}.message{border-radius:var(--radius);word-break:break-word;max-width:78%;transition:background-color var(--transition), color var(--transition);padding:10px 16px;font-size:14.5px;line-height:1.6;animation:.25s ease-out msg-in}@keyframes msg-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.message.user{background:var(--user-bubble);color:var(--user-text);border-bottom-right-radius:4px;align-self:flex-end}.message.assistant{background:var(--ai-bubble);border:1px solid var(--border);border-bottom-left-radius:4px;align-self:flex-start}.message p{margin-bottom:8px}.message p:last-child{margin-bottom:0}.message strong{font-weight:600}.message code{font-family:var(--font-mono);background:#0000000f;border-radius:4px;padding:2px 5px;font-size:13px}[data-theme=dark] .message code{background:#ffffff14}.message.user code{background:#ffffff2e}.message pre{border-radius:var(--radius-xs);background:#0000000a;margin:8px 0;padding:12px;overflow-x:auto}[data-theme=dark] .message pre{background:#ffffff0d}.message.user pre{background:#ffffff1f}.message pre code{background:0 0;padding:0;font-size:13px;line-height:1.5}.tool-notification{background:var(--accent-soft);border:1px solid var(--border);color:var(--text-2);cursor:pointer;max-width:90%;transition:background-color var(--transition);border-radius:20px;align-self:center;padding:5px 14px;font-size:12px;animation:.2s ease-out msg-in}.tool-notification:hover{background:var(--accent-hover)}.tool-notification .tool-summary{align-items:center;gap:6px;display:flex}.tool-notification .tool-details{border-top:1px solid var(--border);white-space:pre-wrap;font-size:11px;font-family:var(--font-mono);color:var(--text-3);margin-top:6px;padding-top:6px;display:none}.tool-notification.expanded .tool-details{display:block}.message.system{background:var(--accent-soft);border-left:3px solid var(--accent);color:var(--text-2);opacity:.9;border-radius:8px;align-self:center;max-width:85%;margin:4px 16px;padding:8px 14px;font-size:.9em}.typing-indicator{background:var(--ai-bubble);border-radius:var(--radius);border:1px solid var(--border);border-bottom-left-radius:4px;align-self:flex-start;gap:4px;padding:14px 18px;animation:.2s ease-out msg-in;display:flex}.typing-indicator .dot{background:var(--text-3);border-radius:50%;width:7px;height:7px;animation:1.4s ease-in-out infinite bounce-dot}.typing-indicator .dot:nth-child(2){animation-delay:.16s}.typing-indicator .dot:nth-child(3){animation-delay:.32s}@keyframes bounce-dot{0%,60%,to{transform:translateY(0)}30%{transform:translateY(-6px)}}.emergency-stop-btn{cursor:pointer;border:none;border-radius:8px;padding:6px 14px;font-size:.85em;font-weight:600;transition:background .2s;color:#fff!important;background:#ef4444!important}.emergency-stop-btn:hover{background:#dc2626!important}#input-area{padding:12px 16px;padding-bottom:calc(12px + env(safe-area-inset-bottom,0px));max-width:var(--max-chat-w);width:100%;transition:padding var(--transition);align-items:flex-end;gap:8px;margin:0 auto;display:flex}#user-input{resize:none;background:var(--input-bg);border:1px solid var(--border);border-radius:var(--radius);min-height:42px;max-height:140px;color:var(--text);font-family:var(--font);transition:border-color var(--transition), box-shadow var(--transition), background-color var(--transition);outline:none;flex:1;padding:10px 14px;font-size:14.5px;line-height:1.5}#user-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}#user-input::placeholder{color:var(--text-3)}#btn-send{background:var(--accent);width:42px;height:42px;color:var(--user-text);border-radius:var(--radius);cursor:pointer;transition:background-color var(--transition), transform .1s, opacity var(--transition);border:none;flex-shrink:0;justify-content:center;align-items:center;display:flex}#btn-send:hover{filter:brightness(1.08)}#btn-send:active{transform:scale(.93)}#btn-send:disabled{opacity:.4;cursor:not-allowed}#btn-send.busy{background:#d94a4a}#btn-send.busy:hover{filter:brightness(1.12)}.dropdown{z-index:100;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);min-width:240px;max-width:360px;max-height:70vh;box-shadow:var(--shadow-lg);transition:background-color var(--transition), border-color var(--transition);padding:8px;animation:.15s ease-out dropdown-in;position:fixed;overflow-y:auto}@keyframes dropdown-in{0%{opacity:0;transform:translateY(-6px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}.dropdown-header{color:var(--text-3);text-transform:uppercase;letter-spacing:.5px;padding:6px 10px 8px;font-size:11px;font-weight:600}.dropdown-divider{background:var(--border);height:1px;margin:6px 4px}.dropdown-grid{grid-template-columns:repeat(2,1fr);gap:4px;display:grid}.dropdown-item{border-radius:var(--radius-sm);font-family:var(--font);color:var(--text);cursor:pointer;text-align:left;width:100%;transition:background-color var(--transition);-webkit-tap-highlight-color:transparent;background:0 0;border:none;align-items:center;gap:8px;padding:10px 12px;font-size:13.5px;display:flex}.dropdown-item:hover{background:var(--accent-soft)}.dropdown-item.active{background:var(--accent-soft);color:var(--accent);font-weight:600}.dropdown-item-icon{flex-shrink:0;font-size:18px;line-height:1}.dropdown-item-desc{color:var(--text-3);margin-top:1px;font-size:11px;line-height:1.3}.dropdown-item .check-icon{color:var(--accent);opacity:0;transition:opacity var(--transition);flex-shrink:0;margin-left:auto}.dropdown-item.active .check-icon{opacity:1}.full-width{grid-column:1/-1}#custom-prompt-inline{padding:8px}#custom-prompt-inline textarea{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text);font-family:var(--font);resize:vertical;min-height:60px;transition:border-color var(--transition), box-shadow var(--transition);outline:none;padding:10px 12px;font-size:13px;line-height:1.5}#custom-prompt-inline textarea:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-soft)}.inline-actions{justify-content:flex-end;gap:8px;margin-top:8px;display:flex}.saved-list{margin-top:8px}.saved-prompt-row{border-radius:var(--radius-xs);transition:background-color var(--transition);align-items:center;gap:8px;padding:7px 10px;display:flex}.saved-prompt-row:hover{background:var(--accent-soft)}.saved-prompt-name{color:var(--text);font-family:var(--font);cursor:pointer;text-align:left;background:0 0;border:none;flex:1;padding:0;font-size:13px}.saved-prompt-name:hover{color:var(--accent)}.saved-prompt-del{width:22px;height:22px;color:var(--text-3);cursor:pointer;opacity:0;transition:opacity var(--transition), background-color var(--transition), color var(--transition);background:0 0;border:none;border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;font-size:12px;display:flex}.saved-prompt-row:hover .saved-prompt-del{opacity:1}.saved-prompt-del:hover{color:#ff3b30;background:#ff3b301f}.modal{z-index:200;-webkit-backdrop-filter:blur(8px);background:#00000059;justify-content:center;align-items:center;animation:.2s ease-out fade-in;display:flex;position:fixed;inset:0}[data-theme=dark] .modal{background:#0000008c}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.modal-content{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);width:90%;max-width:480px;max-height:80vh;box-shadow:var(--shadow-lg);flex-direction:column;animation:.25s ease-out modal-pop;display:flex;overflow:hidden}.modal-sm{max-width:360px}@keyframes modal-pop{0%{opacity:0;transform:scale(.95)translateY(8px)}to{opacity:1;transform:scale(1)translateY(0)}}.modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.modal-header h2{color:var(--text);font-size:16px;font-weight:600}.modal-close{width:32px;height:32px;color:var(--text-3);cursor:pointer;transition:background-color var(--transition), color var(--transition);background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;display:flex}.modal-close:hover{background:var(--accent-soft);color:var(--text)}.modal-body{flex-direction:column;gap:16px;padding:20px;display:flex;overflow-y:auto}.modal-actions{justify-content:flex-end;gap:8px;margin-top:4px;display:flex}.settings-current-ai{text-align:center;color:var(--text-2);background:var(--bg);border-radius:var(--radius-sm);margin-bottom:10px;padding:8px 12px;font-size:.9em}.settings-current-ai strong{color:var(--accent)}.settings-panel{flex-direction:column;gap:16px;display:flex}.settings-section-title{color:var(--text-3);text-transform:uppercase;letter-spacing:.5px;align-items:center;gap:10px;margin-top:4px;font-size:.78em;font-weight:600;display:flex}.settings-section-title:before,.settings-section-title:after{content:"";background:var(--border);flex:1;height:1px}.segmented{background:var(--bg);border:1px solid var(--border);border-radius:999px;gap:2px;padding:3px;display:inline-flex}.segmented-btn{color:var(--text-2);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-radius:999px;padding:5px 14px;font-size:.85em;transition:background .15s,color .15s}.segmented-btn:hover:not(.active){color:var(--text-1)}.segmented-btn.active{background:var(--accent);color:var(--user-text)}.settings-top-tabs{margin-bottom:4px}.provider-tabs{background:var(--bg);border-radius:var(--radius-sm);gap:4px;padding:3px;display:flex}.provider-tab{border-radius:var(--radius-xs);font-family:var(--font);color:var(--text-2);cursor:pointer;transition:background-color var(--transition), color var(--transition);text-align:center;background:0 0;border:none;flex:1;padding:8px 12px;font-size:13px;font-weight:500}.provider-tab:hover{color:var(--text)}.provider-tab.active{background:var(--surface);color:var(--accent);box-shadow:var(--shadow-sm)}.setting-group{flex-direction:column;gap:6px;display:flex}.setting-group label{color:var(--text-2);font-size:13px;font-weight:500}.setting-group input[type=text],.setting-group input[type=password],.setting-group input[type=url],.setting-group select{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text);font-family:var(--font);transition:border-color var(--transition), box-shadow var(--transition);outline:none;padding:10px 12px;font-size:14px}.setting-group input:focus,.setting-group select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.provider-hint{color:var(--text-3);background:var(--accent-soft);border-radius:var(--radius-xs);border-left:3px solid var(--accent);padding:8px 12px;font-size:12px;line-height:1.5}.setting-group-inline{justify-content:space-between;align-items:center;margin-bottom:8px;flex-direction:row!important}.max-strength-wrap{margin-top:14px;margin-bottom:4px}.max-strength-header{color:var(--text);margin-bottom:8px;font-size:13px;font-weight:600}.max-strength-row{grid-template-columns:1fr 1fr;gap:10px;display:grid}.strength-stepper{background:var(--accent-soft);border:1px solid var(--border);transition:border-color var(--transition), box-shadow var(--transition);border-radius:10px;align-items:center;gap:10px;padding:10px 12px;display:flex}.strength-stepper:focus-within{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-soft)}.strength-stepper-channel{background:var(--accent);width:22px;height:22px;color:var(--user-text);border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;font-size:12px;font-weight:700;display:inline-flex}.strength-stepper-control{background:var(--surface);border:1px solid var(--border);border-radius:8px;align-items:center;gap:2px;margin-left:auto;display:flex;overflow:hidden}.strength-stepper-btn{width:28px;height:28px;color:var(--text-2);cursor:pointer;transition:background var(--transition), color var(--transition);background:0 0;border:none;justify-content:center;align-items:center;padding:0;font-size:16px;font-weight:600;display:flex}.strength-stepper-btn:hover{background:var(--accent-soft);color:var(--accent)}.strength-stepper-btn:active{background:var(--accent-hover)}.strength-stepper-input{width:44px;height:28px;color:var(--text);font-variant-numeric:tabular-nums;text-align:center;appearance:textfield;background:0 0;border:none;outline:none;padding:0;font-size:14px;font-weight:600}.strength-stepper-input::-webkit-outer-spin-button{appearance:none;margin:0}.strength-stepper-input::-webkit-inner-spin-button{appearance:none;margin:0}.perm-mode-wrap{margin-top:18px;margin-bottom:4px}.bg-behavior-wrap{margin-top:18px}.perm-mode-header{color:var(--text);justify-content:space-between;align-items:center;gap:10px;margin-bottom:8px;font-size:13px;font-weight:600;display:flex}.perm-mode-remain{color:var(--accent);background:var(--accent-soft);font-variant-numeric:tabular-nums;border-radius:10px;padding:2px 8px;font-size:12px;font-weight:500}.perm-mode-remain.hidden{display:none}.perm-mode-group{grid-template-columns:1fr 1fr 1fr;gap:8px;display:grid}.perm-mode-btn{background:var(--surface);color:var(--text);border:1px solid var(--border);cursor:pointer;text-align:left;border-radius:10px;flex-direction:column;align-items:flex-start;gap:3px;padding:10px 12px;transition:background-color .15s,border-color .15s,transform 50ms;display:flex}.perm-mode-btn:hover{background:var(--accent-soft);border-color:var(--accent)}.perm-mode-btn:active{transform:scale(.98)}.perm-mode-btn.active{background:var(--accent-soft);border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-soft)}.perm-mode-btn-label{color:var(--text);font-size:13px;font-weight:600}.perm-mode-btn.active .perm-mode-btn-label{color:var(--accent)}.perm-mode-btn-sub{color:var(--text-2);font-size:11px;line-height:1.3}.perm-mode-btn-always .perm-mode-btn-sub{color:#d94a4a}.perm-mode-btn-always.active{background:#d94a4a14;border-color:#d94a4a;box-shadow:0 0 0 2px #d94a4a1f}.perm-mode-btn-always.active .perm-mode-btn-label{color:#d94a4a}@media (width<=520px){.perm-mode-group{grid-template-columns:1fr}.perm-mode-btn{padding:12px 14px}.perm-mode-btn-label{font-size:14px}.perm-mode-btn-sub{font-size:12px}}.toggle-btn{background:var(--border);cursor:pointer;width:44px;height:24px;transition:background var(--transition);border:none;border-radius:12px;flex-shrink:0;padding:0;position:relative}.toggle-btn.active{background:var(--accent)}.toggle-knob{width:20px;height:20px;transition:transform var(--transition);background:#fff;border-radius:50%;position:absolute;top:2px;left:2px;box-shadow:0 1px 3px #00000026}.toggle-btn.active .toggle-knob{transform:translate(20px)}.btn-primary{background:var(--accent);color:var(--user-text);font-family:var(--font);border-radius:var(--radius-sm);cursor:pointer;transition:filter var(--transition), transform .1s;border:none;padding:10px 20px;font-size:14px;font-weight:600}.btn-primary:hover{filter:brightness(1.08)}.btn-primary:active{transform:scale(.97)}.btn-primary.btn-saved{pointer-events:none;background:#22c55e}.btn-primary-sm{background:var(--accent);color:var(--user-text);font-family:var(--font);border-radius:var(--radius-xs);cursor:pointer;transition:filter var(--transition), transform .1s;white-space:nowrap;border:none;align-items:center;gap:4px;padding:6px 12px;font-size:12px;font-weight:600;display:inline-flex}.btn-primary-sm:hover{filter:brightness(1.08)}.btn-primary-sm:active{transform:scale(.95)}#disclaimer{padding:6px 16px;padding-bottom:calc(6px + env(safe-area-inset-bottom,0px));text-align:center;color:var(--text-3);opacity:.7;flex-shrink:0;font-size:11px}#disclaimer a{color:var(--accent);text-decoration:none}#disclaimer a:hover{text-decoration:underline}@media (width>=1200px){:root{--sidebar-w:300px;--max-chat-w:860px}}@media (width<=1023px){#sidebar{box-shadow:var(--shadow-lg);position:absolute;top:0;bottom:0;left:0}}@media (width<=767px){:root{--topbar-h:50px;--sidebar-w:85vw}.topbar-left h1{font-size:15px}.pill{max-width:130px;height:30px;padding:0 10px;font-size:12px}#pill-scene-icon{font-size:16px}#pill-scene-label,#pill-scene .pill-arrow{display:none}#pill-scene{min-width:auto;max-width:none;padding:0 8px}.provider-tabs{flex-wrap:wrap}.provider-tab{flex:0 0 calc(50% - 2px)}.settings-top-tabs{flex-wrap:nowrap}.settings-top-tabs .provider-tab{flex:1 1 0}.icon-btn{width:34px;height:34px}#chat-container{padding:12px 10px}.message{max-width:88%;padding:9px 12px;font-size:14px}#input-area{padding:8px 10px;padding-bottom:calc(8px + env(safe-area-inset-bottom,0px))}#user-input{min-height:38px;padding:8px 12px;font-size:14px}#btn-send{width:38px;height:38px}.dropdown{border-radius:var(--radius) var(--radius) 0 0;max-width:none;max-height:60vh;padding-bottom:calc(8px + env(safe-area-inset-bottom,0px));animation:.25s ease-out sheet-up;position:fixed;inset:auto 10px 0!important}@keyframes sheet-up{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}#device-bar{flex-wrap:wrap;gap:10px;padding:6px 10px}.modal-content{width:95%;max-height:85vh}#disclaimer{font-size:10px}}@media (width<=399px){.topbar-left h1{font-size:14px}.pill{max-width:100px;padding:0 8px;font-size:11px}.topbar-center{gap:4px}.topbar-right{gap:2px}.icon-btn{width:32px;height:32px}.dropdown-grid{grid-template-columns:1fr}}@media (height<=500px) and (orientation:landscape){:root{--topbar-h:42px}.pill{height:28px}.icon-btn{width:32px;height:32px}#chat-container{padding:8px 16px}#input-area{padding:6px 12px}#user-input{min-height:34px;max-height:80px}#btn-send{width:34px;height:34px}.dropdown{max-height:90vh}#disclaimer{display:none}}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important}}.safety-notice{-webkit-backdrop-filter:blur(4px);z-index:9999;padding:16px;padding-top:max(16px, env(safe-area-inset-top));padding-bottom:max(16px, env(safe-area-inset-bottom));padding-left:max(16px, env(safe-area-inset-left));padding-right:max(16px, env(safe-area-inset-right));overscroll-behavior:contain;background:#0009;justify-content:center;align-items:center;animation:.25s ease-out safety-fade-in;display:flex;position:fixed;inset:0}body.safety-notice-open{touch-action:none;overflow:hidden}.safety-notice.hidden{display:none}@keyframes safety-fade-in{0%{opacity:0}to{opacity:1}}.safety-notice-card{background:var(--surface);color:var(--text);border:1px solid var(--border);border-radius:16px;flex-direction:column;width:100%;max-width:640px;max-height:90dvh;animation:.3s cubic-bezier(.2,.9,.3,1.2) safety-slide-up;display:flex;overflow:hidden;box-shadow:0 20px 60px #0000004d}@keyframes safety-slide-up{0%{opacity:0;transform:translateY(16px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.safety-notice-header{border-bottom:1px solid var(--border);background:linear-gradient(135deg, var(--accent-soft), transparent);padding:20px 24px 16px}.safety-notice-title{align-items:center;gap:12px;display:flex}.safety-notice-icon{font-size:28px;line-height:1}.safety-notice-title h2{color:var(--text);margin:0;font-size:18px;font-weight:700}.safety-notice-body{overscroll-behavior:contain;-webkit-overflow-scrolling:touch;color:var(--text);flex:1;padding:20px 24px;font-size:13px;line-height:1.7;overflow-y:auto}.safety-notice-body h3{color:var(--accent);margin:18px 0 8px;font-size:14px;font-weight:700}.safety-notice-body h3:first-of-type{margin-top:12px}.safety-notice-body p{margin:0 0 10px}.safety-notice-body ol,.safety-notice-body ul{margin:0 0 10px;padding-left:22px}.safety-notice-body li{margin-bottom:6px}.safety-callout{color:var(--text);background:#ff3b3014;border-left:3px solid #ff3b30;border-radius:6px;margin:12px 0;padding:12px 14px}.safety-callout ul{margin:8px 0 0}.safety-notice-footer{border-top:1px solid var(--border);background:var(--surface);justify-content:center;padding:16px 24px 20px;display:flex}.safety-notice-btn{min-width:220px;height:44px;transition:opacity var(--transition), transform var(--transition), background var(--transition);border-radius:10px;font-size:14px;font-weight:600}.safety-notice-btn:disabled{opacity:.55;cursor:not-allowed;background:var(--border);color:var(--text-2)}.safety-notice-btn:not(:disabled){background:var(--accent);color:var(--user-text);cursor:pointer}.safety-notice-btn:not(:disabled):hover{filter:brightness(1.05);transform:translateY(-1px)}@media (width<=600px){.safety-notice-card{border-radius:12px;max-height:94vh}.safety-notice-header,.safety-notice-body,.safety-notice-footer{padding-left:18px;padding-right:18px}.safety-notice-btn{width:100%;min-width:0}}.update-banner{z-index:9999;background:var(--accent);color:#fff;cursor:pointer;justify-content:center;align-items:center;gap:12px;min-height:36px;padding:8px 44px 8px 16px;font-size:13px;font-weight:500;transition:filter .15s;display:flex;position:fixed;top:0;left:0;right:0;box-shadow:0 2px 8px #0000001f}.update-banner:hover{filter:brightness(1.08)}.update-banner-text{pointer-events:none}.update-banner-close{color:#fff;cursor:pointer;opacity:.85;background:0 0;border:none;border-radius:4px;width:24px;height:24px;font-size:18px;line-height:1;position:absolute;top:50%;right:10px;transform:translateY(-50%)}.update-banner-close:hover{opacity:1;background:#ffffff2e}.permission-modal-backdrop{-webkit-backdrop-filter:blur(4px);z-index:10000;padding:max(16px, env(safe-area-inset-top)) max(16px, env(safe-area-inset-right)) max(16px, env(safe-area-inset-bottom)) max(16px, env(safe-area-inset-left));overscroll-behavior:contain;background:#0000008c;justify-content:center;align-items:center;animation:.18s ease-out perm-fade-in;display:flex;position:fixed;inset:0}@keyframes perm-fade-in{0%{opacity:0}to{opacity:1}}.permission-modal{background:var(--surface);color:var(--text);border:1px solid var(--border);overscroll-behavior:contain;border-radius:14px;flex-direction:column;gap:12px;width:100%;max-width:440px;max-height:90dvh;padding:22px 22px 18px;animation:.22s cubic-bezier(.2,.9,.3,1.2) perm-pop;display:flex;overflow-y:auto;box-shadow:0 20px 60px #00000059}@keyframes perm-pop{0%{opacity:0;transform:translateY(12px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}.permission-title{color:var(--text);font-size:16px;font-weight:700}.permission-subtitle{color:var(--text-2);margin-top:-6px;font-size:13px}.permission-tool-row{background:var(--accent-soft);border-radius:8px;align-items:center;gap:10px;margin-top:4px;padding:10px 12px;display:flex}.permission-tool-label{color:var(--text-2);text-transform:uppercase;letter-spacing:.04em;font-size:12px}.permission-tool-name{color:var(--accent);font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:14px;font-weight:600}.permission-args-label{color:var(--text-2);text-transform:uppercase;letter-spacing:.04em;margin-top:2px;font-size:12px}.permission-args{background:var(--bg);border:1px solid var(--border);color:var(--text);white-space:pre-wrap;word-break:break-word;border-radius:8px;max-height:160px;margin:0;padding:10px 12px;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:12px;line-height:1.5;overflow:auto}.permission-description{background:var(--bg);border:1px solid var(--border);color:var(--text);border-radius:8px;padding:12px 14px;font-size:14px;line-height:1.55}.permission-raw-details{margin-top:2px}.permission-raw-details>summary{cursor:pointer;color:var(--text-2);-webkit-user-select:none;user-select:none;padding:4px 0;font-size:12px;list-style:none}.permission-raw-details>summary::-webkit-details-marker{display:none}.permission-raw-details>summary:before{content:"▸ ";transition:transform .15s;display:inline-block}.permission-raw-details[open]>summary:before{content:"▾ "}.permission-raw-details>summary:hover{color:var(--accent)}.permission-raw-details[open]>.permission-args{margin-top:6px}.permission-buttons{grid-template-columns:1fr 1fr;gap:8px;margin-top:6px;display:grid}.permission-btn{border:1px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer;border-radius:8px;padding:10px 12px;font-size:13px;font-weight:500;transition:background-color .15s,transform 50ms,border-color .15s}.permission-btn:hover{background:var(--accent-soft);border-color:var(--accent)}.permission-btn:active{transform:scale(.97)}.permission-btn-deny{color:#d94a4a;border-color:#d94a4a66;grid-column:1/2}.permission-btn-deny:hover{background:#d94a4a1a;border-color:#d94a4a}.permission-btn-once{grid-column:2/3}.permission-btn-timed{grid-column:1/2}.permission-btn-always{background:var(--accent);color:var(--user-text);border-color:var(--accent);grid-column:2/3}.permission-btn-always:hover{filter:brightness(1.08);background:var(--accent)}@media (width<=480px){.permission-modal{border-radius:12px;gap:10px;padding:18px 16px 14px}.permission-title{font-size:15px}.permission-subtitle{font-size:12.5px}.permission-description{padding:11px 12px;font-size:13.5px}.permission-buttons{grid-template-columns:1fr;gap:10px;margin-top:8px}.permission-btn{min-height:44px;padding:14px;font-size:14px}.permission-btn-deny,.permission-btn-once,.permission-btn-timed,.permission-btn-always{grid-column:1/-1}.permission-btn-once{order:1}.permission-btn-timed{order:2}.permission-btn-always{order:3}.permission-btn-deny{order:4}}@media (height<=520px) and (orientation:landscape){.permission-modal{gap:8px;padding:14px 18px 12px}.permission-title{font-size:14px}.permission-subtitle{margin-top:-4px}.permission-description{padding:9px 12px;font-size:13px}.permission-args{max-height:100px}}.waveform-actions{gap:10px;margin-bottom:8px;display:flex}.waveform-actions .btn-primary,.waveform-actions .btn-secondary{border:1px solid var(--border);background:var(--bg-elev);color:var(--text);cursor:pointer;border-radius:8px;padding:8px 14px;font-size:13px}.waveform-actions .btn-primary{background:var(--accent);color:var(--user-text);border-color:var(--accent)}.waveform-actions .btn-primary:hover{filter:brightness(1.05)}.waveform-actions .btn-secondary:hover{background:var(--bg-hover,#0000000a)}.waveform-list{flex-direction:column;gap:8px;margin-top:12px;display:flex}.waveform-row{border:1px solid var(--border);background:var(--bg-elev);border-radius:8px;grid-template-columns:minmax(100px,1fr) minmax(150px,2fr) auto auto;align-items:center;gap:8px;padding:8px;display:grid}.waveform-name-input,.waveform-desc-input{border:1px solid var(--border);background:var(--bg);color:var(--text);border-radius:6px;width:100%;padding:6px 10px;font-size:13px}.waveform-meta{color:var(--muted,#888);white-space:nowrap;font-size:12px}.waveform-del{border:1px solid var(--border);color:var(--text);cursor:pointer;background:0 0;border-radius:6px;padding:6px 12px;font-size:12px}.waveform-del:hover:not(:disabled){color:#d33;border-color:#d33}.waveform-del:disabled{opacity:.4;cursor:not-allowed}.waveform-empty{text-align:center;color:var(--muted,#888);padding:20px;font-size:13px}@media (width<=560px){.waveform-row{grid-template-columns:1fr auto;grid-template-areas:"name del""desc desc""meta meta"}.waveform-name-input{grid-area:name}.waveform-desc-input{grid-area:desc}.waveform-meta{grid-area:meta}.waveform-del{grid-area:del}}
