*{box-sizing:border-box;margin:0;padding:0}body{font-family:system-ui,-apple-system,sans-serif;background:#0a0a0a;color:#fafafa;min-height:100vh}.app{display:flex;flex-direction:column;height:100vh;max-width:800px;margin:0 auto}.app-container{display:flex;height:100vh}.sidebar{width:280px;background:#111;border-right:1px solid #222;display:flex;flex-direction:column;flex-shrink:0}.sidebar-header{display:flex;justify-content:space-between;align-items:center;padding:1rem;border-bottom:1px solid #222}.sidebar-header h1{font-size:1.25rem;font-weight:600}.new-task-btn{background:#2563eb;color:#fff;border:none;padding:.4rem .75rem;border-radius:6px;font-size:.875rem;cursor:pointer}.new-task-btn:hover:not(:disabled){background:#1d4ed8}.new-task-btn:disabled{opacity:.5;cursor:not-allowed}.task-list{flex:1;overflow-y:auto;padding:.5rem}.no-tasks{color:#666;text-align:center;padding:2rem;font-size:.875rem}.task-item{display:flex;align-items:flex-start;gap:.75rem;padding:.75rem;border-radius:8px;cursor:pointer;margin-bottom:.25rem}.task-item:hover{background:#1a1a1a}.task-item.selected{background:#1a1a1a;border:1px solid #333}.task-status{width:20px;height:20px;display:flex;align-items:center;justify-content:center;font-size:.75rem;border-radius:50%;flex-shrink:0;margin-top:2px}.task-status.pending,.task-status.running{color:#f59e0b}.task-status.completed{color:#22c55e}.task-status.failed{color:#ef4444}.task-status.cancelled{color:#666}.task-info{flex:1;min-width:0}.task-title{font-size:.875rem;color:#ccc;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.task-time{font-size:.75rem;color:#666;margin-top:.25rem}.sidebar-footer{padding:.75rem;border-top:1px solid #222}.sidebar-footer .user-menu-btn{width:100%;justify-content:flex-start}.sidebar-footer .user-dropdown{bottom:100%;top:auto;left:0;right:auto;margin-bottom:.5rem;margin-top:0}.sidebar-tabs{display:flex;padding:0 .5rem;gap:.25rem;border-bottom:1px solid #222}.sidebar-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem .5rem;background:transparent;border:none;color:#888;font-size:.875rem;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color .2s,border-color .2s}.sidebar-tab:hover{color:#ccc}.sidebar-tab.active{color:#fff;border-bottom-color:#2563eb}.tab-icon{font-size:1rem}.tab-label{font-weight:500}.file-list{flex:1;overflow-y:auto;display:flex;flex-direction:column}.file-list-header{padding:.75rem;border-bottom:1px solid #222}.upload-btn{width:100%;padding:.5rem 1rem;background:#2563eb;color:#fff;border:none;border-radius:6px;font-size:.875rem;cursor:pointer;transition:background .2s}.upload-btn:hover:not(:disabled){background:#1d4ed8}.upload-btn:disabled{opacity:.5;cursor:not-allowed}.no-files{padding:2rem 1rem;text-align:center;color:#666;font-size:.875rem}.file-item{display:flex;align-items:center;gap:.75rem;padding:.75rem;cursor:pointer;border-bottom:1px solid #1a1a1a;transition:background .2s}.file-item:hover{background:#1a1a1a}.file-item.selected{background:#1e3a5f}.file-icon{font-size:1.25rem;flex-shrink:0}.file-info{flex:1;min-width:0;overflow:hidden}.file-name{font-size:.875rem;color:#eee;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.file-meta{font-size:.75rem;color:#666;margin-top:.125rem}.main-content{flex:1;display:flex;flex-direction:row;overflow:hidden}.chat-container{flex:1;display:flex;flex-direction:column;height:100%;min-width:0}.file-panel{width:400px;max-width:50%;display:flex;flex-direction:column;background:#0f0f0f;border-left:1px solid #222}.file-panel-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:#111;border-bottom:1px solid #222}.file-panel-title{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:#eee;min-width:0;overflow:hidden}.file-panel-title span:last-child{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.file-panel-actions{display:flex;gap:.5rem;flex-shrink:0}.file-panel-actions .download-btn,.file-panel-actions .close-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:transparent;border:1px solid #333;border-radius:6px;color:#ccc;font-size:1rem;cursor:pointer;text-decoration:none;transition:background .2s,border-color .2s}.file-panel-actions .download-btn:hover,.file-panel-actions .close-btn:hover{background:#222;border-color:#444}.file-panel-content{flex:1;overflow:auto;display:flex;flex-direction:column}.file-preview-image{max-width:100%;height:auto;object-fit:contain;margin:auto;padding:1rem}.file-preview-pdf{width:100%;height:100%;border:none}.file-preview-text{flex:1;margin:0;padding:1rem;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:.8125rem;line-height:1.5;color:#ccc;background:#0a0a0a;overflow:auto;white-space:pre-wrap;word-wrap:break-word}.file-preview-binary{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;height:100%;color:#888}.file-preview-binary .download-link{color:#2563eb;text-decoration:none}.file-preview-binary .download-link:hover{text-decoration:underline}.file-preview-loading,.file-preview-error{display:flex;align-items:center;justify-content:center;height:100%;color:#888}.file-preview-error{color:#ef4444}.messages-area{flex:1;overflow-y:auto;padding:1.5rem;display:flex;flex-direction:column;gap:1rem}.welcome-hero{text-align:center;margin:auto;padding:2rem}.welcome-hero h2{font-size:1.75rem;font-weight:600;margin-bottom:.5rem}.welcome-hero p{color:#888}.message{display:flex;max-width:85%}.message.user{align-self:flex-end}.message.assistant{align-self:flex-start}.message-content{padding:.75rem 1rem;border-radius:12px;font-size:.9375rem;line-height:1.5}.message.user .message-content{background:#2563eb;color:#fff;border-bottom-right-radius:4px}.message.user .message-content p{margin:0}.message.assistant .message-content{background:#1a1a1a;color:#e5e5e5;border-bottom-left-radius:4px}.markdown-content{line-height:1.6}.markdown-content p{margin:0 0 .75em}.markdown-content p:last-child{margin-bottom:0}.markdown-content h1,.markdown-content h2,.markdown-content h3{margin:1em 0 .5em;font-weight:600}.markdown-content h1:first-child,.markdown-content h2:first-child,.markdown-content h3:first-child{margin-top:0}.markdown-content h1{font-size:1.4em}.markdown-content h2{font-size:1.2em}.markdown-content h3{font-size:1.1em}.markdown-content ul,.markdown-content ol{margin:.5em 0;padding-left:1.5em}.markdown-content li{margin:.25em 0}.markdown-content code{background:#252525;padding:.15em .4em;border-radius:4px;font-family:SF Mono,Consolas,monospace;font-size:.9em}.markdown-content pre{background:#0d0d0d;padding:1em;border-radius:8px;overflow-x:auto;margin:.75em 0}.markdown-content pre code{background:transparent;padding:0}.markdown-content blockquote{border-left:3px solid #444;margin:.75em 0;padding-left:1em;color:#aaa}.markdown-content a{color:#60a5fa;text-decoration:none}.markdown-content a:hover{text-decoration:underline}.markdown-content hr{border:none;border-top:1px solid #333;margin:1em 0}.markdown-content table{border-collapse:collapse;margin:.75em 0;width:100%}.markdown-content th,.markdown-content td{border:1px solid #333;padding:.5em;text-align:left}.markdown-content th{background:#252525}.tool-calls{margin-top:.5rem;display:flex;flex-wrap:wrap;gap:.25rem}.tool-call{background:#252525;padding:.125rem .5rem;border-radius:4px;font-size:.75rem}.tool-name{color:#f59e0b}.typing-tool{color:#888;font-size:.75rem;margin-bottom:.5rem}.typing-indicator{display:flex;gap:4px;padding:.25rem 0}.typing-indicator span{width:8px;height:8px;background:#666;border-radius:50%;animation:bounce 1.4s infinite ease-in-out both}.typing-indicator span:nth-child(1){animation-delay:-.32s}.typing-indicator span:nth-child(2){animation-delay:-.16s}@keyframes bounce{0%,80%,to{transform:scale(0)}40%{transform:scale(1)}}.chat-input-form{display:flex;gap:.5rem;padding:1rem 1.5rem;background:#111;border-top:1px solid #222;align-items:flex-end}.chat-input-form textarea{flex:1;background:#1a1a1a;border:1px solid #333;color:#fafafa;padding:.75rem 1rem;border-radius:12px;font-size:.9375rem;resize:none;font-family:inherit;min-height:44px;max-height:150px}.chat-input-form textarea:focus{outline:none;border-color:#2563eb}.chat-input-form textarea::placeholder{color:#666}.chat-input-actions{display:flex;gap:.5rem}.send-btn{background:#2563eb;color:#fff;border:none;width:44px;height:44px;border-radius:12px;font-size:1.25rem;cursor:pointer;display:flex;align-items:center;justify-content:center}.send-btn:hover:not(:disabled){background:#1d4ed8}.send-btn:disabled{opacity:.5;cursor:not-allowed}.delete-btn{background:transparent;border:none;color:#666;cursor:pointer;padding:.25rem .5rem;border-radius:4px;opacity:0;transition:opacity .2s}.task-item:hover .delete-btn{opacity:1}.delete-btn:hover{color:#ef4444;background:#ef44441a}.mic-btn{background:#333;color:#fff;border:none;width:44px;height:44px;font-size:1.25rem;border-radius:12px;cursor:pointer;display:flex;align-items:center;justify-content:center}.mic-btn:hover:not(:disabled){background:#444}.mic-btn:disabled{opacity:.5;cursor:not-allowed}.mic-btn.recording{background:#dc2626;animation:pulse 1s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.live-transcript{background:#1a1a1a;border:1px solid #333;border-bottom:none;border-radius:12px 12px 0 0;padding:.75rem 1rem;color:#888;font-size:.875rem;font-style:italic;margin-bottom:-1px}.chat-input-form:has(.live-transcript) textarea{border-radius:0 0 12px 12px}.loading-screen{display:flex;align-items:center;justify-content:center;height:100vh;color:#666}.login-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;gap:1rem}.login-screen h1{font-size:3rem;font-weight:700}.login-screen p{color:#666;margin-bottom:2rem}.google-btn{display:flex;align-items:center;gap:.75rem;background:#fff;color:#333;border:none;padding:.75rem 1.5rem;border-radius:8px;font-size:1rem;cursor:pointer;transition:background .2s}.google-btn:hover{background:#f0f0f0}.avatar{width:28px;height:28px;border-radius:50%}.user-menu{position:relative}.user-menu-btn{display:flex;align-items:center;gap:.5rem;background:transparent;border:1px solid #333;color:#ccc;padding:.4rem .75rem;border-radius:6px;cursor:pointer;font-size:.875rem}.user-menu-btn:hover{border-color:#555;color:#fff}.user-dropdown{position:absolute;top:100%;right:0;margin-top:.5rem;background:#1a1a1a;border:1px solid #333;border-radius:8px;min-width:200px;overflow:hidden;z-index:100;box-shadow:0 4px 12px #0006}.dropdown-header{padding:.75rem 1rem;border-bottom:1px solid #333;display:flex;flex-direction:column;gap:.25rem}.dropdown-email{color:#888;font-size:.75rem}.dropdown-rank{color:#2563eb;font-size:.75rem;text-transform:capitalize}.dropdown-item{width:100%;text-align:left;background:transparent;border:none;color:#ccc;padding:.75rem 1rem;cursor:pointer;font-size:.875rem}.dropdown-item:hover{background:#252525;color:#fff}.pending-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;gap:2rem}.pending-screen h1{font-size:3rem;font-weight:700}.pending-card{display:flex;flex-direction:column;align-items:center;gap:1rem;background:#1a1a1a;border:1px solid #333;border-radius:16px;padding:2rem 3rem;text-align:center}.pending-card h2{font-size:1.25rem;font-weight:500;color:#fafafa}.avatar-large{width:80px;height:80px;border-radius:50%;border:3px solid #333}.pending-message{color:#f59e0b;max-width:300px;line-height:1.5}.logout-btn{background:transparent;border:1px solid #333;color:#888;padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-size:.875rem}.logout-btn:hover{border-color:#555;color:#fff}@media (max-width: 768px){.sidebar{width:60px}.sidebar-header h1,.new-task-btn,.task-info,.sidebar-footer .user-menu-btn span{display:none}.new-task-btn{display:block;padding:.5rem}.task-item{justify-content:center}.sidebar-tabs{padding:.25rem}.tab-label{display:none}.sidebar-tab,.file-list-header{padding:.5rem}.upload-btn{padding:.5rem;font-size:0}.upload-btn:before{content:"+";font-size:1.25rem}.file-item{justify-content:center;padding:.5rem}.file-info,.file-item .delete-btn{display:none}.main-content{flex-direction:column}.file-panel{width:100%;max-width:100%;max-height:50vh;border-left:none;border-top:1px solid #222}}
