.auth-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;background:linear-gradient(135deg,#065f46 0%,#047857 100%);color:#fff}.loading-spinner{width:40px;height:40px;border:3px solid rgba(255,255,255,.3);border-top:3px solid white;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}.auth-container{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#065f46 0%,#047857 100%);padding:2rem}.auth-card{background:rgba(255,255,255,.95);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:20px;padding:3rem;box-shadow:0 20px 40px #0000001a;text-align:center;max-width:400px;width:100%}.auth-header h1{color:#065f46;font-size:2.5rem;font-weight:700;margin-bottom:.5rem}.auth-header p{color:#6b7280;font-size:1.1rem;margin-bottom:2rem}.login-button{background:linear-gradient(135deg,#065f46 0%,#047857 100%);color:#fff;border:none;padding:1rem 2rem;border-radius:12px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s ease;width:100%;margin-bottom:1.5rem}.login-button:hover{transform:translateY(-2px);box-shadow:0 10px 20px #065f464d}.login-button:disabled{opacity:.7;cursor:not-allowed;transform:none}.auth-info p{color:#6b7280;font-size:.9rem}.authenticated-app{height:100vh;display:flex;flex-direction:column}.auth-header-bar{background:rgba(255,255,255,.95);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid rgba(6,95,70,.1);padding:.75rem 1.5rem;display:flex;justify-content:flex-end;align-items:center;position:sticky;top:0;z-index:1000}.user-info{display:flex;align-items:center;gap:1rem}.user-name{color:#065f46;font-weight:600;font-size:.9rem}.logout-button{background:transparent;color:#065f46;border:1px solid #065f46;padding:.5rem 1rem;border-radius:8px;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s ease}.logout-button:hover{background:#065f46;color:#fff}.message-list{flex:1;overflow-y:auto;padding:var(--space-4) 0}.messages-container{max-width:800px;margin:0 auto;padding:0 var(--space-6)}.message{display:flex;gap:var(--space-2);margin-bottom:var(--space-4);align-items:flex-start}.message-user{flex-direction:row-reverse}.message-avatar{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:var(--radius-md);flex-shrink:0;margin-top:var(--space-1)}.message-user .message-avatar{background:var(--color-primary);color:#fff}.message-ai .message-avatar{background:var(--color-gray-100);color:var(--color-gray-600)}.message-content{flex:1;min-width:0}.message-bubble{position:relative;padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);max-width:85%;word-wrap:break-word;box-shadow:var(--shadow-sm);transition:all var(--transition-fast)}.message-user .message-bubble{background:var(--color-primary);color:#fff;margin-left:var(--space-8)}.message-ai .message-bubble{background:white;color:var(--color-gray-800);border:1px solid var(--color-gray-200);margin-right:var(--space-8)}.message-text{margin:0;line-height:1.4;font-size:.9rem;white-space:pre-wrap}.formatted-content{white-space:normal}.formatted-content h1,.formatted-content h2,.formatted-content h3{margin:var(--space-2) 0 var(--space-1) 0;font-weight:600;color:var(--color-gray-800)}.formatted-content h1{font-size:1.1rem}.formatted-content h2{font-size:1rem}.formatted-content h3{font-size:.95rem}.formatted-content ul{margin:var(--space-1) 0;padding-left:var(--space-4)}.formatted-content li{margin:.25rem 0;list-style-type:disc}.formatted-content strong{font-weight:600;color:var(--color-gray-900)}.formatted-content em{font-style:italic}.formatted-content code{background:var(--color-gray-100);padding:2px 4px;border-radius:var(--radius-sm);font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:.875em}.formatted-content pre{background:var(--color-gray-50);border:1px solid var(--color-gray-200);border-radius:var(--radius-md);padding:var(--space-3);margin:var(--space-2) 0;overflow-x:auto}.formatted-content pre code{background:none;padding:0;border-radius:0}.message-time{display:block;font-size:var(--font-size-xs);margin-top:var(--space-2);opacity:.7}.message-user .message-time{color:#fffc}.message-ai .message-time{color:var(--color-gray-500)}.loading-message{background:var(--color-gray-50);border:1px solid var(--color-gray-200);padding:var(--space-4)}.typing-indicator{display:flex;gap:var(--space-1);align-items:center}.typing-indicator span{width:6px;height:6px;border-radius:50%;background:var(--color-gray-400);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}}.message-bubble:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}@media (max-width: 768px){.messages-container{padding:0 var(--space-4)}.message-bubble{padding:var(--space-3) var(--space-4)}.message-user .message-bubble{margin-left:var(--space-8)}.message-ai .message-bubble{margin-right:var(--space-8)}.message-text{font-size:var(--font-size-sm)}}@media (max-width: 480px){.message-user .message-bubble{margin-left:var(--space-4)}.message-ai .message-bubble{margin-right:var(--space-4)}}.document-upload-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.document-upload-modal{background:rgba(255,255,255,.95);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.2);border-radius:1rem;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;width:100%;max-width:500px;max-height:90vh;overflow:hidden}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;border-bottom:1px solid rgba(0,0,0,.1)}.modal-title{font-size:1.25rem;font-weight:600;color:var(--color-text-primary);margin:0}.close-button{display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;border:none;background:rgba(0,0,0,.05);border-radius:.5rem;color:var(--color-text-secondary);cursor:pointer;transition:all .2s ease}.close-button:hover:not(:disabled){background:rgba(0,0,0,.1);color:var(--color-text-primary)}.close-button:disabled{opacity:.5;cursor:not-allowed}.modal-content{padding:1.5rem}.upload-area{border:2px dashed rgba(99,102,241,.3);border-radius:.75rem;padding:2rem;text-align:center;background:rgba(99,102,241,.02);transition:all .3s ease;cursor:pointer}.upload-area.drag-over{border-color:var(--color-primary);background:rgba(99,102,241,.05);transform:scale(1.02)}.upload-area.uploading{border-color:var(--color-secondary);background:rgba(139,92,246,.02);cursor:default}.upload-content{display:flex;flex-direction:column;align-items:center;gap:1rem}.upload-icon{color:var(--color-primary);opacity:.7}.upload-content h4{font-size:1.125rem;font-weight:600;color:var(--color-text-primary);margin:0}.upload-content p{color:var(--color-text-secondary);margin:0}.browse-button{background:none;border:none;color:var(--color-primary);font-weight:500;cursor:pointer;text-decoration:underline;padding:0;font-size:inherit}.browse-button:hover{color:var(--color-primary-dark)}.file-info{display:flex;align-items:center;gap:.5rem;color:var(--color-text-tertiary);font-size:.875rem;margin-top:.5rem}.upload-progress{display:flex;flex-direction:column;align-items:center;gap:1rem}.progress-circle{position:relative;display:flex;align-items:center;justify-content:center}.progress-ring{transform:rotate(-90deg)}.progress-ring-circle{transition:stroke-dashoffset .3s ease}.progress-text{position:absolute;font-size:.875rem;font-weight:600;color:var(--color-primary)}.upload-progress p{color:var(--color-text-secondary);margin:0}.success-state{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:2rem 0;text-align:center}.success-icon{color:var(--color-success, #10b981)}.success-state h4{font-size:1.25rem;font-weight:600;color:var(--color-text-primary);margin:0}.success-state p{color:var(--color-text-secondary);margin:0}.error-message{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.2);border-radius:.5rem;color:#dc2626;font-size:.875rem;margin-top:1rem}@media (prefers-color-scheme: dark){.document-upload-modal{background:rgba(17,24,39,.95);border-color:#ffffff1a}.modal-header{border-bottom-color:#ffffff1a}.close-button{background:rgba(255,255,255,.05)}.close-button:hover:not(:disabled){background:rgba(255,255,255,.1)}.upload-area{background:rgba(99,102,241,.05);border-color:#6366f166}.upload-area.drag-over{background:rgba(99,102,241,.1)}.upload-area.uploading{background:rgba(139,92,246,.05)}}@media (max-width: 640px){.document-upload-overlay{padding:.5rem}.modal-header,.modal-content{padding:1rem}.upload-area{padding:1.5rem 1rem}.upload-content h4{font-size:1rem}.file-info{font-size:.8125rem}}.close-button:focus-visible,.browse-button:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.upload-area{animation:subtle-pulse 3s ease-in-out infinite}@keyframes subtle-pulse{0%,to{opacity:1}50%{opacity:.95}}.upload-area.uploading{animation:none}.progress-ring-circle{stroke-linecap:round}.message-input-container{padding:var(--space-4) var(--space-6);background:var(--color-gray-50);border-top:1px solid var(--color-gray-200)}.message-input-form{max-width:800px;margin:0 auto}.input-wrapper{display:flex;align-items:flex-end;gap:var(--space-3);padding:var(--space-3);background:var(--color-gray-50);border:2px solid var(--color-gray-200);border-radius:var(--radius-xl);transition:all var(--transition-fast)}.input-wrapper:focus-within{border-color:var(--color-primary);background:#ffffff;box-shadow:0 0 0 3px #1655401a}.attach-button{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;background:transparent;color:var(--color-gray-500);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);flex-shrink:0}.attach-button:hover:not(:disabled){background:var(--color-gray-200);color:var(--color-gray-700)}.attach-button:disabled{opacity:.5;cursor:not-allowed}.message-textarea{flex:1;min-height:36px;max-height:120px;border:none;background:transparent;resize:none;outline:none;font-family:inherit;font-size:var(--font-size-base);line-height:1.5;color:var(--color-gray-800);padding:var(--space-2) 0}.message-textarea::placeholder{color:var(--color-gray-400)}.message-textarea:disabled{opacity:.5;cursor:not-allowed}.send-button{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;background:var(--color-gray-300);color:var(--color-gray-500);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);flex-shrink:0}.send-button:disabled{cursor:not-allowed}.send-button-active{background:var(--color-primary);color:#fff;cursor:pointer}.send-button-active:hover{background:var(--color-primary-dark);transform:translateY(-1px);box-shadow:var(--shadow-md)}.send-button-active:active{transform:translateY(0)}.input-footer{display:flex;justify-content:space-between;align-items:center;margin-top:var(--space-2);padding:0 var(--space-3)}.character-count,.input-hint{font-size:var(--font-size-xs);color:var(--color-gray-400)}@media (max-width: 768px){.message-input-container{padding:var(--space-3) var(--space-4)}.input-footer{flex-direction:column;align-items:flex-start;gap:var(--space-1)}.input-hint{display:none}}@media (max-width: 480px){.input-wrapper{padding:var(--space-2)}.attach-button,.send-button{width:32px;height:32px}.message-textarea{font-size:var(--font-size-sm)}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.4);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:flex-start;justify-content:center;padding-top:15vh}.confirmation-modal{position:relative;background:white;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;z-index:1001;min-width:320px;max-width:400px;width:85vw;max-height:80vh;overflow:hidden;margin:1rem}.modal-header{padding:1.25rem 1.5rem 0;border-bottom:1px solid #f3f4f6}.modal-title{font-size:1.125rem;font-weight:600;color:#1f2937;margin:0 0 .75rem}.modal-body{padding:1rem 1.5rem}.modal-message{font-size:.875rem;color:#4b5563;line-height:1.4;margin:0}.document-name{font-weight:600;color:#1f2937;background:#f9fafb;padding:.25rem .5rem;border-radius:6px;font-family:ui-monospace,SFMono-Regular,SF Mono,Consolas,Liberation Mono,Menlo,monospace}.modal-actions{display:flex;gap:.75rem;padding:1rem 1.5rem 1.25rem;justify-content:flex-end;background:#fafafa;border-top:1px solid #f3f4f6}.modal-button{padding:.5rem 1rem;border-radius:8px;font-weight:500;font-size:.8125rem;cursor:pointer;transition:all .2s ease;border:none;min-width:80px}.modal-button:focus{outline:none;box-shadow:0 0 0 3px #6366f11a}.modal-button-secondary{background:#f3f4f6;color:#374151;border:1px solid #d1d5db}.modal-button-secondary:hover{background:#e5e7eb;border-color:#9ca3af}.modal-button-primary{background:#6366f1;color:#fff}.modal-button-primary:hover{background:#5856eb}.modal-button-destructive{background:#dc2626;color:#fff}.modal-button-destructive:hover{background:#b91c1c}@media (max-width: 480px){.confirmation-modal{min-width:unset;margin:1rem}.modal-actions{flex-direction:column-reverse}.modal-button{width:100%}}.chat-interface{display:flex;flex-direction:column;height:100vh;background:var(--color-gray-50)}.chat-header{display:flex;align-items:center;justify-content:flex-end;padding:var(--space-4) var(--space-6);background:var(--color-gray-50);border-bottom:1px solid var(--color-gray-200);position:sticky;top:0;z-index:10}.user-info{display:flex;align-items:center;gap:var(--space-2)}.user-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-gray-700);opacity:.9}.signout-button{display:flex;align-items:center;justify-content:center;padding:var(--space-2);background:transparent;border:none;border-radius:var(--border-radius-md);color:var(--color-gray-600);cursor:pointer;transition:all .2s ease}.signout-button:hover{background:var(--color-gray-100);color:var(--color-red-600);transform:scale(1.05)}.signout-button:active{transform:scale(.95)}.chat-content{flex:1;display:flex;flex-direction:column;overflow:hidden}.welcome-screen{flex:1;display:flex;align-items:center;justify-content:center;padding:var(--space-8)}.welcome-content{text-align:center;max-width:600px;margin:0 auto}.icon-comparison{display:flex;gap:var(--space-8);justify-content:center;align-items:center;margin-bottom:var(--space-6)}.welcome-icon{font-size:4rem;display:flex;flex-direction:column;align-items:center;gap:var(--space-3);margin-bottom:var(--space-8)}.welcome-icon .ai-icon{margin-top:-12px}.icon-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-gray-600);text-align:center}.ai-icon{filter:drop-shadow(0 4px 8px rgba(22,85,64,.2));transition:all var(--transition-normal)}.welcome-icon:hover .ai-icon{filter:drop-shadow(0 6px 12px rgba(22,85,64,.3))}.holographic-prism{animation:prismRotate 8s linear infinite;transform-origin:center}@keyframes prismRotate{0%{transform:rotateY(0) rotateX(5deg)}25%{transform:rotateY(90deg) rotateX(5deg)}50%{transform:rotateY(180deg) rotateX(5deg)}75%{transform:rotateY(270deg) rotateX(5deg)}to{transform:rotateY(360deg) rotateX(5deg)}}.holographic-prism polygon{transition:all .6s ease;animation:prismShimmer 3s ease-in-out infinite}@keyframes prismShimmer{0%,to{opacity:var(--base-opacity);transform:scale(1)}50%{opacity:calc(var(--base-opacity) + .3);transform:scale(1.02)}}.holographic-prism polygon:nth-child(1){--base-opacity: .3;animation-delay:0s}.holographic-prism polygon:nth-child(2){--base-opacity: .6;animation-delay:.3s}.holographic-prism polygon:nth-child(3){--base-opacity: .9;animation-delay:.6s}.holographic-prism line{stroke-linecap:round;transition:all .4s ease;animation:lightBeam 2s ease-in-out infinite}@keyframes lightBeam{0%,to{stroke-width:2;opacity:.8;stroke-dasharray:none}50%{stroke-width:3;opacity:1;stroke-dasharray:8 4}}.holographic-prism line:nth-child(4){animation-delay:.2s}.holographic-prism line:nth-child(5){animation-delay:.4s}.holographic-prism line:nth-child(6){animation-delay:.6s}.holographic-prism line:nth-child(7){animation-delay:.8s}.holographic-prism circle{transition:all .3s ease;animation:hologramPulse 2.5s ease-in-out infinite}@keyframes hologramPulse{0%,to{transform:scale(1);opacity:.8}50%{transform:scale(1.3);opacity:1}}.holographic-prism circle:nth-child(8){animation-delay:.1s}.holographic-prism circle:nth-child(9){animation-delay:.3s}.holographic-prism circle:nth-child(10){animation-delay:.5s}.holographic-prism circle:nth-child(11){animation-delay:.7s}.holographic-prism circle:nth-child(12){animation-delay:.9s}.welcome-icon:hover .holographic-prism{animation-duration:4s}.welcome-icon:hover .holographic-prism polygon{opacity:1!important;transform:scale(1.1)}.welcome-icon:hover .holographic-prism line{stroke-width:4;opacity:1;stroke-dasharray:12 6}.welcome-icon:hover .holographic-prism circle{transform:scale(1.5);opacity:1!important}.neural-network{animation:neuralBreathing 6s ease-in-out infinite}@keyframes neuralBreathing{0%,to{transform:scale(1)}50%{transform:scale(1.01)}}.neural-network circle{transition:all .5s ease}.neural-network circle:nth-child(5){animation:centralPulse 4s ease-in-out infinite}@keyframes centralPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.05)}}.neural-network line:nth-child(13),.neural-network line:nth-child(14),.neural-network line:nth-child(18),.neural-network line:nth-child(19){animation:mainConnectionFlow 5s ease-in-out infinite}@keyframes mainConnectionFlow{0%,to{opacity:.8}50%{opacity:1}}.neural-network line:nth-child(13){animation-delay:0s}.neural-network line:nth-child(14){animation-delay:1s}.neural-network line:nth-child(18){animation-delay:2s}.neural-network line:nth-child(19){animation-delay:3s}.rr-logo-image{box-shadow:0 4px 8px #0000001a;object-fit:contain}.neural-network circle:nth-child(22),.neural-network circle:nth-child(23){animation:gentleRingPulse 8s ease-in-out infinite}@keyframes gentleRingPulse{0%,to{opacity:.4}50%{opacity:.6}}.neural-network circle:nth-child(22){animation-delay:0s}.neural-network circle:nth-child(23){animation-delay:2s}.welcome-icon:hover .neural-network circle{opacity:1!important}.welcome-icon:hover .neural-network line{opacity:1!important}.welcome-title{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);color:var(--color-gray-800);margin-bottom:var(--space-4);line-height:1.2}.welcome-description{font-size:var(--font-size-lg);color:var(--color-gray-600);margin-bottom:var(--space-8);line-height:1.6}.welcome-suggestions{display:flex;flex-wrap:wrap;gap:var(--space-3);justify-content:center}.suggestion-chip{padding:var(--space-3) var(--space-5);background:var(--color-gray-50);border:1px solid var(--color-gray-200);border-radius:var(--radius-xl);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-gray-700);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.suggestion-chip:hover{background:var(--color-accent);color:var(--color-gray-800);border-color:var(--color-accent);transform:translateY(-2px);box-shadow:var(--shadow-md)}.suggestion-chip:active{transform:translateY(-1px)}@media (max-width: 768px){.chat-header{padding:var(--space-3) var(--space-4)}.chat-title{font-size:var(--font-size-lg)}.welcome-content{padding:var(--space-4)}.welcome-title{font-size:var(--font-size-2xl)}.welcome-description{font-size:var(--font-size-base)}.welcome-suggestions{flex-direction:column;align-items:center}.suggestion-chip{width:100%;max-width:280px}}.document-bubbles{display:flex;flex-wrap:wrap;gap:.5rem;padding:.75rem 1.5rem;background:rgba(255,255,255,.8);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-top:1px solid rgba(255,255,255,.2)}.document-bubble{display:flex;align-items:center;gap:.5rem;background:rgba(99,102,241,.1);border:1px solid rgba(99,102,241,.2);border-radius:1.5rem;padding:.5rem .75rem;font-size:.875rem;color:var(--color-text-primary);transition:all .2s ease;max-width:300px}.document-bubble:hover{background:rgba(99,102,241,.15);border-color:#6366f14d}.bubble-file-icon{color:#dc2626;flex-shrink:0}.bubble-document-name{font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0}.bubble-delete-button{display:flex;align-items:center;justify-content:center;width:1.5rem;height:1.5rem;border:none;background:rgba(239,68,68,.1);border-radius:50%;color:#ef4444;cursor:pointer;transition:all .2s ease;flex-shrink:0}.bubble-delete-button:hover{background:rgba(239,68,68,.2);color:#dc2626}.bubble-delete-button:focus-visible{outline:2px solid #ef4444;outline-offset:2px}@media (max-width: 640px){.document-bubbles{padding:.5rem 1rem;gap:.375rem}.document-bubble{max-width:250px;padding:.375rem .5rem;font-size:.8125rem}.bubble-delete-button{width:1.25rem;height:1.25rem}}.sidebar{width:320px;height:100vh;background:var(--color-primary-dark);border-right:1px solid var(--color-gray-700);display:flex;flex-direction:column;flex-shrink:0;position:relative}.sidebar-header{display:flex;align-items:center;justify-content:center;padding:var(--space-4) var(--space-6);border-bottom:1px solid var(--color-gray-700);background:var(--color-primary-dark)}.sidebar-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-primary-light);margin:0}.sidebar-content{flex:1;overflow-y:auto;padding:var(--space-4)}.sidebar-section{margin-bottom:var(--space-6)}.sidebar-section:last-child{margin-bottom:0;flex:1;display:flex;flex-direction:column}.section-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-primary-light);margin:0 0 var(--space-3) 0;text-transform:uppercase;letter-spacing:.05em}.new-chat-button{display:flex;align-items:center;gap:var(--space-3);width:100%;padding:var(--space-3) var(--space-4);border:1px solid var(--color-primary);background:transparent;color:var(--color-primary-light);border-radius:var(--radius-lg);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:all var(--transition-fast);position:relative;z-index:1;-webkit-tap-highlight-color:transparent;touch-action:manipulation;-webkit-user-select:none;user-select:none}.new-chat-button:hover{background:var(--color-primary);color:#fff;transform:translateY(-1px);box-shadow:var(--shadow-md)}.new-chat-button:active{transform:translateY(0)}.upload-area{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-6);border:2px dashed var(--color-gray-300);border-radius:var(--radius-lg);background:var(--color-gray-50);text-align:center;transition:all var(--transition-fast);cursor:pointer}.upload-area:hover,.upload-area-active{border-color:var(--color-primary);background:rgba(37,99,235,.05)}.upload-area svg{color:var(--color-gray-400);margin-bottom:var(--space-3)}.upload-area-active svg{color:var(--color-primary)}.upload-text{font-size:var(--font-size-sm);color:var(--color-gray-600);margin:0 0 var(--space-2) 0}.upload-link{color:var(--color-primary);font-weight:var(--font-weight-medium);cursor:pointer;text-decoration:underline}.upload-link:hover{color:var(--color-primary-dark)}.upload-hint{font-size:var(--font-size-xs);color:var(--color-gray-400);margin:0}.documents-list{max-height:300px;overflow-y:auto}.document-items{display:flex;flex-direction:column;gap:var(--space-2)}.document-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);background:rgba(180,206,179,.1);border:1px solid var(--color-gray-700);border-radius:var(--radius-md);transition:all var(--transition-fast);cursor:pointer}.document-item:hover{background:rgba(180,206,179,.2);border-color:var(--color-primary);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.document-icon{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:var(--color-secondary);color:#fff;border-radius:var(--radius-md);flex-shrink:0}.document-info{flex:1;min-width:0}.document-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-primary-light);margin:0 0 var(--space-1) 0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.document-meta{display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-size-xs);color:var(--color-gray-400)}.document-delete{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border:none;background:transparent;color:var(--color-gray-400);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);flex-shrink:0;opacity:0}.document-item:hover .document-delete{opacity:1}.document-delete:hover{background:var(--color-error);color:#fff}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-8) var(--space-4);text-align:center}.empty-state svg{color:var(--color-gray-400);margin-bottom:var(--space-3)}.empty-state p{font-size:var(--font-size-sm);color:var(--color-gray-400);margin:0}.chat-history{flex:1;overflow-y:auto;scrollbar-width:none;-ms-overflow-style:none}.chat-history::-webkit-scrollbar{display:none}.chat-items{display:flex;flex-direction:column;gap:var(--space-2)}.chat-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);background:rgba(180,206,179,.1);border:1px solid var(--color-gray-700);border-radius:var(--radius-md);transition:all var(--transition-fast);cursor:pointer;-webkit-tap-highlight-color:transparent;touch-action:manipulation;position:relative;z-index:0}.chat-item:hover{background:rgba(180,206,179,.2);border-color:var(--color-primary);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.chat-item.active{background:rgba(180,206,179,.3);border-color:var(--color-primary);box-shadow:var(--shadow-sm)}.chat-icon{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:var(--color-secondary);color:#fff;border-radius:var(--radius-md);flex-shrink:0}.chat-info{flex:1;min-width:0}.chat-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-primary-light);margin:0 0 var(--space-1) 0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-meta{display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-size-xs);color:var(--color-gray-400)}.chat-delete{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border:none;background:transparent;color:#fff;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);flex-shrink:0;opacity:.7}.chat-delete:hover{background:var(--color-error);color:#fff;opacity:1}@media (max-width: 768px){.sidebar{width:280px}.sidebar-content{padding:var(--space-3)}.upload-area{padding:var(--space-4)}}.app{display:flex;height:100vh;height:100dvh;min-height:-webkit-fill-available;background:linear-gradient(135deg,var(--color-gray-50) 0%,var(--color-gray-100) 100%);overflow:hidden}.main-content{flex:1;display:flex;flex-direction:column;position:relative;min-width:0;margin-left:0}.document-sidebar{width:300px;background:rgba(255,255,255,.95);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-left:1px solid rgba(255,255,255,.2);display:flex;flex-direction:column;overflow:hidden;box-shadow:-4px 0 6px -1px #0000001a}.document-sidebar-header{padding:1.5rem;border-bottom:1px solid rgba(0,0,0,.1);background:rgba(255,255,255,.8)}.document-sidebar-header h3{margin:0;font-size:1.125rem;font-weight:600;color:var(--color-text-primary)}.document-sidebar-content{flex:1;padding:1rem;overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(0,0,0,.2) transparent}.document-sidebar-content::-webkit-scrollbar{width:6px}.document-sidebar-content::-webkit-scrollbar-track{background:transparent}.document-sidebar-content::-webkit-scrollbar-thumb{background:rgba(0,0,0,.2);border-radius:3px}.sidebar-document-card{background:rgba(255,255,255,.9);border:1px solid rgba(255,255,255,.3);border-radius:.75rem;padding:1rem;margin-bottom:.75rem;display:flex;align-items:center;justify-content:space-between;gap:.75rem;transition:all .2s ease;box-shadow:0 2px 4px -1px #0000000f}.sidebar-document-card:hover{box-shadow:0 4px 6px -1px #0000001a;border-color:#6366f14d}.sidebar-document-info{display:flex;align-items:center;gap:.75rem;flex:1;min-width:0}.sidebar-document-info .file-icon{color:#dc2626;flex-shrink:0}.sidebar-document-details{flex:1;min-width:0}.sidebar-document-name{font-size:.875rem;font-weight:600;color:var(--color-text-primary);margin:0 0 .25rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-document-size{font-size:.75rem;color:var(--color-text-tertiary);margin:0}.sidebar-delete-button{display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;border:none;background:rgba(239,68,68,.1);border-radius:.375rem;color:#ef4444;cursor:pointer;transition:all .2s ease;flex-shrink:0}.sidebar-delete-button:hover{background:rgba(239,68,68,.2);color:#dc2626}.sidebar-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem 1rem;text-align:center;color:var(--color-text-secondary)}.sidebar-empty-state .empty-icon{color:var(--color-text-tertiary);margin-bottom:1rem;opacity:.6}.sidebar-empty-state p{font-size:.875rem;margin:0}.mobile-menu-toggle{display:none}@media (max-width: 768px){.app{flex-direction:row;position:relative}.mobile-menu-toggle{display:flex;align-items:center;justify-content:center;position:fixed;top:1rem;left:1rem;z-index:101;width:48px;height:48px;border:none;background:var(--color-primary);color:#fff;border-radius:var(--radius-lg);cursor:pointer;box-shadow:var(--shadow-lg);-webkit-tap-highlight-color:transparent;touch-action:manipulation}.mobile-menu-toggle:active{transform:scale(.95)}.sidebar{position:absolute;left:-100%;transition:left .3s ease;z-index:100;height:100vh;box-shadow:2px 0 8px #0000004d}.sidebar.mobile-visible{left:0}.main-content{width:100%;flex:1}}.main-content{transition:margin-left var(--transition-normal)}.app:focus-within{outline:none}.loading-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(255,255,255,.8);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000}.loading-spinner{width:32px;height:32px;border:3px solid var(--color-gray-200);border-top:3px solid var(--color-primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-weight:400;line-height:1.6;color:var(--color-gray-800);background:var(--color-gray-50);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none}button,a,[role=button]{touch-action:manipulation;-webkit-user-select:none;user-select:none}input,textarea{-webkit-user-select:text;user-select:text}html{height:-webkit-fill-available}:root{--color-primary: #165540;--color-primary-light: #b4ceb3;--color-primary-dark: #013220;--color-secondary: #3a668c;--color-secondary-light: #b6ccd7;--color-secondary-dark: #192839;--color-accent: #e6b751;--color-accent-light: #f2d084;--color-accent-dark: #d49e2a;--color-gray-50: #f8faf9;--color-gray-100: #f1f5f3;--color-gray-200: #e2ebe6;--color-gray-300: #c8d6cc;--color-gray-400: #9bb0a1;--color-gray-500: #6d8574;--color-gray-600: #4a5d50;--color-gray-700: #2d3a32;--color-gray-800: #192839;--color-gray-900: #013220;--color-success: #165540;--color-warning: #e6b751;--color-error: #dc2626;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--font-weight-light: 300;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--space-20: 5rem;--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-2xl: 1.5rem;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--shadow-xl: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1);--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-normal: .3s cubic-bezier(.4, 0, .2, 1);--transition-slow: .5s cubic-bezier(.4, 0, .2, 1)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.focus-ring{outline:2px solid transparent;outline-offset:2px}.focus-ring:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--color-gray-100)}::-webkit-scrollbar-thumb{background:var(--color-gray-300);border-radius:var(--radius-sm)}::-webkit-scrollbar-thumb:hover{background:var(--color-gray-400)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.animate-fade-in{animation:fadeIn var(--transition-normal) ease-out}.animate-slide-in{animation:slideIn var(--transition-normal) ease-out}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}
