@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";*{margin:0;padding:0;box-sizing:border-box}:root{--sidebar-width: 260px;--sidebar-collapsed-width: 72px;--header-height: 64px;--primary-color: #6366f1;--primary-hover: #4f46e5;--primary-light: #e0e7ff;--bg-color: #f1f5f9;--sidebar-bg: linear-gradient(180deg, #1e1b4b 0%, #312e81 100%);--sidebar-text: #e0e7ff;--card-bg: #ffffff;--text-color: #1e293b;--text-secondary: #64748b;--text-muted: #94a3b8;--border-color: #e2e8f0;--border-radius: 12px;--border-radius-lg: 16px;--border-radius-sm: 8px;--danger-bg: #fee2e2;--danger-color: #ef4444;--danger-text: #991b1b;--success-bg: #dcfce7;--success-color: #22c55e;--success-text: #166534;--warning-bg: #fef3c7;--warning-color: #f59e0b;--warning-text: #92400e;--info-bg: #dbeafe;--info-color: #3b82f6;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1);--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);--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .2s cubic-bezier(.4, 0, .2, 1);--transition-slow: .3s cubic-bezier(.4, 0, .2, 1)}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background-color:var(--bg-color);color:var(--text-color);min-height:100vh;line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#94a3b8}:focus-visible{outline:2px solid var(--primary-color);outline-offset:2px}::selection{background-color:var(--primary-light);color:var(--primary-hover)}.sidebar{width:var(--sidebar-width);min-height:100vh;background:var(--sidebar-bg);color:var(--sidebar-text);display:flex;flex-direction:column;transition:width var(--transition-slow);position:fixed;left:0;top:0;z-index:100;box-shadow:4px 0 24px #00000026}.sidebar.collapsed{width:var(--sidebar-collapsed-width)}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1rem;border-bottom:1px solid rgba(255,255,255,.08);min-height:var(--header-height)}.logo-container{display:flex;align-items:center;gap:.75rem}.logo-icon{width:40px;height:40px;background:linear-gradient(135deg,var(--primary-color) 0%,#818cf8 100%);border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0;box-shadow:0 4px 12px #6366f166}.sidebar-title{font-size:1.2rem;font-weight:700;white-space:nowrap;overflow:hidden;letter-spacing:-.025em;background:linear-gradient(135deg,#fff,#c7d2fe);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.toggle-btn{position:absolute;top:50%;right:-16px;transform:translateY(-50%);background:linear-gradient(135deg,var(--primary-color) 0%,#818cf8 100%);border:3px solid var(--bg-color, #f1f5f9);color:#fff;width:32px;height:32px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);z-index:101;box-shadow:0 2px 8px #6366f166}.toggle-btn:hover{background:linear-gradient(135deg,#4f46e5,#6366f1);transform:translateY(-50%) scale(1.1);box-shadow:0 4px 12px #6366f180}.sidebar.collapsed .sidebar-header{justify-content:center;padding:1.25rem .75rem}.sidebar.collapsed .logo-container{justify-content:center}.sidebar-nav{flex:1;padding:1rem .75rem;display:flex;flex-direction:column;gap:.375rem}.nav-item{display:flex;align-items:center;gap:.875rem;padding:.875rem 1rem;background:transparent;border:none;color:#e0e7ffb3;font-size:.9rem;font-weight:500;cursor:pointer;border-radius:10px;transition:all var(--transition-fast);width:100%;text-align:left;position:relative;overflow:hidden}.nav-item:before{content:"";position:absolute;left:0;top:0;width:3px;height:100%;background:var(--primary-color);border-radius:0 4px 4px 0;transform:scaleY(0);transition:transform var(--transition-fast)}.nav-item:hover{background:#ffffff14;color:#fff}.nav-item.active{background:linear-gradient(135deg,#6366f14d,#818cf833);color:#fff;box-shadow:0 2px 8px #6366f133}.nav-item.active:before{transform:scaleY(1)}.nav-icon{display:flex;align-items:center;justify-content:center;flex-shrink:0;width:24px;height:24px}.nav-label{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar.collapsed .nav-item{justify-content:center;padding:.875rem}.sidebar.collapsed .nav-label{display:none}.sidebar.collapsed .nav-item:before{display:none}.sidebar-footer{padding:1rem;border-top:1px solid rgba(255,255,255,.08)}.version-info{font-size:.75rem;color:#e0e7ff66;text-align:center}.user-section{display:flex;flex-direction:column;gap:.75rem}.user-info{display:flex;align-items:center;gap:.75rem}.user-avatar{width:36px;height:36px;background:linear-gradient(135deg,#6366f14d,#818cf833);border-radius:10px;display:flex;align-items:center;justify-content:center;color:#e0e7ffe6;flex-shrink:0}.user-details{display:flex;flex-direction:column;overflow:hidden}.user-name{font-size:.875rem;font-weight:600;color:#e0e7ffe6;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{font-size:.7rem;color:#e0e7ff80;text-transform:uppercase;letter-spacing:.05em}.logout-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1rem;background:#ef444426;border:none;color:#fca5a5;font-size:.85rem;font-weight:500;cursor:pointer;border-radius:8px;transition:all var(--transition-fast);width:100%}.logout-btn:hover{background:#ef444440;color:#fecaca}.sidebar.collapsed .user-section{align-items:center}.sidebar.collapsed .user-info{justify-content:center}.sidebar.collapsed .user-details{display:none}.sidebar.collapsed .logout-btn{padding:.625rem;width:auto}.sidebar.collapsed .logout-btn span{display:none}.scadenze-container{padding:1.5rem 2rem 2rem;width:100%;max-width:100%;min-height:100vh}.scadenze-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;flex-wrap:wrap;gap:1rem}.scadenze-header h2{font-size:1.75rem;font-weight:700;color:var(--text-color);letter-spacing:-.025em;margin:0}.btn{border:none;padding:.75rem 1.25rem;border-radius:10px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;gap:.5rem}.btn-primary:disabled{opacity:.7;cursor:not-allowed}.btn-secondary{background:var(--primary-light);color:var(--primary-color);border:1px solid rgba(99,102,241,.2)}.btn-secondary:hover{background:#c7d2fe}.header-center{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.file-name-center{font-size:.85rem;color:var(--text-secondary);background:var(--primary-light);padding:.35rem 1rem;border-radius:20px;font-weight:500}.server-status{display:flex;align-items:center;gap:.4rem;font-size:.8rem;font-weight:500;padding:.35rem .75rem;border-radius:20px;transition:all .3s ease}.server-status.online{background:#22c55e1a;color:#16a34a}.server-status.offline{background:#ef44441a;color:#dc2626}.server-status.checking{background:#eab3081a;color:#ca8a04}.tabs-container{display:flex;gap:.5rem;margin-bottom:1rem;flex-wrap:wrap}.tab-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;border:2px solid var(--border-color);border-radius:8px;background:#fff;font-size:.9rem;font-weight:600;color:var(--text-secondary);cursor:pointer;transition:all .2s}.tab-btn:hover{border-color:var(--primary-color);color:var(--primary-color)}.tab-btn.active{background:var(--primary-color);border-color:var(--primary-color);color:#fff}.tab-btn.tab-success.active{background:#16a34a;border-color:#16a34a}.tab-btn.tab-muted.active{background:#6b7280;border-color:#6b7280}.tab-count{background:#0000001a;padding:.15rem .5rem;border-radius:10px;font-size:.8rem}.tab-btn.active .tab-count{background:#ffffff40}.tab-alert{background:#dc2626;color:#fff;padding:.15rem .5rem;border-radius:10px;font-size:.75rem;font-weight:500}.tab-btn.active .tab-alert{background:#ffffffe6;color:#dc2626}.filters-bar{display:flex;gap:.75rem;margin-bottom:1rem;flex-wrap:wrap;align-items:center;background:#fff;padding:.75rem 1rem;border-radius:8px;box-shadow:0 1px 3px #0000001a;border:1px solid var(--border-color)}.filter-group{display:flex;align-items:center;gap:.5rem}.search-group{width:350px;flex-shrink:0;position:relative}.search-icon{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}.filter-input{padding:.5rem .75rem;border:1px solid var(--border-color);border-radius:6px;font-size:.85rem;background:#fff;transition:all .2s}.filter-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #6366f11a}.search-input{width:100%;padding-left:2.75rem}.filter-select{padding:.5rem .75rem;border:1px solid var(--border-color);border-radius:6px;font-size:.85rem;background:#fff;cursor:pointer;min-width:150px;transition:all .2s}.filter-select.has-value,.filter-input.has-value{background:#eff6ff;border-color:var(--primary-color)}.filter-label-icon{color:var(--text-muted);flex-shrink:0}.date-group{gap:.35rem}.date-label{font-size:.8rem;color:var(--text-secondary);font-weight:500}.date-input{width:130px}.btn-reset-filters{display:flex;align-items:center;gap:.35rem;padding:.5rem .75rem;border:none;border-radius:6px;background:#fee2e2;color:#dc2626;font-size:.8rem;font-weight:500;cursor:pointer;transition:all .2s}.btn-reset-filters:hover{background:#fecaca}.stats-bar{display:flex;gap:1.5rem;margin-bottom:1rem;flex-wrap:wrap;align-items:center;background:#fff;padding:.75rem 1.25rem;border-radius:8px;box-shadow:0 1px 3px #0000001a;border:1px solid var(--border-color)}.stat-item{display:flex;align-items:center;gap:.5rem}.stat-value{font-size:.95rem;font-weight:600;color:var(--text-color)}.stat-item.stat-danger .stat-value{color:#dc2626}.stat-item.stat-success .stat-value{color:#16a34a}.stat-item.stat-primary .stat-value{color:var(--primary-color)}.empty-state{text-align:center;padding:4rem 2rem;background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;border:2px dashed var(--border-color);color:var(--text-muted)}.empty-state h3{font-size:1.25rem;font-weight:600;color:var(--text-color);margin:1rem 0 .5rem}.empty-state p{color:var(--text-secondary);font-size:.95rem;margin:0}.table-wrapper{width:100%;background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;border:1px solid var(--border-color);overflow:visible}.scadenze-table{width:100%;border-collapse:collapse;font-size:.8rem}.scadenze-table th{background:#f8fafc;padding:.85rem .5rem;text-align:left;font-weight:600;font-size:.75rem;color:var(--text-secondary);border-bottom:2px solid var(--border-color);white-space:nowrap}.scadenze-table th:nth-child(10),.scadenze-table th:nth-child(11){width:50px;min-width:50px;text-align:center}.scadenze-table td{padding:.65rem .5rem;border-bottom:1px solid var(--border-color);vertical-align:middle}.scadenze-table tbody tr:last-child td{border-bottom:none}.row-scaduta{background-color:#fee2e2}.row-scaduta:hover{background-color:#fecaca}.row-mora{background-color:#fef9c3}.row-mora:hover{background-color:#fef08a}.row-pagato{background-color:#dcfce7}.row-pagato:hover{background-color:#bbf7d0}.row-non-rinnovato{background-color:#f3f4f6;opacity:.7}.row-non-rinnovato:hover{background-color:#e5e7eb}.td-giorno{text-align:center}.td-giorno .giorno-nome{display:block;font-weight:600}.td-giorno .giorno-indicatore{display:block;font-size:.7rem;color:#6366f1;font-weight:500;margin-top:1px}.td-data .data-content{display:inline-flex;align-items:center;gap:.35rem;white-space:nowrap}.scaduta-badge,.giorni-rimanenti{display:inline-flex;align-items:center;justify-content:center;margin-left:.25rem;padding:.1rem .35rem;border-radius:4px;min-width:32px;text-align:center}.scaduta-badge{background:#fecaca}.scaduta-badge .icon-scaduta{color:#dc2626;flex-shrink:0}.giorni-rimanenti{font-size:.7rem;font-weight:600;color:#d97706;background:#fef3c7;line-height:1}.td-icon-status{text-align:center;vertical-align:middle;width:50px;min-width:50px;max-width:50px}.td-icon-status .no-icon{color:var(--text-muted);font-size:.85rem}.td-icon-status .icon-whatsapp{color:#25d366}.td-icon-status .icon-email{color:#ea4335}.td-icon-status .icon-lettera{color:#6366f1}.td-icon-status .icon-telefono{color:#3b82f6}.td-premio{font-weight:600;white-space:nowrap}.scadenze-table select{padding:.35rem .5rem;border:1px solid var(--border-color);border-radius:4px;font-size:.75rem;background:#fff;cursor:pointer;min-width:80px}.scadenze-table select:focus{outline:none;border-color:var(--primary-color)}.scadenze-table select.has-value{background:#eff6ff;border-color:var(--primary-color)}.td-note{min-width:120px;position:relative}.td-azioni{position:relative;width:40px}.td-azioni.menu-open{z-index:9999;isolation:isolate}.azioni-container{position:relative}.azioni-btn{background:none;border:none;padding:.35rem;border-radius:4px;cursor:pointer;color:var(--text-muted);display:flex;align-items:center;justify-content:center;transition:all .2s}.azioni-btn:hover{background:var(--primary-light);color:var(--primary-color)}.azioni-menu{position:absolute;right:0;top:100%;margin-top:4px;background:#fff;border:1px solid var(--border-color);border-radius:8px;box-shadow:0 4px 12px #00000026;z-index:99998;min-width:160px;overflow:visible}.azioni-menu.menu-up{top:auto;bottom:100%;margin-top:0;margin-bottom:4px}.menu-item{display:flex;align-items:center;gap:.5rem;width:100%;padding:.75rem 1rem;border:none;background:none;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .15s;text-align:left}.menu-item:hover{background:#f1f5f9}.menu-item.menu-pagato{color:#16a34a}.menu-item.menu-pagato:hover{background:#dcfce7}.menu-item.menu-non-rinnovato{color:#6b7280}.menu-item.menu-non-rinnovato:hover{background:#f3f4f6}.menu-item.menu-avviso{color:var(--primary-color)}.menu-item.menu-avviso:hover{background:var(--primary-light)}.menu-item.menu-sollecito{color:var(--warning-color)}.menu-item.menu-sollecito:hover{background:var(--warning-bg)}.menu-item-wrapper{position:relative}.submenu-arrow{margin-left:auto;transform:rotate(180deg)}.submenu{position:fixed;background:#fff;border:1px solid var(--border-color);border-radius:8px;box-shadow:0 8px 24px #00000040;min-width:140px;z-index:99999}.submenu-item{display:flex;align-items:center;gap:.5rem;width:100%;padding:.6rem 1rem;border:none;background:none;font-size:.8rem;font-weight:500;cursor:pointer;transition:all .15s;text-align:left;color:var(--text-color)}.submenu-item:hover{background:var(--primary-light);color:var(--primary-color)}.menu-divider{height:1px;background:var(--border-color);margin:.25rem 0}.legend{display:flex;gap:1.5rem;justify-content:center;padding:1rem;margin-top:.75rem;color:var(--text-secondary);font-size:.8rem}.legend-item{display:flex;align-items:center;gap:.5rem}.legend-color{width:16px;height:16px;border-radius:3px;border:1px solid rgba(0,0,0,.1)}.legend-color.scaduta{background:#fee2e2}.legend-color.mora{background:#fef9c3}.legend-color.pagato{background:#dcfce7}.legend-color.non-rinnovato{background:#f3f4f6}@media(max-width:768px){.scadenze-container{padding:1rem}.scadenze-header{flex-direction:column;align-items:flex-start}.header-actions{width:100%}.header-actions .btn{flex:1;justify-content:center}.tabs-container{width:100%}.tab-btn{flex:1;justify-content:center;padding:.6rem .75rem;font-size:.8rem}.stats-bar{flex-direction:column;align-items:flex-start;gap:.5rem}.legend{flex-wrap:wrap;gap:1rem}.filters-bar{flex-direction:column;align-items:stretch}.search-group,.filter-group{width:100%}.filter-select{flex:1;min-width:auto}.date-group{flex-wrap:wrap}.date-input{flex:1;min-width:100px}}.btn-icon{background:var(--primary-light);color:var(--primary-color);border:1px solid rgba(99,102,241,.2);padding:.75rem;border-radius:var(--border-radius);cursor:pointer;transition:all var(--transition-base);display:flex;align-items:center;justify-content:center}.btn-icon:hover{background-color:#c7d2fe;border-color:#6366f14d}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-content{background:#fff;border-radius:var(--border-radius-lg);box-shadow:0 20px 60px #0000004d;width:100%;max-width:600px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-color);background:#f8fafc}.modal-header h3{font-size:1.1rem;font-weight:600;color:var(--text-color);margin:0}.modal-close{background:none;border:none;cursor:pointer;color:var(--text-secondary);padding:.25rem;border-radius:4px;transition:all .15s}.modal-close:hover{background:var(--border-color);color:var(--text-color)}.modal-tabs{display:flex;border-bottom:1px solid var(--border-color)}.modal-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:1rem;border:none;background:none;font-size:.9rem;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all .15s;border-bottom:2px solid transparent}.modal-tab:hover{background:#f8fafc;color:var(--text-color)}.modal-tab.active{color:var(--primary-color);border-bottom-color:var(--primary-color);background:var(--primary-light)}.modal-body{padding:1.5rem;overflow-y:auto;flex:1}.template-section{margin-bottom:1.5rem}.template-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}.template-header h4{font-size:.95rem;font-weight:600;color:var(--text-color);margin:0}.template-label{display:block;font-size:.85rem;font-weight:500;color:var(--text-secondary);margin-bottom:.35rem;margin-top:.75rem}.template-input{width:100%;padding:.75rem;border:1px solid var(--border-color);border-radius:8px;font-size:.9rem;transition:all .15s}.template-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #6366f11a}.template-textarea{width:100%;padding:.75rem;border:1px solid var(--border-color);border-radius:8px;font-size:.9rem;font-family:inherit;resize:vertical;transition:all .15s}.template-textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #6366f11a}.placeholders-info{background:#f8fafc;border:1px solid var(--border-color);border-radius:8px;padding:1rem}.placeholders-info h4{font-size:.85rem;font-weight:600;color:var(--text-color);margin:0 0 .75rem}.placeholders-list{display:flex;flex-wrap:wrap;gap:.5rem}.placeholders-list code{background:var(--primary-light);color:var(--primary-color);padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:500}.modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem;border-top:1px solid var(--border-color);background:#f8fafc}.pdf-container{padding:2rem;max-width:1100px}.pdf-header{margin-bottom:2rem}.pdf-header h2{font-size:1.75rem;font-weight:700;color:var(--text-color);margin-bottom:.5rem;letter-spacing:-.025em}.pdf-description{color:var(--text-secondary);font-size:.95rem}.pdf-content-layout{display:grid;grid-template-columns:1fr 320px;gap:1.5rem;align-items:start}.pdf-form{background:var(--card-bg);border-radius:var(--border-radius-lg);padding:2rem;box-shadow:var(--shadow);border:1px solid var(--border-color)}.form-group{margin-bottom:1.75rem}.form-group:last-child{margin-bottom:0}.form-group label{display:block;font-weight:600;margin-bottom:.75rem;color:var(--text-color);font-size:.9rem}.form-group .checkbox-label{display:flex;align-items:center;gap:.75rem;cursor:pointer;font-weight:500;margin-bottom:0}.form-group .checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:var(--primary-color)}.form-group .checkbox-label span{color:var(--text-color)}.file-input-wrapper{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.spin{animation:spin 1s linear infinite}.file-info{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:var(--primary-light);border-radius:var(--border-radius-sm);font-size:.85rem;color:var(--primary-color)}.btn-remove{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:.25rem;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all var(--transition-fast)}.btn-remove:hover{color:var(--danger-color);background:var(--danger-bg)}.file-name{font-size:.85rem;color:var(--text-secondary);padding:.5rem 1rem;background:var(--primary-light);border-radius:var(--border-radius-sm)}.logo-preview{margin-top:1rem;padding:1.5rem;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-radius:var(--border-radius);display:inline-block;border:2px dashed var(--border-color)}.logo-preview img{max-width:150px;max-height:60px;object-fit:contain}.logo-preview-inline{display:inline-flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-radius:var(--border-radius);border:2px solid var(--border-color)}.logo-preview-inline img{max-width:120px;max-height:45px;object-fit:contain}.btn-remove-logo{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:.35rem;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all var(--transition-fast)}.btn-remove-logo:hover{color:var(--danger-color);background:var(--danger-bg)}.file-preview-inline{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:linear-gradient(135deg,#ecfdf5,#d1fae5);border-radius:var(--border-radius);border:2px solid #10b981;color:#047857}.file-preview-inline svg:first-child{flex-shrink:0}.file-preview-name{font-weight:600;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-preview-count{font-size:.85rem;color:#059669}.btn-remove-file{background:none;border:none;color:#6b7280;cursor:pointer;padding:.35rem;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all var(--transition-fast);margin-left:.25rem}.btn-remove-file:hover{color:var(--danger-color);background:var(--danger-bg)}.btn-remove-file:disabled{opacity:.5;cursor:not-allowed}.status-message{display:flex;align-items:center;gap:.75rem;padding:1rem 1.25rem;border-radius:var(--border-radius);background:var(--info-bg);color:var(--info-color);font-size:.9rem;font-weight:500;margin-top:1.5rem;border:1px solid rgba(59,130,246,.2)}.status-message .spin{animation:spin 1s linear infinite}.status-message.success{background:var(--success-bg);color:var(--success-text);border-color:#22c55e33}.info-box{padding:1rem 1.25rem;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-radius:var(--border-radius);font-size:.9rem;margin-top:1rem;border:1px solid var(--border-color)}.pdf-info{background:var(--card-bg);border-radius:var(--border-radius-lg);padding:1.5rem;box-shadow:var(--shadow);border:1px solid var(--border-color);position:sticky;top:1rem}.pdf-info h3{font-size:1rem;font-weight:700;margin-bottom:1.25rem;color:var(--text-color);text-transform:uppercase;letter-spacing:.05em;font-size:.8rem}.pdf-info ul{list-style:none;padding:0}.pdf-info li{padding:.75rem 0;border-bottom:1px solid var(--border-color);font-size:.9rem;color:var(--text-secondary);line-height:1.5}.pdf-info li:last-child{border-bottom:none;padding-bottom:0}.pdf-info li strong{color:var(--text-color);font-weight:600}.compagnie-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1rem}.compagnia-card{display:flex;align-items:center;gap:1rem;padding:1.5rem;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:2px solid var(--border-color);border-radius:var(--border-radius-lg);cursor:pointer;transition:all var(--transition-fast);text-align:left}.compagnia-card:hover{border-color:var(--primary-color);background:linear-gradient(135deg,#eef2ff,#e0e7ff);box-shadow:0 4px 12px #6366f126;transform:translateY(-2px)}.compagnia-card svg{color:var(--primary-color);flex-shrink:0}.compagnia-info{display:flex;flex-direction:column;gap:.25rem}.compagnia-nome{font-weight:700;font-size:1.1rem;color:var(--text-color)}.compagnia-desc{font-size:.85rem;color:var(--text-secondary)}.compagnia-selezionata{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;background:linear-gradient(135deg,#eef2ff,#e0e7ff);border:1px solid var(--primary-color);border-radius:var(--border-radius-lg);margin-bottom:1.5rem}.compagnia-selezionata-info{display:flex;align-items:center;gap:.75rem;font-weight:600;color:var(--text-color)}.compagnia-selezionata-info svg{color:var(--primary-color)}.produttori-list{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--border-color)}.produttori-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.produttori-header h4{font-size:1rem;font-weight:600;color:var(--text-color);margin:0}.produttori-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:.75rem}.produttore-card{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-radius:var(--border-radius);border:1px solid var(--border-color);transition:all var(--transition-fast)}.produttore-card:hover{border-color:var(--primary-color);box-shadow:0 2px 8px #6366f11a}.produttore-info{display:flex;align-items:center;gap:.75rem}.produttore-info svg{color:var(--primary-color)}.produttore-info>div{display:flex;flex-direction:column}.produttore-nome{font-weight:600;color:var(--text-color);font-size:.95rem}.produttore-count{font-size:.8rem;color:var(--text-secondary)}.btn-sm{padding:.5rem .75rem;font-size:.85rem}.btn-genera-pdf{width:100%;justify-content:center;padding:1rem 1.5rem;font-size:1rem}.btn-sm svg{width:16px;height:16px}@media(max-width:900px){.pdf-content-layout{grid-template-columns:1fr}.pdf-info{position:static;order:2}}@media(max-width:768px){.pdf-container{padding:1rem}.pdf-form{padding:1.25rem}.file-input-wrapper{flex-direction:column;align-items:flex-start}.btn{width:100%;justify-content:center}.produttori-header{flex-direction:column;align-items:flex-start;gap:.75rem}.produttori-grid{grid-template-columns:1fr}.logo-preview-inline,.file-preview-inline{width:100%;justify-content:space-between}.file-preview-name{max-width:120px}}.sinistri-container{padding:2rem;max-width:100%}.sinistri-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.sinistri-header h2{font-size:1.75rem;font-weight:700;color:var(--text-color);letter-spacing:-.025em}.sinistri-container .server-status{display:flex;align-items:center;gap:.4rem;font-size:.8rem;font-weight:500;padding:.35rem .75rem;border-radius:20px;transition:all .3s ease}.sinistri-container .server-status.online{background:#22c55e1a;color:#16a34a}.sinistri-container .server-status.offline{background:#ef44441a;color:#dc2626}.sinistri-container .server-status.checking{background:#eab3081a;color:#ca8a04}.header-actions{display:flex;gap:.75rem}.btn{border:none;padding:.875rem 1.5rem;border-radius:var(--border-radius);font-size:.9rem;font-weight:600;cursor:pointer;transition:all var(--transition-base);display:inline-flex;align-items:center;gap:.5rem}.btn-primary{background:linear-gradient(135deg,var(--primary-color) 0%,#818cf8 100%);color:#fff;box-shadow:0 4px 14px #6366f159}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #6366f173}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-primary:disabled{opacity:.7;cursor:not-allowed;transform:none}.btn-primary .spin{animation:spin 1s linear infinite}.btn-secondary{background-color:var(--primary-light);color:var(--primary-color);border:1px solid rgba(99,102,241,.2)}.btn-secondary:hover{background-color:#c7d2fe;border-color:#6366f14d}.btn-danger{background-color:var(--danger-bg);color:var(--danger-color);border:1px solid rgba(239,68,68,.2)}.btn-danger:hover{background-color:#fecaca;border-color:#ef44444d}.actions-bar{display:flex;gap:.75rem;align-items:center;flex-wrap:wrap;margin-bottom:1rem}.compagnie-importate{display:flex;align-items:center;gap:.5rem;margin-left:auto;flex-wrap:wrap}.compagnia-tag{display:inline-flex;align-items:center;gap:.25rem;padding:.35rem .75rem;background:var(--primary-color);color:#fff;border-radius:20px;font-size:.8rem;font-weight:500}.remove-compagnia{background:none;border:none;color:#ffffffb3;cursor:pointer;font-size:1.1rem;line-height:1;padding:0 .25rem;margin-left:.25rem}.remove-compagnia:hover{color:#fff}.file-name{font-size:.85rem;color:var(--text-secondary);margin-bottom:1rem}.stats-bar{display:flex;gap:1.5rem;padding:1rem 1.5rem;background:var(--card-bg);border-radius:12px;margin-bottom:1rem;box-shadow:0 1px 3px #0000001a;flex-wrap:wrap;align-items:center}.stats-tabs{display:flex;gap:.25rem}.stat-tab{display:flex;align-items:center;gap:.35rem;padding:.4rem .65rem;border:1px solid var(--border-color);border-radius:6px;background:#fff;font-size:.8rem;cursor:pointer;transition:all .15s ease;color:var(--text-secondary)}.stat-tab:hover{border-color:var(--primary-color);color:var(--primary-color)}.stat-tab.active{background:var(--primary-light);border-color:var(--primary-color);color:var(--primary-color);font-weight:600}.stat-tab.warning.active{background:#fef3c7;border-color:#f59e0b;color:#b45309}.stat-tab.gestito.active{background:#fef9c3;border-color:#eab308;color:#a16207}.stat-tab.success.active{background:#dcfce7;border-color:#22c55e;color:#166534}.stat-tab.danger.active{background:#fee2e2;border-color:#ef4444;color:#991b1b}.tab-count{font-weight:600}.stat{display:flex;align-items:center;gap:.5rem}.stat-label{font-size:.85rem;color:var(--text-secondary)}.stat-value{font-size:1.1rem;font-weight:600}.stat-value.success{color:#166534}.stat-value.danger{color:#991b1b}.stat-value.warning{color:#854d0e}.stat-value.gestito{color:#ca8a04}.filters-bar{display:flex;gap:1rem;margin-bottom:1rem;flex-wrap:wrap}.search-input{flex:1;min-width:200px;padding:.75rem 1rem;border:1px solid var(--border-color);border-radius:8px;font-size:.9rem}.search-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #2563eb1a}.filter-select{padding:.75rem 1rem;border:1px solid var(--border-color);border-radius:8px;font-size:.9rem;background:#fff;cursor:pointer}.filter-select:focus{outline:none;border-color:var(--primary-color)}.table-wrapper{background:var(--card-bg);border-radius:12px;box-shadow:0 1px 3px #0000001a;overflow-x:auto;max-height:calc(100vh - 350px);overflow-y:auto}.sinistri-table{width:100%;border-collapse:collapse;font-size:.85rem}.sinistri-table th{background:#e5e7eb;color:#374151;font-weight:600;text-align:left;padding:.75rem;white-space:nowrap;position:sticky;top:0;z-index:10}.sinistri-table td{padding:.5rem .75rem;border-bottom:1px solid var(--border-color);vertical-align:middle}.sinistri-table tbody tr:hover{background-color:#4b556314}.sinistri-table tbody tr.row-riscattato{background-color:#c8ffc8}.sinistri-table tbody tr.row-riscattato:hover{background-color:#b4f5b4}.sinistri-table tbody tr.row-non-riscattato{background-color:#ffc8c8}.sinistri-table tbody tr.row-non-riscattato:hover{background-color:#ffb4b4}.sinistri-table tbody tr.row-gestito{background-color:#ffff96}.sinistri-table tbody tr.row-gestito:hover{background-color:#ffff78}.mese-separator{background:#d1d5db!important}.mese-separator td{color:#374151;font-weight:600;font-size:.9rem;padding:.5rem .75rem;border-top:3px solid #d1d5db}.col-compagnia{font-weight:600;color:#374151}.col-numero{font-family:monospace;font-size:.8rem}.col-contraente{min-width:150px}.col-data{white-space:nowrap}.col-mese{font-size:.75rem;color:var(--text-secondary)}.col-targa{font-family:monospace;font-weight:500}.col-importo{text-align:right;white-space:nowrap}.col-gestione{min-width:140px}.gestione-select{width:100%;padding:.4rem .5rem;border:1px solid var(--border-color);border-radius:6px;font-size:.8rem;background:#fff;cursor:pointer}.gestione-select:focus{outline:none;border-color:var(--primary-color)}.gestione-select.riscattato{background-color:#c8ffc8;border-color:#22c55e}.gestione-select.non-riscattato{background-color:#ffc8c8;border-color:#ef4444}.gestione-select.gestito{background-color:#ffff96;border-color:#eab308}.col-note{min-width:120px;position:relative}.nota-container{position:relative;cursor:pointer;border-radius:6px;transition:all .2s}.nota-preview{display:flex;align-items:center;gap:.35rem;padding:.4rem .6rem;border-radius:6px;font-size:.75rem;color:var(--text-muted);background:#f8fafc;border:1px dashed var(--border-color);transition:all .2s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:150px}.nota-preview svg{flex-shrink:0;opacity:.5}.nota-container:hover .nota-preview{background:#f1f5f9;border-color:var(--primary-color);color:var(--primary-color)}.nota-container:hover .nota-preview svg{opacity:1}.nota-container.has-note .nota-preview{background:#eff6ff;border:1px solid #93c5fd;color:#1e40af}.nota-container.has-note .nota-preview svg{opacity:1;color:#3b82f6}.nota-container.has-note:hover .nota-preview{background:#dbeafe}.nota-tooltip{display:none;position:absolute;bottom:calc(100% + 8px);left:0;background:#1e293b;color:#fff;padding:.6rem .8rem;border-radius:6px;font-size:.75rem;line-height:1.4;max-width:250px;white-space:pre-wrap;word-break:break-word;z-index:200;box-shadow:0 4px 12px #0003}.nota-tooltip:after{content:"";position:absolute;top:100%;left:16px;border:6px solid transparent;border-top-color:#1e293b}.nota-container.has-note:hover .nota-tooltip{display:block}.nota-container.editing{position:absolute;z-index:50;right:0;top:0;width:250px}.nota-textarea{width:100%;min-height:80px;padding:.75rem;border:2px solid var(--primary-color);border-radius:8px;font-size:.8rem;font-family:inherit;resize:vertical;background:#fff;box-shadow:0 4px 12px #00000026}.nota-textarea:focus{outline:none}.nota-textarea::placeholder{color:var(--text-muted)}.col-azioni{width:50px;text-align:center;position:relative}.row-menu-open{position:relative;z-index:100}.col-azioni.menu-open{z-index:9999;isolation:isolate}.azioni-container{position:relative;display:inline-block}.btn-azioni{background:none;border:none;padding:.35rem;cursor:pointer;color:var(--text-secondary);border-radius:4px;transition:all .15s ease;display:flex;align-items:center;justify-content:center}.btn-azioni:hover{background:var(--primary-light);color:var(--primary-color)}.sinistri-container .azioni-menu{position:fixed;right:auto!important;background:#fff;border:1px solid var(--border-color);border-radius:8px;box-shadow:0 8px 24px #00000040;z-index:99999;min-width:160px}.azioni-item{display:flex;align-items:center;gap:.5rem;width:100%;padding:.65rem 1rem;border:none;background:none;font-size:.85rem;color:var(--text-color);cursor:pointer;transition:all .15s ease;text-align:left}.azioni-item:hover{background:var(--primary-light)}.azioni-item.active{background:var(--primary-light);color:var(--primary-color);font-weight:600}.azioni-item svg{flex-shrink:0}.legend{display:flex;gap:1.5rem;margin-top:1rem;padding:.75rem;justify-content:flex-end;flex-wrap:wrap}.legend-item{display:flex;align-items:center;gap:.5rem;font-size:.8rem;color:var(--text-secondary)}.legend-color{width:16px;height:16px;border-radius:4px;border:1px solid var(--border-color)}.legend-color.riscattato{background:#c8ffc8}.legend-color.non-riscattato{background:#ffc8c8}.legend-color.gestito{background:#ffff96}.empty-state{text-align:center;padding:4rem 2rem;background:var(--card-bg);border-radius:var(--border-radius-lg);box-shadow:var(--shadow);border:2px dashed var(--border-color)}.empty-icon{color:var(--text-muted);margin-bottom:1.5rem}.empty-state h3{font-size:1.25rem;font-weight:600;color:var(--text-color);margin-bottom:.5rem}.empty-state p{color:var(--text-secondary);font-size:.95rem}.empty-hint{margin-top:1rem;font-size:.85rem!important}@media(max-width:768px){.sinistri-header{flex-direction:column;align-items:flex-start}.filters-bar{flex-direction:column}.search-input{width:100%}.stats-bar{flex-direction:column;gap:.5rem}.stats-tabs{flex-wrap:wrap}.stat-tab{font-size:.75rem;padding:.3rem .5rem}.actions-bar{flex-direction:column;align-items:stretch}.compagnie-importate{margin-left:0;margin-top:.5rem}}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;border-radius:12px;width:100%;max-width:450px;box-shadow:0 20px 40px #0003;overflow:hidden}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-color)}.modal-header h3{margin:0;font-size:1.1rem;font-weight:600;color:var(--text-color)}.modal-close{background:none;border:none;padding:.25rem;cursor:pointer;color:var(--text-secondary);border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .15s ease}.modal-close:hover{background:var(--primary-light);color:var(--primary-color)}.modal-body{padding:1.5rem}.modal-body .form-group{margin-bottom:1.25rem}.modal-body .form-group:last-child{margin-bottom:0}.modal-body label{display:flex;align-items:center;gap:.5rem;font-weight:600;margin-bottom:.75rem;color:var(--text-color);font-size:.9rem}.modal-body label svg{color:var(--primary-color)}.select-wrapper{position:relative}.modal-select{width:100%;padding:.875rem 2.5rem .875rem 1rem;border:2px solid var(--border-color);border-radius:10px;font-size:.95rem;background:linear-gradient(135deg,#f8fafc,#fff);cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%236366f1' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;background-size:18px;transition:all .2s ease}.modal-select:hover{border-color:var(--primary-color)}.modal-select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 4px #6366f126}.file-dropzone{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;padding:2rem 1.5rem;border:2px dashed var(--border-color);border-radius:10px;background:linear-gradient(135deg,#f8fafc,#fff);cursor:pointer;transition:all .2s ease;color:var(--text-secondary)}.file-dropzone:hover{border-color:var(--primary-color);background:linear-gradient(135deg,#eef2ff,#fff)}.file-dropzone:hover svg{color:var(--primary-color)}.file-dropzone svg{color:var(--text-muted);transition:color .2s ease}.file-dropzone span{font-size:.9rem}.file-dropzone-hint{font-size:.8rem!important;color:var(--text-muted)}.file-selected-preview{display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;background:linear-gradient(135deg,#ecfdf5,#d1fae5);border:2px solid #10b981;border-radius:10px}.file-selected-preview>svg{color:#059669;flex-shrink:0}.file-selected-info{flex:1;display:flex;flex-direction:column;gap:.15rem;min-width:0}.file-selected-name{font-weight:600;color:#047857;font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.file-selected-size{font-size:.75rem;color:#059669}.file-selected-remove{background:none;border:none;padding:.35rem;cursor:pointer;color:#6b7280;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .15s ease}.file-selected-remove:hover{background:#ef44441a;color:#ef4444}.modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem;border-top:1px solid var(--border-color);background:#f9fafb}.btn-group{display:flex;gap:.5rem;align-items:center}.btn-group-right{margin-left:auto}.btn-nuovo{background:linear-gradient(135deg,#10b981,#34d399);color:#fff;border:none;width:42px;height:42px;border-radius:var(--border-radius);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-base);box-shadow:0 4px 14px #10b98159}.btn-nuovo:hover{transform:translateY(-2px);box-shadow:0 6px 20px #10b98173}.btn-nuovo:active{transform:translateY(0)}.modal-nuovo-sinistro{max-width:700px}.modal-body-scroll{padding:1.5rem;max-height:60vh;overflow-y:auto}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}.form-row .form-group{margin-bottom:0}.form-row .form-group.full-width{grid-column:1 / -1}.modal-input{width:100%;padding:.75rem 1rem;border:2px solid var(--border-color);border-radius:8px;font-size:.9rem;transition:all .2s ease;background:#fff}.modal-input:hover{border-color:#a5b4fc}.modal-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #6366f126}.modal-textarea{width:100%;padding:.75rem 1rem;border:2px solid var(--border-color);border-radius:8px;font-size:.9rem;transition:all .2s ease;background:#fff;resize:vertical;min-height:80px;font-family:inherit}.modal-textarea:hover{border-color:#a5b4fc}.modal-textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #6366f126}@media(max-width:768px){.modal-nuovo-sinistro{max-width:95%;margin:1rem}.form-row{grid-template-columns:1fr}.modal-body-scroll{max-height:70vh}}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:1rem}.login-loading{display:flex;flex-direction:column;align-items:center;gap:1rem;color:#fff}.login-loading .spin{animation:spin 1s linear infinite}.login-card{background:#fff;border-radius:16px;box-shadow:0 25px 50px -12px #00000040;padding:2.5rem;width:100%;max-width:420px}.login-header{text-align:center;margin-bottom:2rem}.login-logo{display:inline-flex;align-items:center;justify-content:center;width:80px;height:80px;background:linear-gradient(135deg,var(--primary-color) 0%,#818cf8 100%);border-radius:20px;color:#fff;margin-bottom:1rem}.login-header h1{font-size:1.75rem;font-weight:700;color:var(--text-color);margin:0 0 .5rem}.login-header p{color:var(--text-secondary);margin:0}.login-error{display:flex;align-items:center;gap:.5rem;background:#ef44441a;color:#dc2626;padding:.75rem 1rem;border-radius:8px;margin-bottom:1.5rem;font-size:.875rem}.setup-info{color:var(--text-secondary);font-size:.875rem;text-align:center;margin-bottom:1.5rem;line-height:1.5}.login-form .form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.login-form .form-group{margin-bottom:1.25rem}.login-form label{display:flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:500;color:var(--text-color);margin-bottom:.5rem}.login-form label svg{color:var(--text-secondary)}.login-form input{width:100%;padding:.75rem 1rem;border:1px solid var(--border-color);border-radius:8px;font-size:.95rem;transition:all .2s;background:#fafafa}.login-form input:focus{outline:none;border-color:var(--primary-color);background:#fff;box-shadow:0 0 0 3px #6366f11a}.login-form input::placeholder{color:#9ca3af}.btn-login{width:100%;padding:.875rem 1.5rem;background:linear-gradient(135deg,var(--primary-color) 0%,#818cf8 100%);color:#fff;border:none;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.5rem;transition:all .2s;margin-top:.5rem}.btn-login:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #6366f166}.btn-login:disabled{opacity:.7;cursor:not-allowed}.btn-login .spin{animation:spin 1s linear infinite}@media(max-width:480px){.login-card{padding:1.5rem}.login-form .form-row{grid-template-columns:1fr}}.app-layout{display:flex;min-height:100vh}.main-content{flex:1;margin-left:var(--sidebar-width);width:calc(100% - var(--sidebar-width));min-height:100vh;transition:margin-left .3s ease,width .3s ease;background-color:var(--bg-color)}.sidebar.collapsed~.main-content,.app-layout:has(.sidebar.collapsed) .main-content{margin-left:var(--sidebar-collapsed-width);width:calc(100% - var(--sidebar-collapsed-width))}.app-loading{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;color:var(--text-secondary)}.app-loading .spin{animation:spin 1s linear infinite;color:var(--primary-color)}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}
