.spinner-container{display:flex;flex-direction:column;justify-content:center;align-items:center}.spinner-container.full-screen{height:100vh}.spinner{border:2px solid #f3f3f3;border-radius:50%;animation:spin 1s linear infinite}.spinner.extra-small{width:10px;height:10px;border-width:1px}.spinner.small{width:30px;height:30px;border-width:2px}.spinner.medium{width:50px;height:50px;border-width:3px}.spinner.large{width:70px;height:70px;border-width:4px}.spinner-container p{margin-top:10px}.sidebar{width:60px;height:100vh;background-color:#f5f5f5;border-right:1px solid #ddd;display:flex;flex-direction:column;padding:10px;box-sizing:border-box;position:fixed;left:0;top:0;transition:width .3s ease,padding .3s ease;overflow:hidden;z-index:100}.sidebar:hover,.sidebar-expanded{width:280px;padding:20px}@media (min-width: 768px){.sidebar:not(.sidebar-open){width:60px;padding:10px}.sidebar:not(.sidebar-open):hover{width:280px;padding:20px}}.sidebar-toggle{display:none;position:fixed;top:20px;left:20px;z-index:1001;background-color:#345b5e;color:#fff;border:none;border-radius:8px;padding:12px;cursor:pointer;box-shadow:0 2px 8px #0003;transition:background-color .2s}.sidebar-toggle:hover{background-color:#0f3f42}.sidebar-close-btn{display:none;position:absolute;top:10px;right:10px;background:none;border:none;color:#666;cursor:pointer;padding:5px;border-radius:4px;z-index:10}.sidebar-close-btn:hover{background-color:#e0e0e0}.sidebar-overlay{display:none}@media (max-width: 767px){.sidebar-toggle{display:block}.sidebar{position:fixed;top:0;left:0;z-index:1000;transform:translate(-100%);box-shadow:2px 0 10px #0000001a;width:280px!important;padding:20px!important}.sidebar.sidebar-open{transform:translate(0)}.sidebar-close-btn{display:block}.sidebar-overlay{display:block;position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;z-index:999}.sidebar-collapsed,.sidebar-expanded{width:280px!important;padding:20px!important}}.sidebar-logo{display:flex;align-items:center;gap:12px;margin-bottom:25px;padding:15px 10px;border-radius:8px;justify-content:flex-start}.sidebar-logo-icon{width:32px;height:32px;flex-shrink:0;transition:width .3s ease,height .3s ease}.sidebar-logo-icon.expanded{width:48px;height:48px}.sidebar-logo-icon.collapsed{width:32px;height:32px}.sidebar-logo-text{font-size:20px;font-weight:700;color:#345b5e;white-space:nowrap;letter-spacing:-.5px;transition:opacity .3s ease}.sidebar-nav{display:flex;flex-direction:column;gap:8px;margin-bottom:20px}.nav-item{display:flex;align-items:center;gap:12px;padding:12px;border-radius:8px;text-decoration:none;color:#666;background:none;border:none;cursor:pointer;transition:background-color .2s,color .2s;width:100%;text-align:left}.nav-item:hover{background-color:#e8f4f8;color:#345b5e}.nav-item.active{background-color:#345b5e;color:#fff}.nav-item:disabled{opacity:.5;cursor:not-allowed}.nav-icon{width:20px;height:20px;flex-shrink:0}.nav-text{font-size:14px;white-space:nowrap}.new-chat-nav{background-color:#345b5e!important;color:#fff!important}.new-chat-nav:hover:not(:disabled){background-color:#0f3f42!important;color:#fff!important}.new-chat-nav:disabled{background-color:#ccc!important;color:#666!important}.sidebar-bottom{margin-top:auto;padding-top:20px}.profile-info{display:flex;align-items:center;gap:10px;flex:1}.profile-details{flex:1;min-width:0}.limits-inline{margin-top:2px}.limit-text{font-size:11px;color:#666;white-space:nowrap;display:flex;align-items:center;gap:2px}.limit-item-inline{display:flex;align-items:center;gap:px}.limit-icon{font-size:10px;opacity:.8}.limit-separator{color:#999;margin:0 4px}.profile-section{position:relative}.profile-button{display:flex;align-items:center;gap:10px;width:100%;padding:10px;background:none;border:none;border-radius:8px;cursor:pointer;transition:background-color .2s}.profile-button:hover{background-color:#e8f4f8}.profile-avatar{width:32px;height:32px;background-color:#345b5e;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.profile-icon{color:#fff;font-size:16px}.profile-name{font-size:14px;color:#333;flex:1;text-align:left;white-space:nowrap}.profile-dropdown-icon{font-size:12px;color:#666;transition:transform .2s}.profile-dropdown-icon.open{transform:rotate(180deg)}.profile-dropdown{position:absolute;bottom:100%;left:0;right:0;background:#fff;border:1px solid #ddd;border-radius:8px;box-shadow:0 4px 12px #0000001a;margin-bottom:8px;z-index:1000}.profile-dropdown-item{display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px;background:none;border:none;text-align:left;cursor:pointer;transition:background-color .2s;font-size:14px;color:#333}.profile-dropdown-item:hover{background-color:#f5f5f5}.profile-dropdown-item.logout{color:#dc3545}.profile-dropdown-item.logout:hover{background-color:#fdf2f2}.dropdown-icon{font-size:14px}.profile-dropdown-divider{height:1px;background-color:#eee;margin:4px 0}.threads-list{flex:1;overflow-y:auto;min-height:0}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px;padding:0 5px}.section-header h3{margin:0;font-size:16px;color:#333}.new-thread-btn{background-color:#345b5e;color:#fff;border:none;border-radius:6px;padding:6px 12px;font-size:12px;cursor:pointer;transition:background-color .2s}.new-thread-btn:hover:not(:disabled){background-color:#0f3f42}.new-thread-btn:disabled{opacity:.5;cursor:not-allowed}.thread-item{display:flex;padding:12px 16px;margin-bottom:8px;background-color:#fff;color:#333;text-decoration:none;border:1px solid #ddd;border-radius:6px;transition:background-color .2s ease;justify-content:space-between;flex-shrink:0;align-items:center;gap:10px;cursor:pointer;position:relative}.thread-item input[type=text]{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.thread-item:hover{background-color:#f8f9fa}.thread-item.selected-thread{background-color:#345b5e;border:1px solid #345b5e;color:#fff}.thread-item.selected-thread:hover{background-color:#2a4a4d;border-color:#2a4a4d}.thread-item.selected-thread .thread-name{color:#fff;font-weight:600}.thread-item.selected-thread .thread-date{color:#e0e0e0}.thread-item.selected-thread .thread-menu-btn{color:#fff}.thread-item.selected-thread .thread-menu-btn:hover{background-color:#ffffff1a;color:#fff}.thread-menu-btn{background:none;border:none;padding:6px;cursor:pointer;border-radius:4px;color:#666;transition:background-color .2s,color .2s;display:flex;align-items:center;justify-content:center}.thread-menu-btn:hover{background-color:#e9ecef;color:#333}.thread-dropdown{position:absolute;top:100%;right:0;background:#fff;border:1px solid #ddd;border-radius:6px;box-shadow:0 4px 12px #00000026;z-index:1000;min-width:120px;margin-top:4px}.thread-dropdown-item{display:flex;align-items:center;gap:8px;width:100%;padding:8px 12px;background:none;border:none;text-align:left;cursor:pointer;font-size:13px;color:#333;transition:background-color .2s}.thread-dropdown-item:hover{background-color:#f8f9fa}.thread-dropdown-item.delete{color:#dc3545}.thread-dropdown-item.delete:hover{background-color:#fdf2f2}.edit-thread-btn,.delete-thread-btn{padding:6px;border:none;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color .2s;margin-left:4px}.edit-thread-btn{background-color:#28a745;color:#fff}.edit-thread-btn:hover:not(:disabled){background-color:#218838}.delete-thread-btn{background-color:#6c757d;color:#fff}.delete-thread-btn:hover:not(:disabled){background-color:#5a6268}.edit-thread-btn:disabled,.delete-thread-btn:disabled{opacity:.6;cursor:not-allowed}@media (min-width: 768px) and (max-width: 1024px){.sidebar-expanded{width:240px}}@media (min-width: 1025px){.sidebar{width:280px}}.sidebar-section{margin-bottom:15px;flex-shrink:0}.threads-section{flex:1;display:flex;flex-direction:column;min-height:0}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px;flex-shrink:0}.section-header h3{margin:0;font-size:16px;color:#333;font-weight:600}.section-button{display:flex;width:100%;padding:12px 16px;background-color:#345b5e;color:#fff;text-decoration:none;border-radius:6px;text-align:center;font-size:14px;transition:background-color .2s;justify-content:center;gap:8px}.section-button:hover{background-color:#0f3f42}.new-thread-btn{padding:6px 12px;background-color:#345b5e;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:12px;transition:background-color .2s}.new-thread-btn:hover{background-color:#0f3f42}.new-thread-btn:disabled{opacity:.7;cursor:not-allowed}.threads-list{flex:1;overflow-y:auto;min-height:0;padding-right:5px}.threads-list.hidden,.section-header.hidden{display:none}.threads-list.visible,.section-header.visible{display:block}.section-header.visible{display:flex}.no-threads{text-align:center;color:#666;padding:40px 0}.no-threads p{margin:0 0 5px;font-size:14px}.no-threads span{font-size:12px;color:#999}.thread-info{display:flex;flex-direction:column;gap:4px;flex:1;min-width:0}.thread-info input{background:#fff;border:1px solid #ddd;border-radius:4px;padding:4px 8px;font-size:14px;width:100%}.thread-name{font-weight:700;color:#1a202c;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.thread-name.truncated-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;display:inline-block;vertical-align:middle}.thread-item .thread-info{flex-grow:1;min-width:0;display:flex;flex-direction:column;align-items:flex-start}.thread-date{font-size:.75rem;color:#718096}.delete-thread-btn{padding:4px 8px;color:#eb2126;background:none;border:none;border-radius:4px;cursor:pointer;font-size:12px;transition:background-color .2s;display:flex;align-items:center;justify-content:center}.delete-thread-btn:hover{background-color:#eb21261a}.edit-thread-btn{padding:4px 8px;color:#286eb3;background:none;border:none;border-radius:4px;cursor:pointer;font-size:12px;transition:background-color .2s;display:flex;align-items:center;justify-content:center}.edit-thread-btn:hover{background-color:#286eb31a}.edit-thread-btn:disabled,.delete-thread-btn:disabled{opacity:.5;cursor:not-allowed}.threads-list::-webkit-scrollbar{width:6px}.threads-list::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.threads-list::-webkit-scrollbar-thumb{background:#ccc;border-radius:3px}.threads-list::-webkit-scrollbar-thumb:hover{background:#999}.threads-list{scrollbar-width:thin;scrollbar-color:#ccc #f1f1f1}@media (prefers-reduced-motion: no-preference){.sidebar,.sidebar-toggle,.section-button,.new-thread-btn,.thread-item,.edit-thread-btn,.delete-thread-btn{transition:all .2s ease}}.thread-menu{position:relative}.thread-dropdown{position:absolute;top:30px;right:0;background:#fff;border:1px solid #ddd;border-radius:6px;box-shadow:0 4px 12px #00000026;z-index:100;min-width:120px;overflow:hidden}.thread-dropdown-item{display:flex;align-items:center;gap:8px;width:100%;padding:8px 12px;background:none;border:none;text-align:left;cursor:pointer;font-size:14px;color:#333;transition:background-color .2s}.thread-dropdown-item:hover{background-color:#e0f7ff}.thread-dropdown-item.delete{color:#eb2126}.thread-dropdown-item.delete:hover{background-color:#eb21261a}.thread-dropdown-item span{font-size:13px}.thread-actions{display:flex;align-items:flex-start;gap:4px;flex-shrink:0;position:relative}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#0006;display:flex;justify-content:center;align-items:center;z-index:9999}.modal-content{background:#fff;padding:2rem;border-radius:12px;width:90%;max-width:400px;box-shadow:0 5px 15px #0003;text-align:center;animation:fadeIn .3s ease}.modal-content h3{margin-bottom:1rem;color:#d9534f}.modal-buttons{display:flex;justify-content:center;margin-top:1.5rem;gap:1rem}.confirm-btn,.cancel-btn{padding:.6rem 1.2rem;border:none;border-radius:6px;cursor:pointer}.confirm-btn{background-color:#b22729;color:#fff}.cancel-btn{background-color:#286eb3;color:#fff}@keyframes fadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.profile-name{font-weight:500;color:#2d3748;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:150px;display:inline-block;font-size:14px}.new-chat-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.new-chat-modal-content{background-color:#fff;padding:30px;border-radius:10px;box-shadow:0 5px 15px #0000004d;width:90%;max-width:500px;position:relative;text-align:center;color:#333}.new-chat-close-btn{position:absolute;top:15px;right:15px;background:none;border:none;font-size:24px;cursor:pointer;color:#888;transition:color .2s}.new-chat-close-btn:hover{color:#333}.new-chat-modal-content h2{margin-top:0;margin-bottom:10px;font-size:1.8em;color:#0f3f42}.new-chat-modal-content p{margin-bottom:25px;font-size:1em;color:#555}.new-chat-upload-area{margin-bottom:20px}.new-chat-dropzone{border:2px dashed #ccc;border-radius:8px;padding:30px;cursor:pointer;transition:border-color .3s ease;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:150px}.new-chat-dropzone.error{border-color:#e74c3c}.new-chat-dropzone.has-file{border-style:solid;border-color:#28a745}.new-chat-dropzone:hover{border-color:#286eb3}.new-chat-file-info{display:flex;align-items:center;gap:10px;font-size:1.1em;color:#333}.new-chat-file-icon{font-size:2em}.new-chat-clear-btn{background:none;border:none;font-size:1.2em;color:#e74c3c;cursor:pointer;margin-left:10px}.new-chat-upload-prompt{display:flex;flex-direction:column;align-items:center}.new-chat-upload-icon{font-size:3em;color:#286eb3;margin-bottom:10px}.new-chat-upload-text{font-size:1.1em;color:#555}.new-chat-upload-label{color:#286eb3;cursor:pointer;font-weight:700}.new-chat-upload-label:hover{text-decoration:underline}.new-chat-upload-hint{font-size:.85em;color:#888;margin-top:5px}.new-chat-url-input-area{margin-top:15px}.new-chat-url-input{width:calc(100% - 20px);padding:12px;border:1px solid #ddd;border-radius:5px;font-size:1em;outline:none;transition:border-color .2s}.new-chat-url-input:focus{border-color:#286eb3}.new-chat-url-input.input-error{border-color:#e74c3c}.new-chat-error-message{color:#e74c3c;font-size:.9em;margin-top:10px}.new-chat-action-buttons{margin-top:25px}.new-chat-submit-btn{background-color:#345b5e;color:#fff;padding:12px 25px;border:none;border-radius:5px;font-size:1.1em;cursor:pointer;transition:background-color .3s ease;display:inline-flex;align-items:center;justify-content:center;gap:8px}.new-chat-submit-btn:hover:not(:disabled){background-color:#0f3f42}.new-chat-submit-btn:disabled{background-color:#ccc;cursor:not-allowed}.new-chat-file-info{display:flex;align-items:center;justify-content:center;gap:10px;padding:15px;background-color:#f8f9fa;border-radius:8px;border:2px solid #286EB3}.new-chat-file-icon{font-size:1.5em;color:#286eb3}.new-chat-file-name{font-weight:500;color:#333;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:250px;flex:1;text-align:left}.new-chat-clear-btn{background:none;border:none;font-size:1.2em;color:#e74c3c;cursor:pointer;padding:2px 6px;border-radius:50%;transition:background-color .2s}.new-chat-clear-btn:hover{background-color:#f8d7da}.new-chat-multiple-files{text-align:left;width:100%}.new-chat-files-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px;padding-bottom:10px;border-bottom:1px solid #e0e0e0}.new-chat-files-count{font-weight:600;color:#286eb3;font-size:.9em}.new-chat-clear-all-btn{background:#e74c3c;color:#fff;border:none;border-radius:4px;padding:4px 8px;font-size:.8em;cursor:pointer;transition:background-color .2s}.new-chat-clear-all-btn:hover{background-color:#c0392b}.new-chat-files-list{max-height:200px;overflow-y:auto;padding-right:5px}.new-chat-file-item{margin-bottom:10px;border:1px solid #e0e0e0;border-radius:6px;overflow:hidden}.new-chat-file-info{display:flex;align-items:center;padding:8px 12px;background-color:#f8f9fa;gap:10px}.new-chat-file-details{flex:1;min-width:0}.new-chat-file-name{display:block;font-weight:500;color:#333;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:.9em}.new-chat-file-size{display:block;font-size:.75em;color:#666;margin-top:2px}.new-chat-file-status{margin-top:6px}.new-chat-status-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.new-chat-status-text{font-size:.75em;font-weight:500}.new-chat-progress-percentage{font-size:.7em;font-weight:600}.new-chat-progress-bar{width:100%;height:3px;background-color:#e0e0e0;border-radius:1.5px;overflow:hidden}.new-chat-progress-fill{height:100%;transition:width .3s ease;border-radius:1.5px}.new-chat-remove-btn{background:none;border:none;font-size:1.1em;color:#e74c3c;cursor:pointer;padding:4px;border-radius:50%;transition:background-color .2s;flex-shrink:0}.new-chat-remove-btn:hover:not(:disabled){background-color:#f8d7da}.new-chat-remove-btn:disabled{color:#ccc;cursor:not-allowed}.new-chat-submit-btn .spinner{border-color:#ffffff transparent #ffffff transparent}.new-chat-modal-content{max-width:600px;max-height:80vh;overflow-y:auto}.app-header{position:fixed;top:0;left:0;right:0;background-color:#fff;border-bottom:1px solid #e5e7eb;box-shadow:0 1px 3px #0000001a;z-index:50;height:64px}.app-header-container{display:flex;align-items:center;justify-content:space-between;height:100%;padding:0 24px;position:relative}.app-header-left-spacer{flex:1}.app-header-center-section{display:flex;align-items:center;gap:16px;position:absolute;left:50%;transform:translate(-50%)}.app-header-title-section{display:flex;flex-direction:column;align-items:center}.app-header-logo-icon{height:120px;width:120px}.app-header-app-name{font-size:24px;font-weight:800;color:#b22729;margin:0;letter-spacing:-.5px;text-align:center}.app-header-app-subname{font-size:14px;font-weight:600;color:#39393a;margin:0}.app-header-profile-section{position:relative}.app-header-profile-button{display:flex;align-items:center;gap:8px;padding:8px 12px;background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;cursor:pointer;transition:all .2s ease;font-family:inherit}.app-header-profile-button:hover{background-color:#f3f4f6;border-color:#d1d5db;box-shadow:0 1px 2px #0000000d}.app-header-profile-avatar{width:32px;height:32px;background:linear-gradient(135deg,#d1d5db,#9ca3af);border-radius:50%;display:flex;align-items:center;justify-content:center}.app-header-profile-name{color:#374151;font-weight:500;font-size:14px}.app-header-dropdown-icon{color:#6b7280;font-size:12px;transition:transform .2s ease}.app-header-dropdown-icon.open{transform:rotate(180deg)}.app-header-dropdown-menu{position:absolute;right:0;top:calc(100% + 8px);width:192px;background-color:#fff;border-radius:8px;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;border:1px solid #e5e7eb;padding:4px 0;z-index:60;animation:appHeaderDropdownFadeIn .15s ease-out}.app-header-right-section{display:flex;align-items:center;gap:1rem}.header-right-controls{display:flex;align-items:center;gap:1rem;flex-shrink:0}.user-limits-display{display:flex;align-items:center;gap:1rem;background:linear-gradient(135deg,#f3f4f6,#e5e7eb);padding:.5rem 1rem;border-radius:20px;border:1px solid #d1d5db;box-shadow:0 2px 4px #0000000d}.user-limits-display span{font-size:.875rem;font-weight:600;color:#374151;padding:.25rem .75rem;background:#ffffffb3;border-radius:12px;border:1px solid rgba(209,213,219,.5);transition:all .2s ease}.user-limits-display span:hover{background:#ffffffe6;transform:translateY(-1px)}@keyframes appHeaderDropdownFadeIn{0%{opacity:0;transform:scale(.95) translateY(-4px)}to{opacity:1;transform:scale(1) translateY(0)}}.app-header-dropdown-item{display:flex;align-items:center;gap:12px;width:100%;padding:12px 16px;background:none;border:none;text-align:left;cursor:pointer;transition:background-color .15s ease;font-family:inherit;font-size:14px;font-weight:500}.app-header-dropdown-item:hover{background-color:#f9fafb}.app-header-dropdown-item.logout{color:#dc2626}.app-header-dropdown-item.logout:hover{background-color:#fef2f2}.app-header-dropdown-item-icon{color:#6b7280;font-size:16px}.app-header-dropdown-item.logout .app-header-dropdown-item-icon{color:#ef4444}.app-header-dropdown-divider{height:1px;background-color:#e5e7eb;margin:4px 8px}.app-header-dropdown-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;z-index:40}.app-main-content-with-header{padding-top:64px}@media (max-width: 768px){.app-header-container{padding:0 16px}.app-header-center-section{position:static;transform:none;left:auto;flex:1;justify-content:center;max-width:calc(100% - 200px)}.app-header-left-spacer{display:none}.app-header-logo-icon{height:60px;width:60px}.app-header-app-name{font-size:18px;font-weight:700}.app-header-right-section{flex-shrink:0;min-width:180px}.user-limits-display{gap:.5rem;padding:.25rem .75rem}.user-limits-display span{font-size:.75rem;padding:.125rem .5rem}.app-header-profile-name{max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}}@media (max-width: 480px){.app-header-container{padding:0 12px}.app-header-center-section{max-width:calc(100% - 160px)}.app-header-logo-icon{height:50px;width:50px}.app-header-app-name{font-size:16px}.user-limits-display{flex-direction:column;gap:.25rem;padding:.25rem .5rem}.user-limits-display span{font-size:.7rem;padding:.125rem .375rem}.app-header-profile-name{max-width:80px}.app-header-right-section{min-width:140px}}:root{--primary-color: #286EB3;--primary-dark: #2563eb;--primary-light: #93c5fd;--error-color: #ef4444;--error-light: #fee2e2;--success-color: #286EB3;--success-text-color: #FFFFFF;--warning-color: #f59e0b;--warning-light: #fef3c7;--text-dark: #1f2937;--text-light: #6b7280;--background-light: #f9fafb;--border-color: #e5e7eb;--card-shadow: 0 1px 3px rgba(0, 0, 0, .1), 0 1px 2px rgba(0, 0, 0, .06);--brand-red: #B22729;--brand-gray: #39393A}*{box-sizing:border-box;margin:0;padding:0}.container{max-width:1000px;width:100%;padding:2rem 1rem;margin:0 auto}.header{text-align:center;margin-bottom:2rem}.header h2{font-size:1.5rem;margin-bottom:.5rem}.header p{color:var(--text-light);font-size:1.1rem}.card{background:#fff;border-radius:8px;box-shadow:var(--card-shadow);overflow:hidden}.upload-section{padding:1.5rem;border-bottom:1px solid var(--border-color)}.upload-section h2{margin-bottom:1rem;font-size:1.25rem}.dropzone{border:2px dashed var(--border-color);border-radius:8px;padding:2rem;text-align:center;background-color:var(--background-light);transition:all .2s ease;cursor:pointer}.dropzone:hover{background-color:#f0f4f8}.dropzone.error{border-color:var(--error-color);background-color:var(--error-light)}.dropzone.has-file{border-color:var(--success-color);background-color:#f3f3f3}.upload-prompt{display:flex;flex-direction:column;align-items:center;gap:.5rem}.upload-icon{font-size:2.5rem;margin-bottom:.5rem;color:var(--text-light)}.upload-text{margin:.5rem 0}.upload-label{color:var(--primary-color);font-weight:500;cursor:pointer}.upload-label:hover{color:var(--primary-dark);text-decoration:underline}.upload-hint{font-size:.75rem;color:var(--text-light);margin-top:.5rem}.hidden-input{display:none}.file-info{display:flex;align-items:center;justify-content:center;gap:.5rem}.file-icon{font-size:1.25rem}.file-name{font-weight:500}.clear-btn{background:none;border:none;color:var(--text-light);cursor:pointer;font-size:1rem;padding:.25rem;border-radius:50%}.clear-btn:hover{background-color:#e5e7eb;color:var(--error-color)}.error-message{margin-top:.75rem;color:var(--error-color);font-size:.875rem;display:flex;align-items:center;gap:.25rem}.action-buttons{display:flex;justify-content:flex-end;margin-top:1.5rem}.submit-btn{background-color:#345b5e;color:#fff;border:none;padding:.5rem 1rem;border-radius:.375rem;font-weight:500;cursor:pointer;transition:background-color .2s ease}.submit-btn:hover:not(.disabled){background-color:#0f3f42}.submit-btn.disabled{background-color:#0f3f42;cursor:not-allowed}.url-input-area{display:flex;flex-direction:row;gap:10px;align-items:center;width:100%;margin-bottom:10px;margin-top:10px}.url-input{flex-grow:1;padding:10px 15px;border:1px solid #ced4da;border-radius:6px;font-size:1em;outline:none;transition:border-color .2s ease,box-shadow .2s ease;min-width:0}.url-input:focus{border-color:#007bff;box-shadow:0 0 0 .2rem #007bff40}.url-input.input-error{border-color:#dc3545}.url-input:disabled{background-color:#e9ecef;cursor:not-allowed}.loader-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;text-align:center}.loader{border:3px solid #f3f3f3;border-top:3px solid var(--primary-color);border-radius:50%;width:2rem;height:2rem;animation:spin 1s linear infinite;margin-bottom:1rem}.multiple-files{display:flex;flex-direction:column;gap:.75rem}.files-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:.5rem;border-bottom:1px solid var(--border-color)}.files-count{font-weight:500;color:var(--text-dark)}.clear-all-btn{background:none;border:1px solid var(--error-color);color:var(--error-color);padding:.25rem .75rem;border-radius:4px;font-size:.875rem;cursor:pointer;transition:all .2s ease}.clear-all-btn:hover{background-color:var(--error-color);color:#fff}.files-list{display:flex;flex-direction:column;gap:.5rem}.file-item{background:#fff;border:1px solid var(--border-color);border-radius:6px;padding:.75rem}.file-info{display:flex;align-items:flex-start;gap:.75rem;margin-bottom:.5rem}.file-details{flex:1;display:flex;flex-direction:column;gap:.25rem}.file-name{font-weight:500;color:var(--text-dark)}.file-status{display:flex;flex-direction:column;gap:.5rem;margin-top:.5rem}.status-text{font-size:.875rem;font-weight:500}.status-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.25rem}.progress-percentage{font-size:.75rem;font-weight:600;min-width:35px;text-align:right}.file-size{font-size:.8rem;color:var(--text-light)}.remove-btn{background:none;border:none;color:var(--text-light);cursor:pointer;font-size:1rem;padding:.25rem;border-radius:3px;transition:all .2s ease}.remove-btn:hover{background-color:var(--error-light);color:var(--error-color)}.progress-container{display:flex;flex-direction:column;gap:.25rem}.progress-bar{width:100%;height:8px;background-color:#e5e7eb;border-radius:4px;overflow:hidden;position:relative;box-shadow:inset 0 1px 2px #0000001a}.progress-fill{height:100%;border-radius:4px;transition:width .5s cubic-bezier(.4,0,.2,1);position:relative}.progress-text{font-size:.75rem;color:var(--text-light);text-align:right;font-weight:500}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes pulse{0%,to{opacity:1;transform:scaleY(1)}50%{opacity:.85;transform:scaleY(1.05)}}@keyframes glow{0%{box-shadow:0 0 #10b98100}50%{box-shadow:0 0 10px #10b981cc}to{box-shadow:0 0 #10b98100}}@keyframes rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.rotating-icon{display:inline-block;animation:rotate 2s linear infinite}.status-text{transition:color .3s ease;font-weight:500}.progress-percentage{font-weight:600;transition:color .3s ease}.google-url-item{background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border-left:3px solid #0284c7}.google-badge{display:inline-block;margin-left:.5rem;padding:.125rem .5rem;background:linear-gradient(135deg,#0ea5e9,#0284c7);color:#fff;font-size:.7rem;font-weight:600;border-radius:12px;text-transform:uppercase;letter-spacing:.5px;box-shadow:0 2px 4px #0284c74d}.file-item{transition:all .3s ease;border-radius:8px;padding:.75rem;margin-bottom:.5rem}.tab-navigation{display:flex;border-bottom:1px solid var(--border-color);background:#fff}.tab-btn{background:none;border:none;padding:1rem 1.5rem;color:var(--text-light);font-weight:500;cursor:pointer;border-bottom:2px solid transparent;transition:all .2s ease}.tab-btn:hover{color:var(--text-dark);background-color:var(--background-light)}.tab-btn.active{color:var(--primary-color);border-bottom-color:var(--primary-color);background-color:#fff}.results-section{padding:1.5rem}.results-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.results-header h2{margin:0;font-size:1.5rem}.results-actions{display:flex;gap:.75rem;flex-wrap:wrap}.view-toggle-btn{background:none;border:1px solid var(--border-color);padding:.5rem 1rem;border-radius:6px;color:var(--text-dark);cursor:pointer;font-size:.875rem;transition:all .2s ease}.view-toggle-btn:hover{border-color:var(--primary-color);color:var(--primary-color)}.chat-btn{background-color:var(--primary-color);color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-size:.875rem;font-weight:500;transition:background-color .2s ease}.chat-btn:hover:not(:disabled){background-color:var(--primary-dark)}.chat-btn.primary{background-color:var(--success-color)}.chat-btn:disabled{background-color:var(--text-light);cursor:not-allowed}.combined-view{background:var(--background-light);border-radius:8px;padding:1.5rem}.combined-view h3{margin-bottom:1rem;color:var(--text-dark)}.combined-summary{display:flex;flex-direction:column;gap:1.5rem}.combined-section{background:#fff;padding:1.25rem;border-radius:6px;box-shadow:var(--card-shadow)}.combined-section h4{margin-bottom:1rem;color:var(--text-dark);border-bottom:1px solid var(--border-color);padding-bottom:.5rem}.file-summary,.file-insights{margin-bottom:1rem;padding:.75rem;background:var(--background-light);border-radius:4px}.file-summary h5,.file-insights h6{margin-bottom:.5rem;color:var(--primary-color);font-size:.9rem}.file-summary p{color:var(--text-dark);line-height:1.5}.tabbed-results{display:flex;flex-direction:column;gap:1rem}.file-tabs{display:flex;flex-wrap:wrap;gap:.5rem;border-bottom:1px solid var(--border-color);padding-bottom:.5rem}.file-tab{background:none;border:1px solid var(--border-color);padding:.5rem 1rem;border-radius:4px;color:var(--text-dark);cursor:pointer;font-size:.875rem;transition:all .2s ease;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.file-tab:hover{border-color:var(--primary-color);color:var(--primary-color)}.file-tab.active{background-color:var(--primary-color);border-color:var(--primary-color);color:#fff}.tab-content{background:#fff;border-radius:8px;padding:1.5rem;box-shadow:var(--card-shadow)}.file-result h3{margin-bottom:1rem;color:var(--text-dark)}.file-details{display:flex;gap:1rem;margin-bottom:1.5rem;padding:.75rem;background:var(--background-light);border-radius:6px;flex-wrap:wrap}.file-details p{margin:0;font-size:.875rem;color:var(--text-light)}.file-analysis{display:flex;flex-direction:column;gap:1.25rem}.analysis-section{padding:1rem;border:1px solid var(--border-color);border-radius:6px}.analysis-section h4{margin-bottom:.75rem;color:var(--text-dark);font-size:1.1rem}.analysis-section p{color:var(--text-dark);line-height:1.6;margin-bottom:.5rem}.file-actions{margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--border-color);text-align:right}@media (max-width: 768px){.container{padding:1rem .5rem}.results-header{flex-direction:column;align-items:stretch}.results-actions,.file-tabs{justify-content:center}.file-tab{max-width:150px}.file-details{flex-direction:column;gap:.5rem}.combined-summary{gap:1rem}.dropzone{padding:1rem}.upload-icon{font-size:2rem}}.chat-container{display:flex;flex-direction:column;min-height:100vh;max-width:100%;background-color:#f8fafc}.chat-header{background:#fff;border-bottom:1px solid #e2e8f0;padding:1rem 1.5rem;box-shadow:0 1px 3px #0000001a;flex-shrink:0}.header-content{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.header-info{display:flex;align-items:center;gap:.75rem;flex:1}.header-icon{color:#3b82f6}.header-content h2{margin:0;font-size:1.25rem;font-weight:600;color:#1f2937}.header-buttons{display:flex;align-items:center;gap:.75rem}.file-tabs-container{background:#fff;border-bottom:1px solid #e2e8f0;padding:0 1.5rem;overflow-x:auto}.file-tabs{display:flex;gap:.25rem;min-height:48px;align-items:flex-end}.file-tab{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:transparent;border:none;border-radius:8px 8px 0 0;color:#64748b;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap;min-width:fit-content;position:relative}.file-tab:hover{background:#f1f5f9;color:#334155}.file-tab.active{background:#f8fafc;color:#3b82f6;border-bottom:2px solid #3b82f6}.file-tab.combined-tab.active{color:#f59e0b;border-bottom-color:#f59e0b}.tab-name{max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media (max-width: 768px){.file-tabs-container{padding:0 1rem}.tab-name{max-width:100px}.file-tab{padding:.5rem .75rem;font-size:.8rem}}.markdown-content{line-height:1.6;color:#374151}.markdown-paragraph{margin:.5em 0}.markdown-list{margin:.5em 0;padding-left:1.5em}.markdown-list-item{margin:.25em 0}.markdown-code{background-color:#f3f4f6;padding:.125em .25em;border-radius:.25rem;font-family:Courier New,monospace;font-size:.9em}.markdown-pre{background-color:#f8f9fa;border:1px solid #e9ecef;border-radius:.375rem;padding:1rem;overflow-x:auto;margin:1em 0}.markdown-pre code{background:none;padding:0;border-radius:0}.message-text .markdown-content{max-width:none}.message-text ul,.message-text ol{margin:.5em 0;padding-left:1.5em}.message-text li{margin:.25em 0}.message-text p:first-child{margin-top:0}.message-text p:last-child{margin-bottom:0}.toggle-summary-btn{display:flex;align-items:center;gap:.5rem;background:#f3f4f6;border:1px solid #d1d5db;border-radius:.5rem;padding:.5rem .75rem;cursor:pointer;transition:all .2s ease;font-size:.875rem;font-weight:500;color:#374151}.toggle-summary-btn:hover{background:#e5e7eb;border-color:#9ca3af}.toggle-validation-btn{display:flex;align-items:center;gap:.5rem;background:#fef3c7;border:1px solid #f59e0b;border-radius:.5rem;padding:.5rem .75rem;cursor:pointer;transition:all .2s ease;font-size:.875rem;font-weight:500;color:#92400e}.toggle-validation-btn:hover{background:#fde68a;border-color:#d97706}.analysis-container{display:flex;flex-direction:column;background-color:#fff;flex-grow:1}.analysis-loading{padding:2rem;text-align:center;background:#f8fafc}.summary-insights-row{display:flex;flex-direction:row;padding:20px 30px;gap:30px;background-color:#fff;flex-grow:1;flex-wrap:wrap;justify-content:space-between}.summary-column,.insights-column{flex:1;display:flex;flex-direction:column;min-width:300px}.summary-insights-row .analysis-card{height:100%;display:flex;flex-direction:column}.summary-insights-row .card-content{flex:1;display:flex;flex-direction:column}.validation-container{background:#fff;border-bottom:1px solid #e2e8f0;flex-shrink:0}.validation-row{padding:20px 30px;border-bottom:1px solid #e2e8f0}.analysis-card,.validation-card{background:#fff;border:none;border-radius:0}.card-header{display:flex;justify-content:space-between;align-items:center;padding:10px;cursor:pointer;background:transparent;border:none;margin-bottom:12px}.card-title{display:flex;align-items:center;gap:.5rem}.card-title h3{font-size:1.3em;color:#343a40;margin:0;border-bottom:2px solid #007bff;padding-bottom:6px;display:inline-block;font-weight:600}.validation-card .card-title h3{color:#92400e}.card-icon{color:#6366f1;flex-shrink:0}.expand-toggle{background:none;border:none;cursor:pointer;padding:.25rem;border-radius:.375rem;color:#6b7280;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.expand-toggle:hover{background:#e5e7eb;color:#374151}.card-content{background-color:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;font-size:1em;line-height:1.6;color:#495057;flex:1 1 auto;box-shadow:0 2px 8px #00000014;transition:max-height .3s ease-out,padding .3s ease-out;overflow:hidden;padding:15px}.card-content.collapsed{max-height:200px;padding:20px;overflow-y:auto}.card-content.expanded{max-height:none;padding:20px;overflow-y:auto}.card-content ul{list-style-type:disc;padding-left:20px;margin:0}.card-content ul li{margin-bottom:10px}.validation-issue{background:transparent}.issue-summary-content{margin-bottom:1rem}.details-toggle-btn{background:#7bbaf8;color:#fff;border:none;padding:.5rem 1rem;border-radius:.375rem;cursor:pointer;font-size:.875rem;font-weight:500;margin-bottom:1rem;transition:background-color .2s ease}.details-toggle-btn:hover{background:#59acff}.issue-details{padding:2rem;border-top:1px solid #e2e8f0;border-radius:.5rem;background:#fafbfc;margin-top:.5rem}.messages-container{flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:1rem;background:#f8fafc;min-height:50vh;box-sizing:border-box}.messages-loading{display:flex;justify-content:center;align-items:center;height:200px}.no-messages{display:flex;flex-direction:column;align-items:center;justify-content:center;height:200px;color:#6b7280;text-align:center}.no-messages-icon{margin-bottom:1rem;color:#9ca3af}.no-messages p{margin:0;font-style:italic}.no-thread{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:#6b7280;text-align:center}.no-thread-icon{margin-bottom:1rem;color:#9ca3af}.message{display:flex;gap:12px;max-width:80%;align-items:flex-start}.user-message{align-self:flex-end;flex-direction:row-reverse}.ai-message{align-self:flex-start}.message-icon{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:4px}.user-message .message-icon{background-color:#286eb3;color:#fff}.ai-message .message-icon{background-color:#e9ecef;color:#495057}.message-content{background-color:#fff;padding:12px 16px;border-radius:12px;box-shadow:0 1px 3px #0000001a;min-width:0;flex:1;word-wrap:break-word;overflow-wrap:break-word}.user-message .message-content{background-color:#286eb3;color:#fff}.message-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px;font-size:11px;gap:10px}.user-message .message-header{color:#fffc}.ai-message .message-header{color:#6c757d}.sender{font-weight:600;font-size:12px}.timestamp{opacity:.8}.message-text{line-height:1.5;font-size:14px;word-wrap:break-word;overflow-wrap:break-word}.message-text h1,.message-text h2,.message-text h3{margin:12px 0 8px;font-weight:600}.message-text h1{font-size:18px}.message-text h2{font-size:16px}.message-text h3{font-size:14px}.message-text ul,.message-text ol{margin:8px 0;padding-left:20px}.message-text li{margin:4px 0;line-height:1.4}.message-text strong{font-weight:600}.user-message .message-text h1,.user-message .message-text h2,.user-message .message-text h3,.user-message .message-text strong{color:#fff}.typing-indicator-container{display:flex;align-items:center;gap:3px}.typing-message{opacity:.8}.typing-indicator{padding:8px 0}.typing-dots{display:flex;gap:4px;align-items:center}.typing-dots span{width:6px;height:6px;border-radius:50%;background-color:#6c757d;animation:typing 1.4s infinite ease-in-out}.typing-dots span:nth-child(1){animation-delay:-.32s}.typing-dots span:nth-child(2){animation-delay:-.16s}@keyframes typing{0%,80%,to{transform:scale(.8);opacity:.5}40%{transform:scale(1);opacity:1}}.message-form{background-color:#fff;padding:20px;border-top:1px solid #e9ecef;box-shadow:0 -2px 8px #0000001a;flex-shrink:0;display:flex;flex-direction:column;align-items:center;width:100%}.input-container{display:flex;gap:12px;max-width:1000px;margin:0 auto;align-items:center;width:100%}.message-input{flex:1;padding:12px 16px;border:1px solid #ced4da;border-radius:24px;font-size:14px;outline:none;transition:border-color .2s}.message-input:focus{border-color:#286eb3;box-shadow:0 0 0 2px #007bff40}.message-input:disabled{background-color:#f8f9fa;cursor:not-allowed}.send-button{width:44px;height:44px;background-color:#286eb3;color:#fff;border:none;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color .2s;flex-shrink:0}.send-button:hover:not(:disabled){background-color:#0056b3}.send-button:disabled{background-color:#6c757d;cursor:not-allowed}.llm-warning{text-align:center;margin-top:8px;font-size:11px;color:#666}.messages-container::-webkit-scrollbar{width:6px}.messages-container::-webkit-scrollbar-track{background:#f1f1f1}.messages-container::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.messages-container::-webkit-scrollbar-thumb:hover{background:#a1a1a1}.header-buttons{display:flex;gap:10px;align-items:center}.analysis-container{padding:20px 30px;background:#fff;border-bottom:1px solid #e9ecef}.summary-insights-row{display:flex;gap:30px;padding:0;flex-wrap:wrap}.summary-column,.insights-column{flex:1;min-width:300px}.analysis-card{background:#fff;border-radius:8px;overflow:hidden}.card-header{cursor:pointer;-webkit-user-select:none;user-select:none;padding:0;background:transparent;border:none;display:flex;justify-content:space-between;align-items:center;width:100%}.card-title h3{font-size:1.3em;color:#343a40;margin:0 0 10px;padding:0 0 8px;border-bottom:2px solid #007bff}.expand-toggle{background:none;border:none;cursor:pointer;color:#007bff;padding:5px;border-radius:4px;transition:background-color .2s}.expand-toggle:hover{background-color:#f8f9fa}.card-content{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;padding:20px;box-shadow:0 2px 8px #00000014;transition:max-height .3s ease;overflow:hidden}.card-content.collapsed{max-height:200px;padding:15px 20px}.card-content.expanded{max-height:none}.card ul{list-style-type:disc;padding-left:20px;margin:0}.card ul li{margin-bottom:10px;line-height:1.5}.validation-container{background:#fff;border-bottom:1px solid #e9ecef}.validation-row{padding:20px 30px}.validation-card{background:#fff}.validation-card .card-content{background:#f8f9fa}.markdown-content{line-height:1.6;color:#333;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.markdown-content h1{font-size:1.8em;font-weight:700;color:#2c3e50;margin:1.5rem 0 1rem;padding-bottom:.5rem;border-bottom:2px solid #3498db}.markdown-content h2{font-size:1.5em;font-weight:600;color:#34495e;margin:1.25rem 0 .75rem;padding-bottom:.3rem;border-bottom:1px solid #bdc3c7}.markdown-content h3{font-size:1.3em;font-weight:600;color:#2c3e50;margin:1rem 0 .5rem}.markdown-content h4{font-size:1.1em;font-weight:600;color:#34495e;margin:.75rem 0 .5rem}.markdown-content p{margin:0 0 .75rem;line-height:1.6;color:#2c3e50}.markdown-content ul{list-style:none;padding-left:0;margin:.75rem 0}.markdown-content ul li{position:relative;padding-left:1.5rem;margin:.75rem 0;line-height:1.6}.markdown-content ul li:last-child{border-bottom:none;padding-bottom:0}.markdown-content ul li:not(:has(h1)):not(:has(h2)):not(:has(h3)):not(:has(h4)):not(:has(h5)):not(:has(h6)):before{content:"•";position:absolute;left:0;top:0;color:#2c3e50;font-weight:700;font-size:1.2em}.markdown-content ul li h1,.markdown-content ul li h2,.markdown-content ul li h3,.markdown-content ul li h4,.markdown-content ul li h5,.markdown-content ul li h6{padding-left:0;margin-left:-1.5rem}.markdown-content ol{padding-left:1.5rem;margin:.75rem 0;counter-reset:list-counter}.markdown-content ol li{margin:.75rem 0;line-height:1.6;counter-increment:list-counter;position:relative}.markdown-content ol li::marker{color:#2c3e50;font-weight:700}.markdown-content strong{font-weight:700;color:#2c3e50}.markdown-content code{background-color:#f8f9fa;padding:.2rem .4rem;border-radius:3px;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:.9em;border:1px solid #e9ecef}.markdown-content pre{background-color:#f8f9fa;padding:1rem;border-radius:5px;overflow-x:auto;border:1px solid #e9ecef;margin:.75rem 0}.markdown-content pre code{background:none;padding:0;border:none}.markdown-content blockquote{border-left:4px solid #3498db;padding-left:1rem;margin:.75rem 0;font-style:italic;color:#7f8c8d;background-color:#f8f9fa;padding:.75rem 1rem;border-radius:0 5px 5px 0}.markdown-content a{color:#3498db;text-decoration:none}.markdown-content a:hover{text-decoration:underline}.markdown-content table{border-collapse:collapse;width:100%;margin:.75rem 0}.markdown-content th,.markdown-content td{border:1px solid #e9ecef;padding:.5rem;text-align:left}.markdown-content th{background-color:#f8f9fa;font-weight:600}.file-analysis-tabs{margin-bottom:1rem;background:#fff;border-radius:8px;border:1px solid #e5e7eb;overflow:hidden}.tabs-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;background:#f8fafc;border-bottom:1px solid #e5e7eb}.tabs-header h3{margin:0;font-size:1.1rem;font-weight:600;color:#1f2937;display:flex;align-items:center;gap:.5rem}.files-count{font-size:.875rem;color:#6b7280;background:#e5e7eb;padding:.25rem .75rem;border-radius:12px;font-weight:500}.tabs-container{display:flex;flex-wrap:wrap;gap:.5rem;padding:1rem 1.5rem;background:#fff}.analysis-tab{background:#fff;border:1px solid #d1d5db;padding:.5rem 1rem;border-radius:6px;color:#374151;cursor:pointer;font-size:.875rem;font-weight:500;transition:all .2s ease;white-space:nowrap;display:flex;align-items:center;gap:.5rem}.analysis-tab:hover{border-color:#3b82f6;color:#3b82f6;background-color:#eff6ff}.analysis-tab.active{background-color:#3b82f6;border-color:#3b82f6;color:#fff}.combined-tab{font-weight:600;background-color:#f3f4f6;border-color:#9ca3af}.combined-tab:hover{background-color:#e5e7eb;border-color:#6b7280;color:#374151}.combined-tab.active{background-color:#059669;border-color:#059669;color:#fff}.file-tab{max-width:200px;overflow:hidden;text-overflow:ellipsis}@media (max-width: 768px){.message{max-width:90%}.chat-header,.messages-container,.message-form{padding:15px}.tabs-header{flex-direction:column;align-items:flex-start;gap:.5rem;padding:1rem}.tabs-container{padding:1rem;justify-content:center}.analysis-tab{font-size:.8rem;padding:.4rem .8rem}.file-tab{max-width:150px}}body,html{margin:0;padding:0;overflow-x:hidden}.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;width:100vw;position:relative;overflow-x:auto;background:linear-gradient(135deg,#7f9ece,#0f3f42);padding:20px 10px}.login-card{background-color:#fff;padding:30px;border-radius:12px;box-shadow:0 10px 30px #0000001a;text-align:center;width:100%;max-width:450px;animation:fadeIn .8s ease-out;box-sizing:border-box;margin:auto}.login-form input[type=text],.login-form input[type=email],.login-form input[type=password]{width:100%;padding:10px;border:1px solid #ddd;border-radius:8px;font-size:.95em;transition:border-color .3s ease;box-sizing:border-box}@keyframes fadeIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.login-logo{width:120px;height:auto;margin-bottom:15px;border-radius:8px;flex-shrink:0}.login-card h2{margin-bottom:20px;color:#0f3f42;font-size:1.8em;font-weight:600}.login-form .input-group{margin-bottom:12px;text-align:left}.login-form label{display:block;margin-bottom:4px;color:#555;font-weight:500;font-size:.95em}.login-form input[type=text],.login-form input[type=email],.login-form input[type=password]{width:100%;padding:10px;border:1px solid #ddd;border-radius:8px;font-size:.95em;transition:border-color .3s ease}.login-form input[type=text]:focus,.login-form input[type=email]:focus,.login-form input[type=password]:focus{border-color:#007bff;outline:none;box-shadow:0 0 0 3px #007bff40}.login-form input::placeholder{color:#999;opacity:1}.login-form input::-webkit-input-placeholder{color:#999}.login-form input::-moz-placeholder{color:#999;opacity:1}.login-form input:-ms-input-placeholder{color:#999}.remember-me-group{margin-bottom:8px;text-align:left}.remember-me-label{display:flex;align-items:center;cursor:pointer;-webkit-user-select:none;user-select:none;color:#555;font-size:.9em}.remember-me-label input[type=checkbox]{width:18px;height:18px;margin-right:10px;cursor:pointer;accent-color:#345b5e}.remember-me-label input[type=checkbox]:disabled{cursor:not-allowed;opacity:.6}.remember-me-label span{line-height:1.4}.login-error{color:#dc3545;background-color:#f8d7da;border:1px solid #f5c6cb;padding:8px;border-radius:8px;margin-bottom:12px;font-size:.85em;animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.login-card button[type=submit]{width:100%;padding:12px;background-color:#345b5e;color:#fff;border:none;border-radius:8px;font-size:1em;font-weight:600;cursor:pointer;transition:background-color .3s ease,transform .2s ease;-webkit-tap-highlight-color:rgba(0,0,0,.1);touch-action:manipulation;min-height:44px}.login-card button[type=submit]:hover:not(:disabled){background-color:#0f3f42;transform:translateY(-2px)}.login-card button[type=submit]:active:not(:disabled){transform:translateY(0)}.login-card button[type=submit]:disabled{background-color:#345b5e;cursor:not-allowed;opacity:.7}.login-note{margin-top:15px;color:#777;font-size:.85em}.login-link{color:#345b5e;font-weight:600;cursor:pointer;text-decoration:underline;transition:color .3s ease;padding:2px 4px;display:inline-block;-webkit-tap-highlight-color:rgba(52,91,94,.2)}.login-link:hover{color:#0f3f42}.login-link:active{color:#0f3f42;opacity:.8}@media (max-width: 768px){.login-card{max-width:90%;padding:25px 20px}.login-card h2{font-size:1.6em;margin-bottom:15px}.login-logo{width:110px;margin-bottom:12px}.login-form .input-group{margin-bottom:10px}.login-form label{font-size:.9em;margin-bottom:3px}.login-form input[type=text],.login-form input[type=email],.login-form input[type=password]{padding:9px 8px;font-size:.9em}.login-card button[type=submit]{padding:11px;font-size:.95em}.remember-me-label{font-size:.85em}.login-note{font-size:.8em;margin-top:12px}}@media (max-width: 600px){.login-container{padding:15px 10px;min-height:100vh}.login-card{max-width:95%;padding:20px 18px;margin:10px auto}.login-card h2{font-size:1.5em;margin-bottom:12px}.login-logo{width:90px;margin-bottom:10px}.login-form .input-group{margin-bottom:10px}.login-form label{font-size:.85em;margin-bottom:3px}.login-form input[type=text],.login-form input[type=email],.login-form input[type=password]{padding:9px 8px;font-size:.9em}.login-card button[type=submit]{padding:11px;font-size:.95em}.remember-me-label{font-size:.85em}.remember-me-label input[type=checkbox]{width:16px;height:16px;margin-right:8px}.login-note{font-size:.8em;margin-top:12px}.login-error{font-size:.85em;padding:6px;margin-bottom:10px}}@media (max-width: 400px){.login-container{padding:10px 5px}.login-card{max-width:98%;padding:18px 15px}.login-card h2{font-size:1.3em;margin-bottom:10px}.login-logo{width:80px;margin-bottom:8px}.login-form .input-group{margin-bottom:8px}.login-form label{font-size:.85em;margin-bottom:3px}.login-form input[type=text],.login-form input[type=email],.login-form input[type=password]{padding:8px 7px;font-size:.85em}.login-card button[type=submit]{padding:10px;font-size:.9em}.remember-me-label{font-size:.8em}.remember-me-label input[type=checkbox]{width:15px;height:15px;margin-right:6px}.login-note{font-size:.75em;margin-top:10px}}@media (min-width: 1200px){.login-card{max-width:480px;padding:35px}}@media (max-width: 900px) and (max-height: 500px) and (orientation: landscape){.login-container{padding:10px;align-items:flex-start}.login-card{max-width:70%;padding:15px;margin:10px auto}.login-logo{width:70px;margin-bottom:8px}.login-card h2{font-size:1.2em;margin-bottom:10px}.login-form .input-group{margin-bottom:8px}.login-form label{font-size:.8em;margin-bottom:2px}.login-form input[type=text],.login-form input[type=email],.login-form input[type=password]{padding:7px 6px;font-size:.85em}.login-card button[type=submit]{padding:9px;font-size:.85em}.remember-me-label{font-size:.75em}.login-note{font-size:.7em;margin-top:10px}}.billing-container{max-width:1200px;margin:0 auto;padding:2rem;min-height:100vh}.packages-loading{display:flex;justify-content:center;align-items:center;min-height:200px;grid-column:1 / -1}.packages-loading .loading-spinner{font-size:1.1rem;color:#666}.packages-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:200px;grid-column:1 / -1;text-align:center;padding:2rem}.packages-error .error-icon{color:#e74c3c;margin-bottom:1rem}.packages-error h3{color:#333;margin-bottom:.5rem}.packages-error p{color:#666;margin-bottom:1.5rem}.packages-error .retry-button{background:#667eea;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;cursor:pointer;font-size:1rem;transition:background .2s}.packages-error .retry-button:hover{background:#5a6fd8}.billing-header{text-align:center;margin-bottom:3rem}.billing-header h1{font-size:2.5rem;font-weight:700;color:#1a1a1a;margin-bottom:.5rem}.billing-header p{font-size:1.1rem;margin-bottom:2rem}.current-subscription{display:inline-block;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:1rem 2rem;border-radius:12px;margin-bottom:1rem}.subscription-info{display:flex;align-items:center;gap:1rem}.subscription-icon{width:24px;height:24px}.subscription-info h3{margin:0;font-size:1.1rem;font-weight:600}.subscription-info p{margin:0;opacity:.9;font-size:.9rem}.packages-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:2rem;margin-bottom:3rem}.package-card{background:#fff;border:2px solid #e5e7eb;border-radius:16px;padding:2rem;position:relative;transition:all .3s ease;box-shadow:0 4px 6px -1px #0000001a}.package-card:hover{transform:translateY(-4px);box-shadow:0 20px 25px -5px #0000001a}.package-card.popular{border-color:#667eea;transform:scale(1.05)}.package-card.current{border:2px solid #28a745;background:linear-gradient(135deg,#f8fff9,#e8f5e8);position:relative}.package-card.current:before{content:"✓ CURRENT";position:absolute;top:-1px;right:-1px;background:#28a745;color:#fff;padding:.25rem .75rem;font-size:.75rem;font-weight:700;border-radius:0 8px}.popular-badge{position:absolute;top:-12px;left:50%;transform:translate(-50%);background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:.5rem 1rem;border-radius:20px;font-size:.8rem;font-weight:600;display:flex;align-items:center;gap:.25rem}.package-header{text-align:center;margin-bottom:2rem}.package-header h3{font-size:1.5rem;font-weight:700;color:#1a1a1a;margin-bottom:1rem}.package-price{display:flex;align-items:baseline;justify-content:center;gap:.25rem}.price{font-size:3rem;font-weight:800;color:#667eea}.period{font-size:1rem;color:#666;font-weight:500}.package-features{margin-bottom:2rem}.feature{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem;padding:.5rem 0}.check-icon{color:#10b981;flex-shrink:0}.feature span{color:#374151;font-size:.95rem}.package-button{width:100%;padding:1rem 2rem;border:none;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.package-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 20px #667eea66}.package-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.package-button.current-plan{background:linear-gradient(135deg,#10b981,#059669)}.current-plan-buttons{display:flex;flex-direction:column;gap:.75rem}.package-button.reset-plan{background:linear-gradient(135deg,#f59e0b,#d97706);font-size:.95rem}.package-button.reset-plan:hover:not(:disabled){box-shadow:0 10px 20px #f59e0b66}.package-button.disabled-plan{background:linear-gradient(135deg,#9ca3af,#6b7280);cursor:not-allowed;opacity:.7}.package-button.disabled-plan:hover{transform:none;box-shadow:none}.loading-spinner{display:flex;align-items:center;justify-content:center;gap:.5rem}.subscription-notice{background:#fef3c7;border:1px solid #f59e0b;border-radius:12px;padding:1.5rem;display:flex;align-items:center;gap:1rem;margin-bottom:3rem}.notice-icon{color:#f59e0b;flex-shrink:0;width:24px;height:24px}.subscription-notice h3{margin:0 0 .5rem;color:#92400e;font-size:1.1rem;font-weight:600}.subscription-notice p{margin:0;color:#92400e}.limit-reached-notice{background:linear-gradient(135deg,#fee2e2,#fef3c7);border:2px solid #f59e0b;border-radius:12px;padding:1.5rem;display:flex;align-items:flex-start;gap:1rem;margin-top:1.5rem;box-shadow:0 4px 12px #f59e0b33;animation:pulse-border 2s infinite}@keyframes pulse-border{0%,to{border-color:#f59e0b}50%{border-color:#ef4444}}.limit-reached-notice .notice-icon{color:#dc2626;width:28px;height:28px}.limit-reached-notice h3{margin:0 0 .5rem;color:#991b1b;font-size:1.2rem;font-weight:700}.limit-reached-notice p{margin:0;color:#7c2d12;line-height:1.6}.limit-reached-notice strong{color:#991b1b;font-weight:600}.usage-notice{background:linear-gradient(135deg,#e0f2fe,#f0f9ff);border:2px solid #0ea5e9;border-radius:12px;padding:1.5rem;display:flex;align-items:flex-start;gap:1rem;margin-top:1.5rem;box-shadow:0 4px 12px #0ea5e933}.usage-notice .notice-icon{color:#0284c7;width:28px;height:28px}.usage-notice h3{margin:0 0 .5rem;color:#0c4a6e;font-size:1.2rem;font-weight:700}.usage-notice p{margin:0;color:#0369a1;line-height:1.6}.usage-notice strong{color:#0c4a6e;font-weight:600}.billing-footer{text-align:center;padding-top:2rem;border-top:1px solid #e5e7eb}.security-info{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-bottom:1rem;color:#666;font-size:.9rem}.billing-details{color:#666;font-size:.9rem}.billing-details p{margin:.25rem 0}.admin-features{background:#fff;border-radius:16px;padding:2rem;margin-bottom:2rem;box-shadow:0 4px 6px -1px #0000001a}.admin-features h2{color:#1a1a1a;margin-bottom:1.5rem;font-size:1.5rem;font-weight:700}.admin-feature-list{display:flex;flex-direction:column;gap:1rem}.admin-feature{display:flex;align-items:center;gap:1rem;padding:1rem;background:#f0fdf4;border-radius:12px;border:1px solid #bbf7d0}.admin-feature .check-icon{color:#10b981;flex-shrink:0}.admin-feature span{color:#166534;font-weight:500;font-size:1rem}@media (max-width: 768px){.billing-container{padding:1rem}.billing-header h1{font-size:2rem}.packages-grid{grid-template-columns:1fr;gap:1.5rem}.package-card.popular{transform:none}.price{font-size:2.5rem}.admin-features{padding:1.5rem}.admin-feature{padding:.75rem}}.payment-handler-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:2rem;position:fixed;top:0;left:0;right:0;bottom:0;z-index:9999}.payment-processing-card{background:#fff;border-radius:20px;padding:3rem 2rem;box-shadow:0 25px 50px #00000026;text-align:center;max-width:400px;width:100%;animation:fadeInUp .6s ease-out}.payment-loader{width:60px;height:60px;border:4px solid #f0f0f0;border-top:4px solid #667eea;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 2rem}.payment-processing-title{font-size:1.5rem;font-weight:600;color:#333;margin-bottom:.5rem}.payment-processing-subtitle{font-size:1rem;color:#666;margin-bottom:2rem;line-height:1.5}.payment-steps{display:flex;flex-direction:column;gap:.75rem;margin-bottom:2rem}.payment-step{display:flex;align-items:center;gap:.75rem;padding:.5rem 0;font-size:.9rem;color:#555}.payment-step-icon{width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;flex-shrink:0}.payment-step.completed .payment-step-icon{background:#10b981;color:#fff}.payment-step.active .payment-step-icon{background:#667eea;color:#fff;animation:pulse 2s infinite}.payment-step.pending .payment-step-icon{background:#e5e7eb;color:#9ca3af}.payment-step.completed{color:#10b981}.payment-step.active{color:#667eea;font-weight:500}.payment-security-notice{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:1rem;margin-top:1.5rem;font-size:.85rem;color:#64748b;display:flex;align-items:center;gap:.5rem}.security-icon{color:#10b981;flex-shrink:0}.payment-success-card{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.payment-success-card .payment-processing-title,.payment-success-card .payment-processing-subtitle{color:#fff}.payment-success-icon{width:60px;height:60px;background:#fff3;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 1.5rem;animation:successPulse .6s ease-out}.payment-error-card{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.payment-error-card .payment-processing-title,.payment-error-card .payment-processing-subtitle{color:#fff}.payment-error-icon{width:60px;height:60px;background:#fff3;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 1.5rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.1);opacity:.8}}@keyframes successPulse{0%{transform:scale(.8);opacity:0}50%{transform:scale(1.1);opacity:1}to{transform:scale(1);opacity:1}}@media (max-width: 768px){.payment-handler-container{padding:1rem}.payment-processing-card{padding:2rem 1.5rem}.payment-processing-title{font-size:1.25rem}.payment-loader{width:50px;height:50px}}body{margin:0;font-family:Arial,sans-serif}.app-container{display:flex;height:100vh}.content{flex:1;background-color:#ecf0f1;overflow-y:auto;margin-left:60px;padding-top:64px;transition:margin-left .3s ease;min-height:100vh}@media (max-width: 767px){.content{margin-left:0}}.login-mode{padding:0;margin:0;height:100vh;width:100vw}.login-mode .content{padding:0;margin:0}
