.input-wrapper{display:flex;flex-direction:column;gap:var(--spacing-1)}.input-label{font-size:.875rem;font-weight:500;color:var(--text-secondary)}.input-field{height:48px;padding:0 1rem;border:1px solid var(--color-surface-300);border-radius:var(--radius-md);background:#f8fafc;transition:all .2s ease-in-out;color:var(--text-primary);font-size:.9375rem;width:100%}.input-field:hover{background:#fff;border-color:var(--color-surface-400)}.input-field:focus{outline:none;background:#fff;border-color:var(--color-primary-500);box-shadow:0 0 0 4px #6366f126}.input-error{border-color:var(--color-danger-500)}.input-error:focus{box-shadow:0 0 0 3px #ef444433}.error-message{font-size:.75rem;color:var(--color-danger-500)}.btn{display:inline-flex;align-items:center;justify-content:center;border:1px solid transparent;font-weight:600;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);border-radius:var(--radius-md);outline:none;min-height:48px}.btn:focus-visible{box-shadow:0 0 0 2px var(--color-primary-100),0 0 0 4px var(--color-primary-500)}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background-color:var(--color-primary-600);color:#fff;box-shadow:var(--shadow-sm)}.btn-primary:hover:not(:disabled){background-color:var(--color-primary-700);transform:translateY(-2px);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d}.btn-outline{background-color:transparent;border-color:var(--color-surface-200);color:var(--text-primary)}.btn-outline:hover:not(:disabled){background-color:var(--color-surface-50);border-color:var(--color-surface-300)}.btn-sm{padding:var(--spacing-1) var(--spacing-2);font-size:.875rem}.btn-md{padding:var(--spacing-2) var(--spacing-4);font-size:1rem}.btn-lg{padding:var(--spacing-4) var(--spacing-8);font-size:1.125rem}.btn-full{width:100%}.auth-layout{height:100vh;width:100%;overflow:hidden;background-image:linear-gradient(to bottom,#0f172ad9,#0f172af2),linear-gradient(rgba(255,255,255,.08) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.08) 1px,transparent 1px),url(/pharma-bg.png);background-size:cover,50px 50px,50px 50px,cover;background-position:center;background-attachment:fixed;display:flex;justify-content:center;align-items:center;position:relative;font-family:Inter,system-ui,-apple-system,sans-serif}.auth-layout:before{content:"";position:absolute;width:600px;height:600px;background:radial-gradient(circle,rgba(99,102,241,.15) 0%,transparent 70%);top:-100px;left:20%;border-radius:50%;pointer-events:none;animation:pulse 15s infinite ease-in-out}.auth-layout:after{content:"";position:absolute;width:500px;height:500px;background:radial-gradient(circle,rgba(20,184,166,.15) 0%,transparent 70%);bottom:-50px;right:20%;border-radius:50%;pointer-events:none;animation:pulse 20s infinite ease-in-out reverse}@keyframes pulse{0%,to{transform:scale(1);opacity:.5}50%{transform:scale(1.2);opacity:.8}}.auth-layout{display:flex;justify-content:center;align-items:center;padding:2rem}.auth-card{display:grid;grid-template-columns:1.2fr 1fr;width:100%;max-width:1200px;height:85vh;min-height:650px;background:#fff;border-radius:24px;overflow:hidden;box-shadow:0 25px 50px -12px #00000080,0 0 0 1px #ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.auth-left{display:flex;flex-direction:column;justify-content:center;align-items:center;padding:3rem;color:#fff;background:linear-gradient(135deg,#0891b2f2,#0f172af2);position:relative;overflow:hidden}.auth-left:after{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px);background-size:30px 30px;opacity:.3}.auth-right{background:#fff;display:flex;align-items:center;justify-content:center;padding:3rem;position:relative;max-width:none;width:auto}.auth-bg-shapes{position:absolute;inset:0;overflow:hidden;pointer-events:none}.auth-bg-shape{position:absolute;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.08) 0%,transparent 70%);animation:auth-shape-float 20s infinite ease-in-out}.auth-bg-shape:nth-child(1){width:280px;height:280px;top:-80px;right:-60px;animation-delay:0s}.auth-bg-shape:nth-child(2){width:180px;height:180px;bottom:20%;left:-40px;animation-delay:-7s}.auth-bg-shape:nth-child(3){width:120px;height:120px;bottom:-30px;right:20%;animation-delay:-14s}@keyframes auth-shape-float{0%,to{transform:translate(0) scale(1);opacity:.6}50%{transform:translate(10px,-10px) scale(1.05);opacity:.9}}.auth-content{position:relative;z-index:1;width:100%;max-width:420px}.auth-brand{display:flex;align-items:center;gap:1rem;margin-bottom:1.25rem}.auth-logo-img{width:52px;height:52px;object-fit:contain;flex-shrink:0}.auth-logo-text{font-size:1.5rem;font-weight:700;letter-spacing:-.02em;color:#fff}.auth-tagline{font-size:1rem;color:#ffffffd9;margin-bottom:1.5rem;font-weight:500}.auth-description-block{margin-bottom:1.75rem}.auth-description{font-size:.9375rem;line-height:1.6;color:#ffffffe6;margin:0}.auth-description strong{color:#fff;font-weight:600}.auth-pillars{display:flex;flex-wrap:wrap;gap:.75rem 1.25rem;list-style:none;margin:0 0 1.75rem;padding:0}.auth-pillar{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:#ffffff1a;border-radius:8px;font-size:.875rem;font-weight:500;color:#fffffff2}.auth-pillar svg{flex-shrink:0;opacity:.9}.auth-access-notice{display:flex;align-items:center;gap:.5rem;font-size:.8125rem;color:#ffffffbf}.auth-access-notice svg{flex-shrink:0;opacity:.8}@media(max-width:1024px){.auth-card{grid-template-columns:1fr;height:auto;min-height:auto}.auth-left{display:none}.auth-right{padding:2rem}}@media(max-width:968px){.auth-layout{grid-template-columns:1fr}.auth-left{display:none}.auth-right{padding:2rem 1.5rem}}@media(max-width:640px){.auth-form-container{max-width:100%}.auth-pillars{gap:.5rem 1rem}.auth-pillar{font-size:.8125rem;padding:.4rem .6rem}}.dashboard-container{display:flex;flex-direction:column;gap:1.5rem}.dashboard-header{color:var(--color-primary-900);margin-bottom:1.5rem;font-size:1.5rem;font-weight:700}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem}.stat-card{padding:1.5rem;border-radius:var(--radius-lg)}.stat-card-header{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.stat-card-icon{padding:.75rem;border-radius:var(--radius-md)}.stat-card-icon.primary{background-color:var(--color-primary-100);color:var(--color-primary-600)}.stat-card-icon.warning{background-color:var(--color-warning-500);color:#fff}.stat-card-icon.success{background-color:var(--color-accent-500);color:#fff}.stat-card-icon.danger{background-color:var(--color-danger-500);color:#fff}.stat-card-title{font-size:.875rem;color:var(--text-secondary)}.stat-card-value{font-size:1.5rem;font-weight:700;color:var(--text-primary)}.stat-card-footer{font-size:.875rem}.stat-card-footer.success{color:var(--color-accent-500)}.stat-card-footer.secondary{color:var(--text-secondary)}.stat-card-footer.danger{color:var(--color-danger-500)}.batches-panel{margin-top:2rem;padding:1.5rem;border-radius:var(--radius-lg)}.batches-title{margin-bottom:1rem;color:var(--color-primary-900);font-size:1.125rem;font-weight:600}.batches-table{width:100%;border-collapse:collapse;text-align:left}.batches-table thead tr{border-bottom:1px solid var(--color-surface-200)}.batches-table th{padding:1rem;color:var(--text-secondary);font-weight:500}.batches-table tbody tr{border-bottom:1px solid var(--color-surface-100)}.batches-table td{padding:1rem}.batch-id{font-family:monospace}.batch-product{font-weight:500}.batch-status{padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:700}.batch-status.in-progress{color:var(--color-primary-600);background-color:var(--color-primary-100)}.batch-status.qc-pending{color:var(--color-warning-500);background-color:#fffbeb}.batch-status.completed{color:var(--color-accent-500);background-color:#ecfdf5}.searchable-select-wrap{position:relative;width:100%}.searchable-select-label{display:block;margin-bottom:.5rem;font-weight:500;font-size:.875rem;color:var(--text-secondary)}.searchable-select-trigger{position:relative;display:flex;align-items:center;justify-content:space-between;width:100%;min-height:40px;padding:6px 28px 6px 11px;border:1px solid #d9d9d9;border-radius:6px;background:#fff;cursor:pointer;transition:all .2s;font-size:14px;color:var(--text-primary)}.searchable-select-trigger:hover:not(.disabled){border-color:#4096ff}.searchable-select-trigger.open{border-color:#4096ff;box-shadow:0 0 0 2px #0591ff1a;outline:none}.searchable-select-trigger.disabled{background:#0000000a;cursor:not-allowed;color:#00000040}.searchable-select-trigger .placeholder{color:#00000073}.searchable-select-suffix{position:absolute;right:11px;top:50%;transform:translateY(-50%);display:flex;align-items:center;gap:4px;pointer-events:none;color:#00000040}.searchable-select-trigger .searchable-select-suffix{pointer-events:auto}.searchable-select-clear{pointer-events:auto;cursor:pointer;display:inline-flex;padding:2px;border-radius:2px;color:#00000040}.searchable-select-clear:hover{color:#00000073}.searchable-select-arrow{transition:transform .2s}.searchable-select-arrow.open{transform:rotate(180deg)}.searchable-select-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;z-index:1050;background:#fff;border-radius:8px;box-shadow:0 6px 16px #00000014,0 3px 6px -4px #0000001f,0 9px 28px 8px #0000000d;border:1px solid rgba(0,0,0,.06);overflow:hidden}.searchable-select-search{padding:8px;border-bottom:1px solid rgba(0,0,0,.06)}.searchable-select-search-input{width:100%;height:32px;padding:4px 11px;border:1px solid #d9d9d9;border-radius:6px;font-size:14px;outline:none;transition:border-color .2s}.searchable-select-search-input:focus{border-color:#4096ff;box-shadow:0 0 0 2px #0591ff1a}.searchable-select-list{max-height:256px;overflow-y:auto;padding:4px 0}.searchable-select-option{padding:5px 12px;font-size:14px;cursor:pointer;transition:background .2s;color:var(--text-primary)}.searchable-select-option:hover{background:#0000000a}.searchable-select-option.selected{background:#e6f4ff;color:#1677ff;font-weight:500}.searchable-select-empty{padding:8px 12px;font-size:14px;color:#00000073;text-align:center}.customer-list-container{display:flex;flex-direction:column;gap:1.5rem}.customer-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;flex-wrap:wrap;gap:1rem}.customer-title{color:var(--color-primary-900);font-size:1.5rem;font-weight:700}.customer-toolbar{display:flex;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.customer-search{flex:1;min-width:250px;display:flex;align-items:center;background:var(--color-surface-50);border:1px solid var(--color-surface-200);border-radius:var(--radius-md);padding:.5rem 1rem}.customer-search input{border:none;background:transparent;margin-left:.5rem;outline:none;width:100%;color:var(--text-primary)}.customer-table-wrapper{display:block}.customer-table{width:100%;border-collapse:collapse;text-align:left}.customer-table thead tr{border-bottom:1px solid var(--color-surface-200)}.customer-table th{padding:1rem;color:var(--text-secondary);font-weight:600;font-size:.875rem}.customer-table tbody tr{border-bottom:1px solid var(--color-surface-100);transition:background-color .2s}.customer-table tbody tr:hover{background-color:var(--color-surface-50)}.customer-table td{padding:1rem}.customer-company{font-weight:600;color:var(--text-primary)}.customer-contact{font-size:.875rem;color:var(--text-secondary)}.customer-status-badge{padding:.25rem .75rem;border-radius:var(--radius-full);font-size:.75rem;font-weight:600;text-transform:uppercase}.customer-status-badge.active{background-color:var(--color-accent-500);color:#fff}.customer-status-badge.inactive{background-color:var(--color-surface-200);color:var(--text-secondary)}.customer-status-badge.suspended{background-color:var(--color-danger-500);color:#fff}.customer-type-badge{padding:.25rem .5rem;border-radius:var(--radius-md);font-size:.75rem;font-weight:500;background-color:var(--color-primary-50);color:var(--color-primary-700)}.customer-actions{display:flex;gap:.5rem}.customer-action-btn{border:none;background:transparent;cursor:pointer;padding:.25rem;border-radius:var(--radius-sm);transition:all .2s}.customer-action-btn:hover{background-color:var(--color-surface-100)}.customer-action-btn.view{color:var(--color-primary-600)}.customer-action-btn.edit{color:var(--text-secondary)}.customer-action-btn.delete{color:var(--color-danger-500)}.customer-cards-wrapper{display:none}.customer-card{background:var(--color-surface-white);border:1px solid var(--color-surface-200);border-radius:var(--radius-lg);padding:1.25rem;margin-bottom:1rem;transition:all .2s}.customer-card:hover{box-shadow:var(--shadow-md);border-color:var(--color-primary-200)}.customer-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid var(--color-surface-100)}.customer-card-title{flex:1}.customer-card-company{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin-bottom:.25rem}.customer-card-contact{font-size:.875rem;color:var(--text-secondary)}.customer-card-badges{display:flex;gap:.5rem;margin-top:.5rem;flex-wrap:wrap}.customer-card-body{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin-bottom:1rem}.customer-card-field{display:flex;flex-direction:column;gap:.25rem}.customer-card-label{font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.customer-card-value{font-size:.875rem;color:var(--text-primary);font-weight:500}.customer-card-actions{display:flex;gap:.5rem;padding-top:1rem;border-top:1px solid var(--color-surface-100)}.customer-card-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem;border-radius:var(--radius-md);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.customer-card-btn.view{background:var(--color-primary-50);color:var(--color-primary-700);border:1px solid var(--color-primary-200)}.customer-card-btn.edit{background:var(--color-surface-50);color:var(--text-primary);border:1px solid var(--color-surface-200)}.customer-card-btn.delete{background:#fef2f2;color:var(--color-danger-500);border:1px solid #fecaca}.customer-details-container{display:flex;flex-direction:column;gap:2rem}.customer-details-grid{display:grid;grid-template-columns:2fr 1fr;gap:2rem}.customer-info-card{padding:2rem;border-radius:var(--radius-lg)}.customer-info-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid var(--color-surface-200)}.customer-info-title{display:flex;flex-direction:column;gap:.5rem}.customer-info-company{font-size:1.5rem;font-weight:700;color:var(--color-primary-900)}.customer-info-id{font-size:.875rem;color:var(--text-secondary);font-family:monospace}.customer-info-section{margin-bottom:2rem}.customer-info-section:last-child{margin-bottom:0}.customer-info-section-title{font-size:.875rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:1rem}.customer-info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}.customer-info-item{display:flex;flex-direction:column;gap:.25rem}.customer-info-label{font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.customer-info-value{font-size:1rem;color:var(--text-primary);font-weight:500}.customer-info-value.highlight{color:var(--color-primary-600);font-weight:600}.customer-stats-grid{display:flex;flex-direction:column;gap:1.5rem}.customer-stat-card{padding:1.5rem;border-radius:var(--radius-lg);border:1px solid var(--color-surface-200)}.customer-stat-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.customer-stat-icon{padding:.75rem;border-radius:var(--radius-md)}.customer-stat-icon.primary{background-color:var(--color-primary-100);color:var(--color-primary-600)}.customer-stat-icon.success{background-color:#ecfdf5;color:var(--color-accent-500)}.customer-stat-label{font-size:.875rem;color:var(--text-secondary)}.customer-stat-value{font-size:1.75rem;font-weight:700;color:var(--text-primary)}.customer-stat-footer{margin-top:.5rem;font-size:.875rem;color:var(--text-secondary)}.order-history-table{width:100%;border-collapse:collapse}.order-history-table thead tr{border-bottom:1px solid var(--color-surface-200)}.order-history-table th{padding:.75rem;text-align:left;font-size:.875rem;color:var(--text-secondary);font-weight:600}.order-history-table tbody tr{border-bottom:1px solid var(--color-surface-100)}.order-history-table td{padding:.75rem;font-size:.875rem}.order-id{font-family:monospace;font-weight:600}.order-status{padding:.25rem .5rem;border-radius:var(--radius-sm);font-size:.75rem;font-weight:600}.order-status.delivered{background-color:#ecfdf5;color:var(--color-accent-500)}.order-status.pending{background-color:#fffbeb;color:var(--color-warning-500)}.order-status.cancelled{background-color:#fef2f2;color:var(--color-danger-500)}@media(max-width:768px){.customer-header{flex-direction:column;align-items:flex-start}.customer-title{font-size:1.25rem}.customer-toolbar{flex-direction:column;width:100%}.customer-search{min-width:100%}.customer-table-wrapper{display:none}.customer-cards-wrapper{display:block}.customer-details-grid{grid-template-columns:1fr}.customer-info-card{padding:1.25rem}.customer-info-company{font-size:1.25rem}.customer-info-grid{grid-template-columns:1fr;gap:1rem}.customer-info-header{flex-direction:column;gap:1rem}.customer-stat-value{font-size:1.5rem}.order-history-table{font-size:.8125rem}.order-history-table th,.order-history-table td{padding:.5rem}}@media(max-width:480px){.customer-card-body{grid-template-columns:1fr}.customer-card-actions{flex-direction:column}.customer-card-btn{width:100%}}.production-board-container{display:flex;flex-direction:column;gap:1.5rem;height:100%}.production-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.production-title{color:var(--color-primary-900);font-size:1.5rem;font-weight:700}.production-stats{display:flex;gap:2rem;align-items:center}.production-stat{display:flex;flex-direction:column;align-items:center}.production-stat-value{font-size:1.5rem;font-weight:700;color:var(--text-primary)}.production-stat-label{font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.kanban-board{display:flex;gap:1rem;overflow-x:auto;padding-bottom:1rem;flex:1}.kanban-column{min-width:300px;max-width:320px;display:flex;flex-direction:column;background:var(--color-surface-50);border-radius:var(--radius-lg);padding:1rem}.kanban-column-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:2px solid var(--color-surface-200)}.kanban-column-title{font-size:.875rem;font-weight:600;color:var(--text-primary);text-transform:uppercase;letter-spacing:.05em}.kanban-column-count{background:var(--color-surface-200);color:var(--text-primary);padding:.25rem .5rem;border-radius:var(--radius-full);font-size:.75rem;font-weight:600}.kanban-cards{display:flex;flex-direction:column;gap:.75rem;flex:1;overflow-y:auto;max-height:calc(100vh - 300px)}.production-card{background:#fff;border:1px solid var(--color-surface-200);border-radius:var(--radius-md);padding:1rem;cursor:pointer;transition:all .2s}.production-card:hover{box-shadow:var(--shadow-md);border-color:var(--color-primary-300);transform:translateY(-2px)}.production-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.75rem}.production-card-batch{font-family:monospace;font-size:.75rem;font-weight:600;color:var(--color-primary-600)}.production-card-priority{padding:.125rem .5rem;border-radius:var(--radius-sm);font-size:.625rem;font-weight:700;text-transform:uppercase}.production-card-priority.urgent{background:var(--color-danger-500);color:#fff}.production-card-priority.high{background:#fb923c;color:#fff}.production-card-priority.medium{background:var(--color-warning-500);color:#fff}.production-card-priority.low{background:var(--color-surface-300);color:var(--text-secondary)}.production-card-product{font-size:.9375rem;font-weight:600;color:var(--text-primary);margin-bottom:.25rem}.production-card-dosage{font-size:.8125rem;color:var(--text-secondary);margin-bottom:.75rem}.production-card-info{display:flex;flex-direction:column;gap:.5rem;margin-bottom:.75rem}.production-card-info-item{display:flex;align-items:center;gap:.5rem;font-size:.75rem;color:var(--text-secondary)}.production-card-info-item svg{flex-shrink:0}.production-card-progress{margin-top:.75rem}.production-card-progress-label{display:flex;justify-content:space-between;font-size:.75rem;color:var(--text-secondary);margin-bottom:.25rem}.production-card-progress-bar{height:6px;background:var(--color-surface-200);border-radius:var(--radius-full);overflow:hidden}.production-card-progress-fill{height:100%;background:linear-gradient(90deg,var(--color-primary-500),var(--color-accent-500));border-radius:var(--radius-full);transition:width .3s ease}.kanban-column.mixing .kanban-column-header{border-color:#8b5cf6}.kanban-column.granulation .kanban-column-header{border-color:#3b82f6}.kanban-column.compression .kanban-column-header{border-color:#06b6d4}.kanban-column.coating .kanban-column-header{border-color:#10b981}.kanban-column.packaging .kanban-column-header{border-color:#f59e0b}.kanban-column.qc .kanban-column-header{border-color:#ef4444}.kanban-column.completed .kanban-column-header{border-color:#22c55e}.kanban-cards::-webkit-scrollbar{width:6px}.kanban-cards::-webkit-scrollbar-track{background:var(--color-surface-100);border-radius:3px}.kanban-cards::-webkit-scrollbar-thumb{background:var(--color-surface-300);border-radius:3px}.kanban-cards::-webkit-scrollbar-thumb:hover{background:var(--color-surface-400)}@media(max-width:768px){.production-stats{flex-direction:column;gap:1rem;align-items:flex-start}.kanban-board{flex-direction:column}.kanban-column{min-width:100%;max-width:100%}.kanban-cards{max-height:400px}}.chat-widget{position:fixed;bottom:20px;right:20px;z-index:1000;font-family:var(--font-sans)}.chat-button{width:60px;height:60px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #667eea66;transition:all .3s ease;position:relative}.chat-button:hover{transform:scale(1.1);box-shadow:0 6px 16px #667eea80}.chat-button svg{color:#fff}.chat-button-badge{position:absolute;top:-4px;right:-4px;background:#ef4444;color:#fff;border-radius:50%;width:24px;height:24px;font-size:.75rem;font-weight:700;display:flex;align-items:center;justify-content:center;border:2px solid white}.chat-window{position:absolute;bottom:80px;right:0;width:360px;height:520px;background:#fff;border-radius:16px;box-shadow:0 8px 32px #00000026;display:flex;flex-direction:column;overflow:hidden;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.chat-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:1rem 1.25rem;display:flex;justify-content:space-between;align-items:center}.chat-header-title{font-weight:600;font-size:1rem}.chat-header-subtitle{font-size:.75rem;opacity:.9;margin-top:.125rem}.chat-close-btn{background:transparent;border:none;color:#fff;cursor:pointer;padding:.25rem;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:background .2s}.chat-close-btn:hover{background:#fff3}.chat-tabs{display:flex;background:var(--color-surface-50);border-bottom:1px solid var(--color-surface-200)}.chat-tab{flex:1;padding:.75rem;background:transparent;border:none;cursor:pointer;font-size:.875rem;font-weight:500;color:var(--text-secondary);border-bottom:2px solid transparent;transition:all .2s}.chat-tab.active{color:var(--color-primary-600);border-bottom-color:var(--color-primary-600);background:#fff}.chat-list{flex:1;overflow-y:auto;background:#fff}.chat-list-item{padding:.875rem 1rem;display:flex;gap:.75rem;cursor:pointer;transition:background .2s;border-bottom:1px solid var(--color-surface-100)}.chat-list-item:hover{background:var(--color-surface-50)}.chat-list-item.unread{background:var(--color-primary-50)}.chat-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.875rem;flex-shrink:0;position:relative}.chat-avatar-online{position:absolute;bottom:0;right:0;width:12px;height:12px;background:#10b981;border:2px solid white;border-radius:50%}.chat-list-content{flex:1;min-width:0}.chat-list-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:.25rem}.chat-list-name{font-weight:600;font-size:.875rem;color:var(--text-primary)}.chat-list-time{font-size:.75rem;color:var(--text-secondary)}.chat-list-message{font-size:.8125rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-list-item.unread .chat-list-message{color:var(--text-primary);font-weight:500}.chat-unread-badge{width:20px;height:20px;background:var(--color-primary-600);color:#fff;border-radius:50%;font-size:.75rem;font-weight:700;display:flex;align-items:center;justify-content:center;margin-left:auto}.chat-messages{flex:1;overflow-y:auto;padding:1rem;background:var(--color-surface-50);display:flex;flex-direction:column;gap:.75rem}.chat-message{display:flex;gap:.5rem;max-width:80%}.chat-message.sent{align-self:flex-end;flex-direction:row-reverse}.chat-message-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.75rem;flex-shrink:0}.chat-message-bubble{background:#fff;padding:.625rem .875rem;border-radius:18px;font-size:.875rem;line-height:1.4;box-shadow:0 1px 2px #0000001a}.chat-message.sent .chat-message-bubble{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.chat-message-time{font-size:.6875rem;color:var(--text-secondary);margin-top:.25rem;padding:0 .5rem}.chat-input-container{padding:.875rem 1rem;background:#fff;border-top:1px solid var(--color-surface-200);display:flex;gap:.5rem;align-items:center}.chat-input{flex:1;border:1px solid var(--color-surface-200);border-radius:20px;padding:.625rem 1rem;font-size:.875rem;outline:none;transition:border-color .2s}.chat-input:focus{border-color:var(--color-primary-400)}.chat-send-btn{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);border:none;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .2s}.chat-send-btn:hover{transform:scale(1.1)}.chat-send-btn:disabled{opacity:.5;cursor:not-allowed}.chat-list::-webkit-scrollbar,.chat-messages::-webkit-scrollbar{width:6px}.chat-list::-webkit-scrollbar-track,.chat-messages::-webkit-scrollbar-track{background:var(--color-surface-100)}.chat-list::-webkit-scrollbar-thumb,.chat-messages::-webkit-scrollbar-thumb{background:var(--color-surface-300);border-radius:3px}.chat-list::-webkit-scrollbar-thumb:hover,.chat-messages::-webkit-scrollbar-thumb:hover{background:var(--color-surface-400)}@media(max-width:768px){.chat-window{width:calc(100vw - 40px);height:calc(100vh - 100px);max-width:360px}}.sidebar-menu{display:flex;flex-direction:column;gap:.125rem;padding:.5rem;flex:1;overflow-y:auto;overflow-x:hidden}.menu-item{display:flex;align-items:center;padding:.75rem 1rem;border-radius:var(--radius-md);color:#ffffffb3;text-decoration:none;transition:all .2s ease;cursor:pointer;-webkit-user-select:none;user-select:none;position:relative;font-size:.875rem}.menu-item:hover{background-color:#ffffff14;color:#fffffff2}.menu-item.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 4px 12px #667eea4d}.menu-item-icon{display:flex;align-items:center;justify-content:center;min-width:20px;opacity:.9}.menu-item.active .menu-item-icon{opacity:1}.menu-item-label{margin-left:.75rem;font-size:.875rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}.menu-item-arrow{margin-left:auto;transition:transform .2s;opacity:.6}.menu-item-arrow.expanded{transform:rotate(90deg)}.menu-item:hover .menu-item-arrow{opacity:1}.menu-item.has-children{font-weight:500}.menu-item.has-children.expanded{background-color:#ffffff0d;color:#fffffff2}.submenu{max-height:0;overflow:hidden;transition:max-height .3s cubic-bezier(.4,0,.2,1)}.submenu.expanded{max-height:600px;transition:max-height .4s cubic-bezier(.4,0,.2,1)}.submenu-items{padding-left:.5rem;margin-top:.25rem;margin-bottom:.5rem;border-left:2px solid rgba(255,255,255,.1);margin-left:1.5rem}.submenu .menu-item{padding:.625rem 1rem;font-size:.8125rem;color:#ffffffa6;font-weight:400}.submenu .menu-item:hover{color:#ffffffe6;background-color:#ffffff0f}.submenu .menu-item.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-weight:500}.submenu .menu-item-icon{min-width:18px}.sidebar.collapsed .menu-item-label,.sidebar.collapsed .menu-item-arrow,.sidebar.collapsed .submenu{display:none}.sidebar.collapsed .menu-item{justify-content:center;padding:.75rem}.sidebar.collapsed .menu-item-icon{min-width:auto}.menu-item-tooltip{position:absolute;left:calc(100% + .75rem);padding:.5rem .75rem;background:linear-gradient(135deg,#1e293b,#0f172a);color:#fff;border-radius:var(--radius-md);font-size:.8125rem;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .2s;z-index:1000;box-shadow:0 4px 12px #0000004d;border:1px solid rgba(255,255,255,.1)}.sidebar.collapsed .menu-item:hover .menu-item-tooltip{opacity:1}.menu-divider{height:1px;background:#ffffff1a;margin:.75rem 0}.menu-item.has-active-child{color:#ffffffe6}.menu-item.has-active-child .menu-item-icon{color:#667eea}.sidebar-menu::-webkit-scrollbar{width:6px}.sidebar-menu::-webkit-scrollbar-track{background:#ffffff0d;border-radius:3px}.sidebar-menu::-webkit-scrollbar-thumb{background:#fff3;border-radius:3px}.sidebar-menu::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.dashboard-shell{display:grid;grid-template-columns:260px 1fr;grid-template-rows:64px 1fr;height:100vh;overflow:hidden;transition:grid-template-columns .3s ease}.dashboard-shell.collapsed{grid-template-columns:80px 1fr}.sidebar{grid-row:1 / -1;grid-column:1 / 2;background:linear-gradient(180deg,#1e293b,#0f172a);color:#fff;display:flex;flex-direction:column;border-right:1px solid rgba(255,255,255,.08);transition:all .3s ease;overflow:hidden;box-shadow:4px 0 24px #0003}.sidebar.collapsed{width:80px}.sidebar-header{height:64px;display:flex;align-items:center;gap:.5rem;padding:0 1.5rem;border-bottom:1px solid rgba(255,255,255,.1);background:#ffffff08}.sidebar-nav{padding:var(--spacing-4);flex:1}.nav-item{display:flex;align-items:center;padding:var(--spacing-3) var(--spacing-4);color:var(--text-secondary);text-decoration:none;border-radius:var(--radius-md);margin-bottom:var(--spacing-1);transition:all .2s;white-space:nowrap;overflow:hidden}.sidebar.collapsed .nav-item{justify-content:center;padding-left:0;padding-right:0}.nav-item:hover{background-color:#ffffff0d;color:var(--text-inverse)}.nav-item.active{background-color:var(--color-primary-600);color:#fff}.navbar{grid-column:2 / 3;grid-row:1 / 2;background-color:var(--color-surface-white);border-bottom:1px solid var(--color-surface-200);display:flex;align-items:center;justify-content:flex-end;padding:0 var(--spacing-6);box-shadow:var(--shadow-sm);z-index:10}.main-content{grid-column:2 / 3;grid-row:2 / 3;overflow-y:auto;padding:var(--spacing-8);background-color:var(--color-surface-50)}.auth-layout{min-height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(circle at top left,var(--color-primary-50),transparent 40%),radial-gradient(circle at bottom right,var(--color-surface-200),transparent 40%),var(--color-surface-50)}@media(max-width:768px){.dashboard-shell{grid-template-columns:1fr;grid-template-rows:60px 1fr}.dashboard-shell.collapsed{grid-template-columns:1fr}.sidebar{position:fixed;left:-100%;top:0;bottom:0;width:280px;z-index:1000;transition:left .3s ease}.sidebar.mobile-open{left:0}.sidebar.collapsed{width:280px}.navbar{grid-column:1 / -1}.main-content{grid-column:1 / -1;padding:var(--spacing-4)}.mobile-overlay{position:fixed;inset:0;background:#00000080;z-index:999;display:none}.mobile-overlay.active{display:block}}@media(max-width:480px){.main-content{padding:var(--spacing-3)}.navbar{padding:0 var(--spacing-4)}}.qc-page{animation:fadeIn .4s ease-out}.qc-page-header{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem}.qc-page-title{color:var(--color-primary-900);font-size:1.875rem;font-weight:700;margin-bottom:.25rem}.qc-page-subtitle{color:var(--text-secondary);font-size:.9375rem}.qc-panel{padding:1.5rem;border-radius:var(--radius-lg)}.qc-toolbar{display:flex;gap:1rem;margin-bottom:1.25rem;flex-wrap:wrap}.qc-search-wrap{flex:1;min-width:220px;display:flex;align-items:center;background:var(--color-surface-50);border:1px solid var(--color-surface-200);border-radius:var(--radius-md);padding:.5rem .75rem}.qc-search-wrap:focus-within{border-color:var(--color-primary-500);box-shadow:0 0 0 2px var(--color-primary-100)}.qc-search-wrap input{border:none;background:transparent;margin-left:.5rem;outline:none;width:100%;color:var(--text-primary);font-size:.9375rem}.qc-filter-tabs{display:flex;gap:.25rem;flex-wrap:wrap}.qc-filter-tab{padding:.5rem 1rem;border-radius:var(--radius-md);font-size:.875rem;font-weight:500;border:1px solid var(--color-surface-200);background:var(--color-surface-white);color:var(--text-secondary);cursor:pointer;transition:all .2s}.qc-filter-tab:hover{background:var(--color-surface-50);color:var(--text-primary)}.qc-filter-tab.active{background:var(--color-primary-100);border-color:var(--color-primary-500);color:var(--color-primary-700)}.qc-table-wrap{overflow-x:auto}.qc-table{width:100%;border-collapse:collapse;text-align:left}.qc-table thead tr{border-bottom:1px solid var(--color-surface-200)}.qc-table th{padding:.75rem 1rem;color:var(--text-secondary);font-weight:600;font-size:.75rem;text-transform:uppercase;letter-spacing:.025em}.qc-table tbody tr{border-bottom:1px solid var(--color-surface-100);transition:background .15s}.qc-table tbody tr:hover{background:var(--color-surface-50)}.qc-table td{padding:1rem;font-size:.9375rem;color:var(--text-primary)}.qc-sample-code{display:inline-flex;align-items:center;gap:.5rem;font-weight:600;font-family:monospace}.qc-sample-code svg{color:var(--color-primary-500);flex-shrink:0}.qc-badge{display:inline-block;padding:.25rem .75rem;border-radius:var(--radius-full);font-size:.75rem;font-weight:600}.qc-badge--pending{background:var(--color-warning-50);color:var(--color-warning-700)}.qc-badge--in_progress{background:var(--color-primary-100);color:var(--color-primary-700)}.qc-badge--completed,.qc-badge--pass{background:var(--color-success-50);color:var(--color-success-700)}.qc-badge--fail{background:#fee2e2;color:#b91c1c}.qc-badge--conditional{background:var(--color-warning-50);color:var(--color-warning-700)}.qc-empty{text-align:center;padding:3rem 2rem;color:var(--text-secondary)}.qc-empty svg{margin-bottom:1rem;color:var(--color-surface-200)}.qc-empty p{font-size:1rem;margin-bottom:.25rem}.qc-empty span{font-size:.875rem}.qc-detail-back{display:inline-flex;align-items:center;gap:.5rem;color:var(--text-secondary);font-size:.9375rem;margin-bottom:1.5rem;cursor:pointer;background:none;border:none;font-family:inherit;padding:.25rem 0}.qc-detail-back:hover{color:var(--color-primary-600)}.qc-detail-section{margin-bottom:1.5rem;border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--color-surface-200);background:var(--color-surface-white)}.qc-detail-section-header{padding:1rem 1.25rem;border-bottom:1px solid var(--color-surface-100);background:var(--color-surface-50);font-weight:600;color:var(--text-primary);font-size:1rem}.qc-detail-section-body{padding:1.25rem}.qc-detail-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:1.25rem}.qc-detail-field label{display:block;font-size:.75rem;color:var(--text-secondary);margin-bottom:.25rem;text-transform:uppercase;letter-spacing:.03em}.qc-detail-field .value{font-weight:500;color:var(--text-primary)}.qc-param-row td{vertical-align:middle}.qc-param-input{width:100%;max-width:180px;padding:.5rem .75rem;border:1px solid var(--color-surface-200);border-radius:var(--radius-md);font-size:.9375rem;color:var(--text-primary);background:var(--color-surface-white)}.qc-param-input:focus{outline:none;border-color:var(--color-primary-500);box-shadow:0 0 0 2px var(--color-primary-100)}.qc-param-input:disabled{background:var(--color-surface-50);cursor:not-allowed}.qc-param-actions{display:flex;justify-content:center;gap:.5rem}.qc-param-btn{width:36px;height:36px;border-radius:50%;border:none;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:all .2s}.qc-param-btn:disabled{cursor:not-allowed;opacity:.5}.qc-param-btn--pass{background:var(--color-success-50);color:var(--color-success-700)}.qc-param-btn--pass.active{background:var(--color-success-700);color:#fff;box-shadow:0 0 0 2px var(--color-success-50)}.qc-param-btn--fail{background:#fee2e2;color:#b91c1c}.qc-param-btn--fail.active{background:#b91c1c;color:#fff;box-shadow:0 0 0 2px #fee2e2}.qc-param-btn:not(:disabled):hover{transform:scale(1.05)}.qc-decision-group{display:flex;flex-wrap:wrap;gap:1rem;align-items:center}.qc-decision-radio{display:inline-flex;align-items:center;gap:.5rem;cursor:pointer;font-weight:500;color:var(--text-primary)}.qc-decision-radio input{width:1rem;height:1rem;accent-color:var(--color-primary-600)}.qc-decision-radio input:disabled{cursor:not-allowed}.qc-remarks-label{display:block;font-size:.875rem;font-weight:500;color:var(--text-primary);margin-bottom:.5rem}.qc-remarks-textarea{width:100%;min-height:100px;padding:.75rem 1rem;border:1px solid var(--color-surface-200);border-radius:var(--radius-md);font-size:.9375rem;color:var(--text-primary);background:var(--color-surface-white);font-family:inherit;resize:vertical}.qc-remarks-textarea:focus{outline:none;border-color:var(--color-primary-500);box-shadow:0 0 0 2px var(--color-primary-100)}.qc-remarks-textarea:disabled{background:var(--color-surface-50);cursor:not-allowed}.qc-submit-bar{display:flex;justify-content:flex-end;margin-top:1.5rem}.qc-loading{display:flex;justify-content:center;align-items:center;padding:3rem}.qc-spinner{width:32px;height:32px;border:3px solid var(--color-surface-200);border-radius:50%;border-top-color:var(--color-primary-500);animation:spin .8s linear infinite}:root{--color-primary-50: #eff6ff;--color-primary-100: #dbeafe;--color-primary-500: #3b82f6;--color-primary-600: #2563eb;--color-primary-700: #1d4ed8;--color-primary-900: #1e3a8a;--color-accent-500: #10b981;--color-success-50: #ecfdf5;--color-success-600: #059669;--color-success-700: #047857;--color-danger-500: #ef4444;--color-warning-50: #fffbeb;--color-warning-500: #f59e0b;--color-warning-600: #d97706;--color-warning-700: #b45309;--color-surface-white: #ffffff;--color-surface-50: #f8fafc;--color-surface-100: #f1f5f9;--color-surface-200: #e2e8f0;--color-surface-800: #1e293b;--color-surface-900: #0f172a;--text-primary: var(--color-surface-900);--text-secondary: #64748b;--text-inverse: #ffffff;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--shadow-glass: 0 8px 32px 0 rgba(31, 38, 135, .15);--spacing-1: .25rem;--spacing-2: .5rem;--spacing-4: 1rem;--spacing-6: 1.5rem;--spacing-8: 2rem;--spacing-12: 3rem;--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-full: 9999px;--font-sans: "Inter", system-ui, -apple-system, sans-serif;--glass-bg: rgba(255, 255, 255, .7);--glass-border: rgba(255, 255, 255, .3)}[data-theme=dark]{--color-surface-white: #1e293b;--color-surface-50: #0f172a;--color-surface-100: #334155;--color-surface-200: #475569;--text-primary: #f8fafc;--text-secondary: #94a3b8;--text-inverse: #0f172a;--color-primary-50: #172554;--color-primary-100: #1e3a8a;--glass-bg: rgba(30, 41, 59, .7);--glass-border: rgba(255, 255, 255, .1);--shadow-glass: 0 8px 32px 0 rgba(0, 0, 0, .3)}.swal2-popup{font-family:var(--font-sans)!important;border-radius:var(--radius-lg)!important;background:var(--color-surface-white)!important;border:1px solid var(--color-surface-200)!important;box-shadow:var(--shadow-lg)!important;padding:2rem!important}.swal2-title{color:var(--text-primary)!important;font-size:1.5rem!important;font-weight:700!important;margin-bottom:.5rem!important}.swal2-html-container{color:var(--text-secondary)!important;font-size:1rem!important;line-height:1.5!important;margin:1rem 0!important}.swal2-actions{margin-top:1.5rem!important;gap:.75rem!important}.swal2-confirm{background-color:var(--color-primary-600)!important;border:none!important;border-radius:var(--radius-md)!important;padding:.75rem 1.5rem!important;font-weight:600!important;font-size:.875rem!important;transition:all .2s!important;box-shadow:var(--shadow-sm)!important}.swal2-confirm:hover{background-color:var(--color-primary-700)!important;transform:translateY(-1px)!important;box-shadow:var(--shadow-md)!important}.swal2-confirm:focus{box-shadow:0 0 0 3px #3b82f64d!important}.swal2-cancel{background-color:var(--color-surface-200)!important;color:var(--text-primary)!important;border:none!important;border-radius:var(--radius-md)!important;padding:.75rem 1.5rem!important;font-weight:600!important;font-size:.875rem!important;transition:all .2s!important}.swal2-cancel:hover{background-color:var(--color-surface-800)!important;color:#fff!important;transform:translateY(-1px)!important}.swal2-cancel:focus{box-shadow:0 0 0 3px #64748b4d!important}.swal2-popup.swal2-icon-warning .swal2-confirm{background-color:var(--color-danger-500)!important}.swal2-popup.swal2-icon-warning .swal2-confirm:hover{background-color:#dc2626!important}.swal2-icon{border-color:transparent!important;margin:1rem auto!important}.swal2-icon.swal2-success{border-color:var(--color-accent-500)!important}.swal2-icon.swal2-success [class^=swal2-success-line]{background-color:var(--color-accent-500)!important}.swal2-icon.swal2-success .swal2-success-ring{border-color:#10b9814d!important}.swal2-icon.swal2-error{border-color:var(--color-danger-500)!important}.swal2-icon.swal2-error [class^=swal2-x-mark-line]{background-color:var(--color-danger-500)!important}.swal2-icon.swal2-warning{border-color:var(--color-warning-500)!important;color:var(--color-warning-500)!important}.swal2-icon.swal2-question,.swal2-icon.swal2-info{border-color:var(--color-primary-500)!important;color:var(--color-primary-500)!important}.swal2-container{backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.swal2-backdrop-show{background:#0006!important}[data-theme=dark] .swal2-popup{background:var(--color-surface-800)!important;border-color:var(--color-surface-200)!important}[data-theme=dark] .swal2-title{color:var(--text-primary)!important}[data-theme=dark] .swal2-html-container{color:var(--text-secondary)!important}[data-theme=dark] .swal2-cancel{background-color:var(--color-surface-200)!important;color:var(--text-primary)!important}[data-theme=dark] .swal2-cancel:hover{background-color:var(--color-surface-100)!important}.swal2-show{animation:swal2-show .3s!important}.swal2-hide{animation:swal2-hide .2s!important}@keyframes swal2-show{0%{transform:scale(.7);opacity:0}45%{transform:scale(1.05);opacity:1}80%{transform:scale(.95)}to{transform:scale(1)}}@keyframes swal2-hide{0%{transform:scale(1);opacity:1}to{transform:scale(.5);opacity:0}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-sans);background-color:var(--color-surface-50);color:var(--text-primary);-webkit-font-smoothing:antialiased;min-height:100vh;line-height:1.5}button{font-family:inherit}input,textarea,select{font-family:inherit;font-size:1rem}.glass-panel{background:var(--glass-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--glass-border);box-shadow:var(--shadow-glass)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.fade-in{animation:fadeIn .4s ease-out}.spinner-sm{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-radius:50%;border-top-color:#fff;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.table-row-hover:hover{background-color:var(--color-surface-50)}
