.login-screen{background:var(--bg-primary);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.login-container{text-align:center;width:100%;max-width:400px}.login-logo{margin-bottom:48px}.login-logo h1{color:var(--text-primary);margin:0 0 8px;font-size:32px;font-weight:700}.login-logo p{color:var(--text-secondary);margin:0;font-size:14px}.login-content{flex-direction:column;gap:16px;display:flex}.google-login-btn{width:100%;height:48px;color:var(--text-primary);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);cursor:pointer;justify-content:center;align-items:center;gap:12px;padding:0 24px;font-size:15px;font-weight:500;transition:all .2s;display:flex}.google-login-btn:hover{background:var(--bg-tertiary);border-color:var(--border-strong)}.login-error{color:#dc2626;border-radius:var(--radius-md);background:#fef2f2;border:1px solid #fecaca;padding:12px 16px;font-size:13px}.login-footer{margin-top:32px}.login-footer p{color:var(--text-secondary);margin:0 0 4px;font-size:13px}.login-footer .text-muted{color:var(--text-tertiary);font-size:12px}.spinner{animation:1s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.user-menu{position:relative}.user-menu-button{border-radius:var(--radius-md);cursor:pointer;background:0 0;border:none;align-items:center;gap:8px;padding:8px 12px;display:flex}.user-menu-button:hover{background:var(--bg-tertiary)}.user-avatar{object-fit:cover;border-radius:50%;width:32px;height:32px}.user-avatar-placeholder{background:var(--bg-tertiary);width:32px;height:32px;color:var(--text-secondary);border-radius:50%;justify-content:center;align-items:center;font-size:14px;font-weight:600;display:flex}.menu-overlay{z-index:40;position:fixed;inset:0}.menu-dropdown{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-lg);z-index:50;min-width:240px;margin-bottom:8px;position:absolute;bottom:100%;right:0;box-shadow:0 10px 40px #00000026}.menu-header{align-items:center;gap:12px;padding:16px;display:flex}.menu-avatar{border-radius:50%;width:40px;height:40px}.menu-user-info{flex:1}.menu-user-name{color:var(--text-primary);margin:0;font-size:14px;font-weight:600}.menu-user-email{color:var(--text-secondary);margin:0;font-size:12px}.menu-divider{background:var(--border-color);height:1px}.menu-item{width:100%;color:var(--text-primary);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:12px;padding:12px 16px;font-size:14px;display:flex}.menu-item:hover{background:var(--bg-secondary)}.menu-item.logout{color:#dc2626}.chat-panel-header{border-bottom:1px solid var(--border-primary);background:var(--bg-primary);flex-shrink:0;justify-content:space-between;align-items:center;padding:8px 16px;display:flex}.chat-panel-header-buttons{align-items:center;gap:8px;margin-left:auto;display:flex}.chat-panel-base{background:var(--bg-primary);flex-direction:column;height:100%;font-family:SF Mono,Fira Code,Consolas,Monaco,monospace;display:flex;position:relative}.chat-panel-base.empty-chat .chat-main-content{flex-direction:column;flex:1;justify-content:center;align-items:center;padding:0 24px;display:flex}.chat-panel-base.empty-chat .welcome-placeholder{text-align:center;flex-direction:column;justify-content:center;align-items:center;margin-bottom:32px;display:flex}.chat-panel-base.empty-chat .welcome-placeholder h2{color:var(--text-primary);margin-bottom:12px;font-size:28px;font-weight:600}.chat-panel-base.empty-chat .welcome-placeholder p{color:var(--text-secondary);font-size:16px}.chat-panel-base:not(.empty-chat) .chat-main-content{flex-direction:column;flex:1;min-height:0;display:flex}.chat-panel-base:not(.empty-chat) .chat-input-area{border-top:1px solid var(--border-color);background:var(--bg-primary);flex-shrink:0}.chat-panel-base .messages-container{max-width:var(--messages-max-width,800px);flex-direction:column;flex:1;width:100%;margin:0 auto;padding:24px;transition:padding-right .3s,max-width .2s;display:flex;overflow-y:auto}.chat-panel-base.with-sidebar .messages-container{transform:translateX(calc(-1 * (var(--sidebar-actual-width,520px) / 2)))}.chat-panel-base.empty-chat.with-sidebar .chat-main-content{transform:translateX(calc(-1 * (var(--sidebar-actual-width,520px) / 2)));transition:transform .3s}.chat-panel-base.with-sidebar .message{margin-bottom:var(--message-gap,48px)}.chat-panel-base .messages-container>:first-child{margin-top:auto}.chat-panel-base .message{width:100%;margin-bottom:48px;display:flex}.chat-panel-base .message.user{justify-content:flex-end}.chat-panel-base .message.assistant{justify-content:flex-start}.chat-panel-base .message-content{border-radius:20px;max-width:70%;padding:14px 18px;font-size:15px;line-height:1.6}.chat-panel-base .message.user .message-content{background:var(--accent);color:#fff;border-bottom-right-radius:6px}.chat-panel-base .message.assistant .message-content{background:var(--bg-secondary);color:var(--text-primary);border-bottom-left-radius:6px}.chat-panel-base .attached-image{border-radius:8px;max-width:200px;max-height:200px;margin-top:8px}.chat-panel-base .loading-dots span{opacity:0;animation:1.4s infinite dots}.chat-panel-base .loading-dots span:first-child{animation-delay:0s}.chat-panel-base .loading-dots span:nth-child(2){animation-delay:.2s}.chat-panel-base .loading-dots span:nth-child(3){animation-delay:.4s}@keyframes dots{0%,60%,to{opacity:0}30%{opacity:1}}.chat-input-area{width:100%;max-width:800px;margin:0 auto;padding:16px 24px}.chat-input-wrapper{border:1px solid var(--border-strong);-webkit-backdrop-filter:blur(12px);background:#fff9;border-radius:24px;align-items:center;max-width:100%;margin:0 auto;padding:12px 16px;transition:all .2s;display:flex;position:relative;box-shadow:0 2px 16px #00000014,inset 0 1px #ffffffe6}.dark .chat-input-wrapper{background:#27272a99;border:1px solid #ffffff14;box-shadow:0 2px 16px #0000004d,inset 0 1px #ffffff0f}.chat-input-wrapper:hover{border-color:var(--accent);box-shadow:0 4px 20px #0000001a,inset 0 1px #ffffffe6}.chat-input-wrapper:focus-within{border-color:var(--accent);box-shadow:0 4px 24px #0000001f,inset 0 1px #ffffffe6}.dark .chat-input-wrapper:focus-within{border-color:var(--accent);box-shadow:0 4px 24px #0006,inset 0 1px #ffffff14}.chat-input-wrapper.multiline{align-items:flex-end}.chat-input-wrapper textarea{color:var(--text-primary);resize:none;background:0 0;border:none;flex:1;min-height:24px;max-height:220px;padding:0;font-family:SF Mono,Fira Code,Consolas,Monaco,monospace;font-size:15px;line-height:1.5;overflow-y:hidden}.chat-input-wrapper textarea:focus{outline:none}.chat-input-wrapper textarea::placeholder{color:var(--text-tertiary)}.chat-input-icon-btn{width:36px;height:36px;color:var(--text-tertiary);cursor:pointer;background:0 0;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;margin-left:10px;transition:all .15s;display:flex}.chat-input-icon-btn:first-of-type{margin-left:-4px;margin-right:0}.chat-input-icon-btn:hover{background:var(--bg-secondary);color:var(--text-primary)}.chat-input-icon-btn.recording{color:#dc2626;background:#fee2e2;animation:1.5s infinite pulse}.chat-thinking-mode-btn{-webkit-backdrop-filter:blur(8px);color:#333;cursor:pointer;white-space:nowrap;background:#ffffffb3;border:1px solid #ffffff4d;border-radius:999px;justify-content:center;align-items:center;gap:4px;min-width:64px;height:36px;margin-left:10px;padding:0 12px;font-size:12px;transition:all .15s;display:flex;box-shadow:0 2px 8px #00000014,inset 0 1px 1px #ffffff80}.chat-thinking-mode-btn:hover{background:#ffffffd9;box-shadow:0 4px 12px #0000001f,inset 0 1px 1px #ffffff80}.chat-thinking-mode-btn.active{-webkit-backdrop-filter:blur(8px);color:#fff;background:#333333e6;border-color:#33333380;font-weight:500;box-shadow:0 2px 8px #0003,inset 0 1px 1px #ffffff1a}.chat-thinking-mode-btn .pro-badge{color:inherit;opacity:.7;margin-left:2px;font-size:9px;font-weight:600}.chat-send-btn{background:var(--text-tertiary);width:36px;height:36px;color:var(--bg-primary);cursor:pointer;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;margin-left:8px;font-size:12px;font-weight:600;transition:all .2s;display:flex}.chat-send-btn:not(:disabled){background:var(--accent)}.chat-send-btn:hover:not(:disabled){transform:scale(1.05)}.chat-send-btn:disabled{opacity:.5;cursor:not-allowed}.chat-attached-file{background:var(--bg-secondary);color:var(--text-secondary);border-radius:6px;align-items:center;gap:6px;padding:4px 8px;font-size:12px;display:flex}.chat-attached-file .file-name{text-overflow:ellipsis;white-space:nowrap;max-width:100px;overflow:hidden}.chat-attached-file .file-preview{object-fit:cover;border-radius:4px;width:32px;height:32px}.chat-attached-file .file-remove-btn{color:var(--text-tertiary);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;padding:2px;display:flex}.chat-attached-file .file-remove-btn:hover{color:#dc2626}.conv-sidebar-header{background:var(--bg-tertiary);border-bottom:1px solid var(--border-color);flex-shrink:0;align-items:center;gap:6px;padding:12px 12px 10px;display:flex}.conv-sidebar-title{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.06em;flex:1;font-size:12px;font-weight:600}.conv-sidebar-new,.conv-sidebar-close{width:26px;height:26px;color:var(--text-tertiary);cursor:pointer;background:0 0;border:none;border-radius:5px;justify-content:center;align-items:center;transition:background .15s,color .15s;display:flex}.conv-sidebar-new:hover,.conv-sidebar-close:hover{background:var(--bg-secondary);color:var(--text-primary)}.conv-sidebar-body{flex:1;padding:4px 0;overflow-y:auto}.conv-sidebar-group{padding:6px 0 2px}.conv-sidebar-group-label{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em;align-items:center;gap:5px;padding:2px 12px 4px;font-size:10px;font-weight:600;display:flex}.conv-sidebar-group-label span,.conv-sidebar-group-label .folder-name{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.conv-sidebar-group-label .folder-name{cursor:text}.conv-folder-rename-input{border:1px solid var(--accent);background:var(--bg-primary);min-width:0;color:var(--text-primary);text-transform:uppercase;letter-spacing:.05em;border-radius:3px;outline:none;flex:1;padding:1px 4px;font-size:10px;font-weight:600}.conv-folder-del-btn{color:var(--text-tertiary);cursor:pointer;opacity:0;background:0 0;border:none;border-radius:3px;align-items:center;padding:2px;transition:opacity .15s;display:flex}.conv-sidebar-group-label:hover .conv-folder-del-btn{opacity:1}.conv-folder-del-btn:hover{color:#dc2626}.conv-sidebar-item{border-radius:6px;align-items:center;gap:2px;min-height:32px;margin:1px 6px;padding:0 6px 0 12px;display:flex}.conv-sidebar-item:hover,.conv-sidebar-item.active{background:var(--bg-secondary)}.conv-sidebar-item.dragging{opacity:.4}.conv-sidebar-item.drop-folder{background:color-mix(in srgb, var(--accent) 12%, transparent);outline:1.5px solid var(--accent);border-radius:6px}.conv-sidebar-item.drop-before{border-top:2px solid var(--accent)}.conv-sidebar-item.drop-after{border-bottom:2px solid var(--accent)}.conv-sidebar-group.drop-target .conv-sidebar-group-label{background:color-mix(in srgb, var(--accent) 10%, transparent);border-radius:4px}.conv-sidebar-item.active .conv-sidebar-item-title{color:var(--accent);font-weight:500}.conv-sidebar-item-title{text-overflow:ellipsis;white-space:nowrap;min-width:0;color:var(--text-primary);cursor:pointer;flex:1;align-items:center;gap:4px;padding:4px 0;font-size:13px;display:flex;overflow:hidden}.conv-sidebar-rename-input{border:1px solid var(--accent);background:var(--bg-primary);color:var(--text-primary);border-radius:4px;outline:none;flex:1;padding:3px 6px;font-size:13px}.conv-sidebar-item-menu{flex-shrink:0;position:relative}.conv-sidebar-item-menu>button{width:22px;height:22px;color:var(--text-tertiary);cursor:pointer;opacity:0;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;transition:opacity .15s,background .15s;display:flex}.conv-sidebar-item:hover .conv-sidebar-item-menu>button{opacity:1}.conv-sidebar-item-menu>button:hover{background:var(--bg-secondary);color:var(--text-primary)}.conv-sidebar-context-menu{background:var(--bg-primary);border:1px solid var(--border-color);z-index:1100;border-radius:8px;min-width:148px;position:absolute;top:100%;right:0;overflow:hidden;box-shadow:0 4px 16px #0000001f}.conv-sidebar-context-menu button{text-align:left;width:100%;color:var(--text-primary);cursor:pointer;background:0 0;border:none;padding:7px 12px;font-size:13px;transition:background .1s;display:block}.conv-sidebar-context-menu button:hover{background:var(--bg-secondary)}.conv-sidebar-context-menu button.danger{color:#dc2626}.conv-sidebar-context-menu button.danger:hover{background:#fee2e2}.conv-menu-divider{background:var(--border-color);height:1px;margin:3px 0}.conv-sidebar-footer{border-top:1px solid var(--border-color);flex-shrink:0;margin-top:auto;padding:8px}.conv-sidebar-add-folder{width:100%;color:var(--text-tertiary);cursor:pointer;background:0 0;border:none;border-radius:6px;align-items:center;gap:6px;padding:6px 8px;font-size:12px;transition:background .15s;display:flex}.conv-sidebar-add-folder:hover{background:var(--bg-secondary);color:var(--text-primary)}.conv-folder-input-row{gap:6px;display:flex}.conv-folder-input-row input{border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-primary);border-radius:5px;outline:none;flex:1;padding:5px 8px;font-size:12px}.conv-folder-input-row input:focus{border-color:var(--accent)}.conv-folder-input-row button{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:5px;padding:5px 10px;font-size:12px}@keyframes pulse{0%,to{opacity:.5}50%{opacity:1}}.input-wrapper .thinking-mode-btn{-webkit-backdrop-filter:blur(8px);color:#333;cursor:pointer;white-space:nowrap;background:#ffffffb3;border:1px solid #ffffff4d;border-radius:999px;align-items:center;gap:4px;height:36px;padding:0 12px;font-size:12px;transition:all .15s;display:flex;box-shadow:0 2px 8px #00000014,inset 0 1px 1px #ffffff80}.input-wrapper .thinking-mode-btn:hover{background:#ffffffd9;box-shadow:0 4px 12px #0000001f,inset 0 1px 1px #ffffff80}.input-wrapper .thinking-mode-btn.active{-webkit-backdrop-filter:blur(8px);color:#fff;background:#333333e6;border-color:#33333380;font-weight:500;box-shadow:0 2px 8px #0003,inset 0 1px 1px #ffffff1a}.input-wrapper .thinking-mode-btn .pro-badge{color:inherit;opacity:.7;margin-left:2px;font-size:9px;font-weight:600}.input-wrapper .input-icon-btn{width:36px;height:36px;color:var(--text-tertiary);cursor:pointer;background:0 0;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;margin-left:10px;transition:all .15s;display:flex}.input-wrapper button.input-icon-btn:first-of-type{margin-left:-4px;margin-right:0}.input-wrapper .input-icon-btn:hover{background:var(--bg-secondary);color:var(--text-primary)}.input-wrapper .input-icon-btn.recording{color:#dc2626;background:#fee2e2;animation:1.5s infinite pulse}.input-wrapper .attached-file{background:var(--bg-secondary);color:var(--text-secondary);border-radius:6px;align-items:center;gap:6px;padding:4px 8px;font-size:12px;display:flex}.input-wrapper .attached-file .file-name{text-overflow:ellipsis;white-space:nowrap;max-width:100px;overflow:hidden}.input-wrapper .attached-file .file-preview{object-fit:cover;border-radius:4px;width:32px;height:32px}.input-wrapper .attached-file .file-remove-btn{color:var(--text-tertiary);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;padding:2px;display:flex}.input-wrapper .attached-file .file-remove-btn:hover{color:#dc2626}.assistant-confirm-card{background:var(--bg-secondary);border:1px solid var(--border-strong);border-radius:10px;margin:6px 0;padding:12px;font-size:12px}.assistant-confirm-header{margin-bottom:8px}.assistant-confirm-label{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em;font-size:10px;font-weight:600}.assistant-confirm-item{margin-bottom:8px}.assistant-confirm-action{color:var(--text-primary);margin-bottom:4px;font-weight:600}.assistant-confirm-preview{background:var(--bg-tertiary);color:var(--text-secondary);white-space:pre-wrap;word-break:break-all;border-radius:6px;max-height:80px;margin-bottom:4px;padding:6px 8px;font-size:11px;overflow-y:auto}.assistant-confirm-args{flex-wrap:wrap;gap:4px;display:flex}.assistant-confirm-arg{background:var(--bg-tertiary);border-radius:4px;align-items:center;gap:3px;padding:2px 6px;font-size:11px;display:inline-flex}.arg-key{color:var(--text-tertiary)}.arg-val{color:var(--text-primary);font-weight:500}.assistant-confirm-actions{justify-content:flex-end;gap:6px;margin-top:10px;display:flex}.assistant-confirm-reject,.assistant-confirm-approve{border-radius:var(--radius-full);border:1px solid var(--border-color);cursor:pointer;align-items:center;gap:4px;padding:5px 12px;font-family:inherit;font-size:12px;font-weight:500;transition:background .15s;display:flex}.assistant-confirm-reject{color:var(--text-secondary);background:0 0}.assistant-confirm-reject:hover{background:var(--bg-tertiary)}.assistant-confirm-approve{background:var(--accent);color:#fff;border-color:var(--accent)}.assistant-confirm-approve:hover{opacity:.9}.assistant-scan-overlay{background:#000000d9;border:1px solid #00ff5066;border-radius:8px;align-items:center;min-height:56px;margin:6px 0;padding:16px;display:flex;position:relative;overflow:hidden}.scan-bar{background:linear-gradient(90deg,#0000,#00ff50e6,#0000);height:2px;animation:1.4s ease-in-out infinite scan-move;position:absolute;left:0;right:0;box-shadow:0 0 12px #00ff5099}@keyframes scan-move{0%{opacity:1;top:0}85%{opacity:1;top:calc(100% - 2px)}to{opacity:0;top:calc(100% - 2px)}}.scan-grid{background-image:linear-gradient(#00ff500d 1px,#0000 1px),linear-gradient(90deg,#00ff500d 1px,#0000 1px);background-size:20px 20px;position:absolute;inset:0}.scan-label{color:#00ff50e6;letter-spacing:.08em;font-family:Courier New,monospace;font-size:11px;font-weight:500;animation:2s ease-in-out infinite scan-flicker;position:relative}@keyframes scan-flicker{0%,to{opacity:1}50%{opacity:.6}}.assistant-widget{z-index:99999;position:fixed;bottom:24px;right:24px}.assistant-widget.open{inset:0}.assistant-widget:not(.open) .assistant-fab-row{position:relative}.assistant-widget.open .assistant-fab-row{z-index:2;align-items:center;gap:8px;display:flex;position:absolute;bottom:24px;right:24px}.assistant-fab{color:#111;cursor:pointer;white-space:nowrap;background:#fff;border:1px solid #0000001a;border-radius:100px;justify-content:center;align-items:center;gap:4px;height:38px;padding:0 16px;font-family:inherit;font-size:13px;font-weight:500;transition:all .2s cubic-bezier(.16,1,.3,1);display:flex;box-shadow:0 4px 16px #0000001f}.assistant-fab:hover{background:#fafafa;transform:translateY(-2px);box-shadow:0 6px 20px #00000026}.assistant-fab.open{color:#fff;background:#111;border-color:#111}.assistant-overlay{cursor:pointer;z-index:0;background:#0006;animation:.3s overlay-in;position:absolute;inset:0}@keyframes overlay-in{0%{opacity:0}to{opacity:1}}.assistant-glass-header{z-index:999;box-sizing:border-box;background:#fafafa;border:1px solid #eee;border-radius:12px;justify-content:space-between;align-items:center;width:816px;max-width:calc(100vw - 48px);height:52px;padding:0 16px;animation:.3s cubic-bezier(.16,1,.3,1) forwards header-slide;display:flex;position:absolute;top:40px;left:50%;transform:translate(-50%);box-shadow:0 4px 20px #00000014}@keyframes header-slide{0%{opacity:0;transform:translate(-50%)translateY(-10px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.assistant-header-left,.assistant-header-right{align-items:center;gap:8px;display:flex}.assistant-header-title{color:#111;margin-left:4px;font-size:13px;font-weight:600}.assistant-input-float{z-index:10;flex-direction:column;align-items:flex-start;width:820px;max-width:calc(100vw - 48px);animation:.3s cubic-bezier(.16,1,.3,1) forwards glass-rise;display:flex;position:absolute;bottom:40px;left:50%;transform:translate(-50%)}.assistant-input-float .chat-input-wrapper{box-sizing:border-box;isolation:isolate;background:#fff;border:1px solid #00000014;border-radius:24px;width:100%;margin:0;transition:all .4s;position:relative;box-shadow:0 8px 32px #0000002e}.assistant-input-float .chat-input-wrapper.autopilot-active{border-color:#ff00004d;box-shadow:0 8px 32px #0000002e,0 0 100px 20px #ff00001f,0 0 250px 40px #ff00000d}.assistant-input-float .chat-input-wrapper.autopilot-active:before,.assistant-input-float .chat-input-wrapper.autopilot-active:after{content:"";pointer-events:none;z-index:-1;opacity:0;border:1px solid #f006;border-radius:26px;animation:6s ease-out infinite border-ripple-uniform-fixed;position:absolute;inset:-4px}.assistant-input-float .chat-input-wrapper.autopilot-active:after{animation-delay:3s}@keyframes border-ripple-uniform-fixed{0%{opacity:0;filter:blur(2px);inset:-2px}15%{opacity:.5}to{opacity:0;filter:blur(15px);border-radius:40px;inset:-120px}}@keyframes glass-rise{0%{opacity:0;transform:translate(-50%)translateY(20px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.assistant-context-preview-mini{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:#ffffffb3;z-index:20;background:#00000026;border-radius:8px;align-items:center;gap:8px;margin-bottom:8px;padding:4px 8px;font-size:11px;font-weight:500;animation:.4s fade-in;display:flex;position:relative}.context-mini-thumbnail{border:1px solid #fff3;border-radius:2px;width:32px;height:18px;overflow:hidden}.context-mini-thumbnail img{object-fit:cover;width:100%;height:100%}.context-mini-dot{background:#4ade80;border-radius:50%;width:4px;height:4px;animation:2s infinite pulse-dot;box-shadow:0 0 6px #4ade80}@keyframes pulse-dot{0%{opacity:.4}50%{opacity:1}to{opacity:.4}}.assistant-glass-messages{z-index:10;flex-direction:column;gap:12px;width:820px;max-width:calc(100vw - 48px);padding:24px 8px;display:flex;position:absolute;top:104px;bottom:160px;left:50%;overflow-y:auto;transform:translate(-50%)}.assistant-glass-messages.empty{flex-direction:column;justify-content:flex-end;align-items:center;padding-bottom:20px;display:flex}.assistant-welcome-center{text-align:center;color:#fff;text-shadow:0 0 12px #ffffff4d,0 2px 4px #0003;margin-top:auto;animation:.5s fade-in}.assistant-welcome-center h3{margin-bottom:8px;font-size:24px;font-weight:700}.assistant-welcome-center p{opacity:.8;font-size:15px}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.assistant-glass-messages::-webkit-scrollbar{width:4px}.assistant-glass-messages::-webkit-scrollbar-track{background:0 0}.assistant-glass-messages::-webkit-scrollbar-thumb{background:#fff3;border-radius:10px}.assistant-glass-msg{display:flex}.assistant-glass-msg.user{justify-content:flex-end}.assistant-glass-msg.assistant{justify-content:flex-start}.assistant-glass-msg-content{max-width:85%;font-size:14px;line-height:1.6}.assistant-glass-msg.user .assistant-glass-msg-content{color:#111;background:#fff;border:1px solid #0000001a;border-radius:18px 18px 4px;padding:10px 16px;box-shadow:0 2px 8px #0000000d}.assistant-glass-msg.assistant .assistant-glass-msg-content{color:#fff;text-shadow:0 1px 2px #0003;padding:4px 0}.assistant-glass-msg-content.loading-dots{color:#fffc;font-style:italic}.assistant-tool-chip{color:#fff;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#ffffff1a;border:1px solid #ffffff4d;border-radius:100px;align-items:center;height:24px;padding:0 12px;font-size:12px;font-weight:600;display:inline-flex}.assistant-tool-chip.running{color:#fef08a;background:#fefce833;border-color:#fde68a66}.assistant-tool-chip.rejected{color:#fecaca;background:#fef2f233;border-color:#fecaca66}.assistant-pill-btn{color:#555;cursor:pointer;z-index:11;background:#fff;border:1px solid #00000014;border-radius:100px;height:36px;padding:0 16px;font-size:12px;font-weight:500;transition:all .2s;box-shadow:0 2px 8px #0000000d}.assistant-pill-btn:hover{color:#111;background:#f8f8f8}.assistant-pill-btn.active{color:#fff;background:#111;border-color:#111}.assistant-header-btn{color:#555;cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;transition:all .15s;display:flex}.assistant-header-btn:hover{color:#111;background:#0000000d}.assistant-header-btn.active{color:#fff;background:#111}.assistant-header-btn.close:hover{color:#ef4444;background:#fee2e2}html,body,#root{height:100%;overflow:hidden}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Pretendard,sans-serif}#root{background:0 0;flex-direction:column;display:flex}*,button,a,input,select,textarea{will-change:auto}.gpu-accelerated{backface-visibility:hidden;transform:translateZ(0)}@media (prefers-color-scheme:dark){:root{--bg-primary:#fff;--bg-secondary:#f8f8f8}}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}.sidebar{background:var(--bg-secondary);border-right:1px solid var(--border-color);z-index:150;flex-direction:column;flex-shrink:0;width:260px;min-width:260px;transition:all .2s;display:flex;position:relative}.sidebar.collapsed>*{display:none!important}.sidebar-header{justify-content:space-between;align-items:center;height:48px;padding:0 16px;display:flex}.workspace-name{text-overflow:ellipsis;white-space:nowrap;font-size:14px;font-weight:600;overflow:hidden}.collapse-btn{width:28px;height:28px;color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-md);pointer-events:auto;background:0 0;border:1px solid #0000;justify-content:center;align-items:center;transition:all .2s;display:flex}.collapse-btn:hover{background:var(--bg-tertiary);border-color:var(--border-color);color:var(--text-primary)}.sidebar-section{padding:8px 0}.section-header{color:var(--text-tertiary);text-transform:uppercase;justify-content:space-between;align-items:center;margin-bottom:4px;padding:0 16px;font-size:11px;font-weight:600;display:flex}.add-protocol-btn{width:20px;height:20px;color:var(--text-tertiary);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;display:flex}.nav-items{flex-direction:column;display:flex}.nav-item{border-radius:var(--radius-md);text-align:left;color:var(--text-primary);cursor:pointer;background:0 0;border:none;align-items:center;gap:12px;margin:0 12px;padding:8px 12px;font-size:14px;display:flex}.nav-item:hover{background:var(--bg-tertiary)}.nav-item.active{background:var(--accent-subtle);color:var(--text-primary)}.nav-item-group{flex-direction:column;display:flex}.nav-item.has-children{width:100%;color:var(--text-secondary);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:6px;align-items:center;gap:8px;padding:10px 12px;font-size:13px;display:flex}.nav-item.has-children .toggle-triangle{border-left:6px solid var(--text-secondary);border-top:5px solid #0000;border-bottom:5px solid #0000;width:0;height:0;transition:transform .15s;display:inline-block}.nav-item.has-children.expanded .toggle-triangle{transform:rotate(90deg)}.nav-submenu{flex-direction:column;padding-left:20px;display:flex}.nav-submenu-item{width:100%;color:var(--text-tertiary);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:6px;align-items:center;gap:8px;padding:8px 12px;font-size:12px;display:flex}.nav-submenu-item.active{background:var(--accent-subtle);color:var(--text-primary)}.sidebar-footer{border-top:1px solid var(--border-color);align-items:center;gap:4px;margin-top:auto;padding:8px 12px;display:flex}.footer-btn{border-radius:var(--radius-md);cursor:pointer;width:36px;height:36px;color:var(--text-secondary);background:0 0;border:none;justify-content:center;align-items:center;display:flex}.footer-btn:hover{background:var(--bg-tertiary)}.user-avatar{border-radius:50%;width:32px;height:32px;margin-left:auto}.user-avatar-initial{background:var(--bg-tertiary);width:32px;height:32px;color:var(--text-secondary);border-radius:50%;justify-content:center;align-items:center;margin-left:auto;font-size:13px;font-weight:600;display:flex}.calendar-layout{gap:24px;height:100%;display:flex}.goals-panel{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);width:280px;min-width:280px}.goals-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:16px;display:flex}.goals-header h3{margin:0;font-size:14px;font-weight:600}.icon-btn-sm{border-radius:var(--radius-sm);width:22px;height:22px;color:var(--text-tertiary);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;transition:background .15s,color .15s;display:flex}.icon-btn-sm:hover{background:var(--bg-hover);color:var(--text-primary)}.goal-input-wrapper{border-bottom:1px solid var(--border-color);gap:8px;padding:16px;display:flex}.goal-input{border:1px solid var(--border-color);border-radius:var(--radius-md);flex:1;height:32px;padding:0 12px;font-size:13px}.goal-add-btn{border-radius:var(--radius-md);background:var(--accent);width:32px;height:32px;color:var(--bg-primary);border:1px solid var(--accent)}.goals-list{padding:8px}.goals-empty{text-align:center;padding:40px 16px}.goals-empty p{margin:0;font-size:13px}.goal-item{border-radius:var(--radius-md);align-items:center;gap:12px;margin-bottom:1px;padding:8px;display:flex}.goal-item:hover{background:var(--bg-tertiary)}.goal-item.completed .goal-text{color:var(--text-tertiary);text-decoration:line-through}.goal-checkbox{border:1px solid var(--border-strong);cursor:pointer;background:0 0;border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;width:18px;height:18px;display:flex}.goal-checkbox.checked{background:var(--accent);border-color:var(--accent);color:var(--bg-primary)}.goal-text{color:var(--text-primary);flex:1;font-size:13px}.goal-delete-btn{width:24px;height:24px;color:var(--text-tertiary);background:0 0;border:none;padding:0;font-size:18px}.calendar-container{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-lg);flex-direction:column;flex:1;display:flex;overflow:hidden}.calendar-grid-wrapper{flex-direction:column;flex:1;display:flex;overflow:hidden}.calendar-grid.grid-month{flex:1;grid-template-columns:repeat(7,1fr);display:grid;overflow-y:auto}.calendar-grid.grid-month .calendar-cell{border-right:1px solid var(--border-color);border-bottom:1px solid var(--border-color);cursor:pointer;min-height:100px;padding:8px}.calendar-grid.grid-month .calendar-cell:nth-child(7n){border-right:none}.calendar-grid.grid-week{flex:1;grid-template-columns:repeat(7,1fr);display:grid;overflow-y:auto}.calendar-grid.grid-week .calendar-cell{border-right:1px solid var(--border-color);border-bottom:1px solid var(--border-color);cursor:pointer;min-height:200px;padding:8px}.calendar-grid.grid-week .calendar-cell:last-child{border-right:none}.calendar-grid.grid-week .cell-date{flex-direction:column;align-items:center;margin-bottom:8px;display:flex}.cell-date-weekday{color:var(--text-tertiary);text-transform:uppercase;margin-bottom:2px;font-size:10px;font-weight:600}.cell-date-num{color:var(--text-primary);border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:18px;font-weight:500;display:flex}.calendar-cell.today .cell-date-num{background:var(--accent);color:var(--bg-primary)}.weekday-header{background:var(--bg-secondary);border-bottom:1px solid var(--border-color);grid-template-columns:repeat(7,1fr);display:grid}.weekday-label{text-align:center;color:var(--text-tertiary);text-transform:uppercase;padding:10px;font-size:11px;font-weight:600}.weekday-label.sunday{color:var(--danger)}.calendar-cell{cursor:pointer}.calendar-cell:hover{background:var(--bg-secondary)}.calendar-cell.other-month{opacity:.35}.calendar-cell.today{background:var(--accent-subtle)}.cell-date{color:var(--text-primary);margin-bottom:4px;font-size:13px;font-weight:500}.cell-date.sunday,.cell-date-weekday.sunday{color:var(--danger)}.cell-schedules{flex-direction:column;gap:2px;display:flex}.schedule-chip{background:var(--accent);color:var(--bg-primary);white-space:nowrap;text-overflow:ellipsis;border-radius:4px;align-items:center;gap:4px;padding:2px 6px;font-size:10px;display:flex;overflow:hidden}.schedule-chip.completed{opacity:.5;text-decoration:line-through}.schedule-chip .time{font-weight:600}.more-schedules{color:var(--text-secondary);text-align:center;font-size:10px}.day-view{flex-direction:column;flex:1;display:flex;overflow:hidden}.day-header{background:var(--bg-secondary);border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:16px 24px;display:flex}.day-header h2{margin:0;font-size:16px;font-weight:600}.btn-add{border-radius:var(--radius-md);background:var(--accent);width:32px;height:32px;color:var(--bg-primary);border:1px solid var(--accent)}.empty-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;height:100%;padding:48px;display:flex}.empty-icon{opacity:.3;margin-bottom:16px;font-size:48px}.empty-state h2{margin:0 0 8px;font-size:18px}.empty-state p{margin:0 0 24px;font-size:13px}.btn-primary{height:36px;padding:0 24px;font-size:14px}.sidebar-base{background:var(--bg-primary);border:1px solid var(--border-color);z-index:55;cursor:pointer;border-radius:12px;flex-direction:column;transition:width .3s;display:flex;position:fixed;top:64px;bottom:140px;right:16px;overflow:hidden;box-shadow:-4px 0 24px #00000026}.sidebar-base:hover{width:48px!important}.sidebar-base.open{cursor:default;resize:horizontal}.sidebar-base:not(.open) .sidebar-header,.sidebar-base:not(.open) .sidebar-content{opacity:0;pointer-events:none}.sidebar-base .sidebar-header{background:var(--bg-tertiary);border-bottom:1px solid var(--border-color);border-radius:12px 12px 0 0;flex-shrink:0;justify-content:space-between;align-items:center;padding:12px 8px 12px 16px;transition:opacity .2s;display:flex}.sidebar-title{color:var(--text-secondary);cursor:pointer;border-radius:4px;padding:2px 6px;font-family:SF Mono,Fira Code,Consolas,monospace;font-size:12px;transition:background .15s}.sidebar-title:hover{background:var(--bg-tertiary)}.sidebar-close-btn{color:var(--text-tertiary);cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;padding:4px;display:flex}.sidebar-close-btn:hover{background:var(--bg-secondary);color:var(--text-primary)}.sidebar-content{background:var(--bg-primary);flex:1;padding:0;transition:opacity .2s;overflow:hidden auto}.confirm-popup-overlay{z-index:200;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#00000073;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.confirm-popup{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-lg);width:90%;max-width:340px;padding:24px;box-shadow:0 8px 32px #0000002e}.confirm-popup h3{color:var(--text-primary);margin:0 0 10px;font-size:16px;font-weight:600}.confirm-popup p{color:var(--text-secondary);margin:0 0 20px;font-size:13px;line-height:1.6}.confirm-popup-actions{justify-content:flex-end;gap:10px;display:flex}.confirm-popup-actions .btn-cancel{height:36px;color:var(--text-primary);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;flex:none;padding:0 16px;font-size:13px}.confirm-popup-actions .btn-cancel:hover{background:var(--bg-tertiary)}.btn-danger{color:#fff;border-radius:var(--radius-md);cursor:pointer;background:#e53e3e;border:none;height:36px;padding:0 16px;font-size:13px}.btn-danger:hover{background:#c53030}.panel-overlay{z-index:1000;background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.panel-panel{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-lg);max-width:90vw;max-height:90vh;position:relative;overflow:hidden}.panel-close{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;width:28px;height:28px;color:var(--text-secondary);z-index:1;justify-content:center;align-items:center;display:flex;position:absolute;top:16px;right:16px}:root{--font-stack:"SF Mono", "Fira Code", "Consolas", "Monaco", monospace;--bg-primary:#fff;--bg-secondary:#fafafa;--bg-tertiary:#f4f4f5;--border-color:#eaeaea;--border-strong:#d4d4d8;--text-primary:#171717;--text-secondary:#737373;--text-tertiary:#a1a1aa;--accent:#000;--accent-hover:#171717;--accent-subtle:#f4f4f5;--radius-md:6px;--radius-lg:8px;--radius-xl:12px;--radius-full:9999px}@media (prefers-color-scheme:dark){:root{--bg-primary:#000;--bg-secondary:#09090b;--bg-tertiary:#18181b;--border-color:#27272a;--border-strong:#3f3f46;--text-primary:#fafafa;--text-secondary:#a1a1aa;--text-tertiary:#737373;--accent:#fff;--accent-hover:#f4f4f5;--accent-subtle:#27272a}}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;font-family:SF Mono,Fira Code,Consolas,Monaco,monospace;font-size:14px;line-height:1.5}*{font-family:SF Mono,Fira Code,Consolas,Monaco,monospace}body.is-mac:not(.is-simple-fullscreen) .sidebar:not(.collapsed) .sidebar-header{flex-direction:row;justify-content:space-between;align-items:center;height:48px;min-height:48px;padding-top:22px;padding-left:16px;padding-right:12px;display:flex}body .sidebar.collapsed{z-index:1000;border-right:none;position:relative;overflow:visible;width:0!important;min-width:0!important}body .sidebar.collapsed:after{content:"";cursor:pointer;z-index:1001;-webkit-app-region:no-drag;background:0 0;width:4px;height:100vh;transition:all .25s cubic-bezier(.16,1,.3,1);position:fixed;top:0;left:0}body .sidebar.collapsed:hover:after{-webkit-backdrop-filter:blur(4px);border-right:1px solid var(--border-color);background:linear-gradient(90deg,#00000005 0%,#0000 100%);width:16px}.mac-traffic-spacer{flex-shrink:0;height:100%;transition:width .2s;display:block}body.is-mac:not(.is-simple-fullscreen) .sidebar.collapsed+.main-content .mac-traffic-spacer{-webkit-app-region:drag;width:68px}body.is-simple-fullscreen .mac-traffic-spacer{width:6px}.top-bar{border-bottom:1px solid var(--border-color);background:var(--bg-primary);z-index:100;-webkit-app-region:drag;justify-content:space-between;align-items:center;height:48px;padding:0 12px 0 0;display:flex}.top-bar button,.top-bar a,.top-bar input,.top-bar select{-webkit-app-region:no-drag}body.is-mac:not(.is-simple-fullscreen) .sidebar.collapsed+.main-content .top-bar{-webkit-app-region:drag;width:100vw;height:48px;position:fixed;top:0;left:0;padding-left:0!important}body.is-mac:not(.is-simple-fullscreen) .sidebar.collapsed+.main-content{padding-top:48px}body.is-simple-fullscreen .sidebar.collapsed+.main-content .top-bar{padding-left:0!important}body.is-simple-fullscreen .sidebar:not(.collapsed)+.main-content .top-bar{padding-left:4px!important}body.is-simple-fullscreen .sidebar:not(.collapsed)+.main-content .mac-traffic-spacer{width:0!important}body.is-simple-fullscreen .sidebar-header,body.is-simple-fullscreen .top-bar{height:48px!important;padding-top:0!important;padding-left:16px!important}.app{background:var(--bg-primary);width:100vw;height:100vh;display:flex;overflow:hidden}.main-content{background:var(--bg-primary);flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.top-bar-left{align-items:center;gap:12px;display:flex}.nav-open-btn{width:28px;height:28px;color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-md);-webkit-app-region:no-drag;background:0 0;border:none;justify-content:center;align-items:center;transition:all .15s;display:flex}.nav-open-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.nav-open-btn svg{stroke-width:2px}.breadcrumb{color:var(--text-secondary);font-size:14px}.btn-new{border-radius:var(--radius-full);color:#fff;cursor:pointer;background:#333333e6;border:1px solid #33333380;height:36px;padding:0 16px;font-size:12px;font-weight:500;transition:opacity .15s}.btn-new:hover{opacity:.8}.btn-new:active{opacity:1}.content-area{flex-direction:column;flex:1;padding:24px;display:flex;overflow-y:auto}.content-area--full{min-height:0;padding:0;overflow:hidden}.text-primary{color:var(--text-primary)}.text-secondary{color:var(--text-secondary)}.text-muted{color:var(--text-tertiary)}.bg-primary{background:var(--bg-primary)}.bg-secondary{background:var(--bg-secondary)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--border-strong)}.calendar-header{border-bottom:1px solid var(--border-color);background:var(--bg-primary);flex-shrink:0;justify-content:space-between;align-items:center;gap:16px;padding:16px 20px;display:flex}.header-title{color:var(--text-primary);white-space:nowrap;margin:0;font-size:16px;font-weight:600}.nav-buttons{align-items:center;gap:2px;display:flex}.nav-buttons button{border:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:6px;justify-content:center;align-items:center;padding:5px 10px;font-family:inherit;font-size:12px;font-weight:500;transition:all .12s;display:flex}.nav-buttons button:hover{background:var(--bg-secondary);color:var(--text-primary);border-color:var(--border-strong)}.header-right{align-items:center;display:flex}.view-switcher{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;gap:2px;padding:2px;display:flex;overflow:hidden}.view-switcher button{color:var(--text-tertiary);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-radius:6px;align-items:center;gap:5px;padding:5px 12px;font-family:inherit;font-size:12px;font-weight:500;transition:all .12s;display:flex}.view-switcher button:hover{color:var(--text-primary);background:var(--bg-tertiary)}.view-switcher button.active{background:var(--bg-primary);color:var(--text-primary);box-shadow:0 1px 4px #00000014}.schedule-grid{width:100%}.schedule-grid table{border-collapse:collapse;width:100%}.schedule-grid thead{background:var(--bg-tertiary);border-bottom:1px solid var(--border-color)}.schedule-grid th{text-align:left;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);padding:12px 16px;font-size:12px;font-weight:600}.schedule-grid th.time{width:100px}.schedule-grid th.title{width:auto}.schedule-grid th.category{width:120px}.schedule-grid th.status,.schedule-grid th.actions{width:100px}.schedule-grid tbody tr{border-bottom:1px solid var(--border-color);transition:background .15s}.schedule-grid tbody tr:hover{background:var(--bg-tertiary)}.schedule-grid tbody tr.completed{opacity:.6}.schedule-grid td{padding:12px 16px;font-size:14px}.schedule-grid td.time{color:var(--text-secondary);white-space:nowrap;font-family:monospace}.schedule-grid td .title-text{font-weight:500}.schedule-grid td .title-text.completed{color:var(--text-tertiary);text-decoration:line-through}.schedule-grid .category-badge{border-radius:var(--radius-sm);background:var(--bg-tertiary);color:var(--text-secondary);padding:2px 8px;font-size:11px;display:inline-block}.schedule-grid .status-badge{border-radius:var(--radius-sm);align-items:center;gap:4px;padding:2px 8px;font-size:11px;display:inline-flex}.schedule-grid .status-badge.completed{color:#16a34a;background:#dcfce7}.schedule-grid .status-badge.pending{background:var(--bg-tertiary);color:var(--text-secondary)}.schedule-grid .actions-cell{gap:4px;display:flex}.schedule-grid .icon-btn{cursor:pointer;border-radius:var(--radius-sm);color:var(--text-secondary);background:0 0;border:none;padding:6px;transition:all .15s}.schedule-grid .icon-btn:hover{background:var(--bg-secondary);color:var(--text-primary)}.schedule-grid .icon-btn.danger:hover{color:#dc2626;background:#fee2e2}.schedule-grid .empty-state{text-align:center;color:var(--text-tertiary);padding:48px}.form-overlay{z-index:200;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0006;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.form-container{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:16px;width:100%;max-width:480px;max-height:90vh;font-family:SF Mono,Fira Code,Consolas,Monaco,monospace;overflow-y:auto;box-shadow:0 20px 60px #0003}.form-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:20px 24px 16px;display:flex}.form-header h3{color:var(--text-primary);margin:0;font-size:15px;font-weight:600}.close-btn{cursor:pointer;color:var(--text-tertiary);background:0 0;border:none;border-radius:6px;padding:4px;transition:all .12s;display:flex}.close-btn:hover{color:var(--text-primary);background:var(--bg-secondary)}form{flex-direction:column;gap:16px;padding:20px 24px 24px;display:flex}.form-group{flex-direction:column;gap:6px;display:flex}.form-group label{letter-spacing:.06em;text-transform:uppercase;color:var(--text-tertiary);font-size:11px;font-weight:600}.form-group input,.form-group select,.form-group textarea{background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-primary);border-radius:8px;outline:none;width:100%;padding:9px 12px;font-family:inherit;font-size:13px;transition:border-color .12s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--accent)}.form-group textarea{resize:vertical;min-height:72px;line-height:1.5}.form-group select{cursor:pointer}.form-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}.goals-checkbox-list{flex-direction:column;gap:6px;max-height:160px;padding:4px 0;display:flex;overflow-y:auto}.goal-checkbox-item{cursor:pointer;text-transform:none;letter-spacing:0;color:var(--text-primary);border-radius:6px;align-items:flex-start;gap:8px;padding:6px 8px;font-size:13px;font-weight:400;transition:background .1s;display:flex}.goal-checkbox-item:hover{background:var(--bg-secondary)}.goal-checkbox-item input[type=checkbox]{width:auto;accent-color:var(--accent);flex-shrink:0;margin-top:2px;padding:0}.goal-checkbox-content{flex-direction:column;gap:2px;display:flex}.goal-title{color:var(--text-primary);font-size:13px}.goal-source{color:var(--text-tertiary);font-size:11px}.form-actions{justify-content:flex-end;gap:8px;padding-top:4px;display:flex}.btn{cursor:pointer;border:none;border-radius:8px;align-items:center;gap:6px;padding:8px 18px;font-family:inherit;font-size:13px;font-weight:500;transition:all .12s;display:flex}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{opacity:.88}.btn-secondary{background:var(--bg-secondary);color:var(--text-secondary);border:1px solid var(--border-color)}.btn-secondary:hover{background:var(--bg-tertiary);color:var(--text-primary)}.search-panel{width:480px;padding:16px}.search-header{align-items:center;gap:12px;margin-bottom:16px;display:flex}.search-input-wrapper{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);flex:1;align-items:center;gap:12px;padding:12px 16px;display:flex}.search-icon{color:var(--text-tertiary);flex-shrink:0}.search-input{color:var(--text-primary);background:0 0;border:none;outline:none;flex:1;font-size:15px}.search-input::placeholder{color:var(--text-tertiary)}.clear-btn{width:24px;height:24px;color:var(--text-tertiary);cursor:pointer;border-radius:var(--radius-md);background:0 0;border:none;justify-content:center;align-items:center;display:flex}.clear-btn:hover{background:var(--bg-tertiary)}.search-filters{flex-direction:column;gap:8px;margin-bottom:16px;display:flex}.search-filters .filter-btn:first-child{width:fit-content}.filter-row{flex-wrap:wrap;gap:8px;display:flex}.filter-btn{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-full);height:28px;color:var(--text-secondary);cursor:pointer;align-items:center;gap:6px;padding:0 12px;font-size:12px;font-weight:500;transition:all .15s;display:flex}.filter-btn:hover{background:var(--bg-tertiary)}.filter-btn.active{background:var(--accent);border-color:var(--accent);color:var(--bg-primary)}.filter-btn .count{opacity:.7;font-size:11px}.search-results{max-height:400px;overflow-y:auto}.search-empty{color:var(--text-tertiary);text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:48px 24px;display:flex}.search-empty p{margin-top:12px;font-size:13px}.results-list{flex-direction:column;gap:8px;display:flex}.search-result-item{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);cursor:pointer;padding:12px 16px;transition:all .15s}.search-result-item:hover{background:var(--bg-tertiary);border-color:var(--border-strong)}.result-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.result-type{text-transform:uppercase;border-radius:var(--radius-full);align-items:center;gap:6px;padding:2px 8px;font-size:11px;font-weight:600;display:flex}.result-type.type-schedule{color:#3b82f6;background:#3b82f61a}.result-type.type-goal{color:#10b981;background:#10b9811a}.result-type.type-memo{color:#f59e0b;background:#f59e0b1a}.result-type.type-journal{color:#8b5cf6;background:#8b5cf61a}.result-type.type-habit{color:#ec4899;background:#ec48991a}.result-date{color:var(--text-tertiary);font-size:11px}.result-title{color:var(--text-primary);margin-bottom:4px;font-size:14px;font-weight:500}.result-content{color:var(--text-secondary);text-overflow:ellipsis;white-space:nowrap;font-size:12px;overflow:hidden}.habit-view{background:var(--bg-primary);flex-direction:column;height:100%;font-family:SF Mono,Fira Code,Consolas,Monaco,monospace;display:flex;overflow-y:auto}.habit-header{justify-content:space-between;align-items:center;padding:20px 28px 0;display:flex}.month-nav{align-items:center;gap:12px;display:flex}.habit-view .icon-btn{border:1px solid var(--border-color);width:30px;height:30px;color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;font-size:16px;transition:background .15s,border-color .15s,color .15s;display:flex}.habit-view .icon-btn:hover{background:var(--bg-secondary);border-color:var(--accent);color:var(--accent)}.month-nav h3{color:var(--text-primary);text-align:center;min-width:130px;margin:0;font-size:15px;font-weight:600}.habit-content{flex-direction:column;gap:16px;padding:24px 28px 40px;display:flex}.empty-state{color:var(--text-tertiary);flex-direction:column;justify-content:center;align-items:center;gap:10px;padding:60px 0;font-size:14px;display:flex}.empty-state p{margin:0}.habits-list{flex-direction:column;gap:16px;display:flex}.habit-item{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;flex-direction:column;gap:14px;padding:16px 20px;display:flex}.habit-info{flex-direction:column;gap:4px;display:flex}.habit-title-row{justify-content:space-between;align-items:center;gap:8px;display:flex}.habit-title-row h4{color:var(--text-primary);margin:0;font-size:14px;font-weight:600}.habit-streak{color:var(--accent);align-items:center;gap:4px;font-size:11px;font-weight:500;display:flex}.habit-protocol{color:var(--text-tertiary);margin:0;font-size:11px}.habit-stats{color:var(--text-tertiary);gap:16px;margin-top:4px;font-size:11px;display:flex}.habit-calendar{border-top:1px solid var(--border-color);padding-top:12px}.calendar-days{flex-wrap:wrap;gap:4px;display:flex}.calendar-day{border:1px solid var(--border-color);background:var(--bg-primary);cursor:pointer;width:26px;height:26px;color:var(--text-tertiary);border-radius:6px;justify-content:center;align-items:center;padding:0;transition:all .15s;display:flex}.calendar-day:hover{border-color:var(--accent);color:var(--accent)}.calendar-day.completed{background:var(--accent);border-color:var(--accent);color:#fff}.calendar-day.missed{opacity:.4}.document-panel{background:var(--bg-primary);height:100%;font-family:SF Mono,Fira Code,Consolas,Monaco,monospace;display:flex}.document-list{border-right:1px solid var(--border-color);flex-direction:column;width:220px;min-width:220px;display:flex;overflow:hidden}.document-list-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:16px 16px 12px;display:flex}.document-list-header h3{letter-spacing:.06em;text-transform:uppercase;color:var(--text-tertiary);margin:0;font-size:12px;font-weight:600}.document-empty-state{color:var(--text-tertiary);text-align:center;padding:24px 16px;font-size:13px}.document-items{flex:1;padding:6px 0;overflow-y:auto}.document-item{cursor:pointer;border-radius:0;justify-content:space-between;align-items:center;gap:8px;padding:8px 16px;transition:background .12s;display:flex}.document-item:hover{background:var(--bg-secondary)}.document-item.active{background:var(--bg-tertiary)}.document-item-title{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;flex:1;font-size:13px;overflow:hidden}.document-delete-btn{cursor:pointer;color:var(--text-tertiary);opacity:0;background:0 0;border:none;border-radius:4px;padding:2px;transition:opacity .12s;display:flex}.document-item:hover .document-delete-btn{opacity:1}.document-delete-btn:hover{color:#ef4444;background:#ef44441a}.document-editor{flex-direction:column;flex:1;display:flex;overflow:hidden}.document-toolbar{border-bottom:1px solid var(--border-color);background:var(--bg-secondary);justify-content:space-between;align-items:center;padding:10px 20px;display:flex}.document-hint{color:var(--text-tertiary);font-size:11px}.toolbar-buttons{align-items:center;gap:4px;display:flex}.btn-toggle{border:1px solid var(--border-color);color:var(--text-tertiary);cursor:pointer;background:0 0;border-radius:6px;align-items:center;padding:4px 8px;transition:all .12s;display:flex}.btn-toggle:hover,.btn-toggle.active{background:var(--bg-tertiary);color:var(--text-primary);border-color:var(--border-strong)}.btn-save.document-btn{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:6px;align-items:center;gap:4px;margin-left:4px;padding:4px 12px;font-family:inherit;font-size:12px;font-weight:500;transition:opacity .15s;display:flex}.btn-save.document-btn:hover{opacity:.88}.document-title-input{color:var(--text-primary);background:0 0;border:none;outline:none;width:100%;padding:16px 20px 8px;font-family:inherit;font-size:20px;font-weight:600}.document-title-input::placeholder{color:var(--text-tertiary)}.document-content-input{color:var(--text-primary);resize:none;background:0 0;border:none;outline:none;flex:1;width:100%;padding:8px 20px 24px;font-family:inherit;font-size:14px;line-height:1.7}.document-content-input::placeholder{color:var(--text-tertiary)}.document-content-preview{color:var(--text-primary);flex:1;padding:8px 20px 24px;font-size:14px;line-height:1.7;overflow-y:auto}.document-content-preview h1{margin:16px 0 8px;font-size:20px;font-weight:700}.document-content-preview h2{margin:14px 0 6px;font-size:17px;font-weight:600}.document-content-preview h3{margin:12px 0 4px;font-size:15px;font-weight:600}.document-content-preview code{background:var(--bg-secondary);border-radius:4px;padding:1px 5px;font-size:13px}.document-content-preview pre{background:var(--bg-secondary);border-radius:8px;padding:12px;overflow-x:auto}.document-content-preview blockquote{border-left:3px solid var(--accent);color:var(--text-secondary);margin:8px 0;padding-left:12px}.document-content-preview hr{border:none;border-top:1px solid var(--border-color);margin:16px 0}.document-content-preview li{margin:4px 0 4px 16px;list-style:outside}.document-content-preview a{color:var(--accent);text-decoration:underline}.empty-editor{color:var(--text-tertiary);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:12px;font-size:14px;display:flex}.empty-circle{opacity:.3;font-size:32px}.header-left{align-items:center;gap:12px;display:flex}.tier-badge{border-radius:var(--radius-full);text-transform:uppercase;padding:2px 8px;font-size:10px;font-weight:600}.tier-badge.free{background:var(--bg-tertiary);color:var(--text-secondary)}.tier-badge.pro{background:var(--accent-subtle);color:var(--text-primary)}.tier-badge.max{color:gold;background:linear-gradient(135deg,#1a1a1a 0%,#333 100%);border:1px solid gold}.tier-badge.max svg{margin-right:4px}.header-actions{align-items:center;gap:8px;display:flex;position:absolute;right:24px}.thinking-mode-toggle{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-full);cursor:pointer;align-items:center;gap:6px;height:28px;padding:0 12px;font-size:12px;transition:all .2s;display:flex}.thinking-mode-toggle.active{background:var(--accent);color:var(--bg-primary);border-color:var(--accent)}.thinking-mode-toggle:hover{border-color:var(--border-strong)}.model-selector{position:relative}.model-selector-btn{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);align-items:center;gap:6px;height:28px;padding:0 12px;font-size:12px;display:flex}.model-dropdown{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);z-index:10;min-width:140px;margin-top:4px;padding:4px;position:absolute;top:100%;right:0;box-shadow:0 10px 15px -3px #00000014}.model-option{color:var(--text-primary);text-align:left;background:0 0;border:none;border-radius:4px;justify-content:space-between;align-items:center;width:100%;padding:8px 12px;font-size:13px;display:flex}.model-option:hover{background:var(--bg-secondary)}.model-option.active{color:var(--accent)}.messages-container{flex-direction:column;flex:1;width:100%;max-width:768px;margin:0 auto;padding:32px 32px 120px;display:flex;overflow-y:auto}.empty-message{height:100%;color:var(--text-secondary);text-align:center;flex-direction:column;justify-content:center;align-items:center;display:flex}.empty-message p{margin:0;font-size:14px}.message{width:100%;margin-bottom:24px;display:flex}.message.user{justify-content:flex-end}.message.assistant{justify-content:flex-start}.message-content{word-wrap:break-word;border-radius:20px;max-width:70%;padding:14px 18px;font-size:15px;line-height:1.6}.message.user .message-content{color:#fff;background:linear-gradient(135deg,#2d2d2d 0%,#1a1a1a 100%);border-bottom-right-radius:6px;box-shadow:0 2px 8px #00000026}.message.assistant .message-content{background:var(--bg-primary);color:var(--text-primary);border:1px solid var(--border-color);border-bottom-left-radius:6px;box-shadow:0 1px 3px #0000000d}.message-cost{opacity:.7;margin-top:4px;font-size:10px;display:block}.send-btn:disabled{opacity:.5;cursor:not-allowed}.message .attached-image{border-radius:8px;max-width:200px;max-height:150px;margin-top:8px}.upgrade-popup-overlay{z-index:100;background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.upgrade-popup{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-lg);text-align:center;width:90%;max-width:320px;padding:24px}.upgrade-popup h3{color:var(--text-primary);margin:0 0 8px;font-size:18px;font-weight:600}.upgrade-popup p{color:var(--text-secondary);margin:0 0 16px;font-size:14px}.upgrade-features{text-align:left;margin-bottom:20px}.upgrade-features .feature{color:var(--text-primary);border-bottom:1px solid var(--border-color);align-items:center;gap:8px;padding:8px 0;font-size:14px;display:flex}.upgrade-features .feature:last-child{border-bottom:none}.upgrade-features .feature svg{color:#22c55e}.upgrade-actions{gap:12px;display:flex}.btn-cancel{height:40px;color:var(--text-primary);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;flex:1;font-size:14px}.btn-cancel:hover{background:var(--bg-tertiary)}.btn-upgrade{height:40px;color:var(--bg-primary);background:var(--accent);border-radius:var(--radius-md);cursor:pointer;border:none;flex:1;font-size:14px;font-weight:500}.btn-upgrade:hover{background:var(--accent-hover)}.chat-layout{width:100%;height:100%;display:flex;position:relative}.side-panel{border:1px solid var(--border-strong);z-index:55;-webkit-backdrop-filter:blur(12px);cursor:pointer;border-radius:6px;transition:width .3s,transform .2s,box-shadow .2s,border-color .2s,background .2s;overflow:hidden;box-shadow:-4px 0 24px #00000026,inset 0 1px #ffffffe6;top:88px!important;right:6px!important;bottom:var(--side-panel-bottom,120px)!important;background:#fff9!important;flex-direction:column!important;width:28px!important;min-width:28px!important;display:flex!important;position:fixed!important}.dark .side-panel{border-color:#ffffff1a;box-shadow:-4px 0 24px #0006,inset 0 1px #ffffff0f;background:#27272a99!important}.side-panel>*{opacity:0;pointer-events:none;transition:opacity .2s}.side-panel.open{cursor:default;border-radius:12px;overflow:hidden;width:var(--side-panel-width,260px)!important;min-width:260px!important;max-width:calc(50vw - 130px)!important}.side-panel.open>*{opacity:1;pointer-events:auto}.side-panel:not(.open):before{content:"";background:var(--bg-tertiary);border-bottom:1px solid var(--border-color);pointer-events:none;height:48px;position:absolute;top:0;left:0;right:0}.chat-layout-resize-handle{right:calc(6px + var(--sidebar-actual-width,520px));top:88px;bottom:var(--side-panel-bottom,120px);cursor:ew-resize;z-index:70;background:0 0;width:8px;transition:background .15s;position:fixed}.side-panel:not(.open):hover{border-color:var(--accent);border-radius:10px;transform:translate(-6px);box-shadow:-8px 0 32px #00000038,inset 0 1px #ffffffe6;background:#ffffffd9!important;width:52px!important}.side-panel:not(.open):hover>*{opacity:0;pointer-events:none}.dark .side-panel:not(.open):hover{border-color:var(--accent);background:#27272ad9!important}.chat-layout-resize-handle:hover{background:#fff3}.chat-layout.dragging .chat-layout-sidebar,.chat-layout.dragging .chat-layout-resize-handle,.chat-layout.dragging~* .messages-container,.chat-layout.dragging *{transition:none!important}.chat-layout-main{flex-direction:column;flex:1;min-width:0;height:100%;display:flex}@media (width<=768px){.chat-layout-sidebar.open{z-index:100;border-radius:0;top:0;bottom:0;right:0;width:100%!important}.chat-layout-main.with-sidebar{padding-right:0}}@media (width<=480px){.chat-layout-sidebar,.chat-layout-toggle-bar{display:none}}.protocol-overview{background:var(--bg-primary);flex-direction:column;height:100%;font-family:SF Mono,Fira Code,Consolas,Monaco,monospace;display:flex;overflow-y:auto}.overview-header{justify-content:space-between;align-items:flex-start;gap:16px;padding:28px 32px 0;display:flex}.header-title h1{color:var(--text-primary);margin:0 0 4px;font-size:22px;font-weight:600}.header-date{color:var(--text-tertiary);margin:0;font-size:13px}.btn-new-primary{background:var(--accent);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:8px;align-items:center;gap:6px;padding:8px 16px;font-family:inherit;font-size:13px;font-weight:500;transition:opacity .15s;display:flex}.btn-new-primary:hover{opacity:.88}.overview-content{flex-direction:column;gap:0;padding:24px 32px 40px;display:flex}.overview-empty{text-align:center;color:var(--text-tertiary);padding:48px 0;font-size:14px}.overview-section{border-bottom:1px solid var(--border-color);padding:20px 0}.overview-section:last-child{border-bottom:none}.section-title{letter-spacing:.08em;text-transform:uppercase;color:var(--text-tertiary);align-items:center;gap:8px;margin:0 0 12px;font-size:11px;font-weight:600;display:flex}.text-muted{color:var(--text-tertiary);font-size:13px}.text-completed{color:var(--text-tertiary);text-decoration:line-through}.text-success{color:#22c55e}.goal-list{flex-direction:column;gap:8px;margin:0;padding:0;list-style:none;display:flex}.goal-list-item{color:var(--text-primary);align-items:center;gap:10px;font-size:14px;display:flex}.goal-toggle{cursor:pointer;color:var(--text-tertiary);background:0 0;border:none;flex-shrink:0;padding:0;display:flex}.week-grid{grid-template-columns:repeat(7,1fr);gap:6px;display:grid}.week-day{border:1px solid #0000;border-radius:8px;flex-direction:column;align-items:center;gap:4px;padding:8px 4px;display:flex}.week-day.today{background:var(--bg-secondary);border-color:var(--accent)}.week-day-header{flex-direction:column;align-items:center;gap:2px;display:flex}.week-day-name{color:var(--text-tertiary);text-transform:uppercase;font-size:10px;font-weight:600}.week-day-date{color:var(--text-primary);font-size:14px;font-weight:500}.week-day.today .week-day-date{color:var(--accent)}.week-day-tasks{flex-wrap:wrap;justify-content:center;gap:2px;display:flex}.week-task-dot{background:var(--accent);opacity:.5;border-radius:50%;width:6px;height:6px}.week-task-dot.done{opacity:1}.week-task-more{color:var(--text-tertiary);font-size:10px}.schedule-list{flex-direction:column;gap:8px;margin:0;padding:0;list-style:none;display:flex}.schedule-list-item{color:var(--text-primary);align-items:center;gap:8px;font-size:13px;display:flex}.schedule-time{color:var(--text-tertiary);flex-shrink:0;width:40px;font-size:11px}.schedule-spacer{color:var(--text-tertiary);font-size:11px}.document-list-item{color:var(--text-primary);border-bottom:1px solid var(--border-color);align-items:center;gap:8px;padding:8px 0;font-size:13px;display:flex}.document-list-item:last-child{border-bottom:none}.action-list{flex-direction:column;gap:4px;display:flex}.action-item{background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-primary);cursor:pointer;text-align:left;border-radius:8px;align-items:center;gap:10px;width:100%;padding:10px 12px;font-family:inherit;font-size:13px;transition:all .15s;display:flex}.action-item:hover{border-color:var(--accent);color:var(--accent)}.ml-auto{color:var(--text-tertiary);margin-left:auto}.onboarding-layout{width:100%;height:100%;font-family:SF Mono,Fira Code,Consolas,Monaco,monospace;display:flex;position:relative}.onboarding-layout .chat-panel-base{flex:1;min-width:0}.onboarding-nav-sidebar{background:var(--bg-primary);border-right:1px solid var(--border-color);width:180px;min-width:180px;font-family:var(--font-stack);flex-direction:column;display:flex}.nav-sidebar-header{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px;padding:16px;font-size:11px;font-weight:600}.nav-sidebar-items{flex-direction:column;padding:0 8px;display:flex}.nav-sidebar-item{color:var(--text-secondary);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:6px;align-items:center;gap:8px;width:100%;padding:10px 12px;font-size:13px;transition:all .15s;display:flex}.nav-sidebar-item:hover{background:var(--bg-secondary);color:var(--text-primary)}.nav-sidebar-item.active{background:var(--bg-secondary);color:var(--text-primary);font-weight:500}.nav-sidebar-item .nav-icon{opacity:.6;font-size:10px}.onboarding-layout .message-content,.onboarding-layout .message-content p,.onboarding-layout .message-content div{margin:0}.onboarding-layout .message-content strong{font-weight:600}.onboarding-layout .message-content ul,.onboarding-layout .message-content ol{margin:8px 0;padding-left:20px}.onboarding-layout .message-content li{margin:2px 0}.sidebar-hint{color:var(--text-tertiary);white-space:nowrap;opacity:.6;pointer-events:none;font-size:11px;transition:opacity .2s;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)rotate(90deg)}.protocol-draft-sidebar:hover .sidebar-hint{opacity:1}.protocol-draft-sidebar.open .sidebar-hint{display:none}.sidebar-collapsed-loading{white-space:nowrap;color:var(--text-secondary);font-size:11px;animation:1.5s ease-in-out infinite pulse;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)rotate(90deg)}.draft-loading{animation:1.5s ease-in-out infinite pulse}.chat-sidebar{border-left:1px solid var(--border-color);background:var(--bg-primary);border-radius:12px 0 0 12px;flex-direction:column;width:400px;min-width:320px;max-width:480px;margin:16px 0;display:flex;box-shadow:-4px 0 24px #0000001a}.chat-header{background:var(--bg-tertiary);border-bottom:1px solid var(--border-color);border-radius:12px 12px 0 0;justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.chat-title{color:var(--text-secondary);font-size:13px;font-weight:500}.chat-close-btn{color:var(--text-tertiary);cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;padding:4px;display:flex}.chat-close-btn:hover{background:var(--bg-secondary);color:var(--text-primary)}.chat-sidebar .messages-container{flex:1;padding:16px;overflow-y:auto}.chat-sidebar .message{margin-bottom:12px}.chat-sidebar .input-area{border-top:1px solid var(--border-color);padding:12px}.chat-toggle-bar{background:var(--bg-secondary);border:1px solid var(--border-color);cursor:pointer;z-index:60;width:40px;height:64px;color:var(--text-tertiary);border-right:none;border-radius:8px 0 0 8px;justify-content:center;align-items:center;transition:all .2s;display:flex;position:fixed;top:50%;right:0;transform:translateY(-50%)}.chat-toggle-bar:hover{background:var(--bg-tertiary);color:var(--text-primary)}.draft-toggle-bar{background:var(--bg-tertiary);cursor:pointer;z-index:50;border-radius:4px;justify-content:center;align-items:center;width:8px;height:48px;display:flex;position:fixed;top:50%;right:16px;transform:translateY(-50%)}.draft-toggle-bar:before{content:"";background:var(--text-tertiary);opacity:.5;border-radius:1px;width:2px;height:24px}.draft-toggle-bar:hover:before{opacity:1}.draft-toggle-bar.open{display:none}.protocol-draft-sidebar{background:var(--bg-primary);border:1px solid var(--border-color);z-index:55;cursor:pointer;border-radius:12px;flex-direction:column;width:32px;transition:width .3s;display:flex;position:fixed;top:64px;bottom:140px;right:16px;overflow:hidden;box-shadow:-4px 0 24px #00000026}.protocol-draft-sidebar:hover{width:48px}.protocol-draft-sidebar.open{cursor:default;resize:horizontal;width:400px;min-width:280px;max-width:600px}.protocol-draft-sidebar:not(.open) .draft-header,.protocol-draft-sidebar:not(.open) .draft-editor{opacity:0;pointer-events:none}.draft-header{background:var(--bg-tertiary);border-bottom:1px solid var(--border-color);border-radius:12px 12px 0 0;flex-shrink:0;justify-content:space-between;align-items:center;padding:12px 8px 12px 16px;transition:opacity .2s;display:flex}.draft-filename{color:var(--text-secondary);cursor:pointer;font-size:12px;font-weight:500}.draft-filename:hover{color:var(--text-primary)}.draft-name-input{background:var(--bg-primary);border:1px solid var(--border-color);color:var(--text-primary);border-radius:4px;width:120px;padding:4px 8px;font-size:12px;font-weight:500}.draft-header-right,.draft-header-right{align-items:center;gap:12px;display:flex}.draft-progress{color:var(--text-tertiary);font-size:11px}.draft-history-btn{color:var(--text-tertiary);cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;padding:4px;display:flex}.draft-history-btn:hover:not(:disabled){background:var(--bg-secondary);color:var(--text-primary)}.draft-history-btn:disabled{opacity:.3;cursor:default}.draft-close-btn{color:var(--text-tertiary);cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;padding:4px;display:flex}.draft-close-btn:hover{background:var(--bg-secondary);color:var(--text-primary)}.draft-editor{background:var(--bg-primary);flex:1;padding:0;transition:opacity .2s;overflow:hidden auto}.draft-document{color:var(--text-primary);padding:24px 20px 32px;font-family:SF Mono,Fira Code,Consolas,monospace;font-size:13px;line-height:1.8}.draft-document h1{color:var(--text-primary);margin-bottom:16px;font-size:20px;font-weight:600}.draft-document h2{color:var(--text-primary);margin-top:20px;margin-bottom:8px;font-size:15px;font-weight:600}.draft-document li{margin-bottom:4px}.draft-empty{height:100%;color:var(--text-tertiary);justify-content:center;align-items:center;font-style:italic;display:flex}.highlight{cursor:pointer;border-radius:3px;padding:2px 4px}.highlight.needs-info{background:#fb923c4d}.highlight.needs-info:hover{background:#fb923c80}.highlight.confirmed{background:#22c55e4d}.diff-container{white-space:normal;margin:0;display:inline}.diff-old{color:#cf1322;-webkit-box-decoration-break:clone;box-decoration-break:clone;background-color:#ff4d4f26;border-radius:0;margin-right:4px;padding:2px 0;text-decoration:line-through;display:inline}.diff-new{color:#135200;cursor:pointer;-webkit-box-decoration-break:clone;box-decoration-break:clone;background-color:#b7eb8f99;border:none;padding:3px 4px;font-weight:600;transition:background-color .2s;display:inline;position:relative}.diff-new:hover{background-color:#b7eb8fe6}.diff-new:after{content:"클릭하여 확정";color:#fff;white-space:nowrap;opacity:0;pointer-events:none;z-index:10;background:#333;border-radius:4px;margin-bottom:6px;padding:2px 8px;font-size:10px;font-weight:400;transition:opacity .2s;position:absolute;bottom:100%;left:50%;transform:translate(-50%)}.diff-new:hover:after{opacity:1}.selection-badge{background:var(--bg-secondary);border-bottom:1px solid var(--border-color);color:var(--text-primary);box-sizing:border-box;border:1px solid var(--border-color);border-bottom:1px solid #0000000d;border-radius:20px 20px 0 0;align-items:center;gap:12px;width:100%;margin-bottom:0;padding:8px 20px;font-size:13px;animation:.3s slideUp;display:flex;box-shadow:0 -2px 10px #0000000d}.selection-badge+.chat-input-wrapper{border-radius:0 0 24px 24px!important;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d!important}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.selection-text{text-overflow:ellipsis;white-space:nowrap;flex:1;font-style:italic;font-weight:500;overflow:hidden}.selection-clear{color:var(--text-tertiary);cursor:pointer;background:0 0;border:none;align-items:center;padding:2px;display:flex}.selection-clear:hover{color:var(--text-primary)}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.text-highlight.needs-discuss{cursor:pointer;background:#fb923c40;border-radius:2px;padding:0 2px}.text-highlight.needs-discuss:hover{background:#fb923c73}.text-highlight.confirmed{background:#22c55e40;border-radius:2px;padding:0 2px}.inline-input-popup{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-lg);z-index:60;width:320px;padding:16px;position:fixed;bottom:120px;right:16px;box-shadow:0 8px 24px #00000026}.popup-question{color:var(--text-secondary);border-bottom:1px solid var(--border-color);margin-bottom:12px;padding-bottom:12px;font-size:13px}.popup-input-row{gap:8px;display:flex}.popup-input-row input{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);height:36px;color:var(--text-primary);flex:1;padding:0 12px;font-family:SF Mono,Fira Code,Consolas,monospace;font-size:13px}.popup-input-row input:focus{border-color:var(--accent);outline:none}.popup-input-row button{background:var(--accent);height:36px;color:var(--bg-primary);border-radius:var(--radius-md);cursor:pointer;border:none;padding:0 16px;font-size:13px;font-weight:500}.popup-input-row button:hover{opacity:.9}.subscription-modal-overlay{z-index:1000;background:#00000080;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.subscription-modal{background:var(--bg-primary);border-radius:16px;width:90%;max-width:360px;padding:32px;animation:.3s slideUp;position:relative}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.subscription-modal .modal-close-btn{color:var(--text-tertiary);cursor:pointer;background:0 0;border:none;padding:4px;position:absolute;top:16px;right:16px}.subscription-modal .modal-close-btn:hover{color:var(--text-primary)}.subscription-modal .modal-content{text-align:center}.subscription-modal .modal-icon{color:#f59e0b;background:#fef3c7;border-radius:50%;justify-content:center;align-items:center;width:80px;height:80px;margin:0 auto 16px;display:flex}.subscription-modal h2{color:var(--text-primary);margin:0 0 8px;font-size:20px;font-weight:600}.subscription-modal .modal-desc{color:var(--text-secondary);margin:0 0 24px;font-size:14px;line-height:1.5}.subscription-modal .modal-features{background:var(--bg-secondary);border-radius:8px;flex-direction:column;gap:12px;margin-bottom:24px;padding:16px;display:flex}.subscription-modal .feature{color:var(--text-primary);align-items:center;gap:8px;font-size:14px;display:flex}.subscription-modal .feature svg{color:#10b981}.subscription-modal .upgrade-btn{color:#fff;cursor:pointer;background:#f59e0b;border:none;border-radius:8px;width:100%;padding:12px;font-size:14px;font-weight:600;transition:background .15s}.subscription-modal .upgrade-btn:hover{background:#d97706}.subscription-modal .later-btn{width:100%;color:var(--text-secondary);cursor:pointer;background:0 0;border:none;margin-top:8px;padding:12px;font-size:14px}.subscription-modal .later-btn:hover{color:var(--text-primary)}@media (width<=768px){.protocol-draft-sidebar.open{border-radius:0;width:100%;max-width:100%;top:0;bottom:0;right:0}.onboarding-layout{flex-direction:column}}@media (width<=480px){.protocol-draft-sidebar{display:none}}.onboarding-document,.onboarding-editor{background:var(--bg-primary)}.onboarding-content{width:100%;max-width:650px;margin:0 auto;padding:40px}.onboarding-section{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-lg);margin-bottom:24px;padding:16px}.onboarding-section.assistant{border-left:3px solid var(--accent)}.onboarding-section.user{background:var(--bg-secondary)}.onboarding-text{color:var(--text-primary);font-size:14px;line-height:1.6}.onboarding-text strong{font-weight:600}.onboarding-text ul{margin:12px 0;padding-left:20px}.onboarding-text li{margin-bottom:8px}.onboarding-user-text{color:var(--text-primary);font-size:14px;line-height:1.6}.onboarding-loading{color:var(--text-secondary);font-size:13px;font-style:italic}.draft-actions{border-top:1px solid var(--border-color);background:var(--bg-secondary);padding:16px 24px}.draft-preview{text-align:center;margin-bottom:16px}.draft-preview h4{color:var(--text-primary);margin:0 0 4px;font-size:14px;font-weight:600}.draft-preview p{color:var(--text-secondary);margin:0;font-size:13px}.draft-buttons{justify-content:center;gap:12px;display:flex}.btn-reject{max-width:140px;height:40px;color:var(--text-primary);background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;flex:1;font-size:14px;font-weight:500;transition:all .2s}.btn-reject:hover{background:var(--bg-tertiary);border-color:var(--border-strong)}.btn-accept{max-width:140px;height:40px;color:var(--bg-primary);background:var(--accent);border:1px solid var(--accent);border-radius:var(--radius-md);cursor:pointer;flex:1;justify-content:center;align-items:center;gap:6px;font-size:14px;font-weight:500;transition:all .2s;display:flex}.btn-accept:hover{background:var(--accent-hover)}.admin-panel{flex-direction:column;height:100%;display:flex}.admin-panel .panel-header{border-bottom:1px solid var(--border-color);background:var(--bg-secondary);justify-content:space-between;align-items:center;padding:16px 24px;display:flex}.admin-panel .panel-header h2{margin:0;font-size:16px;font-weight:600}.admin-stats{border-bottom:1px solid var(--border-color);grid-template-columns:repeat(4,1fr);gap:12px;padding:24px;display:grid}.stat-card{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-lg);align-items:center;gap:12px;padding:16px;display:flex}.stat-info{flex-direction:column;display:flex}.stat-value{color:var(--text-primary);font-size:20px;font-weight:600}.stat-label{color:var(--text-secondary);font-size:12px}.admin-content{flex:1;overflow-y:auto}.user-list{padding:24px}.user-list-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.user-list-header h3{margin:0;font-size:16px;font-weight:600}.btn-refresh{border:1px solid var(--border-color);border-radius:var(--radius-md);background:0 0;height:28px;padding:0 12px;font-size:13px}.user-table{border-collapse:collapse;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-lg);width:100%;overflow:hidden}.user-table thead{background:var(--bg-secondary);border-bottom:1px solid var(--border-color)}.user-table th{text-align:left;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px;padding:12px 16px;font-size:11px;font-weight:600}.user-table td{color:var(--text-primary);border-bottom:1px solid var(--border-color);padding:12px 16px;font-size:13px}.user-table tbody tr:last-child td{border-bottom:none}.user-row{cursor:pointer}.user-row:hover{background:var(--bg-secondary)}.user-cell{align-items:center;gap:12px;display:flex}.user-avatar-small{border-radius:50%;width:24px;height:24px}.user-avatar-placeholder-small{background:var(--bg-tertiary);width:24px;height:24px;color:var(--text-secondary);border-radius:50%;justify-content:center;align-items:center;font-size:11px;font-weight:600;display:flex}.user-info{flex-direction:column;display:flex}.user-name{color:var(--text-primary);font-size:13px;font-weight:500}.user-email{color:var(--text-secondary);font-size:12px}.loading-state{text-align:center;color:var(--text-secondary);padding:48px}.user-detail{padding:24px}.user-detail-header{align-items:center;gap:12px;margin-bottom:24px;display:flex}.back-btn{border:1px solid var(--border-color);border-radius:var(--radius-md);height:28px;color:var(--text-primary);background:0 0;align-items:center;gap:4px;padding:0 12px;font-size:13px;display:flex}.user-profile{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);align-items:center;gap:16px;margin-bottom:24px;padding:24px;display:flex}.user-avatar-large{border-radius:50%;width:56px;height:56px}.user-avatar-placeholder-large{background:var(--bg-tertiary);width:56px;height:56px;color:var(--text-secondary);border-radius:50%;justify-content:center;align-items:center;font-size:22px;font-weight:600;display:flex}.user-profile-info h4{margin:0 0 4px;font-size:16px;font-weight:600}.user-profile-info p{margin:0;font-size:13px}.user-uid{font-family:monospace;color:var(--text-tertiary)!important;font-size:12px!important}.user-stats-grid{grid-template-columns:repeat(5,1fr);gap:12px;margin-bottom:24px;display:grid}.user-stat-item{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);flex-direction:column;align-items:center;padding:16px;display:flex}.user-stat-item .stat-label{color:var(--text-secondary);margin-bottom:4px;font-size:12px}.user-stat-item .stat-value{color:var(--text-primary);font-size:20px;font-weight:600}.conversations-section{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden}.conversations-section h4{border-bottom:1px solid var(--border-color);background:var(--bg-secondary);margin:0;padding:16px 24px;font-size:14px;font-weight:600}.empty-state{text-align:center;color:var(--text-secondary);padding:48px}.conversations-list{max-height:400px;overflow-y:auto}.conversation-item{border-bottom:1px solid var(--border-color)}.conversation-item:last-child{border-bottom:none}.conversation-item summary{cursor:pointer;justify-content:space-between;align-items:center;padding:16px 24px;font-size:13px;list-style:none;display:flex}.conversation-item summary::-webkit-details-marker{display:none}.conversation-item summary:hover{background:var(--bg-secondary)}.conversation-date{color:var(--text-secondary);font-size:12px}.conversation-messages{background:var(--bg-secondary);padding:0 24px 16px}.conversation-message{border-radius:var(--radius-md);margin-bottom:8px;padding:12px;font-size:13px;line-height:1.4}.conversation-message.user{background:var(--bg-tertiary);color:var(--text-primary)}.conversation-message.assistant{background:var(--accent);color:var(--bg-primary)}.message-role{opacity:.7;text-transform:uppercase;margin-bottom:4px;font-size:10px;font-weight:600;display:block}.admin-management-section{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;margin:20px 0;padding:16px}.admin-management-section h4{color:var(--text-primary);align-items:center;gap:8px;margin:0 0 16px;font-size:14px;font-weight:600;display:flex}.management-controls{flex-wrap:wrap;gap:24px;display:flex}.control-group{flex-direction:column;gap:8px;display:flex}.control-group label{color:var(--text-tertiary);font-size:12px;font-weight:500}.control-group select{background:var(--bg-primary);border:1px solid var(--border-color);height:36px;color:var(--text-primary);cursor:pointer;border-radius:6px;min-width:120px;padding:0 12px;font-size:13px}.control-group select:focus{border-color:var(--accent);outline:none}.control-group button{cursor:pointer;border:none;border-radius:6px;align-items:center;gap:6px;height:36px;padding:0 16px;font-size:13px;font-weight:500;transition:all .15s;display:flex}.control-group button:disabled{opacity:.5;cursor:not-allowed}.btn-reset{background:var(--bg-tertiary);color:var(--text-primary)}.btn-reset:hover:not(:disabled){background:var(--accent);color:var(--bg-primary)}.btn-delete{color:#dc2626;background:#fee2e2}.btn-delete:hover:not(:disabled){color:#fff;background:#dc2626}.timer-view{background:var(--bg-primary);flex-direction:column;height:100%;font-family:SF Mono,Fira Code,Consolas,Monaco,monospace;display:flex;overflow-y:auto}.timer-header{justify-content:space-between;align-items:center;padding:20px 28px 0;display:flex}.header-left{color:var(--text-secondary);align-items:center;gap:8px;font-size:13px;font-weight:500;display:flex}.timer-content{flex-direction:column;align-items:center;gap:24px;width:100%;max-width:440px;margin:0 auto;padding:32px 28px 40px;display:flex}.timer-protocol{background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-secondary);border-radius:20px;align-items:center;gap:6px;padding:4px 12px;font-size:12px;display:flex}.timer-display{justify-content:center;align-items:center;width:220px;height:220px;display:flex;position:relative}.timer-circle{width:100%;height:100%;position:absolute;top:0;left:0;transform:none}.timer-progress{stroke:var(--accent);stroke-linecap:round;transition:stroke-dasharray .5s}.timer-time{z-index:1;align-items:center;gap:2px;display:flex}.timer-time-input{width:64px;color:var(--text-primary);text-align:center;background:0 0;border:none;outline:none;padding:0;font-family:SF Mono,Fira Code,Consolas,Monaco,monospace;font-size:44px;font-weight:600;line-height:1}.timer-time-input:not(:disabled):hover{color:var(--accent)}.timer-time-input:disabled{opacity:1;cursor:default}.timer-input-seconds{width:52px}.timer-time-separator{color:var(--text-tertiary);margin-bottom:4px;font-size:40px;font-weight:300;line-height:1}.timer-type-badge{letter-spacing:.1em;text-transform:uppercase;color:var(--text-tertiary);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:20px;padding:3px 10px;font-size:11px;font-weight:600}.timer-controls{align-items:center;gap:12px;display:flex}.timer-btn{cursor:pointer;border:none;border-radius:12px;align-items:center;gap:8px;padding:10px 24px;font-family:inherit;font-size:14px;font-weight:500;transition:all .15s;display:flex}.timer-btn-primary{background:var(--accent);color:#fff;padding:12px 32px;font-size:15px}.timer-btn-primary:hover{opacity:.88;transform:translateY(-1px)}.timer-btn-secondary{background:var(--bg-secondary);color:var(--text-secondary);border:1px solid var(--border-color)}.timer-btn-secondary:hover{background:var(--bg-tertiary);color:var(--text-primary)}.timer-presets{width:100%}.presets-title{letter-spacing:.08em;text-transform:uppercase;color:var(--text-tertiary);margin-bottom:10px;font-size:11px;font-weight:600}.presets-grid{grid-template-columns:repeat(3,1fr);gap:8px;display:grid}.preset-btn{background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;border-radius:10px;flex-direction:column;align-items:center;gap:2px;padding:10px 8px;font-family:inherit;font-size:12px;font-weight:500;transition:all .15s;display:flex}.preset-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.preset-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}.preset-btn:disabled{opacity:.4;cursor:not-allowed}.preset-time{opacity:.7;font-size:11px}.timer-stats{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;width:100%;padding:16px 20px}.stats-title{letter-spacing:.08em;text-transform:uppercase;color:var(--text-tertiary);margin-bottom:6px;font-size:11px;font-weight:600}.stats-value{color:var(--text-primary);align-items:baseline;gap:8px;font-size:22px;font-weight:600;display:flex}.stats-count{color:var(--text-tertiary);font-size:13px;font-weight:400}.browser-panel{background:#fff;flex-direction:column;width:100%;height:100%;display:flex}.browser-panel-unavailable{color:#666;justify-content:center;align-items:center;gap:1rem}.browser-toolbar{background:#f9f9f9;border-bottom:1px solid #eee;flex-shrink:0;align-items:center;gap:8px;padding:8px 12px;display:flex}.browser-nav-btn{cursor:pointer;color:#555;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;padding:6px;display:flex}.browser-nav-btn:hover:not(:disabled){background:#e5e5e5}.browser-nav-btn:disabled{color:#ccc;cursor:default}.browser-address-bar{background:#fff;border:1px solid #ddd;border-radius:6px;flex:1;align-items:center;gap:8px;padding:4px 10px;display:flex}.browser-address-icon{color:#999;flex-shrink:0}.browser-address-input{color:#333;border:none;outline:none;flex:1;width:100%;font-size:13px}.browser-webview{border:none;flex:1;width:100%;min-height:0}.tab-bar{border-bottom:1px solid var(--border-color);background:var(--bg-secondary);flex-shrink:0;align-items:center;gap:2px;height:36px;min-height:36px;padding:0 6px;display:flex}.tab-list{scrollbar-width:none;align-items:center;gap:2px;display:flex;overflow-x:auto}.tab-list::-webkit-scrollbar{display:none}.tab-drag-spacer{-webkit-app-region:drag;flex:1;min-width:20px;height:100%}.tab-item{cursor:pointer;width:140px;height:28px;color:var(--text-secondary);white-space:nowrap;-webkit-user-select:none;user-select:none;border-radius:6px;flex-shrink:0;align-items:center;gap:5px;padding:0 8px 0 11px;font-size:12px;transition:background .1s,color .1s,opacity .1s;display:flex;position:relative;overflow:hidden}.tab-item:hover{background:var(--bg-tertiary,#0000000d);color:var(--text-primary)}.tab-item.active{background:var(--bg-primary);color:var(--text-primary);font-weight:500;box-shadow:0 1px 3px #00000012}.tab-item.dragging{opacity:.4}.tab-item.drop-before:before{content:"";background:var(--accent);border-radius:2px;width:2px;position:absolute;top:4px;bottom:4px;left:-1px}.tab-item.drop-after:after{content:"";background:var(--accent);border-radius:2px;width:2px;position:absolute;top:4px;bottom:4px;right:-1px}.tab-item.drop-group{background:color-mix(in srgb, var(--accent) 12%, transparent);outline:1px dashed var(--accent)}.tab-title{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.tab-close{cursor:pointer;width:16px;height:16px;color:var(--text-tertiary);opacity:0;background:0 0;border:none;border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;padding:0;transition:opacity .1s,background .1s,color .1s;display:flex}.tab-item:hover .tab-close,.tab-item.active .tab-close{opacity:1}.tab-close:hover{background:var(--bg-tertiary,#00000014);color:var(--text-primary)}.tab-group-label{cursor:pointer;flex-shrink:0;align-items:center;gap:4px;padding-right:4px;display:flex}.tab-group-bar{background:var(--gc,#333);cursor:pointer;border-radius:2px;flex-shrink:0;width:2px;height:18px;margin:0 2px;transition:opacity .1s;display:block;position:relative}.tab-group-bar:before{content:"";position:absolute;inset:-4px -6px}.tab-group-bar:hover{opacity:.6}.tab-group-name{color:var(--text-primary);opacity:.7;text-overflow:ellipsis;white-space:nowrap;cursor:pointer;min-width:0;max-width:72px;font-family:inherit;font-size:10.5px;font-weight:500;overflow:hidden}.tab-group-name:hover{opacity:1}.tab-group-menu{z-index:9999;background:var(--bg-primary);border:1px solid var(--border-strong);border-radius:8px;flex-direction:column;gap:1px;min-width:168px;padding:4px;display:flex;position:fixed;box-shadow:0 8px 24px #00000024}.tab-group-menu-colors{grid-template-columns:repeat(3,16px);justify-content:start;gap:7px;padding:6px 8px 4px;display:grid}.tab-group-menu-name{background:var(--bg-secondary);border:1px solid var(--border-color);width:100%;height:28px;color:var(--text-primary);box-sizing:border-box;border-radius:5px;outline:none;margin:2px 0 4px;padding:0 8px;font-family:inherit;font-size:12px;transition:border-color .1s}.tab-group-menu-name:focus{border-color:var(--text-secondary)}.tab-group-menu-name::placeholder{color:var(--text-tertiary)}.tab-group-menu button{width:100%;color:var(--text-primary);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:5px;align-items:center;gap:6px;padding:6px 10px;font-family:inherit;font-size:12px;transition:background .1s;display:flex}.tab-group-menu button:hover{background:var(--bg-secondary)}.tab-group-menu button.danger{color:#dc2626}.tab-group-menu button.danger:hover{background:#fef2f2}.tab-group-menu .tab-color-swatch{width:16px;height:16px;min-width:unset;padding:0}.tab-group-menu .tab-color-swatch:hover{background:inherit}.tab-group-menu .tab-context-divider{margin:2px 4px}.tab-new-btn{cursor:pointer;width:28px;height:28px;color:var(--text-tertiary);background:0 0;border:none;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;transition:background .1s,color .1s;display:flex}.tab-new-btn:hover{background:var(--bg-tertiary,#0000000d);color:var(--text-primary)}.tab-context-overlay{z-index:9998;position:fixed;inset:0}.tab-context-menu{z-index:9999;background:var(--bg-primary);border:1px solid var(--border-strong);border-radius:8px;flex-direction:column;gap:1px;min-width:160px;padding:4px;display:flex;position:fixed;box-shadow:0 8px 24px #00000024}.tab-context-menu button{width:100%;color:var(--text-primary);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:5px;align-items:center;gap:6px;padding:6px 10px;font-family:inherit;font-size:12px;transition:background .1s;display:flex}.tab-context-menu button:hover{background:var(--bg-secondary)}.tab-context-menu button.danger{color:#dc2626}.tab-context-menu button.danger:hover{background:#fef2f2}.tab-context-divider{background:var(--border-color);height:1px;margin:3px 4px}.tab-color-picker{z-index:9999;background:var(--bg-primary);border:1px solid var(--border-strong);border-radius:10px;gap:6px;padding:8px;display:flex;position:fixed;box-shadow:0 8px 24px #00000024}.tab-color-swatch{cursor:pointer;border:2px solid #0000;border-radius:50%;flex-shrink:0;width:16px;height:16px;transition:transform .1s,border-color .1s}.tab-color-swatch:hover{transform:scale(1.2)}.tab-color-swatch.selected{border-color:var(--text-primary);transform:scale(1.15)}.ctx-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.account-panel-container{width:360px}.account-panel{padding:24px}.account-panel .panel-header{margin-bottom:24px}.account-panel .panel-header h2{margin:0;font-size:16px;font-weight:600}.account-content{flex-direction:column;gap:24px;display:flex}.account-profile{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);align-items:center;gap:16px;padding:16px;display:flex}.account-avatar{border-radius:50%;width:56px;height:56px}.account-avatar-placeholder{background:var(--bg-tertiary);width:56px;height:56px;color:var(--text-secondary);border-radius:50%;justify-content:center;align-items:center;display:flex}.account-info h3{margin:0 0 4px;font-size:16px;font-weight:600}.account-info p{color:var(--text-secondary);margin:0;font-size:13px}.account-subscription{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:16px}.subscription-header{color:var(--text-secondary);align-items:center;gap:8px;margin-bottom:12px;font-size:13px;display:flex}.subscription-tier{border-radius:var(--radius-md);padding:8px 16px;font-size:20px;font-weight:600;display:inline-block}.subscription-tier.free{background:var(--bg-tertiary);color:var(--text-secondary)}.subscription-tier.pro{color:#000;background:linear-gradient(135deg,#fbbf24 0%,#f59e0b 100%)}.upgrade-section{border-top:1px solid var(--border-color);margin-top:16px;padding-top:16px}.upgrade-benefits{margin-bottom:12px}.upgrade-benefits p{color:var(--text-secondary);margin-bottom:8px;font-size:12px;font-weight:600}.upgrade-benefits ul{margin:0;padding:0;list-style:none}.upgrade-benefits li{color:var(--text-primary);padding:4px 0 4px 16px;font-size:13px;position:relative}.upgrade-benefits li:before{content:"○";color:var(--text-tertiary);font-size:10px;position:absolute;left:0}.upgrade-btn{background:var(--accent);width:100%;height:36px;color:var(--bg-primary);border-radius:var(--radius-md);cursor:pointer;border:none;font-size:13px;font-weight:500;transition:all .2s}.upgrade-btn:hover{opacity:.9}.account-user-profile{border-bottom:1px solid var(--border-color);margin-bottom:20px;padding-bottom:20px}.account-user-profile .section-title{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:14px;font-size:12px;font-weight:600}.profile-form{flex-direction:column;gap:10px;display:flex}.profile-field{flex-direction:column;gap:4px;display:flex}.profile-field label{color:var(--text-secondary);font-size:12px}.profile-field input,.profile-field select,.profile-field textarea{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);width:100%;color:var(--text-primary);box-sizing:border-box;padding:7px 10px;font-family:inherit;font-size:13px}.profile-field input:focus,.profile-field select:focus,.profile-field textarea:focus{border-color:var(--accent);outline:none}.profile-field textarea{resize:none;line-height:1.5}.profile-save-btn{background:var(--accent);height:32px;color:var(--bg-primary);border-radius:var(--radius-md);cursor:pointer;border:none;align-self:flex-end;padding:0 16px;font-size:13px;font-weight:500;transition:opacity .2s}.profile-save-btn:hover{opacity:.85}.logout-btn{width:100%;height:44px;color:var(--text-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;background:0 0;justify-content:center;align-items:center;gap:8px;font-size:14px;font-weight:500;transition:all .2s;display:flex}.logout-btn:hover{background:var(--bg-tertiary)}.assistant-tool-chip{border-radius:var(--radius-full);border:1px solid var(--border-color);color:var(--text-secondary);background:var(--bg-secondary);align-items:center;gap:4px;padding:3px 10px;font-size:11.5px;font-weight:500;display:inline-flex}.assistant-tool-chip.running{border-color:var(--accent);color:var(--accent);animation:1s ease-in-out infinite tool-pulse}.assistant-tool-chip.done{color:#16a34a;background:#16a34a0a;border-color:#16a34a30}.assistant-tool-chip.rejected{color:var(--text-tertiary);text-decoration:line-through}@keyframes tool-pulse{0%,to{opacity:1}50%{opacity:.6}}.assistant-toggle-btn{border-radius:var(--radius-full);border:1px solid var(--border-color);height:28px;color:var(--text-tertiary);cursor:pointer;background:0 0;flex-shrink:0;justify-content:center;align-items:center;margin-left:4px;padding:0 8px;font-family:inherit;font-size:11px;font-weight:500;transition:background .15s,color .15s,border-color .15s;display:flex}.assistant-toggle-btn:hover{background:var(--bg-secondary);color:var(--text-primary);border-color:var(--border-strong)}.assistant-toggle-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}.assistant-open-editor-btn{border-radius:var(--radius-full);color:#7ef07e;cursor:pointer;background:#1a3a1a;border:1px solid #2a4a2a;align-items:center;gap:6px;margin-top:10px;padding:6px 14px;font-size:12px;font-weight:500;transition:background .15s,border-color .15s;display:inline-flex}.assistant-open-editor-btn:hover{background:#223a22;border-color:#3a6a3a}.dev-panel{background:var(--bg-primary,#0f0f0f);gap:0;height:100%;display:flex;overflow:hidden}.dev-sidebar{width:240px;box-shadow:1px 0 0 0 var(--border-color,#1e1e1e);flex-direction:column;flex-shrink:0;display:flex;overflow:hidden}.dev-sidebar-header{color:var(--text-tertiary);letter-spacing:.08em;text-transform:uppercase;flex-shrink:0;justify-content:space-between;align-items:center;padding:16px 14px 10px;font-size:10.5px;font-weight:600;display:flex}.dev-new-form{border-bottom:1px solid var(--border-color);background:var(--bg-primary);flex-direction:column;gap:8px;padding:10px 12px 12px;display:flex}.dev-input{background:var(--bg-secondary,#161616);border:1px solid var(--border-color);border-radius:var(--radius-full);color:var(--text-primary);outline:none;width:100%;padding:9px 14px;font-family:inherit;font-size:12.5px;transition:border-color .15s}.dev-input:focus{border-color:var(--border-strong)}.dev-input::placeholder{color:var(--text-tertiary)}.dev-new-form-actions{justify-content:flex-end;align-items:center;gap:4px;padding-top:2px;display:flex}.dev-app-list{flex:1;padding:6px 0;overflow-y:auto}.dev-empty{color:var(--text-tertiary);text-align:center;padding:28px 16px;font-size:12px;line-height:2}.dev-app-item{cursor:pointer;border-radius:0;justify-content:space-between;align-items:center;gap:8px;padding:9px 14px;transition:background .1s;display:flex}.dev-app-item:hover{background:var(--bg-secondary)}.dev-app-item.active{background:var(--bg-tertiary)}.dev-app-item:hover .dev-delete-btn{opacity:1}.dev-delete-btn{opacity:0;color:var(--text-tertiary,#555);flex-shrink:0;transition:opacity .15s,color .15s}.dev-delete-btn:hover{color:#e05555!important}.dev-app-item-info{flex-direction:column;gap:2px;min-width:0;display:flex}.dev-app-title{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:12.5px;overflow:hidden}.dev-app-desc{color:var(--text-tertiary);white-space:nowrap;text-overflow:ellipsis;font-size:11px;overflow:hidden}.dev-workspace{flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.dev-placeholder{color:var(--text-tertiary);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:14px;display:flex}.dev-placeholder p{font-size:14px}.dev-chat{flex:1;min-height:0}.dev-toolbar{height:44px;box-shadow:0 1px 0 0 var(--border-color,#1e1e1e);background:var(--bg-primary);z-index:2;flex-shrink:0;justify-content:space-between;align-items:center;gap:12px;padding:0 16px;display:flex}.dev-app-name{color:var(--text-primary);align-items:center;gap:7px;font-size:13px;font-weight:500;display:flex}.dev-dirty-dot{background:#f0a500;border-radius:50%;width:6px;height:6px;display:inline-block}.dev-toolbar-actions{align-items:center;gap:6px;display:flex}.dev-toolbar-divider{background:var(--border-color,#2a2a2a);flex-shrink:0;width:1px;height:16px;margin:0 4px}.dev-drawer-btn{border:1px solid var(--border-color,#2a2a2a);border-radius:var(--radius-full);height:28px;color:var(--text-tertiary,#666);cursor:pointer;background:0 0;align-items:center;gap:5px;padding:0 10px;font-family:inherit;font-size:12px;font-weight:500;transition:background .15s,color .15s,border-color .15s;display:flex;position:relative}.dev-drawer-btn:hover{background:var(--bg-secondary);color:var(--text-primary);border-color:var(--border-strong)}.dev-drawer-btn.active{background:var(--bg-tertiary,#1e1e1e);color:var(--text-primary);border-color:var(--border-strong)}.dev-error-dot{width:6px;height:6px;box-shadow:0 0 0 2px var(--bg-primary);background:#f85149;border-radius:50%;animation:1.4s ease-in-out infinite error-pulse;position:absolute;top:4px;right:4px}@keyframes error-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(1.2)}}.dev-btn-primary,.dev-btn-secondary,.dev-btn-publish{border-radius:var(--radius-full);cursor:pointer;border:none;font-family:inherit;font-size:12px;font-weight:500;line-height:1;transition:background .15s,color .15s,opacity .15s}.dev-btn-primary{background:var(--accent);color:var(--bg-primary);padding:8px 20px}.dev-btn-primary:hover:not(:disabled){background:var(--accent-hover)}.dev-btn-secondary{color:var(--text-tertiary);background:0 0;border:none;padding:8px 12px}.dev-btn-secondary:hover:not(:disabled){color:var(--text-primary)}.dev-toolbar-actions .dev-btn-secondary{background:var(--bg-secondary,#1e1e1e);border:1px solid var(--border-color,#2a2a2a);color:var(--text-secondary,#aaa);align-items:center;height:28px;padding:5px 12px;display:flex}.dev-toolbar-actions .dev-btn-secondary:hover:not(:disabled){background:var(--bg-tertiary,#252525);color:var(--text-primary)}.dev-btn-publish{color:#7ef07e;background:#1a3a1a;border:1px solid #2a4a2a;align-items:center;gap:5px;height:28px;padding:0 12px;display:flex}.dev-btn-publish:hover:not(:disabled){background:#1f4a1f;border-color:#3a6a3a}.dev-btn-primary:disabled,.dev-btn-secondary:disabled,.dev-btn-publish:disabled{opacity:.35;cursor:not-allowed}.dev-icon-btn{cursor:pointer;color:var(--text-tertiary);background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;padding:4px;transition:color .15s,background .15s;display:flex}.dev-icon-btn:hover{color:var(--text-primary);background:var(--bg-secondary)}.dev-icon-btn.active{color:var(--accent)}.dev-layout{flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden}.dev-layout-top{border-bottom:1px solid var(--border-color,#1e1e1e);flex:1;min-height:0;display:flex}.dev-editor-pane{border-right:1px solid var(--border-color,#1e1e1e);flex-direction:column;width:50%;min-width:0;display:flex;overflow:hidden}.dev-editor-mode-bar{border-bottom:1px solid var(--border-color,#1e1e1e);background:var(--bg-secondary,#141414);flex-shrink:0;justify-content:space-between;align-items:center;height:32px;padding:0 8px;display:flex}.dev-editor-mode-toggle{gap:0;display:flex}.dev-editor-mode-toggle button{border:1px solid var(--border-color,#1e1e1e);color:var(--text-tertiary,#666);cursor:pointer;background:0 0;padding:3px 10px;font-family:inherit;font-size:11px;font-weight:500;transition:background .15s,color .15s}.dev-editor-mode-toggle button:first-child{border-radius:4px 0 0 4px}.dev-editor-mode-toggle button:last-child{border-left:0;border-radius:0 4px 4px 0}.dev-editor-mode-toggle button.active{background:var(--accent,#6c5ce7);color:#fff;border-color:var(--accent,#6c5ce7)}.dev-run-btn{color:#7ef07e;cursor:pointer;background:#1a3a1a;border:1px solid #2a5a2a;border-radius:4px;align-items:center;gap:4px;padding:3px 10px;font-family:inherit;font-size:11px;font-weight:500;transition:background .15s,border-color .15s;display:inline-flex}.dev-run-btn:hover:not(:disabled){background:#223a22;border-color:#3a6a3a}.dev-run-btn:disabled{opacity:.5;cursor:default}.dev-preview-pane{flex-direction:column;flex:1;min-width:0;min-height:0;display:flex;overflow:hidden}.dev-terminal-pane{flex-direction:column;flex-shrink:0;height:200px;display:flex;overflow:hidden}.dev-preview-bar{background:var(--bg-primary);height:32px;box-shadow:0 1px 0 0 var(--border-color,#1e1e1e);color:var(--text-tertiary);z-index:1;flex-shrink:0;justify-content:space-between;align-items:center;padding:0 12px;font-size:11px;display:flex}.dev-preview-canvas{background:var(--bg-secondary,#0d0d0d);flex:1;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.dev-preview-frame{background:#fff;border:none}.dev-preview-frame--desktop{width:100%;height:100%;position:absolute;inset:0}.dev-prompt-container{z-index:10;background:#fff;border:1px solid #00000014;border-radius:9999px;align-items:center;gap:0;width:70%;max-width:600px;padding:6px 6px 6px 18px;display:flex;position:absolute;bottom:24px;left:50%;transform:translate(-50%);box-shadow:0 8px 30px #0000001a,0 2px 8px #0000000f}.dev-prompt-input{color:#111;background:0 0;border:none;outline:none;flex:1;min-width:0;font-family:inherit;font-size:13.5px;line-height:1.5}.dev-prompt-input::placeholder{color:#aaa}.dev-prompt-input:disabled{opacity:.5}.dev-prompt-submit{color:#fff;cursor:pointer;background:#111;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;transition:background .15s,opacity .15s,transform .1s;display:flex}.dev-prompt-submit:hover:not(:disabled){background:#333}.dev-prompt-submit:active:not(:disabled){transform:scale(.92)}.dev-prompt-submit:disabled{color:#aaa;cursor:not-allowed;background:#ddd}.dev-prompt-submit.loading{animation:.8s linear infinite prompt-spin}@keyframes prompt-spin{to{transform:rotate(360deg)}}.dev-device-toggle{background:var(--bg-secondary,#161616);border:1px solid var(--border-color,#1e1e1e);border-radius:6px;display:flex;overflow:hidden}.dev-device-toggle button{border:none;border-right:1px solid var(--border-color,#1e1e1e);color:var(--text-tertiary,#555);cursor:pointer;white-space:nowrap;background:0 0;align-items:center;padding:4px 10px;font-family:inherit;font-size:10.5px;font-weight:500;transition:background .15s,color .15s;display:flex}.dev-device-toggle button:last-child,.dev-device-toggle .dev-custom-ratio:last-child{border-right:none}.dev-device-toggle button:hover,.dev-device-toggle button.active{background:var(--bg-tertiary);color:var(--text-primary)}.dev-custom-ratio{border-right:1px solid var(--border-color,#1e1e1e);align-items:center;display:flex}.dev-custom-ratio.active{background:var(--bg-tertiary)}.dev-ratio-input{width:52px;color:var(--text-tertiary,#555);text-align:center;cursor:pointer;background:0 0;border:none;outline:none;padding:4px 6px;font-family:inherit;font-size:10.5px;font-weight:500}.dev-custom-ratio.active .dev-ratio-input,.dev-ratio-input:focus{color:var(--text-primary);cursor:text}.dev-pixel-label{color:var(--text-tertiary,#444);letter-spacing:.04em;-webkit-user-select:none;user-select:none;font-variant-numeric:tabular-nums;font-size:10px}.dev-terminal{background:var(--bg-primary);flex-direction:column;height:100%;display:flex;overflow:hidden}.dev-terminal-bar{background:var(--bg-primary);height:30px;box-shadow:0 1px 0 0 var(--border-color,#1e1e1e);color:var(--text-tertiary);flex-shrink:0;justify-content:space-between;align-items:center;padding:0 12px;font-size:11px;display:flex}.dev-terminal-bar>span{align-items:center;display:flex}.dev-terminal-body{flex:1;min-height:0;padding:10px 16px;font-family:JetBrains Mono,Fira Code,Menlo,monospace;font-size:12px;line-height:1.7;overflow-y:auto}.dev-terminal-ready{color:var(--text-tertiary);font-family:JetBrains Mono,Fira Code,Menlo,monospace;animation:1.2s step-end infinite terminal-blink}@keyframes terminal-blink{0%,to{opacity:1}50%{opacity:.25}}.dev-terminal-line{align-items:flex-start;gap:10px;display:flex}.dev-terminal-ts{color:#3a3a3a;flex-shrink:0;padding-top:1px;font-size:11px}.dev-terminal-msg{white-space:pre-wrap;word-break:break-all}.dev-terminal-log .dev-terminal-msg{color:#c9d1d9}.dev-terminal-info .dev-terminal-msg{color:#58a6ff}.dev-terminal-warn .dev-terminal-msg{color:#f0a500}.dev-terminal-error .dev-terminal-msg{color:#f85149}.dev-terminal-system .dev-terminal-msg{color:#3fb950}
