.session-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:2000;padding:var(--space-md)}.session-modal{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-lg);width:100%;max-width:400px;display:flex;flex-direction:column;overflow:hidden}.session-modal-header{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-lg);border-bottom:1px solid var(--border-color)}.session-modal-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:#f59e0b1a;border-radius:var(--radius-md)}.session-modal-icon svg{width:24px;height:24px;color:#f59e0b}.session-modal-title h3{margin:0;font-size:1.125rem;font-weight:600;color:var(--text-primary)}.session-modal-title p{margin:4px 0 0;font-size:.875rem;color:var(--text-secondary)}.session-modal-content{padding:var(--space-lg)}.session-modal-content>p{margin:0 0 var(--space-lg) 0;font-size:.875rem;color:var(--text-secondary);line-height:1.5}.session-timer{display:flex;align-items:center;justify-content:center}.session-timer-value{font-size:3rem;font-weight:700;color:var(--error-red);background:#ef44441a;padding:var(--space-md) var(--space-xl);border-radius:var(--radius-lg);font-family:var(--font-mono)}.session-modal-footer{display:flex;gap:var(--space-md);padding:var(--space-lg);border-top:1px solid var(--border-color)}.session-btn{flex:1;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);font-size:.875rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.session-btn-secondary{background:transparent;border:1px solid var(--border-color);color:var(--text-secondary)}.session-btn-secondary:hover{background:var(--bg-hover);border-color:var(--text-secondary)}.session-btn-primary{background:var(--info-blue);border:1px solid var(--info-blue);color:#fff}.session-btn-primary:hover{background:#2563eb;border-color:#2563eb}@media (max-width: 480px){.session-modal{margin:var(--space-md)}.session-modal-header,.session-modal-content{padding:var(--space-md)}.session-modal-footer{padding:var(--space-md);flex-direction:column}.session-timer-value{font-size:2.5rem}}.login-modal{max-width:400px}.login-form{padding:var(--space-lg);display:flex;flex-direction:column;gap:var(--space-md)}.invoice-panel{display:flex;flex-direction:column;gap:var(--space-xl)}.invoice-message{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);font-size:.875rem}.invoice-message svg{width:18px;height:18px;flex-shrink:0}.invoice-message.error{background:var(--error-bg);color:var(--error-red)}.invoice-message.success{background:var(--success-bg);color:var(--data-green)}.invoice-form-section{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-lg)}.invoice-form-section h3{margin:0 0 var(--space-lg) 0;font-size:1rem;font-weight:600;color:var(--text-primary)}.invoice-form{display:flex;flex-direction:column;gap:var(--space-lg)}.form-row{display:grid;grid-template-columns:2fr 1fr 1fr;gap:var(--space-md)}.form-group select,.form-group input{padding:var(--space-sm) var(--space-md);background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:.9375rem}.form-group select:focus,.form-group input:focus{outline:none;border-color:var(--data-green)}.form-group.checkbox input[type=checkbox]{width:18px;height:18px;cursor:pointer}.invoice-preview{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--space-md);display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-md)}.preview-item{display:flex;flex-direction:column;gap:var(--space-xs)}.preview-label{font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.preview-value{font-size:.9375rem;font-weight:500;color:var(--text-primary)}.preview-value.exempt{color:#60a5fa}.preview-value.amount{font-size:1.125rem;font-weight:600;color:var(--data-green)}.preview-value.amount.exempt{color:#60a5fa}.preview-warning{grid-column:1 / -1;background:var(--error-bg);color:var(--error-red);padding:var(--space-sm);border-radius:var(--radius-sm);font-size:.875rem;text-align:center}.btn-close-invoice{display:flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);background:var(--data-green);color:var(--graphite-black);border:none;border-radius:var(--radius-md);font-size:.9375rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.btn-close-invoice:hover:not(:disabled){background:#00cc6f;transform:translateY(-1px)}.btn-close-invoice:disabled{opacity:.5;cursor:not-allowed}.btn-close-invoice svg{width:20px;height:20px}.spinner-small{width:18px;height:18px;border:2px solid rgba(0,0,0,.2);border-top-color:var(--graphite-black);border-radius:50%;animation:spin .8s linear infinite}.invoices-list-section{display:flex;flex-direction:column;gap:var(--space-md)}.invoices-list-section h3{margin:0;font-size:1rem;font-weight:600;color:var(--text-primary)}.invoice-loading,.invoice-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-md);padding:var(--space-xl);color:var(--text-secondary)}.invoice-empty svg{width:48px;height:48px;opacity:.5}.invoice-table-container{overflow-x:auto;border:1px solid var(--border-color);border-radius:var(--radius-md)}.invoice-table{width:100%;border-collapse:collapse}.invoice-table th,.invoice-table td{padding:var(--space-sm) var(--space-md);text-align:left;border-bottom:1px solid var(--border-color)}.invoice-table th{background:var(--bg-secondary);font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.invoice-table td{font-size:.875rem;color:var(--text-primary)}.invoice-table tbody tr:hover{background:var(--bg-hover)}.invoice-table tbody tr:last-child td{border-bottom:none}.exempt-amount{color:#60a5fa!important}.status-exempt,.status-billed{display:inline-flex;align-items:center;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);font-size:.75rem;font-weight:500}.status-exempt{background:#3b82f626;color:#60a5fa}.status-billed{background:var(--success-bg);color:var(--data-green)}.file-links{display:flex;gap:var(--space-xs)}.file-link{display:inline-flex;align-items:center;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);font-size:.75rem;font-weight:600;text-decoration:none;transition:all var(--transition-fast)}.file-link.csv{background:#22c55e26;color:#22c55e}.file-link.csv:hover{background:#22c55e40}.file-link.json{background:#fbbf2426;color:#fbbf24}.file-link.json:hover{background:#fbbf2440}.file-link.boleto{background:#ef444426;color:#ef4444}.file-link.boleto:hover{background:#ef444440}.btn-icon svg{width:16px;height:16px}.btn-icon.btn-edit:hover{background:var(--info-blue);border-color:var(--info-blue);color:#fff}.btn-icon.btn-delete{background:transparent;border:1px solid var(--border-color);color:var(--text-secondary)}.btn-icon.btn-delete:hover{background:var(--error-red);border-color:var(--error-red);color:#fff}.invoice-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1100;padding:var(--space-lg)}.invoice-modal{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-lg);width:100%;max-width:420px;display:flex;flex-direction:column;box-shadow:0 20px 60px #0006}.invoice-modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--border-color)}.invoice-modal-header h3{margin:0;font-size:1rem;font-weight:600;color:var(--text-primary)}.modal-close-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:transparent;border:none;color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.modal-close-btn:hover{background:var(--bg-secondary);color:var(--error-red)}.modal-close-btn svg{width:18px;height:18px}.invoice-modal-content{padding:var(--space-lg);display:flex;flex-direction:column;gap:var(--space-md)}.modal-info{display:flex;justify-content:space-between;align-items:center}.modal-label{font-size:.875rem;color:var(--text-secondary)}.modal-value{font-size:.875rem;font-weight:500;color:var(--text-primary)}.invoice-modal-footer{display:flex;justify-content:flex-end;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);border-top:1px solid var(--border-color)}.invoice-modal-footer .btn-cancel,.invoice-modal-footer .btn-save,.invoice-modal-footer .btn-delete{padding:var(--space-sm) var(--space-lg);border-radius:var(--radius-md);font-size:.875rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.invoice-modal-footer .btn-cancel{background:transparent;border:1px solid var(--border-color);color:var(--text-secondary)}.invoice-modal-footer .btn-cancel:hover{background:var(--bg-secondary);color:var(--text-primary)}.invoice-modal-footer .btn-save{background:var(--data-green);border:none;color:var(--graphite-black)}.invoice-modal-footer .btn-save:hover{background:#00cc6f}.invoice-modal-footer .btn-delete{background:var(--error-red);border:none;color:#fff}.invoice-modal-footer .btn-delete:hover{background:#dc2626}.confirm-modal .invoice-modal-content{text-align:center}.confirm-icon{display:flex;justify-content:center}.confirm-icon svg{width:48px;height:48px;color:var(--warning-amber)}.confirm-message{margin:0;font-size:.9375rem;color:var(--text-primary)}.confirm-warning{margin:0;font-size:.875rem;color:var(--text-secondary)}.form-group-companies{flex:2}.multi-select-container{position:relative}.multi-select-trigger{display:flex;align-items:center;justify-content:space-between;padding:var(--space-sm) var(--space-md);background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.multi-select-trigger:hover{border-color:var(--data-green)}.multi-select-text{font-size:.9375rem;color:var(--text-primary)}.multi-select-trigger .chevron{width:18px;height:18px;color:var(--text-secondary);transition:transform var(--transition-fast)}.multi-select-trigger .chevron.open{transform:rotate(180deg)}.multi-select-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:0 8px 24px #0000004d;z-index:100;max-height:300px;display:flex;flex-direction:column}.multi-select-actions{display:flex;gap:var(--space-sm);padding:var(--space-sm);border-bottom:1px solid var(--border-color)}.multi-select-actions button{flex:1;padding:var(--space-xs) var(--space-sm);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:.75rem;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.multi-select-actions button:hover{background:var(--data-green);border-color:var(--data-green);color:var(--graphite-black)}.multi-select-options{overflow-y:auto;max-height:240px;padding:var(--space-xs)}.multi-select-option{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast)}.multi-select-option:hover{background:var(--bg-hover)}.multi-select-option.has-invoice{opacity:.6}.multi-select-option input[type=checkbox]{width:16px;height:16px;cursor:pointer;accent-color:var(--data-green)}.multi-select-option .company-name{flex:1;font-size:.875rem;color:var(--text-primary)}.multi-select-option .badge{padding:2px 6px;border-radius:var(--radius-sm);font-size:.625rem;font-weight:600;text-transform:uppercase}.multi-select-option .badge.exempt{background:#3b82f626;color:#60a5fa}.multi-select-option .badge.existing{background:#fbbf2426;color:#fbbf24}.invoice-preview{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--space-md);display:flex;flex-direction:column;gap:var(--space-md)}.preview-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:var(--space-sm);border-bottom:1px solid var(--border-color)}.preview-title{font-size:.875rem;font-weight:600;color:var(--text-primary)}.preview-period{font-size:.875rem;color:var(--data-green);font-weight:500}.preview-companies{display:flex;flex-direction:column;gap:var(--space-xs);max-height:200px;overflow-y:auto}.preview-company{display:flex;justify-content:space-between;align-items:center;padding:var(--space-sm);background:var(--bg-secondary);border-radius:var(--radius-sm);border-left:3px solid var(--data-green)}.preview-company.existing{border-left-color:#fbbf24;opacity:.7}.preview-company.exempt{border-left-color:#60a5fa}.preview-company .company-name{font-size:.875rem;color:var(--text-primary);display:flex;align-items:center;gap:var(--space-xs)}.company-modules-badge{font-size:.6875rem;padding:2px 6px;background:#8b5cf626;color:#a78bfa;border-radius:var(--radius-sm);font-weight:500}.preview-company .company-status{font-size:.8125rem;font-weight:500}.preview-company .status-existing{color:#fbbf24}.preview-company .status-exempt{color:#60a5fa}.preview-company .status-billable{color:var(--data-green)}.preview-summary{display:flex;flex-wrap:wrap;gap:var(--space-md);padding-top:var(--space-sm);border-top:1px solid var(--border-color)}.summary-item{display:flex;align-items:center;gap:var(--space-xs);font-size:.8125rem;color:var(--text-secondary)}.summary-item strong{color:var(--text-primary)}.summary-item.warning,.summary-item.warning strong{color:#fbbf24}.summary-item.total{margin-left:auto;font-size:.9375rem}.summary-item.total strong{color:var(--data-green);font-size:1rem}@media (max-width: 768px){.form-row{grid-template-columns:1fr}.preview-companies{max-height:150px}.preview-summary{flex-direction:column;gap:var(--space-sm)}.summary-item.total{margin-left:0}.invoice-table-container{font-size:.8125rem}.invoice-table th,.invoice-table td{padding:var(--space-xs) var(--space-sm)}}.admin-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--space-lg)}.admin-modal{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-lg);width:100%;max-width:1000px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0006}.admin-modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-lg);border-bottom:1px solid var(--border-color)}.admin-modal-header h2{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin:0}.admin-close-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:transparent;border:none;color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-md);transition:all var(--transition-fast)}.admin-close-btn:hover{background:var(--bg-secondary);color:var(--error-red)}.admin-close-btn svg{width:20px;height:20px}.admin-tabs{display:flex;border-bottom:1px solid var(--border-color);padding:0 var(--space-lg)}.admin-tab{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);background:transparent;border:none;color:var(--text-secondary);font-size:.9375rem;font-weight:500;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:all var(--transition-fast)}.admin-tab:hover{color:var(--text-primary)}.admin-tab.active{color:var(--data-green);border-bottom-color:var(--data-green)}.admin-tab svg{width:18px;height:18px}.admin-message{display:flex;align-items:center;gap:var(--space-sm);margin:var(--space-md) var(--space-lg);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);font-size:.875rem}.admin-message.error{background:var(--error-bg);color:var(--error-red);border:1px solid var(--error-red)}.admin-message.success{background:var(--success-bg);color:var(--data-green);border:1px solid var(--data-green)}.admin-message svg{width:18px;height:18px;flex-shrink:0}.admin-content{flex:1;overflow-y:auto;padding:var(--space-lg)}.admin-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-md);padding:var(--space-2xl);color:var(--text-secondary)}.admin-loading .spinner{width:32px;height:32px;border:3px solid var(--border-color);border-top-color:var(--data-green);border-radius:50%;animation:spin .8s linear infinite}.admin-toolbar{display:flex;justify-content:flex-end;margin-bottom:var(--space-lg)}.btn-create{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-lg);background:var(--data-green);color:var(--graphite-black);border:none;border-radius:var(--radius-md);font-size:.875rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.btn-create:hover{background:var(--data-green-hover)}.btn-create svg{width:18px;height:18px}.admin-table-container{overflow-x:auto;border:1px solid var(--border-color);border-radius:var(--radius-md)}.admin-table{width:100%;border-collapse:collapse;font-size:.875rem}.admin-table th,.admin-table td{padding:var(--space-sm) var(--space-md);text-align:left;border-bottom:1px solid var(--border-color)}.admin-table th{background:var(--bg-secondary);color:var(--text-secondary);font-weight:500;font-size:.8125rem;text-transform:uppercase;letter-spacing:.05em}.admin-table td{color:var(--text-primary)}.admin-table tbody tr:hover{background:var(--bg-hover)}.admin-table tbody tr:last-child td{border-bottom:none}.status-badge{display:inline-flex;align-items:center;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);font-size:.75rem;font-weight:500}.status-badge.active{background:var(--success-bg);color:var(--data-green)}.status-badge.inactive{background:var(--error-bg);color:var(--error-red)}.admin-badge{display:inline-flex;align-items:center;justify-content:center;color:var(--warning-amber)}.admin-badge svg{width:18px;height:18px}.exempt-badge{display:inline-flex;align-items:center;gap:var(--space-xs);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);font-size:.75rem;font-weight:500;background:#3b82f626;color:#60a5fa}.exempt-badge svg{width:12px;height:12px}.plan-cell{display:flex;align-items:center;gap:var(--space-sm)}.plan-cell .plan-name{background:var(--info-bg);color:var(--info-blue);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);font-size:.75rem;font-weight:500}.btn-remove-plan{color:var(--error-red);opacity:.5}.btn-remove-plan:hover{opacity:1}.companies-list{display:flex;flex-wrap:wrap;gap:var(--space-xs)}.company-badge{background:var(--bg-secondary);color:var(--text-primary);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);font-size:.75rem}.description-cell{max-width:250px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text-secondary)}.modules-checkbox-list{display:flex;flex-direction:column;gap:var(--space-sm);max-height:200px;overflow-y:auto;padding:var(--space-sm);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md)}.module-checkbox-item{display:flex;align-items:flex-start;gap:var(--space-sm);padding:var(--space-sm);cursor:pointer;border-radius:var(--radius-sm);transition:background var(--transition-fast)}.module-checkbox-item:hover{background:var(--bg-primary)}.module-checkbox-item input[type=checkbox]{margin-top:2px;flex-shrink:0}.module-checkbox-info{display:flex;flex-direction:column;gap:2px}.module-checkbox-name{font-weight:500;color:var(--text-primary)}.module-checkbox-desc{font-size:.8rem;color:var(--text-secondary)}.module-checkbox-price{font-size:.8rem;color:var(--data-green);font-weight:500}.action-buttons{display:flex;gap:var(--space-xs)}.btn-icon{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:transparent;border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.btn-icon svg{width:16px;height:16px;stroke:currentColor}.btn-icon.btn-edit{color:var(--info-blue)}.btn-icon.btn-edit:hover{background:var(--info-bg);border-color:var(--info-blue)}.btn-icon.btn-delete{color:var(--error-red)}.btn-icon.btn-delete:hover{background:var(--error-bg);border-color:var(--error-red)}.btn-link{background:none;border:none;color:var(--data-green);font-size:.8125rem;cursor:pointer;padding:0}.admin-form-container{max-width:600px;margin:0 auto}.admin-form-container h3{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin-bottom:var(--space-lg)}.admin-form{display:flex;flex-direction:column;gap:var(--space-md)}.form-hint{font-size:.75rem;color:var(--text-secondary);margin-top:var(--space-xs);display:block}.form-group input[type=text],.form-group input[type=email],.form-group input[type=password],.form-group input[type=number],.form-group select{padding:var(--space-sm) var(--space-md);background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:.9375rem;transition:border-color var(--transition-fast)}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--data-green)}.form-group.checkbox{flex-direction:row;align-items:center}.form-group.checkbox label{display:flex;align-items:center;gap:var(--space-sm);cursor:pointer}.form-group.checkbox input[type=checkbox]{width:18px;height:18px;accent-color:var(--data-green)}.form-row{display:flex;gap:var(--space-md)}.form-row .form-group{flex:1}.form-row .form-group-small{flex:0 0 80px}.input-with-button{display:flex;gap:var(--space-xs)}.input-with-button input{flex:1}.generate-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);flex-shrink:0}.generate-btn:hover{background:var(--data-green);border-color:var(--data-green);color:var(--graphite-black)}.generate-btn svg{width:18px;height:18px}.form-actions{display:flex;justify-content:flex-end;gap:var(--space-md);margin-top:var(--space-md);padding-top:var(--space-md);border-top:1px solid var(--border-color)}.btn-cancel{padding:var(--space-sm) var(--space-lg);background:transparent;border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);font-size:.875rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.btn-cancel:hover{background:var(--bg-secondary);color:var(--text-primary)}.btn-save{padding:var(--space-sm) var(--space-lg);background:var(--data-green);border:none;border-radius:var(--radius-md);color:var(--graphite-black);font-size:.875rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.btn-save:hover{background:var(--data-green-hover)}.association-info{color:var(--text-secondary);font-size:.9375rem;margin-bottom:var(--space-lg)}.association-info strong{color:var(--text-primary)}.plan-list{display:flex;flex-direction:column;gap:var(--space-sm)}.plan-option{display:flex;justify-content:space-between;align-items:center;padding:var(--space-md);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.plan-option:hover{border-color:var(--data-green);background:var(--bg-hover)}.plan-option-info{display:flex;flex-direction:column;gap:var(--space-xs)}.plan-option-name{font-weight:600;color:var(--text-primary)}.plan-option-details{font-size:.8125rem;color:var(--text-secondary);font-family:JetBrains Mono,monospace}.plan-option svg{width:20px;height:20px;color:var(--text-secondary)}@media (max-width: 768px){.admin-modal-overlay{padding:var(--space-sm)}.admin-modal{max-height:95vh}.admin-tabs{overflow-x:auto;padding:0 var(--space-sm)}.admin-tab{padding:var(--space-sm) var(--space-md);font-size:.8125rem;white-space:nowrap}.admin-content{padding:var(--space-md)}.admin-table-container{margin:0 calc(-1 * var(--space-md));border-radius:0;border-left:none;border-right:none}.admin-form-container{max-width:100%}.form-row{flex-direction:column}.form-row .form-group-small{flex:1}}.credentials-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:2000;padding:var(--space-md)}.credentials-modal{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-lg);width:100%;max-width:450px;padding:var(--space-xl);box-shadow:0 20px 60px #00000080}.credentials-header{text-align:center;margin-bottom:var(--space-lg)}.credentials-header svg{width:48px;height:48px;color:var(--data-green);margin-bottom:var(--space-md)}.credentials-header h3{margin:0 0 var(--space-sm) 0;font-size:1.125rem;color:var(--text-primary)}.credentials-header p{margin:0;font-size:.875rem;color:var(--text-secondary)}.credentials-content{display:flex;flex-direction:column;gap:var(--space-md)}.credential-field{display:flex;flex-direction:column;gap:var(--space-xs)}.credential-field label{font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.credential-value{display:flex;gap:var(--space-xs)}.credential-value input{flex:1;padding:var(--space-sm) var(--space-md);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-family:JetBrains Mono,monospace;font-size:.875rem}.btn-copy{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);flex-shrink:0}.btn-copy:hover{background:var(--data-green);border-color:var(--data-green);color:var(--graphite-black)}.btn-copy svg{width:18px;height:18px}.btn-copy-all{display:flex;align-items:center;justify-content:center;gap:var(--space-sm);width:100%;padding:var(--space-sm) var(--space-md);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:.875rem;cursor:pointer;transition:all var(--transition-fast);margin-top:var(--space-sm)}.btn-copy-all:hover{background:var(--data-green);border-color:var(--data-green);color:var(--graphite-black)}.btn-copy-all svg{width:16px;height:16px}.credentials-footer{margin-top:var(--space-lg);padding-top:var(--space-lg);border-top:1px solid var(--border-color)}.btn-close-credentials{width:100%;padding:var(--space-md);background:var(--data-green);border:none;border-radius:var(--radius-md);color:var(--graphite-black);font-size:.875rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.btn-close-credentials:hover{background:#00cc6a}.ai-mappings-panel{display:flex;flex-direction:column;gap:var(--space-lg)}.ai-stats-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--space-md)}.stat-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--space-md);display:flex;flex-direction:column;gap:var(--space-xs)}.stat-card .stat-label{font-size:.75rem;font-weight:500;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.stat-card .stat-value{font-size:1.5rem;font-weight:700;color:var(--text-primary);font-family:JetBrains Mono,monospace}.stat-card .stat-value.success{color:var(--data-green)}.stat-card .stat-value.cost{color:var(--warning-amber)}.usage-stats-section{margin-bottom:var(--space-lg)}.usage-stats-row{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-md)}.usage-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--space-md);display:flex;flex-direction:column;gap:var(--space-md)}.usage-card.tokens-card{border-left:3px solid var(--info-blue)}.usage-card.cost-card{border-left:3px solid var(--warning-amber)}.usage-card-header{display:flex;align-items:center;gap:var(--space-sm);color:var(--text-secondary);font-size:.875rem;font-weight:500}.usage-card-header svg{width:18px;height:18px}.tokens-card .usage-card-header svg{color:var(--info-blue)}.cost-card .usage-card-header svg{color:var(--warning-amber)}.usage-card-content{display:flex;align-items:center;gap:var(--space-lg)}.usage-stat{flex:1;display:flex;flex-direction:column;gap:var(--space-xs)}.usage-value{font-size:1.5rem;font-weight:700;font-family:JetBrains Mono,monospace;color:var(--text-primary)}.tokens-card .usage-value{color:var(--info-blue)}.usage-value.cost{color:var(--warning-amber)}.usage-label{font-size:.75rem;font-weight:500;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.usage-divider{width:1px;height:40px;background:var(--border-color)}@media (max-width: 768px){.usage-stats-row{grid-template-columns:1fr}.usage-card-content{gap:var(--space-md)}.usage-value{font-size:1.25rem}}.ai-sub-tabs{display:flex;gap:var(--space-sm);border-bottom:1px solid var(--border-color);padding-bottom:var(--space-sm)}.ai-sub-tab{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:transparent;border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);font-size:.875rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.ai-sub-tab:hover{background:var(--bg-secondary);color:var(--text-primary)}.ai-sub-tab.active{background:var(--data-green);border-color:var(--data-green);color:var(--graphite-black)}.ai-sub-tab svg{width:16px;height:16px}.file-type-badge{display:inline-flex;align-items:center;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.file-type-badge.pdf{background:#ef444426;color:#ef4444}.file-type-badge.excel{background:#22c55e26;color:#22c55e}.status-badge.approved{background:var(--success-bg);color:var(--data-green)}.status-badge.pending{background:#fbbf2426;color:var(--warning-amber)}.status-badge.success{background:var(--success-bg);color:var(--data-green)}.status-badge.error{background:var(--error-bg);color:var(--error-red)}.mapping-name{font-weight:500;color:var(--text-primary)}.mapping-source{font-size:.75rem;color:var(--text-secondary);margin-top:2px}.log-filename{font-weight:500;color:var(--text-primary);max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.btn-icon.btn-toggle{color:var(--text-secondary)}.btn-icon.btn-toggle.active{color:var(--data-green);border-color:var(--data-green);background:var(--success-bg)}.btn-icon.btn-toggle:hover{background:var(--bg-secondary)}.cost-cell{font-family:JetBrains Mono,monospace;font-size:.8125rem;color:var(--warning-amber)}.tokens-cell{font-family:JetBrains Mono,monospace;font-size:.8125rem;color:var(--text-secondary)}.date-cell{font-size:.8125rem;color:var(--text-secondary)}.ai-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-2xl);text-align:center;color:var(--text-secondary)}.ai-empty-state svg{width:48px;height:48px;margin-bottom:var(--space-md);opacity:.5}.ai-empty-state p{font-size:.9375rem}.badge{display:inline-flex;align-items:center;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.badge-pdf{background:#3b82f626;color:#3b82f6}.badge-excel{background:#22c55e26;color:#22c55e}.badge-success{background:var(--success-bg);color:var(--data-green)}.badge-error{background:var(--error-bg);color:var(--error-red)}.badge-inactive{background:var(--bg-secondary);color:var(--text-secondary)}.badge-approved{background:#3b82f626;color:#60a5fa}.badge-ocr{background:#a855f726;color:#a855f7;margin-left:var(--space-xs)}.status-badges{display:flex;gap:var(--space-xs);flex-wrap:wrap}.log-filename{display:flex;align-items:center;gap:var(--space-sm)}.log-filename span:first-child{max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mapping-name{display:flex;flex-direction:column;gap:2px}.mapping-source{font-size:.75rem;color:var(--text-secondary)}.empty-message{text-align:center;padding:var(--space-xl);color:var(--text-secondary);font-style:italic}.btn-expand{display:flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;background:transparent;border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.btn-expand:hover{background:var(--bg-secondary);color:var(--text-primary)}.btn-expand svg{width:14px;height:14px;transition:transform var(--transition-fast)}.btn-expand.expanded svg{transform:rotate(90deg)}.btn-expand.expanded{background:var(--data-green);border-color:var(--data-green);color:var(--graphite-black)}.expanded-row{background:var(--bg-secondary)}.expanded-row td{border-bottom:none}.expanded-content-row{background:var(--bg-secondary)}.expanded-content-row>td{padding:0!important}.expanded-logs{padding:var(--space-md) var(--space-lg);padding-left:60px;background:var(--bg-input);border-top:1px solid var(--border-light)}.expanded-logs h4{font-size:.875rem;font-weight:600;color:var(--text-primary);margin:0 0 var(--space-md) 0}.logs-subtable{width:100%;border-collapse:collapse;font-size:.8125rem}.logs-subtable th{text-align:left;padding:var(--space-xs) var(--space-sm);background:var(--bg-secondary);color:var(--text-secondary);font-weight:500;border-bottom:1px solid var(--border-light)}.logs-subtable td{padding:var(--space-xs) var(--space-sm);color:var(--text-primary);border-bottom:1px solid var(--border-light)}.logs-subtable tr:last-child td{border-bottom:none}.no-logs-message{color:var(--text-secondary);font-size:.875rem;margin:0;font-style:italic}.btn-show-error{color:#ef4444;opacity:.8;transition:opacity .2s}.btn-show-error:hover{opacity:1}.btn-show-error svg{width:16px;height:16px}.error-message-row td{background:#ef44441a!important;border-bottom:none!important}.error-message-content{padding:var(--space-sm) var(--space-md);color:#ef4444;font-size:.8125rem;line-height:1.5;word-break:break-word}.error-message-content strong{color:#dc2626}.ai-pagination{display:flex;align-items:center;justify-content:center;gap:var(--space-md);padding:var(--space-md) 0;margin-top:var(--space-md)}.btn-pagination{display:flex;align-items:center;gap:var(--space-xs);padding:var(--space-sm) var(--space-md);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:.875rem;cursor:pointer;transition:all var(--transition-fast)}.btn-pagination:hover:not(:disabled){background:var(--bg-hover);border-color:var(--data-green)}.btn-pagination:disabled{opacity:.5;cursor:not-allowed}.btn-pagination svg{width:16px;height:16px}.pagination-info{font-size:.875rem;color:var(--text-secondary)}.ai-filter-bar{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);margin-bottom:var(--space-md)}.filter-label{display:flex;align-items:center;gap:var(--space-xs);font-size:.875rem;font-weight:500;color:var(--text-secondary);white-space:nowrap}.filter-label svg{width:16px;height:16px}.company-filter-select{flex:1;max-width:300px;padding:var(--space-sm) var(--space-md);background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:.875rem;cursor:pointer;transition:border-color var(--transition-fast)}.company-filter-select:focus{outline:none;border-color:var(--data-green)}.company-filter-select:hover{border-color:var(--text-secondary)}@media (max-width: 768px){.ai-stats-cards{grid-template-columns:repeat(2,1fr)}.expanded-logs{padding-left:var(--space-md)}.ai-pagination{flex-wrap:wrap}.ai-filter-bar{flex-direction:column;align-items:stretch;gap:var(--space-sm)}.company-filter-select{max-width:100%}}.pipeline-jobs-panel{display:flex;flex-direction:column;gap:var(--space-lg)}.pipeline-filters{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);flex-wrap:wrap}.filter-group{display:flex;align-items:center;gap:var(--space-sm)}.filter-select{padding:var(--space-sm) var(--space-md);background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:.875rem;cursor:pointer;min-width:140px}.filter-select:focus{outline:none;border-color:var(--data-green)}.btn-refresh{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;margin-left:auto;transition:all var(--transition-fast)}.btn-refresh:hover{background:var(--data-green);border-color:var(--data-green);color:var(--graphite-black)}.btn-refresh svg{width:18px;height:18px}.pipeline-jobs-table{font-size:.8125rem}.job-filename{display:flex;align-items:center;gap:var(--space-sm);flex-wrap:wrap}.job-filename>span:first-child{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:500}.badge-status-completed{background:var(--success-bg);color:var(--data-green)}.badge-status-failed{background:var(--error-bg);color:var(--error-red)}.badge-status-pending{background:var(--warning-bg);color:var(--warning-amber)}.badge-status-ingest,.badge-status-extract_fast,.badge-status-parse_rows,.badge-status-normalize,.badge-status-validate{background:var(--info-bg);color:var(--info-blue)}.badge-batch{background:#a855f726;color:#a855f7}.progress-cell{display:flex;align-items:center;gap:var(--space-sm)}.progress-bar{flex:1;height:6px;background:var(--bg-primary);border-radius:3px;overflow:hidden;min-width:60px}.progress-fill{height:100%;background:var(--info-blue);border-radius:3px;transition:width .3s ease}.progress-fill.success{background:var(--data-green)}.progress-fill.error{background:var(--error-red)}.progress-text{font-size:.75rem;color:var(--text-secondary);min-width:35px;text-align:right}.error-row{background:#ef44440d}.expanded-events{padding:var(--space-md) var(--space-lg);padding-left:60px;background:var(--bg-input);border-top:1px solid var(--border-light)}.events-header{display:flex;flex-direction:column;gap:var(--space-sm);margin-bottom:var(--space-md)}.events-header h4{font-size:.875rem;font-weight:600;color:var(--text-primary);margin:0}.job-error-message{display:flex;align-items:flex-start;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:var(--error-bg);border:1px solid var(--error-red);border-radius:var(--radius-md);color:var(--error-red);font-size:.8125rem}.job-error-message svg{width:16px;height:16px;flex-shrink:0;margin-top:2px}.events-loading{display:flex;align-items:center;gap:var(--space-sm);color:var(--text-secondary);font-size:.875rem;padding:var(--space-md)}.events-loading .spinner{width:18px;height:18px;border-width:2px}.events-timeline{display:flex;flex-direction:column;gap:0}.event-item{display:flex;gap:var(--space-md);position:relative}.event-indicator{display:flex;flex-direction:column;align-items:center;width:20px;flex-shrink:0}.event-dot{width:12px;height:12px;border-radius:50%;background:var(--text-secondary);flex-shrink:0}.event-dot.success{background:var(--data-green)}.event-dot.failure{background:var(--error-red)}.event-dot.in_progress{background:var(--info-blue)}.event-dot.pending{background:var(--warning-amber)}.event-line{width:2px;flex:1;background:var(--border-color);min-height:20px}.event-content{flex:1;padding-bottom:var(--space-md)}.event-header{display:flex;align-items:center;gap:var(--space-sm);flex-wrap:wrap;margin-bottom:var(--space-xs)}.event-stage{font-weight:600;color:var(--text-primary);font-size:.875rem}.event-type{font-size:.6875rem}.badge-started{background:var(--info-bg);color:var(--info-blue)}.badge-completed{background:var(--success-bg);color:var(--data-green)}.badge-failed{background:var(--error-bg);color:var(--error-red)}.badge-retry,.badge-warning{background:var(--warning-bg);color:var(--warning-amber)}.badge-info{background:var(--info-bg);color:var(--info-blue)}.event-duration,.event-tokens{font-size:.75rem;color:var(--text-secondary);font-family:JetBrains Mono,monospace}.event-message{font-size:.8125rem;color:var(--text-secondary);margin:var(--space-xs) 0;line-height:1.4}.event-time{font-size:.75rem;color:var(--text-muted)}.no-events-message{color:var(--text-secondary);font-size:.875rem;font-style:italic;margin:0}@media (max-width: 768px){.pipeline-filters{flex-direction:column;align-items:stretch}.filter-group{width:100%}.filter-select{flex:1}.btn-refresh{margin-left:0;width:100%}.expanded-events{padding-left:var(--space-md)}.job-filename>span:first-child{max-width:120px}}.plans-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--space-md)}.plans-modal{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-lg);width:100%;max-width:900px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden}.plans-modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-lg);border-bottom:1px solid var(--border-color)}.plans-modal-header h2{margin:0;font-size:1.25rem;color:var(--text-primary)}.plans-close-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:transparent;border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.plans-close-btn:hover{background:var(--bg-hover);color:var(--error-red);border-color:var(--error-red)}.plans-close-btn svg{width:18px;height:18px}.plans-modal-content{flex:1;overflow-y:auto;padding:var(--space-lg)}.plans-loading,.plans-error{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-md);padding:var(--space-xl);color:var(--text-secondary)}.plans-error svg{width:48px;height:48px;color:var(--error-red)}.plans-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:var(--space-lg)}.plans-grid.single-plan{display:flex;justify-content:center}.plans-grid.single-plan .plan-card{max-width:400px;width:100%}.plan-card{position:relative;background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-lg);display:flex;flex-direction:column;align-items:center;text-align:center;transition:all var(--transition-fast)}.plan-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0003}.plan-card.current{border-color:var(--data-green);background:#00ff880d}.plan-card.plan-demo{border-color:var(--text-secondary)}.plan-card.plan-demo .plan-card-icon svg{color:var(--text-secondary)}.plan-card.plan-basic{border-color:var(--info-blue)}.plan-card.plan-basic .plan-card-icon svg{color:var(--info-blue)}.plan-card.plan-medium{border-color:var(--data-green)}.plan-card.plan-medium .plan-card-icon svg{color:var(--data-green)}.plan-card.plan-advanced{border-color:#f59e0b}.plan-card.plan-advanced .plan-card-icon svg{color:#f59e0b}.plan-card.plan-unlimited{border-color:var(--data-green);background:linear-gradient(135deg,#00ff880d,#00ff8805)}.plan-card.plan-unlimited .plan-card-icon svg{color:var(--data-green)}.plan-card.plan-unlimited .unlimited-icon svg{width:56px;height:56px}.plan-unlimited-message{font-size:1rem;font-weight:500;color:var(--data-green);margin-bottom:var(--space-lg);padding:var(--space-sm) var(--space-md);background:#00ff881a;border-radius:var(--radius-md);border:1px solid rgba(0,255,136,.2)}.current-badge{position:absolute;top:-12px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:var(--space-xs);background:var(--data-green);color:var(--graphite-black);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-full);font-size:.75rem;font-weight:600;white-space:nowrap}.current-badge svg{width:14px;height:14px}.plan-card-icon{width:64px;height:64px;display:flex;align-items:center;justify-content:center;margin-bottom:var(--space-md)}.plan-card-icon svg{width:48px;height:48px;color:var(--data-green)}.plan-card-name{margin:0 0 var(--space-sm) 0;font-size:1.125rem;font-weight:600;color:var(--text-primary)}.plan-card-price{margin-bottom:var(--space-md)}.price-value{font-size:1.5rem;font-weight:700;color:var(--data-green)}.price-period{font-size:.875rem;color:var(--text-secondary)}.plan-card-features{width:100%;display:flex;flex-direction:column;gap:var(--space-sm);margin-bottom:var(--space-lg)}.feature{display:flex;align-items:center;gap:var(--space-sm);font-size:.875rem;color:var(--text-secondary)}.feature svg{width:16px;height:16px;flex-shrink:0;color:var(--data-green)}.plan-card-btn{width:100%;padding:var(--space-sm) var(--space-md);background:transparent;border:1px solid var(--data-green);border-radius:var(--radius-md);color:var(--data-green);font-size:.875rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.plan-card-btn:hover{background:var(--data-green);color:var(--graphite-black)}.plans-modal-footer{padding:var(--space-md) var(--space-lg);border-top:1px solid var(--border-color);text-align:center}.plans-modal-footer p{margin:0;font-size:.875rem;color:var(--text-secondary)}.spinner{width:40px;height:40px;border:3px solid var(--border-color);border-top-color:var(--data-green);border-radius:50%;animation:spin 1s linear infinite}@media (max-width: 600px){.plans-modal{max-height:95vh}.plans-modal-header,.plans-modal-content{padding:var(--space-md)}.plans-grid{grid-template-columns:1fr}.plan-card{padding:var(--space-md)}.plan-card-icon{width:48px;height:48px}.plan-card-icon svg{width:36px;height:36px}}.change-password-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:2000;padding:var(--space-md)}.change-password-modal{position:relative;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-lg);width:100%;max-width:400px;padding:var(--space-xl);box-shadow:0 20px 60px #00000080}.change-password-close{position:absolute;top:var(--space-md);right:var(--space-md);display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:transparent;border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.change-password-close:hover{background:var(--bg-secondary);color:var(--error-red);border-color:var(--error-red)}.change-password-close svg{width:16px;height:16px}.change-password-header{text-align:center;margin-bottom:var(--space-lg)}.change-password-icon{width:64px;height:64px;background:#00ff881a;border:2px solid var(--data-green);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto var(--space-md)}.change-password-icon svg{width:32px;height:32px;color:var(--data-green)}.change-password-header h2{margin:0 0 var(--space-sm) 0;font-size:1.25rem;color:var(--text-primary)}.change-password-header p{margin:0;font-size:.875rem;color:var(--text-secondary);line-height:1.5}.change-password-form{display:flex;flex-direction:column;gap:var(--space-md)}.change-password-error{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:var(--error-bg);border:1px solid var(--error-red);border-radius:var(--radius-md);color:var(--error-red);font-size:.875rem}.change-password-error svg{width:18px;height:18px;flex-shrink:0}.change-password-form .form-group{display:flex;flex-direction:column;gap:var(--space-xs)}.change-password-form .form-group label{font-size:.875rem;font-weight:500;color:var(--text-secondary)}.change-password-form .form-group input{width:100%;padding:var(--space-sm) var(--space-md);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:.875rem;transition:border-color var(--transition-fast)}.change-password-form .form-group input:focus{outline:none;border-color:var(--data-green)}.change-password-form .form-group input::placeholder{color:var(--text-secondary);opacity:.6}.change-password-btn{display:flex;align-items:center;justify-content:center;gap:var(--space-sm);width:100%;padding:var(--space-md);background:var(--data-green);border:none;border-radius:var(--radius-md);color:var(--graphite-black);font-size:.875rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast);margin-top:var(--space-sm)}.change-password-btn:hover:not(:disabled){background:#00cc6a;transform:translateY(-1px)}.change-password-btn:disabled{opacity:.7;cursor:not-allowed}.change-password-btn svg{width:18px;height:18px}.spinner-small{width:18px;height:18px;border:2px solid transparent;border-top-color:var(--graphite-black);border-radius:50%;animation:spin .8s linear infinite}@media (max-width: 480px){.change-password-modal{padding:var(--space-lg)}.change-password-icon{width:56px;height:56px}.change-password-icon svg{width:28px;height:28px}}.dashboard-modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;box-sizing:border-box}.dashboard-modal{background:#1a1a2e;border-radius:16px;width:100%;max-width:1200px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 25px 50px -12px #00000080;border:1px solid rgba(255,255,255,.1)}.dashboard-modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid rgba(255,255,255,.1);background:linear-gradient(135deg,#1a1a2e,#16162a)}.dashboard-modal-header h2{margin:0;font-size:1.25rem;font-weight:600;color:#fff;display:flex;align-items:center;gap:10px}.dashboard-modal-header h2 svg{width:24px;height:24px;stroke:#3b82f6}.dashboard-close-btn{background:#ffffff1a;border:none;width:36px;height:36px;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.dashboard-close-btn:hover{background:#fff3}.dashboard-close-btn svg{width:18px;height:18px;stroke:#94a3b8}.dashboard-content{padding:24px;overflow-y:auto;flex:1}.dashboard-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;gap:16px;color:#94a3b8}.dashboard-loading .spinner{width:40px;height:40px;border:3px solid rgba(59,130,246,.2);border-top-color:#3b82f6;border-radius:50%;animation:spin 1s linear infinite}.dashboard-error{display:flex;align-items:center;gap:8px;padding:12px 16px;margin:0 24px;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:8px;color:#f87171;font-size:.875rem}.dashboard-error svg{width:18px;height:18px;flex-shrink:0}.dashboard-summary{display:grid;grid-template-columns:repeat(7,1fr);gap:12px;margin-bottom:24px}@media (max-width: 1100px){.dashboard-summary{grid-template-columns:repeat(4,1fr)}}@media (max-width: 800px){.dashboard-summary{grid-template-columns:repeat(3,1fr)}}@media (max-width: 600px){.dashboard-summary{grid-template-columns:repeat(2,1fr)}}.summary-card{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:16px;display:flex;align-items:center;gap:12px;transition:all .2s ease}.summary-card:hover{background:#ffffff14;border-color:#ffffff26}.summary-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.summary-icon svg{width:24px;height:24px}.summary-icon.total{background:#3b82f633}.summary-icon.total svg{stroke:#3b82f6}.summary-icon.today{background:#10b98133}.summary-icon.today svg{stroke:#10b981}.summary-icon.week{background:#f59e0b33}.summary-icon.week svg{stroke:#f59e0b}.summary-icon.companies{background:#8b5cf633}.summary-icon.companies svg{stroke:#8b5cf6}.summary-icon.users{background:#ec489933}.summary-icon.users svg{stroke:#ec4899}.summary-icon.tokens{background:#06b6d433}.summary-icon.tokens svg{stroke:#06b6d4}.summary-icon.cost{background:#22c55e33}.summary-icon.cost svg{stroke:#22c55e}.summary-data{display:flex;flex-direction:column}.summary-value{font-size:1.5rem;font-weight:700;color:#fff;line-height:1.2}.summary-label{font-size:.75rem;color:#94a3b8;margin-top:2px}.dashboard-chart-section{background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:20px;margin-bottom:24px}.chart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.chart-header h3{margin:0;font-size:1rem;font-weight:600;color:#fff}.chart-toggle{display:flex;gap:4px;background:#ffffff0d;border-radius:8px;padding:4px}.toggle-btn{background:transparent;border:none;padding:8px 16px;font-size:.8rem;color:#94a3b8;cursor:pointer;border-radius:6px;transition:all .2s ease}.toggle-btn:hover{color:#fff;background:#ffffff0d}.toggle-btn.active{background:#3b82f6;color:#fff}.chart-legend{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:16px;padding:12px;background:#ffffff08;border-radius:8px}.legend-item{display:flex;align-items:center;gap:6px}.legend-color{width:12px;height:12px;border-radius:3px;flex-shrink:0}.legend-label{font-size:.75rem;color:#e2e8f0;white-space:nowrap}.timeline-chart{min-height:200px}.no-data{display:flex;align-items:center;justify-content:center;height:200px;color:#64748b;font-size:.875rem}.chart-container{padding:10px 0}.chart-bars{display:flex;align-items:flex-end;justify-content:space-around;height:180px;gap:8px}.chart-bar-wrapper{display:flex;flex-direction:column;align-items:center;flex:1;max-width:100px}.chart-bar-container{display:flex;flex-direction:column;align-items:center;height:150px;width:100%;justify-content:flex-end}.chart-bar{width:100%;max-width:50px;background:#ffffff1a;border-radius:6px 6px 0 0;display:flex;flex-direction:column;justify-content:flex-end;overflow:hidden;transition:all .3s ease;cursor:pointer}.chart-bar:hover{transform:scale(1.05)}.bar-segment{width:100%;min-height:2px;transition:all .3s ease}.bar-value{font-size:.75rem;color:#fff;font-weight:600;margin-top:6px}.bar-label{font-size:.7rem;color:#94a3b8;margin-top:8px}.dashboard-tables{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}@media (max-width: 768px){.dashboard-tables{grid-template-columns:1fr}}.dashboard-table-section{background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:20px}.dashboard-table-section h3{margin:0 0 16px;font-size:.95rem;font-weight:600;color:#fff;display:flex;align-items:center;gap:8px}.dashboard-table-section h3 svg{width:18px;height:18px;stroke:#94a3b8}.ranking-list{display:flex;flex-direction:column;gap:12px;max-height:300px;overflow-y:auto}.ranking-list::-webkit-scrollbar{width:6px}.ranking-list::-webkit-scrollbar-track{background:#ffffff0d;border-radius:3px}.ranking-list::-webkit-scrollbar-thumb{background:#fff3;border-radius:3px}.ranking-item{display:flex;align-items:center;gap:12px}.ranking-position{width:28px;height:28px;border-radius:50%;background:#ffffff1a;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:600;color:#94a3b8;flex-shrink:0}.ranking-item:nth-child(1) .ranking-position{background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#1a1a2e}.ranking-item:nth-child(2) .ranking-position{background:linear-gradient(135deg,#94a3b8,#64748b);color:#1a1a2e}.ranking-item:nth-child(3) .ranking-position{background:linear-gradient(135deg,#d97706,#b45309);color:#1a1a2e}.ranking-content{flex:1;min-width:0}.ranking-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.ranking-name-group{display:flex;flex-direction:column;min-width:0}.ranking-name{font-size:.875rem;color:#fff;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ranking-company{font-size:.7rem;color:#64748b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ranking-count{font-size:.875rem;color:#94a3b8;font-weight:600;flex-shrink:0;margin-left:8px}.ranking-bar{height:6px;background:#ffffff1a;border-radius:3px;overflow:hidden}.ranking-bar-fill{height:100%;border-radius:3px;transition:width .5s ease}.admin-tickets-modal{max-width:700px;max-height:85vh}.header-with-back{display:flex;align-items:center;gap:var(--space-md)}.back-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:transparent;border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.back-btn:hover{background:var(--bg-secondary);color:var(--text-primary);border-color:var(--text-secondary)}.back-btn svg{width:18px;height:18px}.status-filter-tabs{display:flex;border-bottom:1px solid var(--border-color)}.filter-tab{flex:1;padding:var(--space-md);background:transparent;border:none;border-bottom:2px solid transparent;color:var(--text-secondary);font-size:.875rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.filter-tab:hover{color:var(--text-primary);background:var(--bg-secondary)}.filter-tab.active{color:var(--data-green);border-bottom-color:var(--data-green)}.tickets-list-container{padding:var(--space-lg);min-height:300px;max-height:450px;overflow-y:auto}.tickets-loading,.tickets-error,.tickets-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-md);padding:var(--space-xl);color:var(--text-secondary)}.tickets-loading .spinner{width:24px;height:24px;border:2px solid var(--border-color);border-top-color:var(--data-green);border-radius:50%;animation:spin .8s linear infinite}.tickets-error{color:var(--error-red)}.tickets-empty svg{width:48px;height:48px;color:var(--text-secondary);opacity:.5}.tickets-list{display:flex;flex-direction:column;gap:var(--space-sm)}.ticket-item{border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--space-md);cursor:pointer;transition:all var(--transition-fast);background:var(--bg-secondary)}.ticket-item:hover{border-color:var(--data-green);background:var(--bg-tertiary)}.ticket-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-sm)}.ticket-meta{display:flex;align-items:center;gap:var(--space-xs);font-size:.75rem;color:var(--text-secondary)}.ticket-separator{opacity:.5}.ticket-company{font-weight:600;color:var(--data-green)}.ticket-user{color:var(--text-secondary)}.ticket-item-body{margin-bottom:var(--space-sm)}.ticket-name{font-size:.9375rem;font-weight:600;color:var(--text-primary);display:block;margin-bottom:var(--space-xs)}.ticket-description-preview{font-size:.8125rem;color:var(--text-secondary);line-height:1.4;margin:0}.ticket-item-footer{display:flex;justify-content:space-between;align-items:center}.ticket-date{font-size:.75rem;color:var(--text-secondary)}.ticket-attachments-count{display:flex;align-items:center;gap:var(--space-xs);font-size:.75rem;color:var(--text-secondary)}.ticket-attachments-count svg{width:14px;height:14px}.status-badge-inline.acknowledge{background:#fbbf2426;color:var(--warning-amber)}.pagination-btn svg{width:18px;height:18px}.pagination-info{font-size:.875rem;color:var(--text-secondary);min-width:160px;text-align:center}.ticket-detail-container{padding:var(--space-lg);overflow-y:auto;max-height:calc(85vh - 60px)}.ticket-detail-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-lg);padding-bottom:var(--space-md);border-bottom:1px solid var(--border-color)}.ticket-detail-meta{display:flex;align-items:center;gap:var(--space-sm);font-size:.875rem}.detail-company{font-weight:600;color:var(--data-green)}.detail-separator{color:var(--text-secondary);opacity:.5}.detail-user{color:var(--text-secondary)}.status-badge{display:inline-block;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);font-size:.75rem;font-weight:600}.status-badge.acknowledge{background:#fbbf2426;color:var(--warning-amber)}.ticket-item.has-notification{border-color:var(--data-green);background:#22c55e0d}.ticket-item.has-notification:hover{background:#22c55e1a}.ticket-detail-section{margin-bottom:var(--space-lg)}.detail-label{display:block;font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:var(--space-xs)}.detail-value{font-size:.9375rem;color:var(--text-primary);margin:0}.detail-value.description{line-height:1.6;white-space:pre-wrap;background:var(--bg-secondary);padding:var(--space-md);border-radius:var(--radius-md)}.attachments-list{display:flex;flex-direction:column;gap:var(--space-sm)}.attachment-link{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:var(--bg-secondary);border-radius:var(--radius-md);text-decoration:none;color:var(--text-primary);transition:all var(--transition-fast)}.attachment-link:hover{background:var(--bg-tertiary);color:var(--data-green)}.attachment-link svg{width:18px;height:18px;color:var(--data-green);flex-shrink:0}.attachment-name{flex:1;font-size:.875rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.attachment-size{font-size:.75rem;color:var(--text-secondary);flex-shrink:0}.resolution-section{background:#22c55e0d;padding:var(--space-md);border-radius:var(--radius-md);border-left:3px solid var(--data-green)}.resolution-info{display:flex;flex-direction:column;gap:var(--space-sm)}.resolution-notes{font-size:.9375rem;color:var(--text-primary);line-height:1.6;margin:0;white-space:pre-wrap}.resolution-meta{display:flex;gap:var(--space-md);font-size:.75rem;color:var(--text-secondary)}.resolve-form-section{background:var(--bg-secondary);padding:var(--space-md);border-radius:var(--radius-md);border:1px solid var(--border-color)}.resolution-textarea{width:100%;min-height:100px;padding:var(--space-sm) var(--space-md);background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:.9375rem;font-family:inherit;resize:vertical;transition:all var(--transition-fast);margin-bottom:var(--space-md)}.resolution-textarea:focus{outline:none;border-color:var(--data-green);box-shadow:0 0 0 3px #22c55e1a}.resolution-textarea::placeholder{color:var(--text-secondary);opacity:.6}.resolution-textarea:disabled{opacity:.6;cursor:not-allowed}.btn-resolve{display:flex;align-items:center;justify-content:center;gap:var(--space-sm);width:100%;padding:var(--space-sm) var(--space-md);background:var(--data-green);border:none;border-radius:var(--radius-md);color:var(--graphite-black);font-size:.9375rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.btn-resolve:hover:not(:disabled){background:var(--data-green-hover)}.btn-resolve:disabled{opacity:.6;cursor:not-allowed}.btn-resolve svg{width:18px;height:18px}.spinner-small{width:16px;height:16px;border:2px solid rgba(0,0,0,.2);border-top-color:var(--graphite-black);border-radius:50%;animation:spin .8s linear infinite}.resolve-success-message{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-md);padding:var(--space-xl);color:var(--data-green)}.resolve-success-message svg{width:48px;height:48px}.resolve-success-message span{font-size:1rem;font-weight:500}.messages-section{margin-bottom:var(--space-lg)}.messages-list{display:flex;flex-direction:column;gap:var(--space-sm);max-height:300px;overflow-y:auto}.message-item.chat-bubble.from-user{align-self:flex-start;background:var(--bg-secondary);border-radius:var(--radius-md) var(--radius-md) var(--radius-md) 4px}.message-item.chat-bubble.from-user .message-author{color:var(--info-blue)}.message-item.chat-bubble.from-admin{align-self:flex-end;background:#22c55e26;border-radius:var(--radius-md) var(--radius-md) 4px var(--radius-md)}.message-item.chat-bubble.from-admin .message-author{color:var(--data-green)}.message-form-section{background:var(--bg-secondary);padding:var(--space-md);border-radius:var(--radius-md);border:1px solid var(--border-color)}.message-textarea{width:100%;min-height:100px;padding:var(--space-sm) var(--space-md);background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:.9375rem;font-family:inherit;resize:vertical;transition:all var(--transition-fast);margin-bottom:var(--space-md)}.message-textarea:focus{outline:none;border-color:var(--data-green);box-shadow:0 0 0 3px #22c55e1a}.message-textarea::placeholder{color:var(--text-secondary);opacity:.6}.message-textarea:disabled{opacity:.6;cursor:not-allowed}.message-form-actions{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md)}.close-ticket-toggle{display:flex;align-items:center;gap:var(--space-sm);cursor:pointer;-webkit-user-select:none;user-select:none}.close-ticket-toggle input[type=checkbox]{display:none}.toggle-slider{position:relative;width:44px;height:24px;background:var(--bg-tertiary);border-radius:12px;border:1px solid var(--border-color);transition:all var(--transition-fast)}.toggle-slider:before{content:"";position:absolute;left:2px;top:2px;width:18px;height:18px;background:var(--text-secondary);border-radius:50%;transition:all var(--transition-fast)}.close-ticket-toggle input:checked+.toggle-slider{background:#22c55e33;border-color:var(--data-green)}.close-ticket-toggle input:checked+.toggle-slider:before{left:22px;background:var(--data-green)}.close-ticket-toggle input:disabled+.toggle-slider{opacity:.5;cursor:not-allowed}.toggle-label{font-size:.8125rem;color:var(--text-secondary);transition:color var(--transition-fast)}.close-ticket-toggle input:checked~.toggle-label{color:var(--data-green);font-weight:500}.btn-send-message{display:flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-lg);background:var(--data-green);border:none;border-radius:var(--radius-md);color:var(--graphite-black);font-size:.875rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast);min-width:160px}.btn-send-message:hover:not(:disabled){background:var(--data-green-hover)}.btn-send-message:disabled{opacity:.6;cursor:not-allowed}.btn-send-message.close-mode{background:var(--data-green);color:var(--graphite-black)}.btn-send-message svg{width:16px;height:16px}@media (max-width: 600px){.admin-tickets-modal{max-width:100%;margin:var(--space-sm);max-height:calc(100vh - var(--space-lg))}.ticket-detail-meta{flex-direction:column;align-items:flex-start;gap:var(--space-xs)}.detail-separator{display:none}.pagination-info{min-width:auto;font-size:.75rem}.resolution-meta{flex-direction:column;gap:var(--space-xs)}.message-form-actions{flex-direction:column;gap:var(--space-sm)}.btn-send-message{width:100%}}.header{background-color:var(--bg-primary);border-bottom:1px solid var(--border-color);padding:var(--space-md) var(--space-lg);transition:background-color var(--transition-normal),border-color var(--transition-normal)}.header-content{display:flex;align-items:center;justify-content:space-between}.header-left{display:flex;align-items:center;gap:var(--space-lg)}.admin-icons{display:flex;align-items:center;gap:var(--space-xs);padding-left:var(--space-md);border-left:1px solid var(--border-color)}.admin-icon-btn{display:flex;align-items:center;justify-content:center;width:44px;height:44px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.admin-icon-btn:hover{background:var(--bg-hover);color:var(--data-green);border-color:var(--data-green)}.admin-icon-btn svg{width:20px;height:20px}.admin-icon-btn-with-badge{position:relative}.notification-badge{position:absolute;top:-4px;right:-4px;min-width:18px;height:18px;padding:0 5px;background:var(--error-red);color:#fff;font-size:.65rem;font-weight:700;border-radius:9px;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 4px #0003;animation:badge-pulse 2s ease-in-out infinite}@keyframes badge-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.logo{display:flex;align-items:center;gap:var(--space-md)}.logo-icon{width:40px;height:40px;object-fit:contain}.logo-text{font-size:1.5rem;letter-spacing:.05em}.logo-data{font-weight:400;color:var(--text-primary)}.logo-silo{font-weight:700;color:var(--text-primary)}.logo-text-container{display:flex;flex-direction:column;gap:0}.logo-company{font-size:.75rem;color:var(--data-green);letter-spacing:.1em;text-transform:uppercase;font-weight:500}.header-right{display:flex;align-items:center;gap:var(--space-md)}.plan-quota-card{display:flex;flex-direction:row;align-items:stretch;height:44px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);overflow:hidden}.plan-icon-col{display:flex;align-items:center;justify-content:center;width:44px;border-right:2px solid var(--data-green)}.plan-icon-col svg{width:22px;height:22px}.plan-details-col{display:flex;flex-direction:column;justify-content:center;gap:0;padding:0 var(--space-md);min-width:90px}.plan-name{font-size:.75rem;font-weight:600;color:var(--text-primary);line-height:1.2}.plan-unlimited-text{font-size:.6875rem;font-weight:500;color:var(--data-green);line-height:1.2}.quota-info{display:flex;align-items:center;gap:var(--space-xs);font-family:JetBrains Mono,monospace;font-size:.6875rem;line-height:1.2}.quota-count{color:var(--data-green);font-weight:600}.quota-count.quota-warning{color:#f59e0b}.quota-count.quota-danger{color:var(--error-red)}.quota-separator,.quota-limit{color:var(--text-secondary)}.plan-quota-card.plan-demo{border-color:var(--text-secondary)}.plan-quota-card.plan-demo .plan-icon-col svg{color:var(--text-secondary)}.plan-quota-card.plan-operacional{border-color:var(--info-blue);background:var(--info-bg)}.plan-quota-card.plan-operacional .plan-icon-col svg,.plan-quota-card.plan-operacional .plan-name{color:var(--info-blue)}.plan-quota-card.plan-profissional{border-color:var(--data-green);background:#00ff881a}.plan-quota-card.plan-profissional .plan-icon-col svg,.plan-quota-card.plan-profissional .plan-name{color:var(--data-green)}.plan-quota-card.plan-enterprise{border-color:#f59e0b;background:#f59e0b1a}.plan-quota-card.plan-enterprise .plan-icon-col svg,.plan-quota-card.plan-enterprise .plan-name{color:#f59e0b}.plan-quota-card.quota-exceeded{border-color:var(--error-red);background:var(--error-bg)}.plan-quota-card.quota-exceeded .quota-count{color:var(--error-red)}.theme-toggle{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.theme-toggle:hover{background:var(--bg-hover);color:var(--data-green);border-color:var(--data-green)}.theme-toggle svg{width:20px;height:20px}.auth-section{position:relative}.login-button{display:flex;align-items:center;gap:var(--space-sm);height:44px;padding:0 var(--space-md);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:.8125rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.login-button:hover{background:var(--bg-hover);border-color:var(--data-green);color:var(--data-green)}.login-button svg{width:18px;height:18px}.user-menu-container{position:relative}.user-button{display:flex;align-items:center;gap:var(--space-sm);height:44px;padding:0 var(--space-sm) 0 4px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:.8125rem;cursor:pointer;transition:all var(--transition-fast)}.user-button:hover{background:var(--bg-hover);border-color:var(--data-green)}.user-avatar{width:36px;height:36px;background:var(--data-green);color:var(--graphite-black);border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.875rem}.user-name{max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chevron-icon{width:16px;height:16px;color:var(--text-secondary);transition:transform var(--transition-fast)}.chevron-icon.open{transform:rotate(180deg)}.user-dropdown{position:absolute;top:calc(100% + var(--space-xs));right:0;min-width:220px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:0 10px 30px #0000004d;z-index:100;overflow:hidden}.user-info{padding:var(--space-md);display:flex;flex-direction:column;gap:var(--space-xs)}.user-full-name{font-weight:600;color:var(--text-primary);white-space:nowrap}.user-email{font-size:.8125rem;color:var(--text-secondary)}.user-company{font-size:.75rem;color:var(--data-green)}.dropdown-divider{height:1px;background:var(--border-color)}.dropdown-item{display:flex;align-items:center;gap:var(--space-sm);width:100%;padding:var(--space-sm) var(--space-md);background:transparent;border:none;color:var(--text-primary);font-size:.875rem;cursor:pointer;transition:all var(--transition-fast);text-align:left}.dropdown-item:hover{background:var(--bg-secondary)}.dropdown-item svg{width:18px;height:18px}.logout-btn:hover{color:var(--error-red)}.logout-btn:hover svg{color:var(--error-red)}.dropdown-version{padding:var(--space-xs) var(--space-md);font-size:.75rem;color:var(--text-muted);text-align:center}@media (max-width: 600px){.header-content{flex-direction:column;gap:var(--space-sm);text-align:center}.header-left{flex-direction:column;gap:var(--space-sm)}.admin-icons{border-left:none;padding-left:0}.admin-icon-btn{width:40px;height:40px}.header-right{flex-direction:column;gap:var(--space-sm)}.user-name{display:none}.plan-quota-card{height:40px}.plan-icon-col{width:40px}.plan-icon-col svg{width:18px;height:18px}.plan-details-col{min-width:auto;padding:0 var(--space-sm)}.plan-name{font-size:.6875rem}.quota-info{font-size:.625rem}.login-button,.user-button{height:40px}.user-avatar{width:32px;height:32px}}.tabs{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border-color);padding-bottom:var(--space-xs)}.tabs-left{display:flex;gap:var(--space-xs)}.tabs-right{display:flex;align-items:center}.tab{padding:var(--space-sm) var(--space-lg);background:transparent;border:none;color:var(--text-secondary);font-size:1rem;font-weight:500;border-radius:var(--radius-md) var(--radius-md) 0 0;transition:all var(--transition-fast);position:relative}.tab.tab-icon{padding:var(--space-sm) var(--space-md);display:flex;align-items:center;justify-content:center;gap:var(--space-xs)}.tab-icon-wrapper{display:flex;align-items:center;justify-content:center}.tab-icon-wrapper svg{width:22px;height:22px}.tab-tooltip{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);background:var(--graphite-black);color:var(--text-primary);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);font-size:.75rem;font-weight:500;white-space:nowrap;opacity:0;visibility:hidden;transition:all var(--transition-fast);pointer-events:none;z-index:100;border:1px solid var(--border-color);box-shadow:0 4px 12px #0000004d}.tab-tooltip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:6px solid transparent;border-top-color:var(--border-color)}.tab:hover .tab-tooltip{opacity:1;visibility:visible}.tab:hover{color:var(--text-primary);background:var(--bg-secondary)}.tab.active{color:var(--data-green);background:var(--bg-secondary)}.tab.active:after{content:"";position:absolute;bottom:-1px;left:0;right:0;height:2px;background:var(--data-green)}.tab.locked{color:var(--text-secondary);opacity:.5;cursor:not-allowed}.tab.locked:hover{background:transparent;color:var(--text-secondary)}.tab.locked:hover .tab-tooltip{opacity:0;visibility:hidden}.lock-icon{width:12px;height:12px;position:absolute;top:4px;right:4px}.beta-badge{position:absolute;top:2px;right:2px;background:var(--warning-amber);color:var(--graphite-black);font-size:.5rem;font-weight:700;padding:1px 3px;border-radius:3px;line-height:1;letter-spacing:.5px}.report-problem-btn{position:relative;display:flex;align-items:center;justify-content:center;padding:var(--space-sm);background:transparent;border:none;color:var(--warning-amber);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.report-problem-btn:hover{background:#ffc1071a;color:var(--warning-amber)}.report-problem-btn svg{width:22px;height:22px}.report-tooltip{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);background:var(--graphite-black);color:var(--text-primary);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);font-size:.75rem;font-weight:500;white-space:nowrap;opacity:0;visibility:hidden;transition:all var(--transition-fast);pointer-events:none;z-index:100;border:1px solid var(--border-color);box-shadow:0 4px 12px #0000004d}.report-tooltip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:6px solid transparent;border-top-color:var(--border-color)}.report-problem-btn:hover .report-tooltip{opacity:1;visibility:visible}.report-problem-btn.has-notification{color:var(--error-red)}.report-problem-btn.has-notification:hover{background:#ef44441a}.report-notification-badge{position:absolute;top:2px;right:2px;min-width:16px;height:16px;padding:0 4px;background:var(--error-red);color:#fff;font-size:.625rem;font-weight:700;border-radius:8px;display:flex;align-items:center;justify-content:center;line-height:1;pointer-events:none}.tipo-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--space-md)}.tipo-modal{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-lg);width:100%;max-width:480px;display:flex;flex-direction:column;overflow:hidden}.tipo-modal-header{display:flex;flex-direction:column;align-items:center;gap:var(--space-sm);padding:var(--space-lg);padding-bottom:var(--space-md)}.tipo-modal-icon{width:56px;height:56px;display:flex;align-items:center;justify-content:center;background:#3b82f61a;border-radius:50%}.tipo-modal-icon svg{width:32px;height:32px;color:#3b82f6}.tipo-modal-header h2{margin:0;font-size:1.25rem;color:var(--text-primary);text-align:center}.tipo-modal-content{padding:0 var(--space-lg);padding-bottom:var(--space-lg);text-align:center}.tipo-modal-content p{margin:0 0 var(--space-sm) 0;font-size:.95rem;color:var(--text-primary);line-height:1.5}.tipo-modal-content p:last-child{margin-bottom:0}.tipo-modal-content strong{color:var(--data-green)}.tipo-hint{font-size:.85rem!important;color:var(--text-secondary)!important;margin-top:var(--space-md)!important}.tipo-modal-actions{display:flex;gap:var(--space-md);padding:var(--space-lg);border-top:1px solid var(--border-color);background:var(--bg-secondary)}.tipo-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);font-size:.9rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.tipo-btn svg{width:18px;height:18px;flex-shrink:0}.tipo-btn-secondary{background:transparent;border:1px solid var(--border-color);color:var(--text-secondary)}.tipo-btn-secondary:hover{background:var(--bg-hover);border-color:var(--text-secondary);color:var(--text-primary)}.tipo-btn-primary{background:var(--data-green);border:1px solid var(--data-green);color:var(--graphite-black)}.tipo-btn-primary:hover{background:#00cc6a;border-color:#00cc6a}@media (max-width: 480px){.tipo-modal{max-width:100%}.tipo-modal-actions{flex-direction:column}.tipo-btn{width:100%}}.ai-benefits-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:2000;padding:var(--space-md);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.ai-benefits-modal{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-lg);width:100%;max-width:560px;max-height:90vh;overflow-y:auto;box-shadow:0 25px 60px #00000080}.ai-benefits-header{text-align:center;padding:var(--space-xl) var(--space-xl) var(--space-lg);border-bottom:1px solid var(--border-color);background:linear-gradient(180deg,rgba(0,179,90,.05) 0%,transparent 100%)}.ai-benefits-icon{display:inline-flex;align-items:center;justify-content:center;width:64px;height:64px;background:linear-gradient(135deg,var(--data-green) 0%,#00cc6a 100%);border-radius:16px;margin-bottom:var(--space-md);box-shadow:0 8px 24px #00b35a4d}.ai-benefits-icon svg{width:32px;height:32px;color:var(--graphite-black)}.ai-benefits-header h2{font-size:1.375rem;font-weight:700;color:var(--text-primary);margin:0 0 var(--space-sm) 0}.ai-benefits-subtitle{font-size:.9375rem;color:var(--text-secondary);margin:0;line-height:1.5}.ai-benefits-content{padding:var(--space-lg);display:flex;flex-direction:column;gap:var(--space-md)}.ai-benefit-card{display:flex;align-items:flex-start;gap:var(--space-md);padding:var(--space-md);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);transition:all var(--transition-fast)}.ai-benefit-card:hover{border-color:var(--data-green);transform:translate(4px)}.ai-benefit-card.highlight{background:#00b35a14;border-color:#00b35a4d}.benefit-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:var(--bg-primary);border-radius:var(--radius-md);flex-shrink:0}.benefit-icon svg{width:20px;height:20px;color:var(--data-green)}.benefit-text h4{font-size:.9375rem;font-weight:600;color:var(--text-primary);margin:0 0 var(--space-xs) 0}.benefit-text p{font-size:.8125rem;color:var(--text-secondary);margin:0;line-height:1.5}.ai-benefits-footer{padding:var(--space-lg);border-top:1px solid var(--border-color);background:var(--bg-secondary)}.ai-benefits-cta{text-align:center;font-size:.875rem;color:var(--text-secondary);margin:0 0 var(--space-md) 0}.ai-benefits-actions{display:flex;gap:var(--space-md);justify-content:center}.ai-benefits-actions .btn-secondary{padding:var(--space-sm) var(--space-lg);background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);font-size:.875rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.ai-benefits-actions .btn-secondary:hover{background:var(--bg-hover);color:var(--text-primary)}.ai-benefits-actions .btn-primary{display:inline-flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-lg);background:var(--data-green);border:none;border-radius:var(--radius-md);color:var(--graphite-black);font-size:.875rem;font-weight:600;text-decoration:none;cursor:pointer;transition:all var(--transition-fast)}.ai-benefits-actions .btn-primary:hover{background:var(--data-green-hover)}.ai-benefits-actions .btn-primary svg{width:16px;height:16px}@media (max-width: 640px){.ai-benefits-modal{max-height:100vh;border-radius:0}.ai-benefits-header{padding:var(--space-lg)}.ai-benefits-icon{width:56px;height:56px}.ai-benefits-icon svg{width:28px;height:28px}.ai-benefits-header h2{font-size:1.25rem}.ai-benefits-actions{flex-direction:column}.ai-benefits-actions .btn-secondary,.ai-benefits-actions .btn-primary{width:100%;justify-content:center}}.hvi-tab{display:flex;flex-direction:column;gap:var(--space-xl)}.section{background:var(--bg-card);border-radius:var(--radius-lg);padding:var(--space-lg);transition:background-color var(--transition-normal)}.section-title{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin-bottom:var(--space-sm)}.section-description{color:var(--text-secondary);font-size:.875rem;margin-bottom:var(--space-lg)}.drop-zone{border:2px dashed var(--text-secondary);border-radius:var(--radius-md);padding:var(--space-2xl);text-align:center;cursor:pointer;transition:all var(--transition-normal);background:var(--bg-input)}.drop-zone:hover{border-color:var(--data-green);background:var(--bg-hover)}.drop-zone.has-files{border-color:var(--data-green);border-style:solid}.drop-zone-content{display:flex;flex-direction:column;align-items:center;gap:var(--space-sm)}.upload-icon{width:48px;height:48px;color:var(--text-secondary)}.drop-zone:hover .upload-icon{color:var(--data-green)}.drop-zone-text{font-size:1rem;color:var(--text-primary)}.drop-zone-hint{font-size:.75rem;color:var(--text-secondary)}.file-list{margin-top:var(--space-md);border:1px solid var(--border-light);border-radius:var(--radius-md);overflow:hidden}.file-list-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-sm) var(--space-md);background:var(--bg-input);font-size:.875rem;color:var(--text-secondary)}.btn-link{background:none;border:none;color:var(--data-green);font-size:.875rem;cursor:pointer}.btn-link:hover{text-decoration:underline}.file-items-container{max-height:200px;overflow-y:auto}.file-items-container::-webkit-scrollbar{width:6px}.file-items-container::-webkit-scrollbar-track{background:var(--bg-input)}.file-items-container::-webkit-scrollbar-thumb{background:var(--border-light);border-radius:3px}.file-items-container::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}.file-item{display:flex;align-items:center;padding:var(--space-sm) var(--space-md);border-top:1px solid var(--border-light);gap:var(--space-md)}.file-name{flex:1;font-size:.875rem;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-size{font-size:.75rem;color:var(--text-secondary);font-family:JetBrains Mono,monospace}.btn-remove{background:none;border:none;color:var(--error-red);font-size:.875rem;padding:var(--space-xs);cursor:pointer;opacity:.7}.btn-remove:hover{opacity:1}.btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);background:var(--data-green);color:var(--graphite-black);border:none;padding:var(--space-md) var(--space-xl);font-size:1rem;font-weight:600;border-radius:var(--radius-md);margin-top:var(--space-lg);transition:all var(--transition-fast);min-width:200px}.btn-primary:hover:not(:disabled){background:var(--data-green-hover)}.btn-primary:disabled{background:var(--light-gray);color:var(--text-muted);cursor:not-allowed}.spinner{width:18px;height:18px;border:2px solid transparent;border-top-color:currentColor;border-radius:50%;animation:spin .8s linear infinite}.results-section{background:var(--bg-primary);border:1px solid var(--border-color)}.processing-steps{display:flex;justify-content:space-between;align-items:flex-start;padding:var(--space-lg) var(--space-md);margin-bottom:var(--space-md);background:var(--bg-input);border-radius:var(--radius-md);gap:var(--space-xs)}.step-item{display:flex;flex-direction:column;align-items:center;gap:var(--space-xs);flex:1;text-align:center;position:relative}.step-item:not(:last-child):after{content:"";position:absolute;top:14px;left:calc(50% + 16px);width:calc(100% - 32px);height:2px;background:var(--border-light);z-index:0}.step-item.step-completed:not(:last-child):after{background:var(--data-green)}.step-indicator{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:600;position:relative;z-index:1;transition:all .3s ease}.step-item.step-pending .step-indicator{background:var(--bg-card);border:2px solid var(--border-light);color:var(--text-muted)}.step-item.step-active .step-indicator{background:var(--success-bg);border:2px solid var(--data-green);color:var(--data-green)}.step-item.step-completed .step-indicator{background:var(--data-green);border:2px solid var(--data-green);color:var(--graphite-black)}.step-item.step-completed .step-indicator svg{width:14px;height:14px}.step-item.step-error .step-indicator{background:var(--error-bg);border:2px solid var(--error-red);color:var(--error-red)}.step-item.step-error .step-indicator svg{width:12px;height:12px}.step-spinner{width:14px;height:14px;border:2px solid transparent;border-top-color:var(--data-green);border-radius:50%;animation:spin .8s linear infinite}.step-number{font-size:.75rem}.step-label{font-size:.6875rem;color:var(--text-secondary);max-width:80px;line-height:1.3}.step-item.step-active .step-label{color:var(--text-primary);font-weight:500}.step-item.step-completed .step-label{color:var(--data-green)}.step-item.step-error .step-label{color:var(--error-red)}.step-percent{font-weight:600;color:var(--data-green)}.step-item.step-active .step-percent{color:var(--data-green)}.step-progress-bar{width:100%;max-width:60px;height:4px;background:var(--border-light);border-radius:2px;overflow:hidden;margin-top:4px}.step-progress-fill{height:100%;background:var(--data-green);border-radius:2px;transition:width .3s ease}.step-progress-bar.ai-progress .step-progress-fill{background:var(--data-green)}.status-message{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-md);border-radius:var(--radius-md);font-size:.875rem;margin-bottom:var(--space-md)}.status-message.status-extracting,.status-message.status-generating-summary,.status-message.status-generating-quantitative,.status-message.status-saving,.status-message.status-cleaning{background:var(--success-bg);color:var(--text-primary);border:1px solid var(--data-green)}.status-message.status-ai-extraction{background:var(--success-bg);color:var(--text-primary);border:1px solid var(--data-green);animation:ai-pulse 2s ease-in-out infinite}@keyframes ai-pulse{0%,to{box-shadow:0 0 #22c55e33}50%{box-shadow:0 0 15px 5px #22c55e1a}}.status-message.status-success{background:var(--success-bg);color:var(--data-green)}.status-message.status-error{background:var(--error-bg);color:var(--error-red)}.subsection-title{font-size:1rem;font-weight:500;color:var(--text-primary);margin-bottom:var(--space-md)}.extract-results{margin-bottom:var(--space-lg)}.result-item{display:flex;justify-content:space-between;align-items:center;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);margin-bottom:var(--space-xs);font-size:.875rem}.result-item.success{background:var(--success-bg)}.result-item.error{background:var(--error-bg)}.result-filename{color:var(--text-primary)}.result-status{color:var(--data-green);font-family:JetBrains Mono,monospace}.result-error{color:var(--error-red)}.result-item.quota-exceeded{background:var(--warning-bg);border:1px solid var(--warning-amber)}.result-quota-exceeded{color:var(--warning-amber);font-size:.8125rem}.btn-ai-upgrade{display:inline-flex;align-items:center;gap:var(--space-xs);padding:var(--space-xs) var(--space-sm);background:linear-gradient(135deg,var(--data-green) 0%,#00cc6a 100%);border:none;border-radius:var(--radius-sm);color:var(--graphite-black);font-size:.75rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast);margin-left:var(--space-sm);flex-shrink:0}.btn-ai-upgrade:hover{transform:translateY(-1px);box-shadow:0 4px 12px #00b35a4d}.btn-ai-upgrade svg{width:14px;height:14px}.summary-result{padding-top:var(--space-md);border-top:1px solid var(--border-color)}.summary-info{margin-bottom:var(--space-md)}.summary-info p{color:var(--text-primary);margin-bottom:var(--space-sm)}.summary-metadata{display:flex;gap:var(--space-lg);font-size:.875rem;color:var(--text-secondary);font-family:JetBrains Mono,monospace}.btn-download{display:inline-flex;align-items:center;gap:var(--space-sm);background:var(--data-green);color:var(--graphite-black);border:none;padding:var(--space-md) var(--space-lg);font-size:1rem;font-weight:600;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.btn-download:hover{background:var(--data-green-hover)}.btn-download svg{width:20px;height:20px}.generated-files{padding-top:var(--space-md);border-top:1px solid var(--border-color)}.file-result{display:flex;justify-content:space-between;align-items:center;padding:var(--space-md);background:var(--success-bg);border-radius:var(--radius-md);margin-bottom:var(--space-sm)}.file-result-info{display:flex;flex-direction:column;gap:var(--space-xs)}.file-result-name{font-size:.9375rem;font-weight:500;color:var(--text-primary)}.file-result-meta{font-size:.75rem;color:var(--text-secondary);font-family:JetBrains Mono,monospace}.login-required{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:var(--space-2xl) var(--space-lg);background:var(--bg-card);border-radius:var(--radius-lg);min-height:400px}.login-required-icon{width:64px;height:64px;color:var(--text-secondary);margin-bottom:var(--space-lg);opacity:.5}.login-required-title{font-size:1.5rem;font-weight:600;color:var(--text-primary);margin-bottom:var(--space-md)}.login-required-message{font-size:1rem;color:var(--text-secondary);margin-bottom:var(--space-sm)}.login-required-hint{font-size:.875rem;color:var(--text-secondary);opacity:.7}.login-required.quota-exceeded{border:1px solid var(--error-red);background:var(--error-bg)}.login-required.quota-exceeded .login-required-icon{color:var(--error-red);opacity:.8}.login-required.quota-exceeded .login-required-title{color:var(--error-red)}.submit-message{padding:var(--space-md);border-radius:var(--radius-md);font-size:.875rem;margin-top:var(--space-md)}.submit-message-success{background:var(--success-bg);color:var(--data-green);border:1px solid var(--data-green)}.submit-message-error{background:var(--error-bg);color:var(--error-red);border:1px solid var(--error-red)}.batch-info{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);border-top:1px solid var(--border-light);background:var(--success-bg)}.batch-icon{width:32px;height:32px;color:var(--data-green);flex-shrink:0}.batch-details{display:flex;flex-direction:column;gap:var(--space-xs)}.batch-count{font-size:.9375rem;font-weight:500;color:var(--text-primary)}.batch-size{font-size:.75rem;color:var(--text-secondary);font-family:JetBrains Mono,monospace}.download-tab{display:flex;flex-direction:column;gap:var(--space-xl)}.download-tab .section{background:var(--bg-card);border-radius:var(--radius-lg);padding:var(--space-lg);transition:background-color var(--transition-normal)}.download-tab .section-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space-lg)}.download-tab .section-title{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin-bottom:var(--space-sm)}.download-tab .section-description{color:var(--text-secondary);font-size:.875rem}.download-tab .btn-refresh{display:flex;align-items:center;justify-content:center;background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--space-sm);cursor:pointer;transition:all var(--transition-fast);width:40px;height:40px}.download-tab .btn-refresh:hover:not(:disabled){background:var(--bg-hover);border-color:var(--data-green)}.download-tab .btn-refresh:disabled{opacity:.6;cursor:not-allowed}.download-tab .btn-refresh svg{width:20px;height:20px;color:var(--text-secondary)}.download-tab .btn-refresh:hover:not(:disabled) svg{color:var(--data-green)}.download-tab .loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-2xl);gap:var(--space-md)}.download-tab .loading-state p{color:var(--text-secondary)}.download-tab .spinner{width:18px;height:18px;border:2px solid transparent;border-top-color:currentColor;border-radius:50%;animation:spin .8s linear infinite}.download-tab .spinner-lg{width:32px;height:32px;border-width:3px}.download-tab .spinner-sm{width:14px;height:14px;border-width:2px}.download-tab .spinner-xs{width:12px;height:12px;border-width:2px}.download-tab .error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-2xl);gap:var(--space-md);color:var(--error-red)}.download-tab .error-state svg{width:48px;height:48px;opacity:.8}.download-tab .error-state p{text-align:center}.download-tab .btn-retry{background:var(--error-red);color:#fff;border:none;padding:var(--space-sm) var(--space-lg);border-radius:var(--radius-md);cursor:pointer;font-size:.875rem;transition:opacity var(--transition-fast)}.download-tab .btn-retry:hover{opacity:.9}.download-tab .empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-2xl);gap:var(--space-md);color:var(--text-secondary)}.download-tab .empty-state svg{width:48px;height:48px;opacity:.5}.download-tab .empty-hint{font-size:.75rem;opacity:.7}.download-tab .producers-summary{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-md)}.download-tab .producers-count{font-size:.875rem;color:var(--text-secondary)}.download-tab .pagination-controls{display:flex;align-items:center;gap:var(--space-sm)}.download-tab .btn-pagination{display:flex;align-items:center;justify-content:center;background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:var(--space-xs);cursor:pointer;transition:all var(--transition-fast);width:32px;height:32px}.download-tab .btn-pagination:hover:not(:disabled){background:var(--bg-hover);border-color:var(--data-green)}.download-tab .btn-pagination:hover:not(:disabled) svg{color:var(--data-green)}.download-tab .btn-pagination:disabled{opacity:.4;cursor:not-allowed}.download-tab .btn-pagination svg{width:16px;height:16px;color:var(--text-secondary)}.download-tab .pagination-info{font-size:.875rem;color:var(--text-primary);font-weight:500;min-width:60px;text-align:center}.download-tab .producers-accordion{display:flex;flex-direction:column;gap:var(--space-sm)}.download-tab .producer-accordion-item{border:1px solid var(--border-color);border-radius:var(--radius-md);overflow:hidden;transition:border-color var(--transition-fast)}.download-tab .producer-accordion-item:hover{border-color:var(--data-green)}.download-tab .producer-accordion-header{display:flex;justify-content:space-between;align-items:center;width:100%;padding:var(--space-sm) var(--space-lg);background:var(--bg-input);border:none;transition:background-color var(--transition-fast)}.download-tab .producer-accordion-header:hover{background:var(--bg-hover)}.download-tab .producer-accordion-header.expanded{background:var(--bg-hover);border-bottom:1px solid var(--border-color)}.download-tab .producer-header-toggle{display:flex;justify-content:space-between;align-items:center;flex:1;background:none;border:none;cursor:pointer;padding:var(--space-sm) 0}.download-tab .btn-delete-producer{display:flex;align-items:center;justify-content:center;background:transparent;border:1px solid var(--error-red);border-radius:var(--radius-sm);padding:var(--space-sm);cursor:pointer;transition:all var(--transition-fast);margin-left:var(--space-md);color:var(--error-red)}.download-tab .btn-delete-producer:hover:not(:disabled){background:var(--error-red);color:#fff}.download-tab .btn-delete-producer:disabled{opacity:.6;cursor:not-allowed}.download-tab .btn-delete-producer svg{width:16px;height:16px}.download-tab .producer-header-info{display:flex;flex-direction:column;align-items:flex-start;gap:var(--space-xs)}.download-tab .producer-name{font-size:1rem;font-weight:500;color:var(--text-primary)}.download-tab .producer-file-count{font-size:.75rem;color:var(--text-secondary);display:flex;align-items:center;gap:var(--space-xs)}.download-tab .file-type-counts{opacity:.7}.download-tab .chevron-icon{width:20px;height:20px;color:var(--text-secondary);transition:transform var(--transition-fast)}.download-tab .producer-accordion-header.expanded .chevron-icon{transform:rotate(180deg)}.download-tab .producer-accordion-content{padding:var(--space-md);background:var(--bg-primary)}.download-tab .files-columns{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-lg)}@media (max-width: 768px){.download-tab .files-columns{grid-template-columns:1fr}}.download-tab .files-column{display:flex;flex-direction:column}.download-tab .column-header{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:var(--bg-input);border-radius:var(--radius-sm);margin-bottom:var(--space-sm);font-weight:500;color:var(--text-primary);font-size:.875rem}.download-tab .column-header svg{width:16px;height:16px;color:var(--data-green)}.download-tab .column-count{color:var(--text-secondary);font-weight:400}.download-tab .column-files{display:flex;flex-direction:column;min-height:60px}.download-tab .file-list-empty{display:flex;align-items:center;justify-content:center;padding:var(--space-lg);color:var(--text-secondary);font-size:.875rem;opacity:.6;font-style:italic}.download-tab .file-item{display:flex;justify-content:space-between;align-items:center;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);transition:background-color var(--transition-fast)}.download-tab .file-item:hover{background:var(--bg-hover)}.download-tab .file-info{display:flex;flex-direction:column;gap:var(--space-xs);min-width:0;flex:1}.download-tab .file-name{font-size:.8rem;color:var(--text-primary);font-family:JetBrains Mono,monospace;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.download-tab .file-date{font-size:.7rem;color:var(--text-secondary)}.download-tab .btn-download-sm{display:flex;align-items:center;justify-content:center;background:var(--data-green);color:var(--graphite-black);border:none;border-radius:var(--radius-sm);padding:var(--space-sm);cursor:pointer;transition:background-color var(--transition-fast);flex-shrink:0}.download-tab .btn-download-sm:hover{background:var(--data-green-hover)}.download-tab .btn-download-sm svg{width:14px;height:14px}.download-tab .file-actions{display:flex;align-items:center;gap:var(--space-xs);flex-shrink:0;margin-left:var(--space-sm)}.download-tab .btn-delete-sm{display:flex;align-items:center;justify-content:center;background:transparent;border:1px solid var(--error-red);border-radius:var(--radius-sm);padding:var(--space-sm);cursor:pointer;transition:all var(--transition-fast);color:var(--error-red);flex-shrink:0}.download-tab .btn-delete-sm:hover:not(:disabled){background:var(--error-red);color:#fff}.download-tab .btn-delete-sm:disabled{opacity:.6;cursor:not-allowed}.download-tab .btn-delete-sm svg{width:12px;height:12px}.download-tab .files-limit-notice{padding:var(--space-sm) var(--space-md);font-size:.75rem;color:var(--text-secondary);text-align:center;border-top:1px dashed var(--border-color);margin-top:var(--space-xs)}.download-tab .jobs-list{display:flex;flex-direction:column;gap:var(--space-md)}.download-tab .job-card{background:var(--bg-input);border-radius:var(--radius-md);border:1px solid var(--border-color);transition:border-color var(--transition-fast);overflow:hidden}.download-tab .job-card:hover{border-color:var(--data-green)}.download-tab .job-card-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-sm) var(--space-md);background:var(--bg-hover);border-bottom:1px solid var(--border-color)}.download-tab .job-meta{display:flex;align-items:center;gap:var(--space-md);flex-wrap:wrap}.download-tab .job-date{font-size:.875rem;font-weight:500;color:var(--text-primary)}.download-tab .job-lot{font-size:.75rem;color:var(--data-green);background:#4caf501a;padding:2px 8px;border-radius:var(--radius-sm)}.download-tab .job-rows{font-size:.75rem;color:var(--text-secondary)}.download-tab .btn-delete-job{display:flex;align-items:center;justify-content:center;background:transparent;border:1px solid var(--error-red);border-radius:var(--radius-sm);padding:6px;cursor:pointer;transition:all var(--transition-fast);color:var(--error-red)}.download-tab .btn-delete-job:hover:not(:disabled){background:var(--error-red);color:#fff}.download-tab .btn-delete-job:disabled{opacity:.6;cursor:not-allowed}.download-tab .btn-delete-job svg{width:14px;height:14px}.download-tab .job-card-body{padding:var(--space-md);display:flex;flex-direction:column;gap:var(--space-sm)}.download-tab .file-row{display:flex;align-items:flex-start;gap:var(--space-md)}.download-tab .file-label{font-size:.75rem;font-weight:500;color:var(--text-secondary);min-width:70px;padding-top:4px}.download-tab .file-list{display:flex;flex-wrap:wrap;gap:var(--space-xs);flex:1}.download-tab .input-file-tag{display:flex;align-items:center;gap:var(--space-xs);background:var(--bg-primary);padding:4px 10px;border-radius:var(--radius-sm);font-size:.8rem;color:var(--text-secondary);max-width:300px;border:1px solid var(--border-color)}.download-tab .input-filename{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.download-tab .file-type-icon{width:14px;height:14px;flex-shrink:0}.download-tab .file-type-icon.pdf{color:#e74c3c}.download-tab .file-type-icon.excel{color:#27ae60}.download-tab .file-original-row{margin-bottom:var(--space-sm)}.download-tab .file-download-item{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-xs) 0}.download-tab .file-download-item .file-type-icon{width:16px;height:16px;flex-shrink:0}.download-tab .file-link{color:var(--data-green);text-decoration:none;font-size:.85rem;font-family:JetBrains Mono,monospace;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.download-tab .file-link:hover{text-decoration:underline;color:var(--data-green-hover)}.download-tab .file-name-no-link{color:var(--text-secondary);font-size:.85rem;font-family:JetBrains Mono,monospace;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.download-tab .download-buttons{display:flex;flex-wrap:wrap;gap:var(--space-sm)}.download-tab .btn-download-type{display:flex;align-items:center;gap:var(--space-xs);padding:6px 12px;border-radius:var(--radius-sm);font-size:.8rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast);border:none;text-decoration:none}.download-tab .btn-download-type svg{width:14px;height:14px}.download-tab .btn-download-type.summary{background:var(--data-green);color:var(--graphite-black)}.download-tab .btn-download-type.summary:hover{background:var(--data-green-hover)}.download-tab .btn-download-type.qualitative{background:var(--info-blue);color:var(--graphite-black)}.download-tab .btn-download-type.qualitative:hover{opacity:.85}.stock-search-tab{display:flex;flex-direction:column;gap:var(--space-lg)}.search-container{display:flex;flex-direction:column;gap:var(--space-md)}.search-input-wrapper{display:flex;gap:var(--space-sm)}.search-input{flex:1;background:var(--bg-secondary);border:2px solid var(--data-green);border-radius:var(--radius-md);padding:var(--space-md) var(--space-lg);color:var(--text-primary);font-size:1rem}.search-input:focus{outline:none;border-color:var(--data-green);box-shadow:0 0 0 3px #0f83}.search-input::placeholder{color:var(--text-muted)}.btn-search{background:var(--data-green);border:none;border-radius:var(--radius-md);padding:var(--space-md);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);min-width:48px}.btn-search:hover:not(:disabled){opacity:.9}.btn-search:disabled{opacity:.5;cursor:not-allowed}.btn-search svg{width:20px;height:20px;color:var(--graphite-black)}.examples-section{display:flex;flex-direction:column;gap:var(--space-xs)}.examples-label{font-size:.75rem;color:var(--text-secondary)}.example-chip{background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-secondary);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-full);font-size:.75rem;cursor:pointer;transition:all var(--transition-fast)}.example-chip:hover{border-color:var(--data-green);color:var(--data-green)}.search-meta{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--space-md);margin-bottom:var(--space-md)}.meta-row{display:flex;gap:var(--space-sm);margin-bottom:var(--space-xs)}.meta-row:last-child{margin-bottom:0}.meta-label{font-size:.875rem;color:var(--text-secondary);min-width:100px}.meta-value{font-size:.875rem;color:var(--text-primary)}.meta-value.highlight{color:var(--data-green);font-weight:600}.filters-applied{display:flex;flex-direction:column;gap:var(--space-xs);margin-bottom:var(--space-md)}.filters-label{font-size:.75rem;color:var(--text-secondary)}.filters-list{display:flex;flex-wrap:wrap;gap:var(--space-xs)}.filter-chip{background:#00ff881a;border:1px solid var(--data-green);color:var(--data-green);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-full);font-size:.75rem;font-family:monospace}.lots-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--space-md)}.lot-card{background:linear-gradient(145deg,var(--bg-tertiary),var(--bg-secondary));border:2px solid var(--border-color);border-left:4px solid var(--data-green);border-radius:var(--radius-md);padding:var(--space-md);transition:all var(--transition-fast);box-shadow:0 4px 6px #0000004d,0 1px 3px #0003,inset 0 1px #ffffff0d}.lot-card:hover{border-color:var(--data-green);transform:translateY(-2px);box-shadow:0 8px 12px #0006,0 4px 6px #00ff8826,inset 0 1px #ffffff14}.lot-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space-sm);padding-bottom:var(--space-sm);border-bottom:1px solid var(--border-color)}.lot-identifiers{display:flex;flex-direction:column;gap:2px}.lot-id{font-weight:600;color:var(--data-green);font-size:.875rem}.lot-fardo{font-size:.75rem;color:var(--text-secondary);font-family:monospace}.lot-producer{font-size:.75rem;color:var(--text-secondary);text-align:right;max-width:50%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lot-metrics{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-xs)}.metric{display:flex;flex-direction:column;align-items:center;padding:var(--space-xs);background:var(--bg-tertiary);border-radius:var(--radius-sm)}.metric-name{font-size:.625rem;color:var(--text-muted);text-transform:uppercase}.metric-val{font-size:.875rem;font-weight:600;color:var(--text-primary)}.no-results{text-align:center;padding:var(--space-xl);color:var(--text-secondary);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md)}.error-message{background:#ff47571a;border:1px solid var(--danger-red);color:var(--danger-red);padding:var(--space-md);border-radius:var(--radius-md)}.load-more-container{display:flex;justify-content:center;margin-top:var(--space-lg)}.btn-load-more{padding:var(--space-md) var(--space-xl);background:transparent;border:2px solid var(--data-green);color:var(--data-green);font-size:.875rem;font-weight:600;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.btn-load-more:hover{background:var(--data-green);color:var(--graphite-black)}.blending-simulator-tab{display:flex;flex-direction:column;gap:var(--space-xl)}.blending-input-section{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-xl)}.section-header{margin-bottom:var(--space-lg)}.section-header .section-title{display:flex;align-items:center;gap:var(--space-sm);font-size:1.25rem;font-weight:600;color:var(--text-primary);margin-bottom:var(--space-xs)}.section-header .section-title svg{width:24px;height:24px;color:var(--data-green)}.section-subtitle{color:var(--text-secondary);font-size:.875rem}.specs-container{display:flex;flex-direction:column;gap:var(--space-lg)}.specs-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:var(--space-md);border-bottom:1px solid var(--border-color)}.specs-title{font-size:.875rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.max-lots-control{display:flex;align-items:center;gap:var(--space-sm)}.max-lots-control label{font-size:.75rem;color:var(--text-secondary)}.max-lots-control select{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:var(--space-xs) var(--space-sm);color:var(--text-primary);font-size:.875rem;cursor:pointer}.specs-sliders{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--space-lg)}.spec-slider-group{display:flex;flex-direction:column;gap:var(--space-xs)}.spec-slider-header{display:flex;align-items:baseline;gap:var(--space-sm)}.spec-slider-label{font-size:.875rem;font-weight:600;color:var(--data-green);min-width:40px}.spec-slider-description{font-size:.75rem;color:var(--text-muted);flex:1}.spec-slider-value{font-size:.875rem;font-weight:600;color:var(--text-primary);min-width:60px;text-align:right}.spec-slider-wrapper{display:flex;flex-direction:column;gap:2px}.spec-slider{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:6px;border-radius:3px;background:linear-gradient(to right,var(--data-green) 0%,var(--data-green) var(--progress),rgba(255,255,255,.1) var(--progress),rgba(255,255,255,.1) 100%);outline:none;cursor:pointer;border:1px solid var(--border-color)}.spec-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:var(--data-green);cursor:pointer;border:2px solid var(--bg-secondary);box-shadow:0 2px 4px #0003;transition:transform var(--transition-fast)}.spec-slider::-webkit-slider-thumb:hover{transform:scale(1.1)}.spec-slider::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:var(--data-green);cursor:pointer;border:2px solid var(--bg-secondary);box-shadow:0 2px 4px #0003}.spec-slider-range{display:flex;justify-content:space-between;font-size:.625rem;color:var(--text-muted)}.btn-simulate{display:flex;align-items:center;justify-content:center;gap:var(--space-sm);width:100%;padding:var(--space-md) var(--space-xl);background:var(--data-green);border:none;border-radius:var(--radius-md);color:var(--graphite-black);font-size:1rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast);margin-top:var(--space-md)}.btn-simulate:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.btn-simulate:disabled{opacity:.6;cursor:not-allowed}.btn-simulate svg{width:18px;height:18px}.blending-results-section{display:flex;flex-direction:column;gap:var(--space-lg)}.status-card{display:flex;align-items:center;gap:var(--space-lg);padding:var(--space-lg);border-radius:var(--radius-lg);border:2px solid}.status-card.status-success{background:#00ff8814;border-color:var(--data-green)}.status-card.status-warning{background:#ffc10714;border-color:var(--warning-amber)}.status-icon{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.status-success .status-icon{background:var(--data-green)}.status-warning .status-icon{background:var(--warning-amber)}.status-icon svg{width:24px;height:24px;color:var(--graphite-black)}.status-content{flex:1;display:flex;flex-direction:column;gap:var(--space-xs)}.status-title{font-size:1.125rem;font-weight:600}.status-success .status-title{color:var(--data-green)}.status-warning .status-title{color:var(--warning-amber)}.status-subtitle{font-size:.875rem;color:var(--text-secondary)}.status-percentage{flex-shrink:0}.circular-progress{width:70px;height:70px}.circle-bg{fill:none;stroke:var(--bg-tertiary);stroke-width:3}.circle-progress{fill:none;stroke-width:3;stroke-linecap:round;transform:rotate(-90deg);transform-origin:50% 50%;transition:stroke-dasharray var(--transition-normal)}.status-success .circle-progress{stroke:var(--data-green)}.status-warning .circle-progress{stroke:var(--warning-amber)}.percentage-text{font-size:.5rem;font-weight:700;fill:var(--text-primary);text-anchor:middle}.warnings-list{display:flex;flex-direction:column;gap:var(--space-xs)}.warning-item{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:#ffc1071a;border:1px solid var(--warning-amber);border-radius:var(--radius-md);color:var(--warning-amber);font-size:.875rem}.warning-item svg{width:18px;height:18px;flex-shrink:0}.results-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:var(--space-lg)}.result-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-lg)}.card-title{display:flex;align-items:center;gap:var(--space-sm);font-size:.875rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:var(--space-md);padding-bottom:var(--space-sm);border-bottom:1px solid var(--border-color)}.card-title svg{width:18px;height:18px;color:var(--data-green)}.blend-composition{display:flex;flex-direction:column;gap:var(--space-md)}.blend-item{display:flex;flex-direction:column;gap:var(--space-xs)}.blend-item-header{display:flex;justify-content:space-between;align-items:flex-start}.blend-item-info{display:flex;flex-direction:column;gap:2px}.blend-item-lote{font-size:.875rem;font-weight:600;color:var(--data-green)}.blend-item-produtor{font-size:.75rem;color:var(--text-secondary)}.blend-item-percent{font-size:1rem;font-weight:700;color:var(--text-primary)}.blend-item-bar-container{height:8px;background:var(--bg-tertiary);border-radius:4px;overflow:hidden}.blend-item-bar{height:100%;background:linear-gradient(90deg,var(--data-green),rgba(0,255,136,.6));border-radius:4px;transition:width var(--transition-normal)}.blend-item-peso{font-size:.75rem;color:var(--text-muted)}.comparison-table{display:flex;flex-direction:column}.comparison-header{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:var(--bg-tertiary);border-radius:var(--radius-sm);font-size:.625rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:var(--space-xs)}.comparison-row{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);font-size:.875rem;transition:background var(--transition-fast)}.comparison-row:hover{background:var(--bg-tertiary)}.param-name{font-weight:600;color:var(--text-primary)}.param-target{color:var(--text-secondary)}.param-expected{color:var(--text-primary);font-weight:500}.param-variation{font-weight:600;text-align:right}.param-variation.variation-good{color:var(--data-green)}.param-variation.variation-ok{color:var(--warning-amber)}.param-variation.variation-bad{color:var(--danger-red)}.explanation-card .explanation-text{color:var(--text-primary);line-height:1.6;font-size:.875rem}.error-card{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-lg);background:#ff47571a;border:1px solid var(--danger-red);border-radius:var(--radius-lg);color:var(--danger-red)}.error-card svg{width:24px;height:24px;flex-shrink:0}@media (max-width: 768px){.specs-sliders,.results-grid{grid-template-columns:1fr}.status-card{flex-direction:column;text-align:center}.comparison-header,.comparison-row{grid-template-columns:1fr 1fr 1fr 1fr;font-size:.75rem}}.correction-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:2000;padding:var(--space-lg)}.correction-modal{background:var(--bg-card);border-radius:var(--radius-lg);width:100%;max-width:500px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 8px 32px #0000004d;border:1px solid var(--border-color)}.correction-modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--border-color)}.correction-modal-header h3{margin:0;font-size:16px;font-weight:600;color:var(--text-primary)}.correction-modal-close{background:none;border:none;font-size:24px;color:var(--text-muted);cursor:pointer;padding:0;line-height:1;transition:color var(--transition-fast)}.correction-modal-close:hover{color:var(--text-primary)}.correction-modal-body{padding:var(--space-lg);overflow-y:auto;flex:1}.correction-modal-filename{font-size:13px;color:var(--text-secondary);margin:0 0 var(--space-md) 0;padding:var(--space-sm) var(--space-md);background:var(--bg-secondary);border-radius:var(--radius-md)}.correction-modal-filename strong{color:var(--text-primary)}.correction-modal-field{margin-bottom:var(--space-md)}.correction-modal-field label{display:block;font-size:13px;font-weight:500;color:var(--text-secondary);margin-bottom:var(--space-sm)}.correction-modal-field textarea{width:100%;padding:var(--space-sm) var(--space-md);font-size:14px;color:var(--text-primary);background:var(--bg-secondary);border:2px solid var(--data-green);border-radius:var(--radius-md);resize:vertical;min-height:80px;font-family:inherit;box-shadow:0 0 0 3px #4caf5026}.correction-modal-field textarea:focus{outline:none;box-shadow:0 0 0 4px #4caf5040}.correction-modal-field textarea:disabled{opacity:.6;cursor:not-allowed}.correction-modal-field textarea::placeholder{color:var(--text-muted)}.correction-modal-examples{margin-bottom:var(--space-md)}.examples-label{display:block;font-size:12px;color:var(--text-muted);margin-bottom:var(--space-sm)}.example-btn{font-size:11px;padding:4px 10px;background:var(--bg-secondary);color:var(--text-secondary);border:1px solid var(--border-color);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast)}.example-btn:hover:not(:disabled){background:var(--bg-hover);color:var(--text-primary);border-color:var(--data-green)}.correction-modal-error{padding:var(--space-sm) var(--space-md);background:var(--error-bg);color:var(--error-red);border-radius:var(--radius-md);font-size:13px;margin-bottom:var(--space-md)}.correction-modal-result{padding:var(--space-md);border-radius:var(--radius-md);font-size:13px;margin-bottom:var(--space-md)}.correction-modal-result.success{background:var(--success-bg);border:1px solid var(--data-green)}.correction-modal-result.failure{background:var(--error-bg);border:1px solid var(--error-red)}.correction-modal-result.support-required{background:#2a2a1a;border:1px solid #d4a800}.correction-modal-result.support-required .result-message{color:#d4a800}.result-message{margin:0 0 var(--space-sm) 0;font-weight:500}.correction-modal-result.success .result-message{color:var(--data-green)}.result-queued{margin-top:var(--space-sm);font-size:12px;color:var(--text-secondary)}.result-queued p{margin:var(--space-xs) 0}.correction-modal-result.failure .result-message{color:var(--error-red)}.result-changes,.result-suggestions,.result-support-info{margin-top:var(--space-sm)}.result-support-info{background:#d4a8001a;padding:var(--space-sm);border-radius:var(--radius-sm)}.result-support-info strong{display:block;font-size:12px;color:#d4a800;margin-bottom:var(--space-xs)}.result-support-info ol{margin:0;padding-left:var(--space-lg);font-size:12px;color:var(--text-secondary)}.result-support-info li{margin-bottom:var(--space-xs)}.result-support-info code{background:var(--bg-secondary);padding:2px 6px;border-radius:var(--radius-sm);font-size:11px;color:var(--text-primary)}.result-changes strong,.result-suggestions strong{display:block;font-size:12px;color:var(--text-secondary);margin-bottom:var(--space-xs)}.result-changes ul,.result-suggestions ul{margin:0;padding-left:var(--space-md);font-size:12px}.result-changes li,.result-suggestions li{margin-bottom:var(--space-xs);color:var(--text-secondary)}.result-changes li:last-child,.result-suggestions li:last-child{margin-bottom:0}.change-field{font-weight:500;color:var(--text-primary)}.change-old{color:var(--error-red);text-decoration:line-through;margin:0 var(--space-xs)}.change-arrow{color:var(--text-muted);margin:0 var(--space-xs)}.change-new{color:var(--data-green);font-weight:500}.correction-modal-footer{display:flex;justify-content:flex-end;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);border-top:1px solid var(--border-color);background:var(--bg-secondary)}.correction-modal-btn{padding:var(--space-sm) var(--space-lg);font-size:13px;font-weight:500;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.correction-modal-btn.cancel{background:transparent;color:var(--text-secondary);border:1px solid var(--border-color)}.correction-modal-btn.cancel:hover:not(:disabled){background:var(--bg-hover);color:var(--text-primary)}.correction-modal-btn.submit{background:var(--data-green);color:var(--graphite-black);border:1px solid var(--data-green)}.correction-modal-btn.submit:hover:not(:disabled){background:var(--data-green-hover)}.correction-modal-btn:disabled{opacity:.5;cursor:not-allowed}.human-assist-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:2000}.human-assist-modal{background:var(--bg-card);border-radius:var(--radius-lg);width:90%;max-width:550px;max-height:85vh;display:flex;flex-direction:column;box-shadow:0 20px 40px #0000004d}.human-assist-modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--border-color)}.human-assist-modal-header h3{margin:0;font-size:16px;color:#f59e0b;display:flex;align-items:center;gap:var(--space-sm)}.human-assist-modal-header h3:before{content:"!";display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;background:#fef3c7;color:#f59e0b;border-radius:50%;font-weight:700;font-size:12px}.human-assist-modal-close{background:none;border:none;font-size:24px;color:var(--text-secondary);cursor:pointer;padding:0;line-height:1}.human-assist-modal-close:hover{color:var(--text-primary)}.human-assist-modal-body{flex:1;overflow-y:auto;padding:var(--space-lg)}.human-assist-modal-filename{font-size:13px;color:var(--text-secondary);margin:0 0 var(--space-md) 0}.human-assist-modal-filename strong{color:var(--text-primary)}.validation-errors-section{background:var(--bg-secondary);border-radius:var(--radius-md);padding:var(--space-md);margin-bottom:var(--space-lg);border-left:3px solid #f59e0b}.validation-errors-section h4{margin:0 0 var(--space-sm) 0;font-size:13px;color:#f59e0b;font-weight:600}.validation-errors-list{display:flex;flex-direction:column;gap:var(--space-sm)}.validation-error-group{display:flex;flex-direction:column;gap:4px}.validation-error-gate{font-size:12px;font-weight:600;color:var(--text-primary);padding:2px 0}.validation-error-item{display:flex;flex-direction:column;gap:2px;padding:var(--space-xs) var(--space-sm);background:var(--bg-primary);border-radius:var(--radius-sm);font-size:12px}.validation-error-item.severity-error{border-left:2px solid var(--error-red)}.validation-error-item.severity-warning{border-left:2px solid #f59e0b}.validation-error-field{font-weight:500;color:var(--text-primary)}.validation-error-message{color:var(--text-secondary)}.validation-error-details{display:flex;gap:var(--space-md);font-size:11px;color:var(--text-muted);margin-top:2px}.human-assist-modal-field{margin-bottom:var(--space-md)}.human-assist-modal-field label{display:block;font-size:13px;font-weight:500;color:var(--text-primary);margin-bottom:var(--space-xs)}.human-assist-modal-field textarea{width:100%;padding:var(--space-sm);border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:13px;background:var(--bg-primary);color:var(--text-primary);resize:vertical;font-family:inherit}.human-assist-modal-field textarea:focus{outline:none;border-color:#f59e0b;box-shadow:0 0 0 2px #f59e0b33}.human-assist-modal-field textarea:disabled{opacity:.6;cursor:not-allowed}.human-assist-modal-examples{margin-bottom:var(--space-md)}.examples-label{font-size:12px;color:var(--text-muted);display:block;margin-bottom:var(--space-xs)}.examples-list{display:flex;flex-wrap:wrap;gap:var(--space-xs)}.example-btn{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:4px 8px;font-size:11px;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.example-btn:hover:not(:disabled){background:#fef3c7;border-color:#f59e0b;color:#92400e}.example-btn:disabled{opacity:.5;cursor:not-allowed}.human-assist-modal-error{background:var(--error-bg);color:var(--error-red);padding:var(--space-sm);border-radius:var(--radius-sm);font-size:13px;margin-bottom:var(--space-md)}.human-assist-modal-result{padding:var(--space-md);border-radius:var(--radius-md);margin-bottom:var(--space-md)}.human-assist-modal-result.success{background:var(--success-bg);border:1px solid var(--data-green)}.human-assist-modal-result.needs-more{background:#fef3c7;border:1px solid #f59e0b}.human-assist-modal-result.failure{background:var(--error-bg);border:1px solid var(--error-red)}.result-message{font-size:13px;font-weight:500;margin:0 0 var(--space-sm) 0}.human-assist-modal-result.success .result-message{color:var(--data-green)}.human-assist-modal-result.needs-more .result-message{color:#92400e}.human-assist-modal-result.failure .result-message{color:var(--error-red)}.result-success p,.result-needs-more p,.result-failure p{margin:0 0 var(--space-xs) 0;font-size:12px;color:var(--text-secondary)}.human-assist-modal-footer{display:flex;justify-content:flex-end;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);border-top:1px solid var(--border-color)}.human-assist-modal-btn{padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);font-size:13px;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.human-assist-modal-btn.cancel{background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-secondary)}.human-assist-modal-btn.cancel:hover:not(:disabled){background:var(--bg-hover)}.human-assist-modal-btn.submit{background:#f59e0b;border:1px solid #f59e0b;color:#1c1917}.human-assist-modal-btn.submit:hover:not(:disabled){background:#d97706;border-color:#d97706}.human-assist-modal-btn:disabled{opacity:.5;cursor:not-allowed}.sidebar-container{position:relative;width:280px;min-width:280px;margin-right:calc(var(--space-lg) + 24px);z-index:5;overflow:visible;transition:width var(--transition-normal),min-width var(--transition-normal),margin-right var(--transition-normal)}.sidebar-container:has(.job-sidebar.closed){width:0;min-width:0;margin-right:calc(var(--space-sm) + 24px)}.job-sidebar{width:280px;background:var(--bg-card);display:flex;flex-direction:column;position:absolute;top:0;left:0;bottom:0;border-radius:var(--radius-lg);overflow:hidden;transform:translate(0);opacity:1;transition:transform var(--transition-normal),opacity var(--transition-normal)}.job-sidebar.closed{transform:translate(100%);opacity:0}.job-sidebar.open{transform:translate(0);opacity:1}.sidebar-toggle-btn{position:absolute;top:50%;right:-24px;transform:translateY(-50%);z-index:15;width:24px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--bg-card);border:1px solid var(--border-color);border-left:none;border-radius:0 var(--radius-md) var(--radius-md) 0;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);box-shadow:2px 0 8px #0000001a}.sidebar-container:has(.job-sidebar.closed) .sidebar-toggle-btn{right:-24px;border-left:1px solid var(--border-color);border-right:none;border-radius:var(--radius-md) 0 0 var(--radius-md);box-shadow:-2px 0 8px #0000001a}.sidebar-toggle-btn:hover{color:var(--data-green);background:var(--bg-secondary)}.sidebar-toggle-btn svg{width:16px;height:16px}.sidebar-toggle-btn .active-jobs-badge{position:absolute;top:4px;right:-8px;background:var(--data-green);color:var(--graphite-black);border-radius:50%;width:18px;height:18px;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:600}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md);border-bottom:1px solid var(--border-color);flex-shrink:0}.sidebar-title{font-size:14px;font-weight:600;color:var(--text-primary);display:flex;align-items:center;gap:var(--space-sm)}.sidebar-title svg{width:18px;height:18px;color:var(--data-green)}.sidebar-tab-icon,.sidebar-title-tooltip{display:none}.sidebar-content{flex:1;overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column}.active-jobs-badge{background:var(--data-green);color:var(--graphite-black);border-radius:50%;width:18px;height:18px;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:600}.sidebar-loading{padding:var(--space-lg) var(--space-md);text-align:center;color:var(--text-secondary);font-size:13px}.sidebar-empty{padding:var(--space-lg) var(--space-md);text-align:center;color:var(--text-secondary)}.sidebar-empty p{margin:0 0 var(--space-sm) 0;font-size:13px}.sidebar-empty-hint{font-size:11px;color:var(--text-muted)}.jobs-section{padding:var(--space-md)}.jobs-section h4{font-size:11px;color:var(--text-muted);margin:0 0 var(--space-sm) 0;text-transform:uppercase;letter-spacing:.5px}.section-header{display:flex;justify-content:flex-start;align-items:center;margin:0 0 var(--space-sm) 0;padding:0;gap:var(--space-sm)}.section-header h4{margin:0;padding:0;white-space:nowrap}.clear-all-btn{font-size:12px;color:var(--text-secondary);background:none;border:none;cursor:pointer;padding:4px 8px;margin-left:var(--space-sm);border-radius:var(--radius-sm);transition:all var(--transition-fast);white-space:nowrap;flex-shrink:0}.clear-all-btn:hover{background:var(--error-bg);color:var(--error-red)}.job-item{background:var(--bg-primary);border-radius:var(--radius-md);margin-bottom:var(--space-sm);overflow:hidden;border:2px solid var(--border-color);transition:box-shadow var(--transition-fast),border-color var(--transition-fast)}.job-item:hover{box-shadow:0 2px 8px #00000026}.job-item.job-pending{border-color:var(--border-color)}.job-item.job-processing{border-color:#3b82f6}.job-item.job-completed{border-color:var(--data-green)}.job-item.job-failed{border-color:var(--error-red)}.job-item.job-human_assist{border-color:#f59e0b}.job-header{display:flex;align-items:center;padding:10px 12px;cursor:pointer;gap:10px}.job-status-icon{width:20px;height:20px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.job-queue-icon{width:16px;height:16px;color:var(--text-muted)}.job-spinner{width:16px;height:16px;border:2px solid #3b82f6;border-top-color:transparent;border-radius:50%;animation:spin 1s linear infinite}.job-check{color:var(--data-green);font-weight:700;font-size:14px}.job-error{color:var(--error-red);font-weight:700;font-size:14px}.job-human-assist{color:#f59e0b;font-weight:700;font-size:14px;width:16px;height:16px;display:flex;align-items:center;justify-content:center;background:#fef3c7;border-radius:50%}.job-info{flex:1;min-width:0}.job-filename{display:block;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text-primary)}.job-meta{display:flex;align-items:center;gap:6px;margin-top:var(--space-xs)}.job-type-badge{font-size:10px;padding:1px 5px;border-radius:var(--radius-sm);font-weight:500}.job-type-mapped,.job-type-ai{background:var(--success-bg);color:var(--data-green)}.job-queue-pos{font-size:10px;color:var(--text-muted)}.job-datetime{font-size:10px;color:var(--text-muted);font-variant-numeric:tabular-nums}.job-progress-text{font-size:11px;color:var(--text-secondary)}.job-expand-bar{display:flex;align-items:center;justify-content:center;padding:4px 0;color:var(--text-muted);cursor:pointer;border-top:1px solid var(--border-light);transition:all var(--transition-fast)}.job-expand-bar:hover{background:var(--bg-hover);color:var(--text-secondary)}.job-expand-bar svg{width:14px;height:14px;transition:transform var(--transition-fast)}.job-expand-bar.expanded svg{transform:rotate(180deg)}.job-delete-btn{width:24px;height:24px;border:none;background:none;color:var(--text-muted);cursor:pointer;font-size:18px;line-height:1;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);flex-shrink:0;transition:all var(--transition-fast)}.job-delete-btn:hover:not(:disabled){background:var(--error-bg);color:var(--error-red)}.job-delete-btn:disabled{opacity:.3;cursor:not-allowed}.job-progress-detail{padding:0 12px 12px}.progress-bar{height:4px;background:var(--border-color);border-radius:2px;overflow:hidden;margin-bottom:6px}.progress-fill{height:100%;background:#3b82f6;transition:width .3s ease}.progress-message{font-size:11px;color:var(--text-muted);display:block}.job-files{padding:var(--space-sm) 12px 12px;border-top:1px solid var(--border-light)}.job-file-link{display:flex;align-items:center;gap:6px;padding:6px var(--space-sm);font-size:12px;color:var(--data-green);text-decoration:none;border-radius:var(--radius-sm);margin-bottom:var(--space-xs);transition:background-color var(--transition-fast)}.job-file-link:last-child{margin-bottom:0}.job-file-link:hover{background:var(--bg-hover)}.job-file-link svg{width:14px;height:14px;flex-shrink:0}.job-error-detail{padding:var(--space-sm) 12px 12px;font-size:11px;color:var(--error-red);border-top:1px solid var(--border-light);display:flex;flex-direction:column;gap:var(--space-sm)}.job-error-detail .error-message{word-break:break-word}.job-retry-btn{display:inline-flex;align-items:center;gap:4px;padding:6px 10px;font-size:11px;font-weight:500;color:var(--text-primary);background:var(--bg-hover);border:1px solid var(--border-color);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);align-self:flex-start}.job-retry-btn:hover{background:var(--data-green);color:var(--graphite-black);border-color:var(--data-green)}.job-retry-btn .retry-icon{width:12px;height:12px}.job-no-files{display:block;padding:6px var(--space-sm);font-size:12px;color:var(--text-muted);font-style:italic}.job-correct-btn{display:inline-flex;align-items:center;gap:4px;padding:6px 10px;font-size:11px;font-weight:500;color:var(--text-primary);background:var(--bg-hover);border:1px solid var(--border-color);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);margin-top:var(--space-sm);width:100%;justify-content:center}.job-correct-btn:hover{background:var(--data-green);color:var(--graphite-black);border-color:var(--data-green)}.job-correct-btn .edit-icon{width:12px;height:12px}.job-assist-btn{display:inline-flex;align-items:center;gap:4px;padding:8px 12px;font-size:12px;font-weight:500;color:#1c1917;background:#f59e0b;border:1px solid #f59e0b;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);margin-top:var(--space-sm);width:100%;justify-content:center}.job-assist-btn:hover{background:#d97706;border-color:#d97706}.job-assist-btn .assist-icon{width:14px;height:14px}.job-converted-excel{color:#f59e0b!important;background:#fef3c7;border:1px solid #fcd34d;margin-top:var(--space-sm);margin-bottom:var(--space-xs)}.job-converted-excel:hover{background:#fde68a!important}.sidebar-footer{margin-top:auto;padding:var(--space-sm) var(--space-md);border-top:1px solid var(--border-light);font-size:11px;color:var(--text-muted);text-align:center}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--space-md)}.modal-content{background:var(--bg-primary);border-radius:var(--radius-lg);max-width:500px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 50px #0000004d;border:1px solid var(--border-color)}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-lg);border-bottom:1px solid var(--border-color)}.modal-header h2{margin:0;font-size:1.25rem;font-weight:600;color:var(--text-primary)}.modal-close-btn{background:transparent;border:none;cursor:pointer;padding:var(--space-xs);border-radius:var(--radius-sm);color:var(--text-secondary);transition:all var(--transition-fast)}.modal-close-btn:hover{background:var(--bg-secondary);color:var(--text-primary)}.modal-close-btn svg{width:20px;height:20px;display:block}.report-form{padding:var(--space-lg);display:flex;flex-direction:column;gap:var(--space-md)}.form-group{display:flex;flex-direction:column;gap:var(--space-xs)}.form-group label{font-size:.875rem;font-weight:500;color:var(--text-secondary)}.form-group input,.form-group textarea{padding:var(--space-sm) var(--space-md);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:1rem;font-family:inherit;transition:all var(--transition-fast)}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--data-green);box-shadow:0 0 0 3px #22c55e1a}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--text-secondary);opacity:.6}.form-group input:disabled,.form-group textarea:disabled{opacity:.6;cursor:not-allowed}.form-group input.input-disabled{background:var(--bg-tertiary);color:var(--text-secondary);opacity:1}.form-group textarea{resize:vertical;min-height:100px}.drop-zone-mini{border:2px dashed var(--border-color);border-radius:var(--radius-md);padding:var(--space-md);text-align:center;cursor:pointer;transition:all var(--transition-fast)}.drop-zone-mini:hover{border-color:var(--data-green);background:#22c55e0d}.drop-zone-mini.has-files{border-color:var(--data-green)}.drop-zone-mini-content{display:flex;flex-direction:column;align-items:center;gap:var(--space-xs);color:var(--text-secondary)}.drop-zone-mini-content span{font-size:.875rem}.upload-icon-mini{width:24px;height:24px;color:var(--text-secondary)}.file-input{display:none}.file-list-mini{margin-top:var(--space-sm);display:flex;flex-direction:column;gap:var(--space-xs)}.file-item-mini{display:flex;align-items:center;justify-content:space-between;padding:var(--space-xs) var(--space-sm);background:var(--bg-secondary);border-radius:var(--radius-sm)}.file-name-mini{font-size:.875rem;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;margin-right:var(--space-sm)}.btn-remove-mini{background:transparent;border:none;color:var(--error-red);cursor:pointer;padding:var(--space-xs);font-size:.75rem;font-weight:600;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.btn-remove-mini:hover{background:#ef44441a}.btn-remove-mini:disabled{opacity:.5;cursor:not-allowed}.status-message-modal{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);font-size:.875rem}.status-message-modal.status-submitting{background:#38bdf81a;color:var(--info-blue)}.status-message-modal.status-success{background:#22c55e1a;color:var(--data-green)}.status-message-modal.status-error{background:#ef44441a;color:var(--error-red)}.form-actions{display:flex;gap:var(--space-md);margin-top:var(--space-sm)}.btn-cancel{flex:1;padding:var(--space-sm) var(--space-md);background:transparent;border:1px solid var(--border-color);color:var(--text-secondary);font-size:1rem;font-weight:500;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.btn-cancel:hover:not(:disabled){background:var(--bg-secondary);color:var(--text-primary)}.btn-cancel:disabled{opacity:.5;cursor:not-allowed}.btn-submit{flex:1;display:flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:var(--data-green);border:none;color:var(--graphite-black);font-size:1rem;font-weight:600;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.btn-submit:hover:not(:disabled){background:var(--data-green-hover)}.btn-submit:disabled{opacity:.7;cursor:not-allowed}.modal-content-wide{max-width:600px}.modal-tabs{display:flex;border-bottom:1px solid var(--border-color)}.modal-tab{flex:1;padding:var(--space-md);background:transparent;border:none;border-bottom:2px solid transparent;color:var(--text-secondary);font-size:.9375rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.modal-tab:hover{color:var(--text-primary);background:var(--bg-secondary)}.modal-tab.active{color:var(--data-green);border-bottom-color:var(--data-green)}.reports-list-container{padding:var(--space-lg);min-height:300px;max-height:500px;overflow-y:auto}.reports-loading,.reports-error,.reports-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-md);padding:var(--space-xl);color:var(--text-secondary)}.reports-loading .spinner{width:24px;height:24px}.reports-error{color:var(--error-red)}.btn-retry{padding:var(--space-xs) var(--space-md);background:transparent;border:1px solid var(--border-color);color:var(--text-secondary);border-radius:var(--radius-md);cursor:pointer;font-size:.875rem;transition:all var(--transition-fast)}.btn-retry:hover{background:var(--bg-secondary);color:var(--text-primary)}.reports-empty svg{width:48px;height:48px;color:var(--text-secondary);opacity:.5}.reports-list{display:flex;flex-direction:column;gap:var(--space-sm)}.report-item{border:1px solid var(--border-color);border-radius:var(--radius-md);overflow:hidden;transition:all var(--transition-fast)}.report-item:hover{border-color:var(--text-secondary)}.report-item.expanded{border-color:var(--data-green)}.report-item-header{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);cursor:pointer;background:var(--bg-secondary)}.report-item-header:hover{background:var(--bg-tertiary)}.report-status-indicator{flex-shrink:0}.status-dot{display:block;width:12px;height:12px;border-radius:50%;background:var(--warning-yellow)}.status-dot.pending{background:var(--warning-yellow)}.status-dot.resolved{background:var(--data-green)}.report-item-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:var(--space-xs)}.report-item-date{font-size:.75rem;color:var(--text-secondary)}.report-item-desc-row{display:flex;align-items:center;gap:var(--space-xs)}.status-icon{width:16px;height:16px;flex-shrink:0}.status-icon.pending{color:var(--warning-yellow)}.status-icon.resolved{color:var(--data-green)}.report-item-desc{font-size:.875rem;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.report-item-chevron{flex-shrink:0;transition:transform var(--transition-fast)}.report-item.expanded .report-item-chevron{transform:rotate(180deg)}.report-item-chevron svg{width:20px;height:20px;color:var(--text-secondary)}.report-item-details{padding:var(--space-md);border-top:1px solid var(--border-color);background:var(--bg-primary);display:flex;flex-wrap:wrap;gap:var(--space-md)}.report-detail-row{display:flex;flex-direction:column;gap:var(--space-xs);flex:1;min-width:150px}.report-detail-row.full-width{flex-basis:100%}.report-detail-row.solution{background:#22c55e1a;padding:var(--space-md);border-radius:var(--radius-md);border-left:3px solid var(--data-green)}.report-detail-label{font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.report-detail-value{font-size:.875rem;color:var(--text-primary)}.status-badge{display:inline-block;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);font-size:.75rem;font-weight:600;width:fit-content}.status-badge.pending{background:#facc1526;color:var(--warning-yellow)}.status-badge.resolved{background:#22c55e26;color:var(--data-green)}.report-files-list{display:flex;flex-direction:column;gap:var(--space-xs)}.report-file-link{font-size:.875rem;color:var(--data-green);text-decoration:none;transition:color var(--transition-fast)}.report-file-link:hover{color:var(--data-green);text-decoration:underline}.char-count{font-size:.75rem;color:var(--text-secondary);text-align:right;margin-top:var(--space-xs)}.char-count.error{color:var(--error-red)}.status-badge-inline{display:inline-flex;align-items:center;gap:var(--space-xs);padding:2px var(--space-sm);border-radius:var(--radius-sm);font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.3px}.status-badge-inline.open{background:#facc1526;color:var(--warning-yellow)}.status-badge-inline.resolved{background:#22c55e26;color:var(--data-green)}.pagination-controls{display:flex;align-items:center;justify-content:center;gap:var(--space-md);padding:var(--space-md);border-top:1px solid var(--border-color);background:var(--bg-secondary)}.pagination-btn{display:flex;align-items:center;justify-content:center;padding:var(--space-xs) var(--space-sm);background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:.875rem;cursor:pointer;transition:all var(--transition-fast);min-width:36px;height:36px}.pagination-btn:hover:not(:disabled){background:var(--bg-tertiary);border-color:var(--data-green);color:var(--data-green)}.pagination-btn:disabled{opacity:.4;cursor:not-allowed}.pagination-info{font-size:.875rem;color:var(--text-secondary);min-width:100px;text-align:center}.status-dot.open{background:var(--warning-yellow)}.status-icon.open{color:var(--warning-yellow)}.status-badge.open{background:#facc1526;color:var(--warning-yellow)}.status-badge.acknowledge,.status-badge-inline.acknowledge{background:#38bdf826;color:var(--info-blue)}.unread-indicator{width:8px;height:8px;background:var(--data-green);border-radius:50%;display:inline-block;margin-left:var(--space-xs);animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.report-item.has-notification{border-color:var(--data-green)}.report-item.has-notification .report-item-header{background:#22c55e0d}.messages-list{display:flex;flex-direction:column;gap:var(--space-sm);max-height:250px;overflow-y:auto;margin-top:var(--space-xs)}.messages-list.chat-style{padding:var(--space-sm);background:var(--bg-tertiary);border-radius:var(--radius-md)}.message-item{background:var(--bg-secondary);border-radius:var(--radius-md);padding:var(--space-md);border-left:3px solid var(--border-color)}.message-item.chat-bubble{max-width:80%;border-left:none;position:relative}.message-item.chat-bubble.from-user{align-self:flex-end;background:#22c55e26;border-radius:var(--radius-md) var(--radius-md) 4px var(--radius-md)}.message-item.chat-bubble.from-user .message-author{color:var(--data-green)}.message-item.chat-bubble.from-admin{align-self:flex-start;background:var(--bg-secondary);border-radius:var(--radius-md) var(--radius-md) var(--radius-md) 4px}.message-item.chat-bubble.from-admin .message-author{color:var(--info-blue)}.message-item.resolution{border-left-color:var(--data-green);background:#22c55e0d}.message-item.chat-bubble.resolution{background:#22c55e1a;border:1px solid rgba(34,197,94,.3)}.message-header{display:flex;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-xs);flex-wrap:wrap}.message-author{font-size:.8125rem;font-weight:600;color:var(--data-green)}.message-date{font-size:.75rem;color:var(--text-secondary)}.message-resolution-badge{font-size:.625rem;font-weight:600;text-transform:uppercase;padding:2px 6px;border-radius:var(--radius-sm);background:#22c55e26;color:var(--data-green)}.message-content{font-size:.875rem;color:var(--text-primary);line-height:1.5;margin:0;white-space:pre-wrap}.acknowledge-actions{background:#38bdf80d;padding:var(--space-md);border-radius:var(--radius-md);border-left:3px solid var(--info-blue)}.acknowledge-buttons{display:flex;align-items:center;gap:var(--space-md);margin-top:var(--space-sm);flex-wrap:wrap}.btn-confirm-closure{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:var(--data-green);border:none;border-radius:var(--radius-md);color:var(--graphite-black);font-size:.875rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.btn-confirm-closure:hover:not(:disabled){background:var(--data-green-hover)}.btn-confirm-closure:disabled{opacity:.6;cursor:not-allowed}.btn-confirm-closure svg{width:16px;height:16px}.acknowledge-or{font-size:.8125rem;color:var(--text-secondary);font-style:italic}.reply-section{border-top:1px solid var(--border-color);padding-top:var(--space-md);margin-top:var(--space-sm)}.reply-form{display:flex;flex-direction:column;gap:var(--space-sm);margin-top:var(--space-xs)}.reply-form textarea{width:100%;padding:var(--space-sm) var(--space-md);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:.875rem;font-family:inherit;resize:vertical;min-height:80px;transition:all var(--transition-fast)}.reply-form textarea:focus{outline:none;border-color:var(--data-green);box-shadow:0 0 0 3px #22c55e1a}.reply-form textarea::placeholder{color:var(--text-secondary);opacity:.6}.reply-form textarea:disabled{opacity:.6;cursor:not-allowed}.btn-send-reply{display:flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:var(--data-green);border:none;border-radius:var(--radius-md);color:var(--graphite-black);font-size:.875rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast);align-self:flex-end;min-width:120px}.btn-send-reply:hover:not(:disabled){background:var(--data-green-hover)}.btn-send-reply:disabled{opacity:.6;cursor:not-allowed}.btn-send-reply svg{width:16px;height:16px}.spinner-small{width:14px;height:14px;border:2px solid rgba(0,0,0,.2);border-top-color:var(--graphite-black);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.app{min-height:100vh;display:flex;flex-direction:column}.app-body{flex:1;display:flex;justify-content:center;padding:var(--space-lg)}.content-wrapper{display:flex;position:relative;max-width:1200px;width:100%}.main-content{flex:1;min-width:0;position:relative;z-index:10;background:var(--bg-primary)}.tab-content{margin-top:var(--space-lg)}:root{--graphite-black: #0F172A;--steel-gray: #334155;--data-green: #22C55E;--data-green-hover: #16A34A;--off-white: #F8FAFC;--light-gray: #CBD5E1;--info-blue: #38BDF8;--warning-amber: #FACC15;--error-red: #EF4444;--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-2xl: 48px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--transition-fast: .15s ease;--transition-normal: .25s ease}:root,:root[data-theme=dark]{--bg-primary: #0F172A;--bg-secondary: #334155;--bg-card: #334155;--bg-input: rgba(15, 23, 42, .5);--bg-hover: rgba(34, 197, 94, .05);--text-primary: #F8FAFC;--text-secondary: #CBD5E1;--text-muted: #94A3B8;--border-color: #334155;--border-light: rgba(203, 213, 225, .2);--scrollbar-track: #0F172A;--scrollbar-thumb: #334155;--success-bg: rgba(34, 197, 94, .1);--error-bg: rgba(239, 68, 68, .1);--info-bg: rgba(56, 189, 248, .1);--warning-bg: rgba(250, 204, 21, .1)}:root[data-theme=light]{--bg-primary: #F8FAFC;--bg-secondary: #E2E8F0;--bg-card: #FFFFFF;--bg-input: #FFFFFF;--bg-hover: rgba(34, 197, 94, .08);--text-primary: #0F172A;--text-secondary: #475569;--text-muted: #64748B;--border-color: #CBD5E1;--border-light: rgba(15, 23, 42, .1);--scrollbar-track: #E2E8F0;--scrollbar-thumb: #94A3B8;--success-bg: rgba(34, 197, 94, .15);--error-bg: rgba(239, 68, 68, .15);--info-bg: rgba(56, 189, 248, .15);--warning-bg: rgba(250, 204, 21, .15)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background-color:var(--bg-primary);color:var(--text-primary);line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background-color var(--transition-normal),color var(--transition-normal)}code,pre{font-family:JetBrains Mono,monospace}button{font-family:inherit;cursor:pointer}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--scrollbar-track)}::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb);border-radius:var(--radius-sm)}::-webkit-scrollbar-thumb:hover{background:var(--light-gray)}
