*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#fff;color:#374151;line-height:1.6;overflow:hidden}.app-container{height:100vh;display:flex;flex-direction:column}.top-header{display:flex;align-items:center;justify-content:space-between;padding:12px 24px;background:#fff;border-bottom:1px solid #e5e7eb;height:64px;flex-shrink:0}.brand{display:flex;align-items:center;gap:12px}.brand-logo{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;color:#fff;box-shadow:0 4px 8px #00000026;transition:all .3s ease}.brand-logo:hover{transform:scale(1.05);box-shadow:0 6px 12px #0003}.brand-text{display:flex;flex-direction:column}.brand-name{font-size:18px;font-weight:600;color:#111827;line-height:1.2}.brand-tagline{font-size:12px;color:#6b7280;line-height:1.2}.header-metrics{display:flex;gap:24px}.metric{display:flex;flex-direction:column;align-items:center;gap:2px}.metric-value{font-size:20px;font-weight:600;color:#111827}.metric-label{font-size:11px;color:#6b7280;text-transform:uppercase;letter-spacing:.5px}.user-section{display:flex;align-items:center;gap:16px}.user-info{display:flex;flex-direction:column;align-items:flex-end;gap:2px}.user-name{font-size:14px;font-weight:500;color:#111827}.user-email{font-size:12px;color:#6b7280}.logout-btn{padding:8px 16px;background:#f3f4f6;color:#374151;border:1px solid #d1d5db;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.logout-btn:hover{background:#e5e7eb;color:#111827}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.login-card{background:#fff;border-radius:16px;padding:40px;width:100%;max-width:400px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.login-header{text-align:center;margin-bottom:32px}.login-header .brand-logo{margin:0 auto 16px;width:48px;height:48px;border-radius:12px}.login-header h1{font-size:24px;font-weight:700;color:#111827;margin-bottom:8px}.login-header p{font-size:14px;color:#6b7280}.google-btn{width:100%;padding:12px 16px;background:#fff;border:1px solid #d1d5db;border-radius:8px;display:flex;align-items:center;justify-content:center;gap:12px;font-size:14px;font-weight:500;color:#374151;cursor:pointer;transition:all .2s ease;margin-bottom:24px}.google-btn:hover:not(:disabled){background:#f9fafb;border-color:#9ca3af}.google-btn:disabled{opacity:.6;cursor:not-allowed}.divider{position:relative;text-align:center;margin:24px 0}.divider:before{content:"";position:absolute;top:50%;left:0;right:0;height:1px;background:#e5e7eb}.divider span{background:#fff;padding:0 16px;color:#6b7280;font-size:14px}.login-form{margin-bottom:24px}.form-group{margin-bottom:20px}.form-group label{display:block;font-size:14px;font-weight:500;color:#374151;margin-bottom:6px}.form-group input{width:100%;padding:12px 16px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;transition:border-color .2s ease;background:#fff}.form-group input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-group input:disabled{background:#f9fafb;cursor:not-allowed}.form-footer{display:flex;justify-content:flex-end;margin-bottom:20px}.login-btn{width:100%;padding:12px 16px;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:8px}.login-btn.primary{background:#3b82f6;color:#fff}.login-btn.primary:hover:not(:disabled){background:#2563eb}.login-btn:disabled{opacity:.6;cursor:not-allowed}.login-footer{text-align:center;font-size:14px;color:#6b7280}.link-btn{background:none;border:none;color:#3b82f6;font-size:14px;font-weight:500;cursor:pointer;text-decoration:underline;transition:color .2s ease}.link-btn:hover{color:#2563eb}.main-content{display:flex;flex:1;overflow:hidden}.sidebar{width:280px;background:#f9fafb;border-right:1px solid #e5e7eb;display:flex;flex-direction:column;flex-shrink:0}.sidebar-header{padding:16px;border-bottom:1px solid #e5e7eb}.new-document-btn{width:100%;padding:12px 16px;background:#fff;border:1px solid #d1d5db;border-radius:8px;display:flex;align-items:center;gap:8px;font-size:14px;font-weight:500;color:#374151;cursor:pointer;transition:all .2s ease}.new-document-btn:hover{background:#f3f4f6;border-color:#9ca3af}.new-document-icon{font-size:16px;font-weight:600;color:#6b7280}.documents-section{flex:1;padding:16px;overflow-y:auto}.section-title{font-size:12px;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px}.upload-area{border:2px dashed #d1d5db;border-radius:12px;padding:40px;text-align:center;color:#6b7280;transition:all .2s ease;cursor:pointer;background:#f9fafb;position:relative;z-index:1}.upload-area:hover{border-color:#3b82f6;background:#eff6ff;color:#1d4ed8;transform:translateY(-1px);box-shadow:0 4px 6px -1px #0000001a}.upload-area.drag-active{border-color:#3b82f6;background:#eff6ff;color:#1d4ed8;transform:scale(1.02);box-shadow:0 8px 15px -3px #0000001a}.upload-area.uploading{opacity:.7;cursor:not-allowed;transform:none}.upload-area input[type=file]{position:absolute;top:0;left:0;width:100%;height:100%;opacity:0;cursor:pointer;z-index:2}.upload-icon{font-size:3rem;margin-bottom:16px;display:block}.upload-text{font-size:1.1rem;margin-bottom:8px;font-weight:500}.upload-hint{font-size:.9rem;opacity:.7}.upload-spinner{width:24px;height:24px;border:2px solid #e5e7eb;border-top:2px solid #3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 16px}.document-list{display:flex;flex-direction:column;gap:4px}.document-item{padding:12px;border-radius:8px;cursor:pointer;transition:all .2s ease;background:transparent;border:1px solid transparent}.document-item:hover{background:#f3f4f6}.document-item.selected{background:#eff6ff;border-color:#3b82f6}.document-name{font-size:14px;font-weight:500;color:#111827;margin-bottom:4px;line-height:1.3}.document-meta{font-size:11px;color:#6b7280;display:flex;gap:12px}.chat-area{flex:1;display:flex;flex-direction:column;background:#fff}.chat-header{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;border-bottom:1px solid #e5e7eb;background:#fff;flex-shrink:0}.chat-title{display:flex;align-items:center;gap:8px;font-size:16px;font-weight:600;color:#111827}.document-icon{font-size:18px}.clear-chat-btn{padding:6px 12px;background:#f3f4f6;color:#6b7280;border:1px solid #d1d5db;border-radius:6px;font-size:12px;cursor:pointer;transition:all .2s ease}.clear-chat-btn:hover{background:#e5e7eb;color:#374151}.chat-messages{flex:1;overflow-y:auto;padding:24px;background:#fff}.message{display:flex;gap:16px;margin-bottom:24px;align-items:flex-start}.message-avatar{width:32px;height:32px;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}.message.user .message-avatar{background:#3b82f6;color:#fff}.message.ai .message-avatar{background:#10b981;color:#fff}.message-content{flex:1;max-width:calc(100% - 48px)}.message-text{font-size:15px;line-height:1.6;color:#111827;margin-bottom:4px}.message-time{font-size:11px;color:#9ca3af}.welcome-message{text-align:center;padding:60px 20px;color:#6b7280}.welcome-icon{font-size:48px;margin-bottom:16px}.welcome-message h2{font-size:24px;font-weight:600;color:#111827;margin-bottom:12px}.welcome-message p{font-size:15px;margin-bottom:8px;line-height:1.5}.select-document-prompt{text-align:center;padding:120px 20px;color:#6b7280}.prompt-icon{font-size:64px;margin-bottom:24px;opacity:.5}.select-document-prompt h2{font-size:24px;font-weight:600;color:#111827;margin-bottom:12px}.select-document-prompt p{font-size:15px;line-height:1.5}.chat-input-container{display:flex;gap:12px;padding:24px;background:#fff;border-top:1px solid #e5e7eb;flex-shrink:0}.chat-input{flex:1;padding:12px 16px;border:1px solid #d1d5db;border-radius:8px;font-size:15px;resize:none;min-height:44px;max-height:120px;font-family:inherit;transition:border-color .2s ease;line-height:1.4}.chat-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.chat-input:disabled{background:#f9fafb;cursor:not-allowed}.send-btn{width:44px;height:44px;background:#3b82f6;color:#fff;border:none;border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;font-size:18px;font-weight:500}.send-btn:hover:not(:disabled){background:#2563eb;transform:translateY(-1px)}.send-btn:disabled{background:#9ca3af;cursor:not-allowed;transform:none}.send-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top:2px solid white;border-radius:50%;animation:spin 1s linear infinite}.typing-indicator{display:flex;gap:4px;align-items:center;padding:8px 0}.typing-indicator span{width:6px;height:6px;border-radius:50%;background:#9ca3af;animation:typing 1.4s infinite ease-in-out}.typing-indicator span:nth-child(1){animation-delay:-.32s}.typing-indicator span:nth-child(2){animation-delay:-.16s}@keyframes typing{0%,80%,to{transform:scale(.8);opacity:.5}40%{transform:scale(1);opacity:1}}.loading-spinner{width:16px;height:16px;border:2px solid #e5e7eb;border-top:2px solid #3b82f6;border-radius:50%;animation:spin 1s linear infinite}.loading-spinner.small{width:12px;height:12px;border-width:1.5px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-placeholder{display:flex;align-items:center;gap:8px;padding:20px;color:#6b7280;font-size:14px}.empty-documents{text-align:center;padding:40px 20px;color:#6b7280}.empty-documents p{font-size:14px;margin-bottom:4px}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-content{background:#fff;border-radius:12px;width:90%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;position:relative}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid #e5e7eb}.modal-header h3{font-size:18px;font-weight:600;color:#111827}.modal-close{background:none;border:none;font-size:24px;color:#6b7280;cursor:pointer;padding:4px;border-radius:4px;transition:all .2s ease}.modal-close:hover{background:#f3f4f6;color:#374151}.error-message{background:#fef2f2;border:1px solid #fecaca;color:#dc2626;padding:12px 16px;border-radius:8px;margin:16px 24px;display:flex;justify-content:space-between;align-items:center;font-size:14px}.success-message{background:#f0fdf4;border:1px solid #bbf7d0;color:#16a34a;padding:12px 16px;border-radius:8px;margin:16px 24px;display:flex;justify-content:space-between;align-items:center;font-size:14px}.close-btn{background:none;border:none;color:inherit;font-size:18px;cursor:pointer;padding:0 8px;opacity:.7;transition:opacity .2s ease}.close-btn:hover{opacity:1}@media (max-width: 768px){.top-header{padding:12px 16px}.brand-name{font-size:16px}.brand-tagline{font-size:11px}.header-metrics{gap:16px}.metric-value{font-size:18px}.user-section{gap:12px}.user-name{font-size:13px}.user-email{font-size:11px}.sidebar{width:240px}.chat-header{padding:12px 16px}.chat-messages,.chat-input-container{padding:16px}.message{gap:12px}.message-content{max-width:calc(100% - 44px)}.login-card{padding:24px}}
