*,*:before,*:after{box-sizing:border-box}:root{--bg: #ffffff;--surface: #f7f7f8;--surface-hover: #efeff1;--card: #ffffff;--border: #e5e5ea;--border-strong: #d1d1d6;--text: #1c1c1e;--text-secondary: #636366;--text-tertiary: #8e8e93;--accent: #007aff;--accent-hover: #006fe0;--accent-text: #ffffff;--user-bubble: #007aff;--user-text: #ffffff;--assistant-bubble: #f0f0f2;--assistant-text: #1c1c1e;--error: #ff3b30;--success: #34c759;--warning: #ff9500;--code-bg: #f2f2f7;--mono: "SF Mono", ui-monospace, "Cascadia Code", Consolas, monospace;--sans: -apple-system, BlinkMacSystemFont, "Segoe UI", "Helvetica Neue", sans-serif;--fs-xs: 12px;--fs-sm: 13px;--fs-base: 15px;--fs-md: 16px;--fs-lg: 20px;--fs-xl: 28px;--lh-tight: 1.3;--lh-base: 1.5;--s-1: 4px;--s-2: 8px;--s-3: 12px;--s-4: 16px;--s-5: 20px;--s-6: 24px;--s-8: 32px;--s-10: 40px;--r-xs: 4px;--r-sm: 8px;--r-md: 12px;--r-lg: 16px;--r-full: 9999px;--radius: var(--r-md);--radius-sm: var(--r-sm);--elev-1: 0 1px 2px rgba(0,0,0,.04), 0 1px 1px rgba(0,0,0,.03);--elev-2: 0 8px 24px rgba(0,0,0,.1), 0 2px 6px rgba(0,0,0,.06);--t-fast: .12s cubic-bezier(.2, 0, .2, 1);--t-base: .2s cubic-bezier(.2, 0, .2, 1);--chat-max-w: 760px;--sidebar-w: 280px;--header-h: 52px;--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px);--safe-left: env(safe-area-inset-left, 0px);--safe-right: env(safe-area-inset-right, 0px);--hit-target: 44px;--z-drawer: 40;--z-modal: 50;--z-toast: 60}@media(prefers-color-scheme:dark){:root{--bg: #0e0e10;--surface: #151517;--surface-hover: #1d1d20;--card: #18181b;--border: #2a2a2e;--border-strong: #3a3a3c;--text: #f2f2f7;--text-secondary: #b0b0b5;--text-tertiary: #8e8e93;--assistant-bubble: #2a2a2e;--assistant-text: #f2f2f7;--code-bg: #1d1d20;--elev-2: 0 10px 32px rgba(0,0,0,.5), 0 2px 8px rgba(0,0,0,.3)}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:0ms!important;transition-duration:0ms!important}}html,body,#root{margin:0;padding:0;min-height:100%;font-family:var(--sans);background:var(--bg);color:var(--text);font-size:var(--fs-md);-webkit-font-smoothing:antialiased;-webkit-text-size-adjust:100%;text-size-adjust:100%}body{overscroll-behavior-y:none}:focus-visible{outline:2px solid var(--accent);outline-offset:2px}button:focus:not(:focus-visible){outline:none}::selection{background:color-mix(in srgb,var(--accent) 30%,transparent)}.icon-btn{background:transparent;border:none;cursor:pointer;width:var(--hit-target);height:var(--hit-target);min-width:var(--hit-target);min-height:var(--hit-target);padding:0;border-radius:var(--r-full);color:var(--text-secondary);font-size:var(--fs-md);display:inline-flex;align-items:center;justify-content:center;transition:background var(--t-fast),color var(--t-fast)}.icon-btn:hover{background:var(--surface-hover);color:var(--text)}.icon-btn:active{background:var(--border)}.icon-btn.icon-btn-danger{color:var(--error)}.icon-btn.icon-btn-danger:hover{background:color-mix(in srgb,var(--error) 12%,transparent)}.btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid transparent;background:transparent;color:var(--text);font-family:var(--sans);font-size:var(--fs-sm);font-weight:500;padding:var(--s-2) var(--s-4);border-radius:var(--r-sm);cursor:pointer;line-height:var(--lh-tight);display:inline-flex;align-items:center;justify-content:center;gap:var(--s-2);transition:background var(--t-fast),color var(--t-fast),border-color var(--t-fast),opacity var(--t-fast);min-height:36px}.btn:disabled{opacity:.4;cursor:default}.btn-block{width:100%}.btn-lg{padding:var(--s-3) var(--s-5);font-size:var(--fs-base);min-height:44px}.btn-primary{background:var(--accent);color:var(--accent-text);border-color:var(--accent)}.btn-primary:hover:not(:disabled){background:var(--accent-hover);border-color:var(--accent-hover)}.btn-secondary{background:var(--surface);color:var(--text);border-color:var(--border-strong)}.btn-secondary:hover:not(:disabled){background:var(--surface-hover)}.btn-ghost{background:transparent;color:var(--text-secondary);border-color:transparent}.btn-ghost:hover:not(:disabled){background:var(--surface-hover);color:var(--text)}.btn-danger{background:transparent;color:var(--error);border-color:color-mix(in srgb,var(--error) 50%,var(--border))}.btn-danger:hover:not(:disabled){background:color-mix(in srgb,var(--error) 10%,transparent);border-color:var(--error)}.connect-screen{min-height:100vh;min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:calc(var(--s-10) + var(--safe-top)) calc(var(--s-6) + var(--safe-right)) calc(var(--s-10) + var(--safe-bottom)) calc(var(--s-6) + var(--safe-left));background:var(--bg);overflow-y:auto}.connect-card{width:100%;max-width:420px;background:var(--card);border:1px solid var(--border);border-radius:var(--r-lg);padding:var(--s-8) var(--s-6);display:flex;flex-direction:column;gap:var(--s-4)}@media(max-width:480px){.connect-screen{padding:calc(var(--s-4) + var(--safe-top)) calc(var(--s-3) + var(--safe-right)) calc(var(--s-4) + var(--safe-bottom)) calc(var(--s-3) + var(--safe-left));align-items:flex-start}.connect-card{padding:var(--s-6) var(--s-5);border-radius:var(--r-md)}}.connect-logo{font-size:var(--fs-xl);text-align:center;line-height:1}.connect-title{font-size:var(--fs-xl);font-weight:700;text-align:center;margin:0;letter-spacing:-.5px}.connect-subtitle{font-size:var(--fs-sm);color:var(--text-secondary);text-align:center;margin:0;line-height:var(--lh-base)}.connect-subtitle code{font-family:var(--mono);font-size:var(--fs-sm);background:var(--code-bg);padding:1px 6px;border-radius:var(--r-xs);color:var(--accent)}.connect-textarea{width:100%;font-family:var(--mono);font-size:var(--fs-md);background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--r-sm);padding:var(--s-3);color:var(--text);resize:none;outline:none;transition:border-color var(--t-fast);line-height:var(--lh-base)}@media(min-width:481px){.connect-textarea{font-size:var(--fs-xs)}}.connect-textarea:focus{border-color:var(--accent)}.connect-textarea:disabled{opacity:.5}.connect-error{font-size:var(--fs-sm);color:var(--error);margin:0;padding:var(--s-2) var(--s-3);background:color-mix(in srgb,var(--error) 12%,transparent);border-radius:var(--r-sm)}.connect-divider{display:flex;align-items:center;gap:var(--s-3);color:var(--text-tertiary);font-size:var(--fs-xs);text-transform:uppercase;letter-spacing:.5px}.connect-divider:before,.connect-divider:after{content:"";flex:1;border-top:1px solid var(--border)}.resume-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:var(--s-4);display:flex;flex-direction:column;gap:var(--s-2)}.resume-label{font-size:var(--fs-xs);font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px}.resume-endpoint{font-family:var(--mono);font-size:var(--fs-sm);color:var(--text);word-break:break-all}.resume-meta{font-size:var(--fs-xs);color:var(--text-secondary)}.resume-id{font-family:var(--mono);font-size:var(--fs-xs)}.resume-actions{display:flex;gap:var(--s-2);margin-top:var(--s-2)}.resume-actions .btn-primary{flex:1}.transfer-entry-btn{width:100%;padding:var(--s-3);background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);color:var(--text-secondary);font-size:var(--fs-sm);font-family:inherit;cursor:pointer;transition:border-color var(--t-fast),color var(--t-fast),background var(--t-fast)}.transfer-entry-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--bg)}.chat-screen{height:100vh;height:100dvh;display:flex;flex-direction:row;background:var(--bg);overflow:hidden}.chat-main{flex:1;min-width:0;display:flex;flex-direction:column;background:var(--bg);overflow:hidden;position:relative}.drawer-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:var(--z-drawer);opacity:0;pointer-events:none;transition:opacity var(--t-base)}.drawer-backdrop.open{opacity:1;pointer-events:auto}.chat-header{display:flex;align-items:center;padding:calc(var(--s-2) + var(--safe-top)) calc(var(--s-2) + var(--safe-right)) var(--s-2) calc(var(--s-2) + var(--safe-left));border-bottom:1px solid var(--border);background:var(--surface);flex-shrink:0;gap:var(--s-1);position:sticky;top:0;z-index:5;min-height:var(--header-h)}.chat-header-left{display:flex;align-items:center;flex-shrink:0}.chat-back-btn{display:none}@media(max-width:768px){.chat-back-btn{display:inline-flex}}.chat-header-menu-btn{display:none}@media(min-width:769px){.chat-header-menu-btn{display:inline-flex}}.chat-header-center{flex:1;min-width:0;text-align:center;display:flex;flex-direction:column;align-items:center;gap:1px}.chat-header-name{font-size:var(--fs-base);font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:200px}.chat-header-sub{display:flex;align-items:center;gap:4px;font-size:var(--fs-xs);color:var(--text-secondary)}.chat-header-actions{display:flex;align-items:center;gap:var(--s-1);flex-shrink:0}.chat-status{display:flex;align-items:center;gap:var(--s-2);flex:1;min-width:0}@media(max-width:380px){.status-error-hint{display:none}}.status-dot{width:8px;height:8px;border-radius:var(--r-full);flex-shrink:0}.dot-green{background:var(--success)}.dot-orange{background:var(--warning)}.dot-red{background:var(--error)}.dot-gray{background:var(--text-tertiary)}.status-label{font-size:var(--fs-sm);font-weight:600;flex-shrink:0}.status-error-hint{font-size:var(--fs-xs);color:var(--error);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-session-label{color:var(--text-secondary);font-size:var(--fs-sm);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:260px}.chat-header-actions{display:flex;align-items:center;gap:var(--s-1)}.chat-messages{flex:1;overflow-y:auto;overflow-anchor:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;padding:var(--s-5) calc(var(--s-4) + var(--safe-right)) var(--s-2) calc(var(--s-4) + var(--safe-left));display:flex;flex-direction:column;gap:var(--s-3);scroll-behavior:smooth;width:100%;max-width:var(--chat-max-w);margin:0 auto}@media(min-width:769px){.chat-messages{padding-left:var(--s-6);padding-right:var(--s-6)}}.chat-empty{text-align:center;color:var(--text-secondary);font-size:var(--fs-md);font-weight:500;margin-top:var(--s-10)}@keyframes msg-enter{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:none}}.msg-user,.msg-assistant,.msg-tools,.msg-result{animation:msg-enter .18s ease-out}.msg-user{display:flex;flex-direction:column;align-items:flex-end}.msg-user-bubble{background:var(--user-bubble);color:var(--user-text);border-radius:var(--r-lg) var(--r-lg) var(--r-xs) var(--r-lg);padding:var(--s-2) var(--s-4);max-width:min(80%,560px);font-size:var(--fs-base);line-height:1.45;white-space:pre-wrap;word-break:break-word;box-shadow:0 1px 2px #0000001f}.msg-time{font-size:11px;color:var(--text-tertiary);margin-top:3px;line-height:1;padding:0 var(--s-1)}.msg-assistant{max-width:100%;display:flex;flex-direction:column;align-items:flex-start}.msg-assistant-bubble{background:none;color:var(--text);border-radius:0;padding:0;max-width:100%;display:block}.msg-assistant-bubble.streaming .markdown p:last-child:after,.msg-assistant-bubble.streaming>*:last-child:after,.msg-assistant-bubble.streaming:after{content:"▋";display:inline;animation:blink-cursor .8s step-end infinite;color:var(--accent);font-size:.85em;margin-left:2px}@keyframes blink-cursor{0%,to{opacity:1}50%{opacity:0}}.chat-messages>.msg-user+.msg-user,.chat-messages>.msg-assistant+.msg-assistant{margin-top:calc(var(--s-1) - var(--s-3))}.msg-tools{display:flex}.tools-group{display:flex;flex-direction:column;align-items:flex-start;width:100%}.tools-header{display:inline-flex;align-items:center;gap:var(--s-1);background:none;border:none;cursor:pointer;padding:var(--s-1) var(--s-2);margin-left:calc(var(--s-2) * -1);border-radius:var(--r-sm);font-family:var(--mono);font-size:var(--fs-xs);color:var(--text-secondary);text-align:left;transition:background var(--t-fast),color var(--t-fast)}.tools-header:hover{color:var(--text);background:var(--surface-hover)}.tools-icon{flex-shrink:0}.tools-label{flex:1}.tools-chevron{flex-shrink:0}.tools-list{width:100%;margin:var(--s-1) 0 0 var(--s-4);padding:0;list-style:none;display:flex;flex-direction:column;gap:var(--s-2)}.tools-item{display:flex;flex-direction:column;gap:var(--s-1)}.tools-item-name{font-family:var(--mono);font-size:var(--fs-xs);font-weight:600;color:var(--text)}.tools-item-input{margin:0;padding:var(--s-2) var(--s-3);background:var(--code-bg);border-radius:var(--r-sm);font-family:var(--mono);font-size:var(--fs-xs);color:var(--text-secondary);white-space:pre-wrap;word-break:break-word;max-height:280px;overflow:auto}.msg-result{display:inline-flex;align-items:center;gap:var(--s-1);font-family:var(--mono);font-size:var(--fs-xs);padding:var(--s-1) var(--s-3);border-radius:var(--r-full);align-self:flex-start}.msg-result.success{color:var(--success);background:color-mix(in srgb,var(--success) 12%,transparent)}.msg-result.error{color:var(--error);background:color-mix(in srgb,var(--error) 12%,transparent)}.msg-status{font-size:var(--fs-xs);color:var(--text-tertiary);text-align:center;font-family:var(--mono)}.typing-wrap{display:flex;align-items:flex-start}.typing-dots{display:inline-flex;gap:5px;align-items:center;padding:var(--s-3) var(--s-4);background:var(--assistant-bubble);border-radius:var(--r-lg) var(--r-lg) var(--r-lg) var(--r-xs);min-width:52px}.typing-dots span{width:7px;height:7px;border-radius:var(--r-full);background:var(--text-tertiary);animation:dot-pulse 1.2s ease-in-out infinite}.typing-dots span:nth-child(2){animation-delay:.2s}.typing-dots span:nth-child(3){animation-delay:.4s}@keyframes dot-pulse{0%,to{opacity:.3;transform:scale(.85)}50%{opacity:1;transform:scale(1)}}.chat-input-bar{display:flex;align-items:flex-end;gap:var(--s-2);padding:var(--s-2) calc(var(--s-2) + var(--safe-right)) calc(var(--s-3) + var(--safe-bottom)) calc(var(--s-2) + var(--safe-left));border-top:1px solid var(--border);background:var(--bg);flex-shrink:0;max-width:100%}@media(min-width:769px){.chat-input-bar{padding-left:calc(var(--s-3) + var(--safe-left));padding-right:calc(var(--s-3) + var(--safe-right))}}.chat-input-extra{flex-shrink:0;color:var(--text-secondary);margin-bottom:2px}.chat-input-extra:disabled{opacity:.35}.chat-input-wrap{flex:1;display:flex;align-items:flex-end;background:var(--surface);border:1px solid var(--border-strong);border-radius:22px;padding:var(--s-2) var(--s-3);gap:var(--s-2);transition:border-color var(--t-fast),box-shadow var(--t-fast);min-width:0;max-width:calc(var(--chat-max-w) - 100px);margin:0 auto}.chat-input-wrap:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 15%,transparent)}.chat-textarea{flex:1;background:none;border:none;outline:none;font-family:var(--sans);font-size:var(--fs-md);color:var(--text);resize:none;max-height:140px;min-height:24px;line-height:var(--lh-base);padding:2px 0;overflow-y:auto}.chat-textarea::placeholder{color:var(--text-tertiary)}.chat-textarea:disabled{opacity:.5}.chat-send-btn{width:36px;height:36px;border-radius:var(--r-full);border:none;background:var(--surface-hover);color:var(--text-tertiary);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background var(--t-fast),color var(--t-fast),transform var(--t-fast);margin-bottom:2px}.chat-send-btn.active{background:var(--accent);color:var(--accent-text)}.chat-send-btn.active:hover{background:var(--accent-hover)}.chat-send-btn.active:active{transform:scale(.93)}.chat-send-btn:disabled{opacity:.4;cursor:default}.chat-fab{position:absolute;bottom:calc(var(--s-4) + 68px);right:var(--s-4);width:36px;height:36px;border-radius:var(--r-full);border:1px solid var(--border);background:var(--card);color:var(--text-secondary);box-shadow:var(--elev-2);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:opacity var(--t-fast),transform var(--t-fast);z-index:10}.chat-fab.hidden{opacity:0;pointer-events:none;transform:translateY(8px)}.session-sidebar{width:var(--sidebar-w);flex-shrink:0;display:flex;flex-direction:column;background:var(--surface);border-right:1px solid var(--border);padding:calc(var(--s-3) + var(--safe-top)) 0 calc(var(--s-3) + var(--safe-bottom)) var(--safe-left);overflow:hidden}@media(max-width:1023px)and (min-width:769px){.session-sidebar{width:240px}}@media(max-width:768px){.session-sidebar{position:fixed;top:0;left:0;bottom:0;width:82vw;max-width:320px;z-index:calc(var(--z-drawer) + 1);transform:translate3d(-100%,0,0);transition:transform var(--t-base);box-shadow:var(--elev-2)}.session-sidebar.drawer-open{transform:translateZ(0)}}.sidebar-head{display:flex;align-items:center;justify-content:space-between;padding:0 var(--s-3) var(--s-2) var(--s-3);min-height:var(--header-h)}.sidebar-title{font-size:var(--fs-xs);font-weight:600;color:var(--text-tertiary);letter-spacing:.4px;text-transform:uppercase}.sidebar-list{flex:1;overflow-y:auto;padding:var(--s-1) var(--s-2);display:flex;flex-direction:column;gap:var(--s-1)}.sidebar-empty{padding:var(--s-3) var(--s-2);color:var(--text-tertiary);font-size:var(--fs-xs);text-align:center}.sidebar-item{display:flex;align-items:stretch;gap:var(--s-1);border-radius:var(--r-sm);transition:background var(--t-fast);position:relative}.sidebar-item:hover{background:var(--surface-hover)}.sidebar-item.active{background:color-mix(in srgb,var(--accent) 14%,transparent)}.sidebar-item-main{flex:1;min-width:0;background:transparent;border:none;color:inherit;cursor:pointer;text-align:left;padding:var(--s-2) var(--s-3);display:flex;align-items:center;gap:var(--s-2);font-size:var(--fs-sm);border-radius:var(--r-sm)}.sidebar-tool{font-size:10px;text-transform:uppercase;letter-spacing:.4px;padding:2px var(--s-2);border-radius:var(--r-full);background:var(--bg);color:var(--text-secondary);border:1px solid var(--border);flex-shrink:0}.sidebar-tool.tool-claude{color:#c47f00;border-color:color-mix(in srgb,#c47f00 40%,var(--border))}.sidebar-tool.tool-gemini{color:#2b7cff;border-color:color-mix(in srgb,#2b7cff 40%,var(--border))}.sidebar-id{font-family:var(--mono);font-size:var(--fs-xs);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-model{font-size:var(--fs-xs);color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-close{background:transparent;border:none;color:var(--text-tertiary);cursor:pointer;padding:0;border-radius:var(--r-sm);opacity:0;transition:opacity var(--t-fast),background var(--t-fast),color var(--t-fast);align-self:center;width:32px;height:32px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.sidebar-item:hover .sidebar-close,.sidebar-item.active .sidebar-close{opacity:1}.sidebar-close:hover{background:color-mix(in srgb,var(--error) 18%,transparent);color:var(--error)}@media(max-width:768px){.sidebar-close{opacity:.6}}.sidebar-foot{display:flex;gap:var(--s-2);padding:var(--s-3) var(--s-2) 0 var(--s-2);border-top:1px solid var(--border);margin-top:var(--s-2)}.sidebar-foot .btn{flex:1;font-size:var(--fs-sm)}.markdown{font-size:var(--fs-base);line-height:1.65;color:var(--text)}.markdown p{margin:0 0 var(--s-3)}.markdown p:last-child{margin-bottom:0}.markdown h1,.markdown h2,.markdown h3,.markdown h4{margin:var(--s-4) 0 var(--s-2);font-weight:600}.markdown h1{font-size:var(--fs-lg)}.markdown h2{font-size:var(--fs-md)}.markdown h3{font-size:var(--fs-base)}.markdown ul,.markdown ol{margin:0 0 var(--s-3);padding-left:var(--s-5)}.markdown li{margin-bottom:var(--s-1)}.markdown code{font-family:var(--mono);font-size:var(--fs-sm);background:var(--code-bg);padding:1px 5px;border-radius:var(--r-xs)}.markdown pre{background:var(--code-bg);border-radius:var(--r-sm);padding:var(--s-4);overflow-x:auto;margin:0 0 var(--s-3)}.markdown pre code{background:none;padding:0;font-size:var(--fs-sm);line-height:1.55}.markdown blockquote{border-left:3px solid var(--border-strong);margin:0 0 var(--s-3);padding:0 0 0 var(--s-4);color:var(--text-secondary)}.markdown a{color:var(--accent)}.markdown hr{border:none;border-top:1px solid var(--border);margin:var(--s-4) 0}.markdown table{border-collapse:collapse;width:100%;margin-bottom:var(--s-3)}.markdown th,.markdown td{border:1px solid var(--border);padding:var(--s-1) var(--s-3);text-align:left}.markdown th{background:var(--surface);font-weight:600}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:var(--z-modal);padding:calc(var(--s-5) + var(--safe-top)) calc(var(--s-5) + var(--safe-right)) calc(var(--s-5) + var(--safe-bottom)) calc(var(--s-5) + var(--safe-left));animation:overlay-fade var(--t-base) ease-out}@keyframes overlay-fade{0%{opacity:0}to{opacity:1}}.modal-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r-lg);padding:var(--s-5);width:100%;max-width:420px;display:flex;flex-direction:column;gap:var(--s-3);box-shadow:var(--elev-2);max-height:calc(100vh - var(--s-10));overflow-y:auto;animation:modal-pop var(--t-base) ease-out}@keyframes modal-pop{0%{transform:translateY(8px) scale(.98);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.modal-card-sm{max-width:360px}.modal-card-md{max-width:420px}.modal-card-lg{max-width:520px}.modal-card.modal-card-bare{max-width:min(960px,100%);max-height:calc(100vh - var(--s-8));padding:0;overflow:hidden;background:var(--card)}.modal-head{display:flex;align-items:center;justify-content:space-between;gap:var(--s-3);margin:calc(var(--s-1) * -1) 0 0}.modal-title{font-size:var(--fs-md);font-weight:600;margin:0;color:var(--text)}.modal-body{display:flex;flex-direction:column;gap:var(--s-3)}.modal-tool{font-family:var(--mono);font-size:var(--fs-sm);background:var(--surface);padding:var(--s-2) var(--s-3);border-radius:var(--r-sm);margin:0}.modal-input{font-family:var(--mono);font-size:var(--fs-xs);color:var(--text-secondary);background:var(--surface);padding:var(--s-3);border-radius:var(--r-sm);max-height:200px;overflow-y:auto;margin:0;white-space:pre-wrap;word-break:break-all}.modal-actions{display:flex;gap:var(--s-2);margin-top:var(--s-1)}.modal-actions .btn{flex:1;min-height:44px}.confirm-text{margin:0;color:var(--text);font-size:var(--fs-sm);line-height:var(--lh-base)}.confirm-hint{margin:0;color:var(--text-secondary);font-size:var(--fs-xs)}.new-session-body{gap:var(--s-4)}.new-session-row{display:flex;align-items:center;gap:var(--s-3);min-height:36px}.new-session-row-col{flex-direction:column;align-items:stretch;gap:var(--s-2)}.new-session-label{flex:0 0 auto;width:64px;font-size:var(--fs-sm);color:var(--text-secondary);font-weight:500;display:flex;flex-direction:column;gap:2px}.new-session-row-col .new-session-label{width:auto}.new-session-hint{font-size:var(--fs-xs);color:var(--text-tertiary);font-weight:400;word-break:break-all}.new-session-tools{display:flex;gap:var(--s-2);flex:1}.new-session-tools .btn{flex:1;min-height:36px}.new-session-input{flex:1;font-family:var(--sans);font-size:var(--fs-sm);padding:var(--s-2) var(--s-3);background:var(--card);color:var(--text);border:1px solid var(--border-strong);border-radius:var(--r-sm);outline:none;transition:border-color var(--t-fast)}.new-session-input:focus{border-color:var(--accent)}.new-session-input::placeholder{color:var(--text-tertiary)}.dir-picker{display:flex;flex-direction:column;border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface);overflow:hidden}.dir-breadcrumb{display:flex;flex-wrap:wrap;align-items:center;padding:var(--s-2) var(--s-3);border-bottom:1px solid var(--border);background:var(--card);font-size:var(--fs-sm);gap:2px;min-height:36px}.dir-crumb-wrap{display:inline-flex;align-items:center}.dir-crumb{background:transparent;border:none;cursor:pointer;padding:2px var(--s-1);border-radius:var(--r-xs);color:var(--accent);font-size:var(--fs-sm);font-family:var(--mono)}.dir-crumb:hover:not(:disabled){background:var(--surface-hover)}.dir-crumb:disabled{color:var(--text);cursor:default;font-weight:500}.dir-crumb-sep{color:var(--text-tertiary);padding:0 2px;font-family:var(--mono);-webkit-user-select:none;user-select:none}.dir-list{max-height:220px;min-height:120px;overflow-y:auto;display:flex;flex-direction:column;padding:var(--s-1)}.dir-item{display:flex;align-items:center;gap:var(--s-2);padding:var(--s-2) var(--s-3);background:transparent;border:none;border-radius:var(--r-sm);font-size:var(--fs-sm);color:var(--text);cursor:pointer;text-align:left;min-height:36px}.dir-item:hover{background:var(--surface-hover)}.dir-item-icon{color:var(--text-tertiary);font-size:var(--fs-xs)}.dir-item-name{font-family:var(--mono)}.dir-loading,.dir-empty{padding:var(--s-3);font-size:var(--fs-sm);color:var(--text-tertiary);text-align:center}.dir-selected{padding:var(--s-2) var(--s-3);border-top:1px solid var(--border);background:var(--card);font-size:var(--fs-xs);display:flex;align-items:center;gap:var(--s-2)}.dir-selected-label{color:var(--text-secondary)}.dir-selected-path{font-family:var(--mono);color:var(--text);background:var(--surface);padding:2px var(--s-2);border-radius:var(--r-xs);word-break:break-all}@media(max-width:480px){.new-session-row{flex-direction:column;align-items:stretch;gap:var(--s-1)}.new-session-label{width:auto}.new-session-tools .btn{min-height:40px}}.logs-modal-card{display:flex;flex-direction:column;height:calc(100vh - var(--s-8));background:var(--card)}.logs-header{display:flex;align-items:center;padding:var(--s-3) var(--s-5);border-bottom:1px solid var(--border);gap:var(--s-3);flex-shrink:0}.logs-title-group{flex:1;min-width:0}.logs-title{font-size:var(--fs-md);font-weight:600;color:var(--text)}.logs-path{font-size:var(--fs-xs);color:var(--text-tertiary);font-family:var(--mono);margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.logs-body{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:var(--s-3) var(--s-5);display:flex;flex-direction:column;gap:2px;background:var(--surface)}.logs-loading,.logs-empty{color:var(--text-tertiary);font-size:var(--fs-sm);text-align:center;margin-top:var(--s-10)}.logs-line{font-family:var(--mono);font-size:var(--fs-xs);color:var(--text);line-height:1.55;white-space:pre-wrap;word-break:break-all}.transfer-sections{display:flex;flex-direction:column;gap:var(--s-4)}.transfer-section{display:flex;flex-direction:column;gap:var(--s-2)}.transfer-section-title{font-size:var(--fs-xs);font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px}.transfer-json-box{display:flex;flex-direction:column;gap:var(--s-2)}.transfer-json{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-sm);padding:var(--s-3);font-family:var(--mono);font-size:var(--fs-xs);line-height:1.55;color:var(--text);max-height:200px;overflow-y:auto;white-space:pre-wrap;word-break:break-all;margin:0;-webkit-user-select:text;user-select:text}.transfer-textarea{width:100%;font-family:var(--mono);font-size:var(--fs-md);background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--r-sm);padding:var(--s-3);color:var(--text);resize:none;outline:none;transition:border-color var(--t-fast);line-height:var(--lh-base)}@media(min-width:481px){.transfer-textarea{font-size:var(--fs-xs)}}.transfer-textarea:focus{border-color:var(--accent)}.transfer-divider{border:none;border-top:1px solid var(--border)}.error-boundary{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--s-6);background:var(--bg)}.error-boundary-card{max-width:560px;width:100%;background:var(--card);border:1px solid var(--border);border-radius:var(--r-md);padding:var(--s-8);display:flex;flex-direction:column;gap:var(--s-3)}.error-boundary-icon{font-size:36px;text-align:center;color:var(--error)}.error-boundary-title{font-size:var(--fs-lg);font-weight:600;text-align:center;margin:0}.error-boundary-message{background:var(--code-bg);padding:var(--s-2) var(--s-3);border-radius:var(--r-sm);font-family:var(--mono);font-size:var(--fs-sm);color:var(--error);margin:0;word-break:break-word}.error-boundary-details{font-size:var(--fs-sm);color:var(--text-secondary)}.error-boundary-details summary{cursor:pointer;padding:var(--s-1) 0;-webkit-user-select:none;user-select:none}.error-boundary-stack{background:var(--code-bg);padding:var(--s-2) var(--s-3);border-radius:var(--r-sm);font-family:var(--mono);font-size:var(--fs-xs);overflow-x:auto;white-space:pre-wrap;word-break:break-word;margin:var(--s-2) 0 0;max-height:260px}.error-boundary-actions{display:flex;gap:var(--s-3);margin-top:var(--s-1)}.error-boundary-actions .btn,.error-boundary-actions .connect-btn,.error-boundary-actions .forget-btn{flex:1}.connect-btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--accent);color:var(--accent-text);border:1px solid var(--accent);font-family:var(--sans);font-size:var(--fs-base);font-weight:600;padding:var(--s-3) var(--s-5);border-radius:var(--r-md);cursor:pointer;transition:background var(--t-fast);min-height:44px}.connect-btn:hover:not(:disabled){background:var(--accent-hover);border-color:var(--accent-hover)}.connect-btn:disabled{opacity:.4;cursor:default}.forget-btn{background:transparent;border:1px solid var(--border-strong);border-radius:var(--r-sm);color:var(--text-secondary);padding:var(--s-3) var(--s-4);font-size:var(--fs-sm);cursor:pointer;font-family:var(--sans);transition:color var(--t-fast),border-color var(--t-fast),background var(--t-fast);white-space:nowrap;min-height:44px}.forget-btn:hover:not(:disabled){color:var(--error);border-color:var(--error)}.forget-btn:disabled{opacity:.4;cursor:default}.chat-empty-pane{flex:1;display:flex;align-items:center;justify-content:center;padding:var(--s-6);background:var(--bg)}.chat-empty-box{max-width:420px;width:100%;text-align:center;display:flex;flex-direction:column;gap:var(--s-4);padding:var(--s-6);background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md)}.chat-empty-title{font-size:var(--fs-md);font-weight:600}.chat-empty-sub{font-size:var(--fs-sm);color:var(--text-secondary);line-height:var(--lh-base)}.chat-empty-actions{display:flex;gap:var(--s-3);justify-content:center;flex-wrap:wrap}@media(max-width:768px){.modal-overlay{align-items:flex-end;padding:0}.modal-card:not(.modal-card-bare){border-bottom-left-radius:0;border-bottom-right-radius:0;max-width:100%;margin:0;padding-bottom:calc(var(--s-5) + var(--safe-bottom));animation:sheet-up var(--t-base) ease-out}@keyframes sheet-up{0%{transform:translateY(100%)}to{transform:none}}}.tab-bar{position:fixed;bottom:0;left:0;right:0;height:calc(56px + var(--safe-bottom));background:var(--surface);border-top:1px solid var(--border);display:flex;z-index:var(--z-drawer);padding-bottom:var(--safe-bottom);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}@media(min-width:769px){.tab-bar{display:none}}.tab-bar-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;background:transparent;border:none;cursor:pointer;color:var(--text-tertiary);font-family:var(--sans);transition:color var(--t-fast);padding:var(--s-1) 0;-webkit-tap-highlight-color:transparent}.tab-bar-item.active{color:var(--accent)}.tab-bar-item:active{opacity:.7}.tab-bar-icon{flex-shrink:0}.tab-bar-label{font-size:10px;font-weight:500;letter-spacing:.2px;line-height:1}.tab-page{padding-bottom:calc(56px + var(--safe-bottom));min-height:100vh;min-height:100dvh}@media(min-width:769px){.tab-page{padding-bottom:0}}.session-list-page{display:flex;flex-direction:column;background:var(--bg);overflow-y:auto}.session-list-header{display:flex;align-items:center;justify-content:space-between;padding:calc(var(--s-4) + var(--safe-top)) calc(var(--s-4) + var(--safe-right)) var(--s-3) calc(var(--s-4) + var(--safe-left));background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0;position:sticky;top:0;z-index:5;min-height:calc(var(--header-h) + var(--safe-top))}.session-list-title{font-size:var(--fs-lg);font-weight:700;margin:0;color:var(--text)}.session-list-body{flex:1;display:flex;flex-direction:column}.session-list-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--s-2);padding:var(--s-10);color:var(--text-tertiary);font-size:var(--fs-sm);text-align:center}.session-list-empty-icon{opacity:.3;margin-bottom:var(--s-2)}.session-list-empty-sub{font-size:var(--fs-xs)}.session-row{display:flex;align-items:center;gap:var(--s-3);padding:var(--s-3) calc(var(--s-4) + var(--safe-right)) var(--s-3) calc(var(--s-4) + var(--safe-left));background:transparent;border:none;border-bottom:1px solid var(--border);cursor:pointer;text-align:left;min-height:68px;width:100%;font-family:var(--sans);transition:background var(--t-fast);-webkit-tap-highlight-color:transparent}.session-row:hover{background:var(--surface-hover)}.session-row:active{background:var(--surface)}.session-row-avatar{width:48px;height:48px;border-radius:var(--r-lg);flex-shrink:0;display:flex;align-items:center;justify-content:center;color:#fff}.avatar-claude{background:linear-gradient(135deg,#c47f00,#e8a000)}.avatar-gemini{background:linear-gradient(135deg,#2b7cff,#5a4fcf)}.session-row-content{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px}.session-row-title-row{display:flex;align-items:baseline;justify-content:space-between;gap:var(--s-2)}.session-row-name{font-size:var(--fs-base);font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.session-row-time{font-size:var(--fs-xs);color:var(--text-tertiary);flex-shrink:0}.session-row-sub{font-family:var(--mono);font-size:var(--fs-xs);color:var(--text-tertiary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.settings-page{background:var(--surface);display:flex;flex-direction:column;overflow-y:auto}.settings-header{padding:calc(var(--s-4) + var(--safe-top)) calc(var(--s-4) + var(--safe-right)) var(--s-3) calc(var(--s-4) + var(--safe-left));background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:5}.settings-title{font-size:var(--fs-lg);font-weight:700;margin:0;color:var(--text)}.settings-section{display:flex;flex-direction:column;margin-top:var(--s-5)}.settings-section-title{display:flex;align-items:center;gap:var(--s-1);font-size:var(--fs-xs);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px;font-weight:600;padding:0 calc(var(--s-4) + var(--safe-right)) var(--s-1) calc(var(--s-4) + var(--safe-left))}.settings-item{display:flex;align-items:center;gap:var(--s-3);padding:var(--s-3) calc(var(--s-4) + var(--safe-right)) var(--s-3) calc(var(--s-4) + var(--safe-left));background:var(--card);border:none;border-top:1px solid var(--border);min-height:52px;cursor:pointer;font-family:var(--sans);font-size:var(--fs-base);color:var(--text);text-align:left;width:100%;transition:background var(--t-fast);-webkit-tap-highlight-color:transparent}.settings-item:last-child{border-bottom:1px solid var(--border)}.settings-item:hover{background:var(--surface-hover)}.settings-item:active{background:var(--surface)}.settings-item-info{cursor:default;flex-direction:column;align-items:flex-start;gap:var(--s-1)}.settings-item-info:hover{background:var(--card)}.settings-item-icon{color:var(--text-secondary);flex-shrink:0}.settings-item-text{flex:1}.settings-item-chevron{color:var(--text-tertiary);flex-shrink:0}.settings-item-label{font-size:var(--fs-xs);font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.4px}.settings-value{font-family:var(--mono);font-size:var(--fs-xs);color:var(--text-secondary);word-break:break-all;-webkit-user-select:text;user-select:text}.settings-item-danger,.settings-item-danger .settings-item-icon{color:var(--error)}.home-page{display:flex;align-items:center;justify-content:center;background:var(--bg);min-height:100vh;min-height:100dvh}.home-content{display:flex;flex-direction:column;align-items:center;gap:var(--s-3);text-align:center}.home-logo{font-size:56px;line-height:1}.home-title{font-size:var(--fs-xl);font-weight:700;margin:0;letter-spacing:-.5px}.home-status{display:flex;align-items:center;gap:var(--s-2);color:var(--text-secondary);font-size:var(--fs-sm)}.home-status-label{font-size:var(--fs-sm);color:var(--text-secondary)}.home-actions{display:flex;gap:var(--s-3);margin-top:var(--s-3)}.home-action-btn{display:flex;flex-direction:column;align-items:center;gap:var(--s-2);padding:var(--s-4) var(--s-5);background:var(--card);border:1px solid var(--border);border-radius:var(--r-lg);cursor:pointer;color:var(--text-primary);min-width:110px;transition:background var(--t-fast),opacity var(--t-fast);position:relative}.home-action-btn:hover:not(:disabled){background:var(--surface-hover)}.home-action-btn:disabled{opacity:.4;cursor:not-allowed}.home-action-icon{color:var(--accent)}.home-action-label{font-size:var(--fs-sm);font-weight:500}.home-action-badge{position:absolute;top:var(--s-2);right:var(--s-2);min-width:18px;height:18px;padding:0 5px;background:var(--accent);color:#fff;border-radius:var(--r-full);font-size:11px;font-weight:600;line-height:18px;text-align:center}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:transparent;border-radius:var(--r-full)}*:hover::-webkit-scrollbar-thumb{background:color-mix(in srgb,var(--text-tertiary) 50%,transparent)}::-webkit-scrollbar-thumb:hover{background:color-mix(in srgb,var(--text-secondary) 70%,transparent)}
