svg{fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.cliente-sidebar-icon{width:20px;height:20px}.dashboard-kpi-icon svg{width:24px;height:24px}.dashboard-kpi-icon.blue svg{stroke:#3b82f6}.dashboard-kpi-icon.green svg{stroke:#22c55e}.dashboard-kpi-icon.yellow svg{stroke:#f59e0b}.dashboard-kpi-icon.pink svg{stroke:#ec4899}.cantiere-count svg{width:16px;height:16px}.chat-empty-icon,.chat-drop-icon{width:64px;height:64px}.chat-attach-icon,.chat-file-icon,.chat-download-icon{width:20px;height:20px}.search-icon,.search-close-btn svg{width:24px;height:24px}.search-result-icon{width:20px;height:20px;color:#3b82f6}.notification-btn svg,.notification-banner-icon svg{width:20px;height:20px}.user-menu-logout svg{width:20px;height:20px}.notifiche-icon{width:32px;height:32px}.tecnici-search-icon{width:20px;height:20px}:root{--color-brand-primary: #667eea;--color-brand-secondary: #764ba2;--color-brand-gradient: linear-gradient(135deg, #667eea 0%, #764ba2 100%);--color-primary-500: #3b82f6;--color-primary-600: #2563eb;--color-primary-700: #1d4ed8;--color-primary-50: #eff6ff;--color-primary-100: #dbeafe;--color-neutral-900: #0f172a;--color-neutral-800: #1e293b;--color-neutral-700: #334155;--color-neutral-600: #475569;--color-neutral-500: #64748b;--color-neutral-400: #94a3b8;--color-neutral-300: #cbd5e1;--color-neutral-200: #e2e8f0;--color-neutral-100: #f1f5f9;--color-neutral-50: #f8fafc;--color-success: #10b981;--color-success-light: #dcfce7;--color-success-dark: #166534;--color-danger: #ef4444;--color-danger-light: #fee2e2;--color-danger-dark: #dc2626;--color-warning: #f59e0b;--color-warning-light: #fef3c7;--color-info: #3b82f6;--color-info-light: #dbeafe;--color-text-primary: #1e293b;--color-text-secondary: #64748b;--color-text-tertiary: #94a3b8;--color-bg-app: #f1f5f9;--color-bg-surface: #ffffff;--color-bg-hover: #f8fafc;--color-bg-elevated: #ffffff;--color-border-default: #e2e8f0;--color-border-light: #f1f5f9;--color-border-dark: #cbd5e1;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--space-12: 48px;--space-16: 64px;--font-sans: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--font-size-xs: 12px;--font-size-sm: 14px;--font-size-base: 16px;--font-size-lg: 20px;--font-size-xl: 24px;--font-size-2xl: 28px;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--line-height-tight: 1.25;--line-height-normal: 1.5;--line-height-relaxed: 1.75;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 1px 3px rgba(0, 0, 0, .1);--shadow-lg: 0 4px 12px rgba(0, 0, 0, .05);--shadow-xl: 0 10px 25px rgba(0, 0, 0, .1);--shadow-2xl: 0 20px 40px rgba(0, 0, 0, .15);--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease;--z-dropdown: 1000;--z-sticky: 1020;--z-fixed: 1030;--z-modal-backdrop: 1040;--z-modal: 1050;--z-popover: 1060;--z-tooltip: 1070;--sidebar-width: 260px;--header-height: 64px;--content-max-width: 1200px}*{margin:0;padding:0;box-sizing:border-box}html,body{height:100%;font-family:var(--font-sans);font-size:var(--font-size-base);line-height:var(--line-height-normal);color:var(--color-text-primary);background:var(--color-bg-app)}[x-cloak]{display:none!important}a{color:inherit;text-decoration:none}button{font-family:inherit;cursor:pointer}input,textarea,select{font-family:inherit}@keyframes slideIn{0%{transform:translate(400px);opacity:0}to{transform:translate(0);opacity:1}}@keyframes slideOut{0%{transform:translate(0);opacity:1}to{transform:translate(400px);opacity:0}}.animate-slide-in{animation:slideIn .3s ease-out forwards}.animate-slide-out{animation:slideOut .3s ease-in forwards}body.pwa-installed{padding-top:env(titlebar-area-height,0)}body,*{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}button,a,.cliente-conversation-item,.cliente-btn,.cliente-nav-item{will-change:transform;transform:translateZ(0)}button,a,.clickable,.cliente-nav-item{transition:transform .1s cubic-bezier(.4,0,.2,1),background-color .15s ease,color .15s ease}button:active,a:active,.clickable:active,.cliente-nav-item:active{transform:scale(.97) translateZ(0)}.cliente-page-container,.cliente-chat-container{animation:fadeInPage .2s ease-out}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}*{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}button,a,.cliente-conversation-item,.cliente-btn,.cliente-nav-item,.clickable{will-change:transform;transform:translateZ(0)}button,a,.clickable,.cliente-nav-item,.cliente-conversation-item{transition:transform .1s cubic-bezier(.4,0,.2,1),background-color .15s ease,color .15s ease,opacity .15s ease}button:active,a:active,.clickable:active,.cliente-nav-item:active,.cliente-conversation-item:active{transform:scale(.97) translateZ(0)}@keyframes spin{to{transform:rotate(360deg) translateZ(0)}}.loading-spinner,[class*=spinner]{animation:spin .8s linear infinite;will-change:transform}@keyframes fadeInPage{0%{opacity:0;transform:translateY(8px) translateZ(0)}to{opacity:1;transform:translateY(0) translateZ(0)}}.cliente-page-container,.cliente-chat-container,.page-transition{animation:fadeInPage .2s ease-out}@keyframes slideInUp{0%{opacity:0;transform:translateY(20px) translateZ(0)}to{opacity:1;transform:translateY(0) translateZ(0)}}.modal-content,.dropdown-menu{animation:slideInUp .25s ease-out}button:focus-visible,a:focus-visible,input:focus-visible,textarea:focus-visible{outline:2px solid var(--color-primary, #6366f1);outline-offset:2px}button:focus:not(:focus-visible),a:focus:not(:focus-visible){outline:none}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}.loading-spinner{animation:none;border-left-color:transparent}}html{scroll-behavior:smooth}@media (prefers-reduced-motion: reduce){html{scroll-behavior:auto}}::selection{background-color:#6366f133;color:inherit}::-moz-selection{background-color:#6366f133;color:inherit}*{-webkit-tap-highlight-color:transparent}@media (hover: none) and (pointer: coarse){button:active,a:active,.clickable:active{background-color:#0000000d}}.skeleton{background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0,#f0f0f0 75%);background-size:200% 100%;animation:skeleton-loading 1.5s ease-in-out infinite}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.cliente-conversation-item:hover{background:#6366f10d}.cliente-conversation-item:active{background:#6366f11a;transform:scale(.995) translateZ(0)}.cliente-conversation-item.active{background:#6366f11a;border-left:3px solid #6366f1}.cliente-conversation-item.active:hover{background:#6366f126}.cliente-btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-base);white-space:nowrap}.cliente-btn-primary{background:var(--color-primary-500);color:#fff}.cliente-btn-primary:hover{background:var(--color-primary-600)}.cliente-btn-secondary{background:#fff;color:var(--color-neutral-600);border:1px solid var(--color-border-default)}.cliente-btn-secondary:hover{background:var(--color-bg-hover)}.cliente-btn-danger{background:var(--color-danger);color:#fff}.cliente-btn-danger:hover{background:var(--color-danger-dark)}.cliente-header-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--color-neutral-100);border-radius:var(--radius-md);color:var(--color-neutral-500);cursor:pointer;border:none;transition:all var(--transition-base)}.cliente-header-btn:hover{background:var(--color-neutral-200)}.cliente-btn-sm{padding:var(--space-2) var(--space-3);font-size:var(--font-size-xs)}.cliente-btn-lg{padding:var(--space-4) var(--space-6);font-size:var(--font-size-base)}.cliente-btn:disabled{opacity:.5;cursor:not-allowed}.cliente-input{width:100%;padding:var(--space-3) var(--space-4);font-size:var(--font-size-sm);color:var(--color-text-primary);background:#fff;border:1px solid var(--color-border-default);border-radius:var(--radius-md);transition:all var(--transition-base)}.cliente-input:focus{outline:none;border-color:var(--color-primary-500);box-shadow:0 0 0 3px #3b82f61a}.cliente-input::-moz-placeholder{color:var(--color-neutral-400)}.cliente-input::placeholder{color:var(--color-neutral-400)}.cliente-input:disabled{background:var(--color-neutral-50);color:var(--color-neutral-400);cursor:not-allowed}.cliente-select{width:100%;padding:var(--space-3) var(--space-4);font-size:var(--font-size-sm);color:var(--color-text-primary);background:#fff;border:1px solid var(--color-border-default);border-radius:var(--radius-md);transition:all var(--transition-base);cursor:pointer}.cliente-select:focus{outline:none;border-color:var(--color-primary-500)}.cliente-textarea{width:100%;padding:var(--space-3) var(--space-4);font-size:var(--font-size-sm);color:var(--color-text-primary);background:#fff;border:1px solid var(--color-border-default);border-radius:var(--radius-md);transition:all var(--transition-base);resize:vertical;min-height:100px}.cliente-textarea:focus{outline:none;border-color:var(--color-primary-500);box-shadow:0 0 0 3px #3b82f61a}.cliente-checkbox{width:20px;height:20px;cursor:pointer}.cliente-label{display:block;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary);margin-bottom:var(--space-2)}.cliente-input-error{border-color:var(--color-danger)}.cliente-input-error:focus{border-color:var(--color-danger);box-shadow:0 0 0 3px #ef44441a}.cliente-error-text{color:var(--color-danger);font-size:var(--font-size-xs);margin-top:var(--space-1)}.card{background:var(--color-bg-surface);border-radius:var(--radius-lg);border:1px solid var(--color-border-default);padding:var(--space-6)}.card-elevated{background:var(--color-bg-surface);border-radius:var(--radius-lg);padding:var(--space-6);box-shadow:var(--shadow-md)}.page-card{background:var(--color-bg-surface);border-radius:var(--radius-lg);padding:var(--space-6);border:1px solid var(--color-border-default);min-height:600px;display:flex;flex-direction:column}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-6)}.card-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0}.card-body{flex:1}.card-footer{display:flex;justify-content:space-between;align-items:center;margin-top:var(--space-4);padding-top:var(--space-4);border-top:1px solid var(--color-border-default)}.cantiere-card,.tecnici-card,.notifiche-card{background:var(--color-neutral-50);border:1px solid var(--color-border-default);border-radius:var(--radius-lg);padding:var(--space-5);transition:all var(--transition-base)}.cantiere-card:hover,.tecnici-card:hover{box-shadow:var(--shadow-lg)}.badge{display:inline-flex;align-items:center;padding:var(--space-1) var(--space-3);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);border-radius:var(--radius-full)}.badge-primary{background:var(--color-primary-50);color:var(--color-primary-700)}.badge-danger{background:var(--color-danger-light);color:var(--color-danger-dark)}.badge-warning{background:var(--color-warning-light);color:var(--color-warning)}.badge-neutral{background:var(--color-neutral-100);color:var(--color-neutral-600)}.count-badge{display:inline-flex;align-items:center;justify-content:center;padding:var(--space-2) var(--space-4);background:var(--color-primary-50);color:var(--color-primary-500);border-radius:var(--radius-md);font-weight:var(--font-weight-semibold);font-size:var(--font-size-xs)}.notification-badge{position:absolute;top:-4px;right:-4px;width:18px;height:18px;background:var(--color-danger);color:#fff;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:var(--font-weight-semibold)}.checkup-status-badge{padding:var(--space-1) var(--space-3);background:var(--color-success-light);color:var(--color-success-dark);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold)}.cantiere-status-badge{padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold)}.cantiere-status-badge.active{background:var(--color-success-light);color:var(--color-success-dark)}.cantiere-status-badge.inactive{background:var(--color-neutral-100);color:var(--color-neutral-600)}.modal-overlay{position:fixed;inset:0;background:#00000080;z-index:var(--z-modal-backdrop);display:flex;align-items:center;justify-content:center}.search-overlay{position:fixed;inset:0;background:#00000080;z-index:var(--z-modal-backdrop);display:flex;align-items:start;justify-content:center;padding-top:100px}.search-modal{background:var(--color-bg-surface);border-radius:var(--radius-lg);width:90%;max-width:600px;box-shadow:var(--shadow-2xl)}.search-input-container{position:relative}.search-input{width:100%;padding:var(--space-5) var(--space-6) var(--space-5) 56px;font-size:var(--font-size-lg);border:none;outline:none;border-radius:var(--radius-lg) var(--radius-lg) 0 0}.search-icon{position:absolute;left:var(--space-5);top:50%;transform:translateY(-50%);width:24px;height:24px;color:var(--color-neutral-400)}.search-close-btn{position:absolute;right:var(--space-5);top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--color-neutral-400)}.search-close-btn:hover{color:var(--color-neutral-500)}.search-results{max-height:400px;overflow-y:auto;border-top:1px solid var(--color-border-default)}.search-category-header{padding:var(--space-3) var(--space-4);background:var(--color-neutral-50);border-bottom:1px solid var(--color-border-default)}.search-category-title{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-neutral-500);text-transform:uppercase}.search-result-item{padding:var(--space-3) var(--space-6);cursor:pointer;transition:background var(--transition-base);display:flex;align-items:center;gap:var(--space-3)}.search-result-item:hover{background:var(--color-neutral-50)}.search-result-title{font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.search-result-subtitle{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.search-empty{padding:var(--space-12);text-align:center;color:var(--color-neutral-400)}.export-overlay{position:fixed;inset:0;background:#00000080;z-index:var(--z-modal-backdrop);display:flex;align-items:center;justify-content:center}.export-modal{background:var(--color-bg-surface);border-radius:var(--radius-lg);width:90%;max-width:500px;padding:var(--space-6)}.export-title{margin:0 0 var(--space-6) 0;font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.export-field{margin-bottom:var(--space-5)}.export-label{display:block;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);margin-bottom:var(--space-2)}.export-select{width:100%;padding:var(--space-3);border:1px solid var(--color-border-default);border-radius:var(--radius-md);font-size:var(--font-size-sm)}.export-select:focus{outline:none;border-color:var(--color-primary-500)}.export-actions{display:flex;gap:var(--space-3);justify-content:flex-end;margin-top:var(--space-6)}.export-btn-cancel{padding:var(--space-3) var(--space-5);background:var(--color-neutral-100);color:var(--color-text-secondary);border:none;border-radius:var(--radius-md);cursor:pointer;font-weight:var(--font-weight-medium);transition:background var(--transition-base)}.export-btn-cancel:hover{background:var(--color-neutral-200)}.export-btn-confirm{padding:var(--space-3) var(--space-5);background:var(--color-primary-500);color:#fff;border:none;border-radius:var(--radius-md);cursor:pointer;font-weight:var(--font-weight-medium);transition:background var(--transition-base)}.export-btn-confirm:hover{background:var(--color-primary-600)}.search-result-icon{width:20px;height:20px;flex-shrink:0}.search-result-item:has(.search-result-icon:first-child) .search-result-icon{color:var(--color-primary-500)}.modal-content{background:var(--color-bg-surface);border-radius:var(--radius-lg);width:90%;max-width:600px;box-shadow:var(--shadow-2xl);max-height:90vh;overflow:hidden;display:flex;flex-direction:column}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--color-border-default)}.modal-header h3{margin:0;font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.modal-close{background:none;border:none;font-size:1.5rem;line-height:1;color:var(--color-neutral-400);cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);transition:all var(--transition-base)}.modal-close:hover{background:var(--color-neutral-100);color:var(--color-neutral-600)}.modal-body{padding:var(--space-6);overflow-y:auto;flex:1}.modal-footer{display:flex;gap:var(--space-3);justify-content:flex-end;padding:var(--space-5) var(--space-6);border-top:1px solid var(--color-border-default);background:var(--color-neutral-50)}.modal-body .form-label{display:block;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);margin-bottom:var(--space-2)}.modal-body .form-input{width:100%;padding:var(--space-3);border:1px solid var(--color-border-default);border-radius:var(--radius-md);font-size:var(--font-size-sm);transition:all var(--transition-base)}.modal-body .form-input:focus{outline:none;border-color:var(--color-primary-500);box-shadow:0 0 0 3px #3b82f61a}.modal-body .form-error{display:block;font-size:var(--font-size-xs);color:var(--color-error);margin-top:var(--space-1)}@media (max-width: 640px){.modal-content{width:95%;max-height:95vh}.modal-header,.modal-body,.modal-footer{padding:var(--space-4)}.modal-footer{flex-direction:column-reverse}.modal-footer button{width:100%}}.notification-btn-container{position:relative}.notification-btn{position:relative;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--color-neutral-100);border-radius:var(--radius-md);color:var(--color-neutral-500);cursor:pointer;border:none;transition:background var(--transition-base)}.notification-btn:hover{background:var(--color-neutral-200)}.notification-dropdown{position:absolute;top:calc(100% + var(--space-2));right:0;width:320px;background:var(--color-bg-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);z-index:var(--z-dropdown);overflow:hidden}.notification-header{padding:var(--space-4);border-bottom:1px solid var(--color-border-default);display:flex;justify-content:space-between;align-items:center}.notification-title{margin:0;font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.notification-mark-read{margin-left:auto;background:none;border:none;color:var(--color-primary-500);font-size:var(--font-size-sm);cursor:pointer}.notification-mark-read:hover{text-decoration:underline}.notification-list{max-height:400px;overflow-y:auto}.notification-item{padding:var(--space-4);border-bottom:1px solid var(--color-neutral-100)}.notification-item-clickable{cursor:pointer;transition:background var(--transition-base)}.notification-item-clickable:hover{background:var(--color-neutral-50)}.notification-item.unread{background:#f0f9ff}.notification-content{display:flex;gap:var(--space-3);align-items:flex-start}.notification-icon{width:32px;height:32px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px}.notification-icon svg{width:18px;height:18px;color:#fff}.notification-dot{width:8px;height:8px;border-radius:var(--radius-full);margin-top:6px}.notification-dot.unread{background:var(--color-primary-500)}.notification-dot.read{background:var(--color-neutral-200)}.notification-count-badge{display:inline-flex;align-items:center;justify-content:center;min-width:24px;height:24px;padding:0 var(--space-2);background:var(--color-primary-100);color:var(--color-primary-700);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold)}.notification-body{flex:1}.notification-item-title{margin:0 0 var(--space-1) 0;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.notification-item-message{margin:0 0 var(--space-1) 0;font-size:var(--font-size-sm);color:var(--color-text-secondary)}.notification-item-time{font-size:var(--font-size-xs);color:var(--color-neutral-400)}.notification-empty{padding:var(--space-8);text-align:center;color:var(--color-neutral-400)}.notification-footer{padding:var(--space-3);border-top:1px solid var(--color-border-default);text-align:center}.notification-view-all{color:var(--color-primary-500);text-decoration:none;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.notification-view-all:hover{text-decoration:underline}.notifiche-container{max-width:900px;margin:0 auto;padding:0 var(--space-4)}.notifiche-card{background:var(--color-bg-surface);border-radius:var(--radius-lg);padding:var(--space-8);box-shadow:var(--shadow-md)}.notifiche-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-6)}.notifiche-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin:0}.notifiche-badge{padding:var(--space-2) var(--space-3);background:var(--color-primary-100);color:var(--color-primary-700);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold)}.notifiche-device-box{background:linear-gradient(to right,#eff6ff,#e0e7ff);border-radius:var(--radius-lg);padding:var(--space-6);margin-bottom:var(--space-6);border:1px solid #c7d2fe;display:flex;justify-content:space-between;align-items:center}.notifiche-device-content{display:flex;align-items:center;gap:var(--space-4)}.notifiche-icon-wrapper{padding:var(--space-3);background:var(--color-bg-surface);border-radius:var(--radius-md);box-shadow:var(--shadow-sm)}.notifiche-icon{width:32px;height:32px;color:var(--color-primary-600)}.notifiche-btn{padding:var(--space-3) var(--space-6);background:var(--color-primary-600);color:#fff;border-radius:var(--radius-md);border:none;font-weight:var(--font-weight-semibold);cursor:pointer;transition:background var(--transition-base)}.notifiche-btn:hover{background:var(--color-primary-700)}.notifiche-empty{text-align:center;padding:var(--space-12) var(--space-6);color:var(--color-text-secondary)}.notifiche-empty-icon{width:48px;height:48px;margin:0 auto var(--space-4);color:var(--color-neutral-300)}.notifiche-device-item{display:flex;justify-content:space-between;align-items:center;padding:var(--space-4);background:var(--color-neutral-50);border-radius:var(--radius-md);margin-bottom:var(--space-2)}.user-avatar-btn{background:var(--color-brand-gradient)!important;border:none!important;cursor:pointer!important;padding:0!important;width:40px!important;height:40px!important;border-radius:var(--radius-full)!important;overflow:hidden!important;display:flex!important;align-items:center!important;justify-content:center!important;transition:transform var(--transition-base)}.user-avatar-btn:hover{transform:scale(1.05)}.user-avatar-initial{color:#fff;font-weight:var(--font-weight-semibold);font-size:var(--font-size-lg)}.user-dropdown-menu{position:absolute;right:0;top:48px;background:var(--color-bg-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);min-width:250px;z-index:var(--z-dropdown)}.user-dropdown-name{font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0}.user-dropdown-email{font-size:var(--font-size-xs);color:var(--color-text-secondary);margin:var(--space-1) 0 0 0}.user-dropdown-link{display:block;padding:var(--space-3) var(--space-4);color:var(--color-text-primary);text-decoration:none;font-size:var(--font-size-sm);transition:background var(--transition-base)}.user-dropdown-link:hover{background:var(--color-neutral-100)}.user-dropdown-logout{padding:var(--space-2) var(--space-4) var(--space-3) var(--space-4)}.user-logout-btn{width:100%;padding:var(--space-3);background:var(--color-danger);color:#fff;border:none;border-radius:var(--radius-sm);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:background var(--transition-base)}.user-logout-btn:hover{background:var(--color-danger-dark)}.user-menu-container{position:relative}.user-menu-dropdown{position:absolute;right:0;top:100%;margin-top:var(--space-2);background:var(--color-bg-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);min-width:200px;z-index:var(--z-dropdown);overflow:hidden}.user-menu-info{padding:var(--space-4);border-bottom:1px solid var(--color-border-default)}.user-menu-name{font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.user-menu-email{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.user-menu-actions{padding:var(--space-2)}.user-menu-logout{width:100%;text-align:left;padding:var(--space-3) var(--space-4);border:none;background:none;color:var(--color-text-primary);cursor:pointer;border-radius:var(--radius-md);transition:all var(--transition-base)}.user-menu-logout:hover{background:var(--color-neutral-100)}.user-menu-logout-content{display:flex;align-items:center;gap:var(--space-3)}.pagination-footer{margin-top:auto;padding:var(--space-6) 0;display:flex;justify-content:center}.pagination-nav{display:inline-flex;gap:var(--space-2);align-items:center}.pagination-btn,.pagination-number{display:inline-flex;align-items:center;justify-content:center;min-width:36px;height:36px;padding:0;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);border-radius:var(--radius-md);border:none;background:transparent;color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-base)}.pagination-btn:hover:not(.pagination-disabled),.pagination-number:hover:not(.pagination-active){color:var(--color-primary-500)}.pagination-active{background:var(--color-primary-500);color:#fff;font-weight:var(--font-weight-semibold);cursor:default}.pagination-disabled{color:var(--color-neutral-300);cursor:not-allowed;opacity:.4}.pagination-dots{color:var(--color-neutral-300);padding:0 var(--space-1)}.pagination-btn svg{width:18px;height:18px}.pwa-install-banner{position:fixed;top:80px;right:var(--space-4);background:linear-gradient(135deg,var(--color-primary-600) 0%,var(--color-primary-700) 100%);color:#fff;padding:var(--space-6);border-radius:var(--radius-xl);box-shadow:var(--shadow-2xl);z-index:var(--z-modal);max-width:400px;animation:slideInUp .3s ease-out}.pwa-install-banner.slide-out{animation:fadeOut .3s ease-in forwards}.pwa-install-content{display:flex;align-items:start;gap:var(--space-3)}.pwa-install-icon{width:32px;height:32px;flex-shrink:0;margin-top:var(--space-1)}.pwa-install-body{flex:1}.pwa-install-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);margin:0 0 var(--space-1) 0}.pwa-install-message{font-size:var(--font-size-sm);opacity:.9;margin:0 0 var(--space-4) 0}.pwa-install-actions{display:flex;gap:var(--space-2)}.pwa-install-btn{background:#fff;color:var(--color-primary-600);padding:var(--space-2) var(--space-4);border-radius:var(--radius-md);font-weight:var(--font-weight-semibold);font-size:var(--font-size-sm);border:none;cursor:pointer;transition:background var(--transition-base)}.pwa-install-btn:hover{background:var(--color-neutral-50)}.pwa-dismiss-btn{color:#fff;padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);background:#ffffff1a;font-size:var(--font-size-sm);border:none;cursor:pointer;transition:background var(--transition-base)}.pwa-dismiss-btn:hover{background:#fff3}.pwa-toast{position:fixed;bottom:var(--space-4);right:var(--space-4);padding:var(--space-4) var(--space-6);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:var(--z-modal);color:#fff;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);opacity:0;transform:translateY(20px);transition:all var(--transition-slow)}.pwa-toast.visible{opacity:1;transform:translateY(0)}.pwa-toast.success{background:var(--color-success)}.pwa-toast.warning{background:var(--color-warning)}.pwa-toast.error{background:var(--color-danger)}.pwa-toast.info{background:var(--color-info)}@keyframes fadeOut{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-20px)}}@media (max-width: 768px){.pwa-install-banner{top:auto;bottom:var(--space-4);right:var(--space-4);left:var(--space-4);max-width:none}.pwa-toast{left:var(--space-4);right:var(--space-4)}}.cliente-conversation-list{display:flex;flex-direction:column;overflow-y:auto;max-height:calc(100vh - 200px)}.cliente-conversation-item{display:flex;align-items:center;gap:12px;padding:20px 16px;cursor:pointer;border-bottom:1px solid #e5e7eb;transition:all .2s ease;position:relative}.cliente-conversation-item:hover{background-color:#f9fafb}.cliente-conversation-item.active{background-color:#eff6ff;border-left:3px solid #4f46e5;padding-left:13px}.conversation-avatar{position:relative;flex-shrink:0;width:48px;height:48px}.avatar-img{width:100%;height:100%;border-radius:50%;-o-object-fit:cover;object-fit:cover;border:2px solid #e5e7eb;transition:border-color .2s}.cliente-conversation-item:hover .avatar-img{border-color:#cbd5e1}.cliente-conversation-item.active .avatar-img{border-color:#4f46e5}.avatar-badge-group{position:absolute;bottom:-2px;right:-2px;width:20px;height:20px;background:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;border:2px solid white;box-shadow:0 2px 4px #0000001a}.chat-conversation-content{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.chat-conversation-info{display:flex;align-items:center;justify-content:space-between;gap:8px}.chat-conversation-title{font-weight:600;font-size:14px;color:#1f2937;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.cliente-conversation-item.active .chat-conversation-title{color:#4f46e5}.chat-conversation-time{font-size:11px;color:#9ca3af;flex-shrink:0}.chat-conversation-preview{font-size:13px;color:#6b7280;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.4}.chat-unread-badge{background:#ef4444;color:#fff;font-size:11px;font-weight:700;padding:2px 8px;border-radius:12px;min-width:20px;text-align:center;flex-shrink:0}.chat-empty-sidebar{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px 16px;color:#9ca3af;text-align:center}.chat-empty-icon{width:48px;height:48px;margin-bottom:12px;opacity:.5}.chat-empty-sidebar p{font-size:14px}@media (max-width: 768px){.cliente-conversation-item{padding:10px 12px;gap:10px}.conversation-avatar{width:40px;height:40px}.avatar-badge-group{width:18px;height:18px;font-size:9px}.chat-conversation-title{font-size:13px}.chat-conversation-preview{font-size:12px}}.cliente-sidebar{width:var(--sidebar-width);background:linear-gradient(180deg,var(--color-neutral-800) 0%,var(--color-neutral-900) 100%);color:#fff;display:flex;flex-direction:column;box-shadow:4px 0 6px -1px #0000001a}.cliente-sidebar-header{padding:var(--space-6);border-bottom:1px solid rgba(255,255,255,.1);margin-bottom:var(--space-2)}.cliente-sidebar-logo{max-width:160px;filter:brightness(0) invert(1)}.cliente-sidebar-nav{flex:1;padding:var(--space-4) var(--space-3)}.cliente-sidebar-link{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);color:var(--color-neutral-300);text-decoration:none;border-radius:var(--radius-md);transition:all var(--transition-base);margin-bottom:var(--space-1);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);background:transparent;cursor:pointer;border:none;width:100%;text-align:left;border-left:3px solid transparent}.cliente-sidebar-link:hover{background:#3b82f61a;color:#60a5fa}.cliente-sidebar-link.active{color:#60a5fa;background:#3b82f633;border-left-color:var(--color-primary-500)}.cliente-sidebar-icon{width:20px;height:20px;flex-shrink:0}@media (max-width: 768px){.cliente-sidebar{position:fixed;left:calc(-1 * var(--sidebar-width));z-index:var(--z-fixed);transition:left var(--transition-slow)}.cliente-sidebar.open{left:0}}.cliente-header{background:var(--color-bg-surface);border-bottom:1px solid var(--color-border-default);padding:var(--space-4) var(--space-6);display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:var(--space-4);min-height:var(--header-height)}.cliente-header-left{display:flex;align-items:center;gap:var(--space-6)}.cliente-header-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0}.cliente-header-center{display:flex;align-items:center;justify-content:center;gap:var(--space-3)}.cliente-header-right{display:flex;align-items:center;gap:var(--space-3);justify-self:end}.cliente-header-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:transparent;border:1px solid var(--color-border-default);border-radius:var(--radius-md);cursor:pointer;transition:all .2s;color:var(--color-text-secondary)}.cliente-header-btn:hover{background:var(--color-bg-hover);border-color:var(--color-brand-primary);color:var(--color-brand-primary)}.cliente-header-btn svg{width:20px;height:20px}@media (max-width: 768px){.cliente-header{grid-template-columns:1fr auto;gap:var(--space-2)}.cliente-header-center{grid-column:1 / -1;justify-content:flex-start;order:3;padding-top:var(--space-2)}}.cliente-header-avatar{width:32px;height:32px;background:var(--color-brand-gradient);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:var(--font-weight-semibold);font-size:var(--font-size-sm);cursor:pointer}.user-avatar-btn{width:40px;height:40px;background:var(--color-brand-gradient);border-radius:50%;border:2px solid var(--color-border-default);display:flex;align-items:center;justify-content:center;cursor:pointer;overflow:hidden;transition:all .2s}.user-avatar-btn:hover{transform:scale(1.05);border-color:var(--color-brand-primary)}.user-avatar-image{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;border-radius:50%}.user-avatar-initial{color:#fff;font-weight:var(--font-weight-semibold);font-size:var(--font-size-sm)}.user-avatar-container{position:relative}.user-dropdown-menu{position:absolute;top:calc(100% + 8px);right:0;background:var(--color-bg-surface);border:1px solid var(--color-border-default);border-radius:var(--radius-lg);box-shadow:0 4px 12px #0000001a;min-width:240px;z-index:1000;overflow:hidden}.user-dropdown-header{padding:var(--space-4);border-bottom:1px solid var(--color-border-default)}.user-dropdown-name{font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0 0 var(--space-1)}.user-dropdown-email{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0}.user-dropdown-links{padding:var(--space-2) 0}.user-dropdown-link{display:block;padding:var(--space-3) var(--space-4);color:var(--color-text-primary);text-decoration:none;transition:background .2s}.user-dropdown-link:hover{background:var(--color-bg-hover)}.user-dropdown-logout{border-top:1px solid var(--color-border-default);padding:var(--space-2)}.user-logout-btn{width:100%;padding:var(--space-3);background:transparent;border:none;color:var(--color-danger);text-align:left;cursor:pointer;font-weight:var(--font-weight-medium);transition:background .2s}.user-logout-btn:hover{background:var(--color-bg-hover)}.pdf-buttons-group{display:flex;align-items:center;gap:var(--space-2)}.pdf-btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border:1px solid var(--color-border-default);border-radius:var(--radius-md);background:var(--color-bg-surface);color:var(--color-text-primary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:all .2s;min-height:40px}.pdf-btn:hover:not(:disabled){background:var(--color-bg-hover);border-color:var(--color-brand-primary);transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.pdf-btn:disabled{opacity:.6;cursor:not-allowed}.pdf-btn svg{width:18px;height:18px}.pdf-btn-primary{background:var(--color-brand-gradient);color:#fff;border-color:transparent}.pdf-btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#1e40af,#3b82f6);transform:translateY(-1px);box-shadow:0 4px 12px #1e40af4d}.pdf-btn-back{background:var(--color-bg-surface);color:var(--color-text-primary)}.pdf-btn-back:hover:not(:disabled){background:var(--color-bg-hover)}.pdf-btn-lang{min-width:44px;padding:var(--space-2);justify-content:center}.pdf-lang-flag{font-size:20px;line-height:1}.pdf-btn-spinner{position:absolute;font-size:16px}.pdf-btn-text{display:inline}@media (max-width: 768px){.pdf-buttons-group{gap:var(--space-1);flex-wrap:wrap}.pdf-btn{padding:var(--space-2);min-height:44px;min-width:44px}.pdf-btn svg{margin:0}.pdf-btn-text{display:none}}.giornate-list{display:flex;flex-direction:column;gap:var(--space-4)}.giornata-item{background:var(--color-bg-surface);border:1px solid var(--color-border-default);border-radius:var(--radius-lg);padding:var(--space-5);transition:all .2s}.giornata-item:hover{box-shadow:0 2px 8px #0000000d;border-color:var(--color-brand-primary)}.giornata-header{margin-bottom:var(--space-4);padding-bottom:var(--space-3);border-bottom:1px solid var(--color-border-default)}.giornata-date-full{display:flex;flex-direction:column;gap:var(--space-1)}.giornata-weekday{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-brand-primary);text-transform:capitalize}.giornata-date-text{font-size:var(--font-size-base);color:var(--color-text-primary);font-weight:var(--font-weight-medium);text-transform:capitalize}.giornata-body{display:flex;flex-direction:column;gap:var(--space-4)}.giornata-stats-grid{display:flex;flex-direction:row;gap:var(--space-3)}.giornata-stat-card{flex:1;display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);background:var(--color-bg-base);border-radius:var(--radius-md);border:1px solid var(--color-border-default);transition:all .2s;min-width:0}.giornata-stat-card:hover{border-color:var(--color-brand-primary);box-shadow:0 2px 4px #0000000d}.stat-icon{width:40px;height:40px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-icon svg{width:20px;height:20px}.stat-icon-work{background:#3b82f61a;color:#2563eb}.stat-icon-travel{background:#f973161a;color:#ea580c}.stat-icon-km{background:#22c55e1a;color:#16a34a}.stat-content{display:flex;flex-direction:column;gap:var(--space-1)}.stat-label{font-size:var(--font-size-xs);color:var(--color-text-secondary);font-weight:var(--font-weight-medium);text-transform:uppercase;letter-spacing:.5px}.stat-value{font-size:var(--font-size-lg);color:var(--color-text-primary);font-weight:var(--font-weight-semibold)}.giornata-badges{display:flex;flex-wrap:wrap;gap:var(--space-3);padding-top:var(--space-3);border-top:1px solid var(--color-border-default);margin-top:var(--space-3)}.giornata-note{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-4);margin-top:var(--space-3);background:#3b82f60d;border-left:3px solid var(--color-brand-primary);border-radius:var(--radius-md);font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:1.5}.note-icon{width:20px;height:20px;flex-shrink:0;color:var(--color-brand-primary);margin-top:2px}.giornata-note span{flex:1}.giornata-badges .badge{padding:var(--space-3) var(--space-5);font-size:var(--font-size-base);font-weight:600;border-width:1.5px}.giornate-totals{margin-top:var(--space-5);padding-top:var(--space-5);border-top:2px solid var(--color-border-default)}.totals-label{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--space-4)}.giornata-totals-grid{display:flex;flex-direction:row;flex-wrap:wrap;gap:var(--space-3)}.giornata-totals-grid .giornata-stat-card{flex:1;min-width:150px}.totals-card{background:linear-gradient(135deg,#3b82f60d,#2563eb0d);border-color:var(--color-brand-primary);border-width:2px}.totals-card .stat-value{font-size:var(--font-size-xl);color:var(--color-brand-primary);font-weight:var(--font-weight-bold)}.totals-badge-card{background:linear-gradient(135deg,#22c55e0d,#16a34a0d);border-color:#16a34a}.totals-badge-card .stat-value{color:#16a34a}.stat-icon-badge{background:#22c55e1a;font-size:24px}@media (max-width: 768px){.giornata-totals-grid{grid-template-columns:repeat(2,1fr)}}.giornata-dettaglio-tecnici{margin-top:var(--space-3);padding-top:var(--space-3);border-top:1px solid var(--color-border-default)}.dettaglio-tecnici-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-3)}.tecnico-dettaglio-card{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);background:var(--color-bg-base);border:1px solid var(--color-border-default);border-radius:var(--radius-md);transition:all .2s}.tecnico-dettaglio-card:hover{border-color:var(--color-brand-primary);box-shadow:0 2px 4px #0000000d}.tecnico-dettaglio-avatar{width:40px;height:40px;border-radius:50%;background:var(--color-brand-gradient);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:var(--font-weight-semibold);font-size:var(--font-size-base);flex-shrink:0}.tecnico-dettaglio-info{flex:1;min-width:0}.tecnico-dettaglio-name{font-weight:var(--font-weight-semibold);color:var(--color-text-primary);font-size:var(--font-size-sm);margin-bottom:var(--space-1)}.tecnico-dettaglio-stats{display:flex;flex-wrap:wrap;gap:var(--space-2);align-items:center}.tecnico-stat{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-2);background:#3b82f61a;border-radius:var(--radius-sm);font-size:var(--font-size-xs);color:var(--color-text-secondary);font-weight:var(--font-weight-medium)}.tecnico-stat svg{width:14px;height:14px;flex-shrink:0}.tecnico-mezzo-aziendale{background:#22c55e1a;color:#16a34a}.tecnico-mezzo-privato{background:#f973161a;color:#ea580c}@media (max-width: 768px){.dettaglio-tecnici-grid{grid-template-columns:1fr}}.app-container{display:flex;height:100vh;background:var(--color-bg-app)}.cliente-main-area{flex:1;display:flex;flex-direction:column;overflow:hidden}.content-area{flex:1;overflow-y:auto;padding:var(--space-6);background:var(--color-bg-app)}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-6)}.page-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.page-title-large{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);text-transform:capitalize}@media (max-width: 768px){.content-area{padding:var(--space-4)}}.page-card{display:flex;flex-direction:column;min-height:calc(100vh - 200px)}.page-not-found{padding:var(--space-6);text-align:center}.page-not-found p{color:var(--color-text-secondary)}.cliente-chat-container{display:flex;height:100%;background:#f9fafb}.cliente-chat-sidebar{width:380px;background:var(--color-bg-surface);border-right:1px solid var(--color-border-default);display:flex;flex-direction:column}.cliente-chat-header{padding:var(--space-5);border-bottom:1px solid var(--color-border-default)}.cliente-conversation-list{flex:1;overflow-y:auto;position:relative;z-index:1;isolation:isolate}.cliente-conversation-item{padding:var(--space-4) var(--space-5);border-bottom:1px solid #f3f4f6;cursor:pointer;transition:background var(--transition-base);position:relative;z-index:2}.cliente-conversation-item:hover{background:#f9fafb}.cliente-conversation-item.active{background:#eef2ff;border-left:3px solid #4f46e5;z-index:3}.cliente-conversation-item.menu-open{z-index:50}.avatar-context-menu{position:fixed;background:#fff;box-shadow:0 4px 12px #00000026;border-radius:8px;overflow:hidden;min-width:150px}.chat-sidebar-actions{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-4)}.chat-sidebar-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0}.chat-btn-new-small{padding:var(--space-2) var(--space-3);font-size:var(--font-size-sm)}.chat-conversation-content{display:flex;justify-content:space-between;align-items:start}.chat-conversation-info{flex:1}.chat-conversation-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0 0 var(--space-1) 0}.chat-conversation-preview{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0 0 var(--space-1) 0}.chat-conversation-time{font-size:var(--font-size-xs);color:var(--color-neutral-400);margin:0}.chat-unread-badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 var(--space-2);background:var(--color-primary-500);color:#fff;border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold)}.cliente-chat-main{flex:1;display:flex;flex-direction:column}.chat-main-relative{position:relative}.chat-header-fixed{padding:var(--space-4) var(--space-5);background:var(--color-bg-surface);border-bottom:1px solid var(--color-border-default)}.chat-header-content{display:flex;align-items:center;gap:var(--space-3)}.chat-header-info{flex:1}.chat-header-title{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0}.chat-header-subtitle{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0}.cliente-chat-messages{flex:1;overflow-y:auto;overflow-x:hidden;padding:12px 20px 40px;position:relative;display:flex;flex-direction:column;justify-content:flex-start;background-color:#efeae2;background-image:repeating-linear-gradient(45deg,transparent,transparent 35px,rgba(255,255,255,.1) 35px,rgba(255,255,255,.1) 70px),repeating-linear-gradient(-45deg,transparent,transparent 35px,rgba(255,255,255,.05) 35px,rgba(255,255,255,.05) 70px);scrollbar-width:none;-ms-overflow-style:none;scroll-behavior:smooth}.cliente-chat-messages::-webkit-scrollbar{display:none}.chat-bg-pattern{position:absolute;inset:0;overflow:hidden;z-index:0;pointer-events:none}.cliente-message{position:relative;z-index:1;margin-bottom:var(--space-4);display:flex}.cliente-message-sent,.cliente-message-sent .cliente-message-time{justify-content:flex-end}.cliente-message-sent .cliente-message-bubble{background:#d9fdd3bf;color:#000;box-shadow:0 1px 3px #0003}.cliente-message-sent .cliente-message-bubble span[style*=✓✓]{filter:drop-shadow(0 1px 1px rgba(0,0,0,.2))}.cliente-message-received .cliente-message-time{justify-content:flex-start}.cliente-message-received .cliente-message-bubble{background:#ffffffbf;color:#000;box-shadow:0 1px 3px #0003}.cliente-message-bubble{max-width:70%;padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);font-size:var(--font-size-sm)}.whatsapp-link{color:#0ea5e9;text-decoration:underline;word-break:break-all;transition:opacity .2s}.whatsapp-link:hover{opacity:.8}.whatsapp-link:active{opacity:.6}.cliente-message-sent .whatsapp-link{color:#e0f2fe}.whatsapp-maps-preview{display:flex;align-items:center;gap:12px;margin-top:8px;padding:12px;background:#00000008;border-radius:8px;border:1px solid rgba(0,0,0,.08);text-decoration:none;color:inherit;transition:all .2s}.whatsapp-maps-preview:hover{background:#0000000d;transform:translateY(-1px);box-shadow:0 2px 8px #0000001a}.whatsapp-maps-preview:active{transform:translateY(0)}.cliente-message-sent .whatsapp-maps-preview{background:#ffffff26;border-color:#fff3}.cliente-message-sent .whatsapp-maps-preview:hover{background:#ffffff40}.whatsapp-maps-icon{width:48px;height:48px;min-width:48px;background:#34a853;border-radius:6px;display:flex;align-items:center;justify-content:center}.whatsapp-maps-icon svg{width:28px;height:28px;color:#fff}.whatsapp-maps-info{flex:1;min-width:0}.whatsapp-maps-title{font-size:14px;font-weight:600;color:var(--color-text);margin-bottom:4px}.cliente-message-sent .whatsapp-maps-title{color:#fffffff2}.whatsapp-maps-address{font-size:13px;color:var(--color-text-secondary);line-height:1.4;word-break:break-word}.cliente-message-sent .whatsapp-maps-address{color:#ffffffbf}.chat-message-sender{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);margin-bottom:var(--space-1)}.chat-message-animated{animation:fadeIn .2s ease}.cliente-message-time{font-size:11px;margin-top:var(--space-1);opacity:.6;display:flex;align-items:center;gap:var(--space-1)}.cliente-check-read{font-size:var(--font-size-sm);font-weight:var(--font-weight-bold)}.cliente-check-read.read{color:#53bdeb}.cliente-check-read.unread{color:#0000004d}.chat-attachments-container{margin-top:var(--space-2)}.chat-attachments-container:has(.chat-image-thumbnail){display:grid;grid-template-columns:repeat(auto-fill,minmax(90px,1fr));gap:4px;max-width:280px}.chat-attachments-container:has(.chat-image-thumbnail:only-child){grid-template-columns:1fr;max-width:240px}.chat-attachments-container:has(.chat-image-thumbnail:only-child) .chat-image-thumbnail{max-width:240px}.chat-attachments-container:has(.chat-image-thumbnail:only-child) .chat-image-thumbnail img{max-height:240px}.chat-attachments-container:has(.chat-image-thumbnail:nth-child(2):last-child){grid-template-columns:repeat(2,1fr);max-width:240px}.chat-attachments-container:has(.chat-image-thumbnail:nth-child(3):last-child){grid-template-columns:repeat(2,1fr);max-width:200px}.chat-attachments-container:has(.chat-image-thumbnail:nth-child(4)){grid-template-columns:repeat(3,1fr);max-width:280px}.chat-attachments-container:not(:has(.chat-image-thumbnail)){display:flex;flex-direction:column;gap:var(--space-1)}.chat-image-thumbnail{display:block;width:100%;margin-top:0;border-radius:6px;overflow:hidden;cursor:pointer;transition:transform var(--transition-base),box-shadow var(--transition-base);box-shadow:0 1px 2px #0000001a;aspect-ratio:1 / 1}.chat-image-thumbnail:hover{transform:scale(1.02);box-shadow:0 2px 8px #0003;z-index:1}.chat-image-thumbnail img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block}.chat-attachment-link{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:#0000000d;border-radius:var(--radius-sm);text-decoration:none;color:var(--color-text-primary);transition:background var(--transition-base);max-width:280px}.chat-attachment-link:hover{background:#0000001a}.chat-file-icon,.chat-download-icon{width:20px;height:20px;flex-shrink:0}.chat-file-info{flex:1}.chat-file-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);margin:0}.chat-file-size{font-size:var(--font-size-xs);color:var(--color-text-secondary);margin:0}.cliente-chat-input-area,.chat-input-fixed{position:sticky;bottom:0;padding:var(--space-4) var(--space-5);background:var(--color-bg-surface);border-top:1px solid var(--color-border-default)}.chat-input-flex{display:flex;gap:var(--space-3);align-items:end}.chat-input-form{flex:1;display:flex;gap:var(--space-3);align-items:center}.chat-send-btn{padding:var(--space-3) var(--space-4);background:var(--color-primary-500);color:#fff;border-radius:var(--radius-md);border:none;cursor:pointer;transition:background var(--transition-base);display:flex;align-items:center;justify-content:center;white-space:nowrap}.chat-send-btn:hover{background:var(--color-primary-600)}.chat-attach-label{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;background:var(--color-neutral-100);border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-base);flex-shrink:0}.chat-attach-label:hover{background:var(--color-neutral-200)}.chat-attach-icon{width:20px;height:20px;color:var(--color-neutral-500)}.chat-attach-input{display:none}.chat-pending-attachments{display:flex;gap:var(--space-2);margin-bottom:var(--space-3);flex-wrap:wrap}.chat-pending-item{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--color-neutral-50);border:1px solid var(--color-border-default);border-radius:var(--radius-md)}.chat-pending-thumbnail{width:40px;height:40px;-o-object-fit:cover;object-fit:cover;border-radius:var(--radius-sm)}.chat-pending-thumbnail img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.chat-pending-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--color-neutral-100);border-radius:var(--radius-sm);font-size:var(--font-size-xl)}.chat-pending-info{flex:1;min-width:0}.chat-pending-filename{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary);margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-pending-meta{font-size:var(--font-size-xs);color:var(--color-text-secondary);margin:0}.chat-remove-attachment{background:none;border:none;cursor:pointer;padding:var(--space-1);flex-shrink:0}.chat-remove-icon{width:16px;height:16px;color:var(--color-danger)}[data-drop-area]{transition:all var(--transition-base)}[data-drop-area].drag-active{border-color:var(--color-primary-500);background:var(--color-primary-50)}[data-drop-area]:hover{border-color:var(--color-neutral-400)}[wire\:loading][wire\:target=attachments]{opacity:.6;pointer-events:none}div[data-message-uploader]{z-index:10}[data-drop-overlay]{display:none;position:absolute;inset:0;background:#0009;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:50;pointer-events:none;margin:-20px}[data-drop-overlay].active{display:flex;align-items:center;justify-content:center}.chat-drop-content{text-align:center;color:#fff}.chat-drop-icon{width:64px;height:64px;margin:0 auto var(--space-4)}.chat-drop-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);margin:0 0 var(--space-2) 0}.chat-drop-subtitle{font-size:var(--font-size-base);margin:0}.chat-empty-sidebar,.chat-no-selection,.chat-empty-messages{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-12) var(--space-6);text-align:center;color:var(--color-text-secondary)}.chat-no-selection{height:100%;background:#f9fafb}.chat-empty-icon{width:64px;height:64px;color:var(--color-neutral-300);margin-bottom:var(--space-4)}.chat-no-selection-content{max-width:300px;text-align:center}.chat-no-selection-content h3{font-size:var(--font-size-lg);margin:0}.chat-empty-btn{margin-top:var(--space-4)}.chat-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:var(--z-modal)}.chat-modal-container{background:var(--color-bg-surface);border-radius:var(--radius-lg);width:90%;max-width:500px;max-height:90vh;overflow-y:auto}.chat-modal-content{padding:var(--space-6)}.chat-modal-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0 0 var(--space-6) 0}.chat-modal-field{margin-bottom:var(--space-4)}.chat-modal-field-last{margin-bottom:0}.chat-modal-label{display:block;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary);margin-bottom:var(--space-2)}.chat-modal-actions{display:flex;gap:var(--space-3);justify-content:flex-end;margin-top:var(--space-6)}.chat-error-message{padding:var(--space-3) var(--space-4);background:var(--color-danger-light);color:var(--color-danger-dark);border-radius:var(--radius-md);margin-bottom:var(--space-3);font-size:var(--font-size-sm)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.chat-hamburger-btn{display:none;background:transparent;border:none;padding:var(--space-2);cursor:pointer;color:var(--color-text-secondary);transition:color var(--transition-base);flex-shrink:0}.chat-hamburger-btn:hover{color:var(--color-primary-500)}.chat-hamburger-icon{width:24px;height:24px}.chat-sidebar-close-btn{display:none;background:transparent;border:none;padding:var(--space-2);cursor:pointer;color:var(--color-text-secondary);transition:color var(--transition-base);flex-shrink:0}.chat-sidebar-close-btn:hover{color:var(--color-danger)}.chat-close-icon{width:20px;height:20px}.chat-sidebar-overlay{display:none;position:fixed;inset:0;background:#00000080;z-index:998;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}@media (max-width: 768px){.chat-hamburger-btn,.chat-sidebar-close-btn,.chat-sidebar-overlay{display:block}.cliente-chat-sidebar{position:fixed;top:0;left:0;bottom:0;width:85%;max-width:320px;transform:translate(-100%);transition:transform .3s ease-in-out;z-index:999;background:var(--color-bg-surface);box-shadow:2px 0 8px #0000001a;border-right:none}.cliente-chat-sidebar.sidebar-open{transform:translate(0)}.cliente-chat-main{width:100%;margin-left:0}.cliente-conversation-item{padding:var(--space-3) var(--space-4)}.avatar-img{width:40px;height:40px}.chat-input-form{flex-wrap:wrap}.cliente-input{min-width:0;flex:1}.conversation-avatar{position:relative;z-index:1000}.avatar-context-menu{z-index:1001}.cliente-conversation-item{pointer-events:auto}.conversation-avatar{position:relative}.avatar-context-menu{pointer-events:auto!important}}.whatsapp-message-system{align-self:center;max-width:80%;margin:var(--space-8) 0}.whatsapp-bubble-system{background:#0000000d;padding:var(--space-8) var(--space-12);border-radius:var(--radius-md);text-align:center}.whatsapp-bubble-system .whatsapp-text{font-size:var(--font-sm);color:var(--color-text-muted);line-height:var(--leading-relaxed);white-space:pre-wrap;word-break:break-word}.whatsapp-bubble-system .whatsapp-time{font-size:var(--font-xs);color:var(--color-text-muted);opacity:.7;margin-top:var(--space-4)}.cantieri-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--space-5)}.cantiere-card{background:var(--color-neutral-50);border:1px solid var(--color-border-default);border-radius:var(--radius-lg);padding:var(--space-5);transition:all var(--transition-base);display:flex;flex-direction:column;min-height:180px}.cantiere-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.cantiere-header{display:flex;justify-content:space-between;align-items:start;margin-bottom:var(--space-3);min-height:80px}.cantiere-info{flex:1}.cantiere-name{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0 0 var(--space-1) 0;line-height:1.4}.cantiere-address{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0;line-height:1.5}.cantiere-status-badge{padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);white-space:nowrap}.cantiere-status-badge.in-lavorazione{background:#fef3c7;color:#92400e;border:1px solid #fcd34d}.cantiere-footer{display:flex;justify-content:space-between;align-items:center;margin-top:auto;padding-top:var(--space-4);border-top:1px solid var(--color-border-default)}.cantiere-count{display:flex;align-items:center;gap:var(--space-2)}.cantiere-count svg{width:18px;height:18px;stroke:var(--color-text-secondary);fill:none}.cantiere-count-text{font-size:var(--font-size-sm);color:var(--color-text-secondary);font-weight:var(--font-weight-medium)}.cantiere-detail-header{padding:var(--space-6)}.cantiere-meta-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--space-4);margin:var(--space-6) 0}.meta-item{display:flex;gap:var(--space-3);align-items:flex-start}.meta-icon{width:20px;height:20px;color:var(--color-neutral-400);flex-shrink:0;margin-top:2px}.meta-label{font-size:var(--font-size-xs);color:var(--color-text-secondary);margin-bottom:var(--space-1)}.meta-value{font-size:var(--font-size-sm);color:var(--color-text-primary);font-weight:var(--font-weight-medium)}.cantiere-stats-row{display:flex;gap:var(--space-6);padding-top:var(--space-6);border-top:1px solid var(--color-border-default);margin-top:var(--space-6)}.stat-box{text-align:center}.stat-value{font-size:28px;font-weight:var(--font-weight-bold);color:var(--color-text-primary);line-height:1}.stat-label{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-top:var(--space-2)}.commesse-list{display:flex;flex-direction:column;gap:var(--space-4)}.commessa-item{display:block;padding:var(--space-5);background:var(--color-neutral-50);border:1px solid var(--color-border-default);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-base);text-decoration:none;color:inherit}.commessa-item:active{transform:translateY(0)}.commessa-item:hover{box-shadow:var(--shadow-sm);border-color:var(--color-border-dark);background:#fff;transform:translateY(-1px)}.commessa-header{display:flex;justify-content:space-between;align-items:start;margin-bottom:var(--space-4)}.commessa-info{flex:1}.commessa-numero{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-primary-600);margin-bottom:var(--space-1)}.commessa-nome{font-size:var(--font-size-base);font-weight:var(--font-weight-medium);color:var(--color-text-primary);margin-bottom:var(--space-2)}.commessa-descrizione{font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:1.5}.commessa-footer{padding-top:var(--space-4);border-top:1px solid var(--color-border-light)}.commessa-stats{display:flex;gap:var(--space-4);flex-wrap:wrap}.stat-item{display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-size-sm);color:var(--color-text-secondary)}.stat-item.stat-success{color:var(--color-success)}.stat-item .icon-xs{width:16px;height:16px}.commessa-title-section{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-3)}.commessa-numero-badge{display:inline-block;padding:var(--space-2) var(--space-3);background:var(--color-primary-600);color:#fff;border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold)}.commessa-descrizione-text{font-size:var(--font-size-base);color:var(--color-text-secondary);line-height:1.6;margin:var(--space-4) 0}.commessa-cantiere-info{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-4);background:var(--color-neutral-50);border-radius:var(--radius-md);font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-top:var(--space-4)}.commessa-cantiere-info svg{width:18px;height:18px;flex-shrink:0}.text-separator{color:var(--color-neutral-400)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--space-5)}.stat-card{background:var(--color-bg-surface);border:1px solid var(--color-border-default);border-radius:var(--radius-lg);padding:var(--space-5);display:flex;gap:var(--space-4);align-items:flex-start;transition:all var(--transition-base)}.stat-card:hover{box-shadow:var(--shadow-sm);border-color:var(--color-border-dark)}.stat-card-highlight{background:linear-gradient(135deg,var(--color-primary-50) 0%,var(--color-bg-surface) 100%);border-color:var(--color-primary-600)}.stat-icon{width:48px;height:48px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-icon svg{width:24px;height:24px;color:#fff}.stat-icon-blue{background:linear-gradient(135deg,#667eea,#764ba2)}.stat-icon-purple{background:linear-gradient(135deg,#a8edea,#fed6e3)}.stat-icon-green{background:linear-gradient(135deg,#10b981,#059669)}.stat-content{flex:1}.stat-value{font-size:32px;font-weight:var(--font-weight-bold);color:var(--color-text-primary);line-height:1;margin-bottom:var(--space-2)}.stat-label{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--space-3)}.stat-details{display:flex;gap:var(--space-3);flex-wrap:wrap}.stat-detail-item{font-size:var(--font-size-xs);padding:var(--space-1) var(--space-2);background:var(--color-neutral-100);color:var(--color-text-secondary);border-radius:var(--radius-sm)}.stat-detail-item.stat-success{background:var(--color-success-light);color:var(--color-success-dark)}.stat-detail-item.stat-info{background:var(--color-info-light);color:var(--color-primary-700)}.checkup-list{display:flex;flex-direction:column;gap:var(--space-4)}.checkup-item{padding:var(--space-5);background:var(--color-neutral-50);border:1px solid var(--color-border-default);border-radius:var(--radius-md);transition:all var(--transition-base)}.checkup-item:hover{box-shadow:var(--shadow-sm);border-color:var(--color-border-dark);background:#fff}.checkup-header{display:flex;justify-content:space-between;align-items:start;margin-bottom:var(--space-4)}.checkup-info{flex:1}.checkup-numero{font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);color:var(--color-primary-600);margin-bottom:var(--space-1)}.checkup-tipo{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--space-1)}.checkup-impianto{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.checkup-status{flex-shrink:0}.checkup-footer{display:flex;justify-content:space-between;align-items:center;padding-top:var(--space-4);border-top:1px solid var(--color-border-light)}.checkup-meta{display:flex;gap:var(--space-4);flex-wrap:wrap}.checkup-actions{display:flex;gap:var(--space-3);align-items:center}.btn-link{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:transparent;border:none;color:var(--color-primary-600);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:all var(--transition-base);border-radius:var(--radius-sm)}.btn-link:hover{background:var(--color-primary-50);color:var(--color-primary-700)}.btn-link svg{width:16px;height:16px}.tabs-container{border-top:1px solid var(--color-border-default);padding-top:var(--space-6)}.tabs-nav{display:flex;gap:var(--space-2);border-bottom:2px solid var(--color-border-default);margin-bottom:var(--space-6)}.tab-button{padding:var(--space-3) var(--space-5);background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-base)}.tab-button:hover{color:var(--color-text-primary)}.tab-button.active{color:var(--color-primary-600);border-bottom-color:var(--color-primary-600)}.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--space-4)}.photo-item{position:relative;aspect-ratio:1;border-radius:var(--radius-md);overflow:hidden;cursor:pointer;transition:transform var(--transition-base)}.photo-item:hover{transform:scale(1.02)}.photo-item img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.photo-overlay{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top,rgba(0,0,0,.7),transparent);padding:var(--space-3);opacity:0;transition:opacity var(--transition-base)}.photo-item:hover .photo-overlay{opacity:1}.photo-info{display:flex;flex-direction:column;gap:var(--space-1)}.photo-checkup,.photo-date{font-size:var(--font-size-xs);color:#fff}.documents-list{display:flex;flex-direction:column;gap:var(--space-3)}.document-item{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-4);background:var(--color-neutral-50);border:1px solid var(--color-border-default);border-radius:var(--radius-md);transition:all var(--transition-base);text-decoration:none;color:inherit}.document-item:hover{background:#fff;box-shadow:var(--shadow-sm);border-color:var(--color-primary-600)}.document-icon{width:48px;height:48px;background:var(--color-primary-50);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.document-icon svg{width:24px;height:24px;color:var(--color-primary-600)}.document-info{flex:1}.document-name{font-weight:var(--font-weight-medium);color:var(--color-text-primary);margin-bottom:var(--space-1)}.document-meta{font-size:var(--font-size-xs);color:var(--color-text-secondary)}.document-action{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--color-neutral-100);border-radius:var(--radius-md);transition:background var(--transition-base)}.document-action svg{width:20px;height:20px;color:var(--color-text-secondary)}.document-item:hover .document-action{background:var(--color-primary-600)}.document-item:hover .document-action svg{color:#fff}.badge-status{padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium)}.badge-success{background:var(--color-success-light);color:var(--color-success-dark)}.badge-warning{background:#fef3c7;color:#92400e}@media (max-width: 640px){.photo-grid{grid-template-columns:repeat(2,1fr)}.tabs-nav{overflow-x:auto;-webkit-overflow-scrolling:touch}.tab-button{white-space:nowrap}.photo-type{font-size:var(--font-size-xs);color:#ffffffe6;text-transform:capitalize}.photo-checkup,.photo-date{font-size:var(--font-size-xs);color:#fff}}.commessa-detail-header{padding:var(--space-6)}.commessa-title-row{margin-bottom:var(--space-4)}.commessa-title-section{display:flex;align-items:center;gap:var(--space-3);flex-wrap:wrap}.commessa-numero-badge{display:inline-flex;align-items:center;padding:var(--space-2) var(--space-4);background:var(--color-primary-50);color:var(--color-primary-700);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);letter-spacing:.05em}.commessa-title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin:0}.commessa-description{font-size:var(--font-size-base);color:var(--color-text-secondary);line-height:1.6;margin:var(--space-3) 0}.commessa-cantiere-info{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) 0;color:var(--color-text-secondary);font-size:var(--font-size-sm);border-top:1px solid var(--color-border-default);margin-top:var(--space-4)}.cantiere-name{font-weight:var(--font-weight-medium)}.commessa-stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:var(--space-4);margin-top:var(--space-5);padding-top:var(--space-5);border-top:1px solid var(--color-border-default)}.commessa-stats-row .stat-item{text-align:center}.commessa-stats-row .stat-value{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-primary-600);margin-bottom:var(--space-1)}.commessa-stats-row .stat-label{font-size:var(--font-size-xs);color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.05em;font-weight:var(--font-weight-medium)}.tabs-navigation{display:flex;gap:var(--space-2);background:#fff;border-radius:var(--radius-lg);padding:var(--space-2);box-shadow:var(--shadow-sm);overflow-x:auto}.tab-button{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);background:transparent;border:none;border-radius:var(--radius-md);color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:all var(--transition-base);white-space:nowrap}.tab-button:hover{background:var(--color-neutral-50);color:var(--color-text-primary)}.tab-button.active{background:var(--color-primary-500);color:#fff}.tab-button.active svg{stroke:#fff}.tab-badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 var(--space-2);background:var(--color-primary-100);color:var(--color-primary-700);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-bold)}.tab-button.active .tab-badge{background:#ffffff40;color:#fff}.tab-content{margin-top:var(--space-6)}.interventi-list{display:flex;flex-direction:column;gap:var(--space-4);padding:var(--space-5)}.intervento-card{background:var(--color-neutral-50);border:1px solid var(--color-border-default);border-radius:var(--radius-lg);padding:var(--space-5);transition:all var(--transition-base)}.intervento-card:hover{box-shadow:var(--shadow-md);border-color:var(--color-primary-200)}.intervento-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space-4)}.intervento-info{flex:1}.intervento-numero{font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);color:var(--color-primary-600);margin-bottom:var(--space-1)}.intervento-tipo{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.intervento-body{display:flex;flex-direction:column;gap:var(--space-3);margin-bottom:var(--space-4)}.intervento-impianto{display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-size-sm);color:var(--color-text-secondary)}.intervento-descrizione{font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:1.6}.intervento-stato-impianto{display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-size-sm)}.stato-badge{padding:var(--space-1) var(--space-3);border-radius:var(--radius-md);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium)}.stato-funzionante{background:#d1fae5;color:#065f46}.stato-funzionante_con_anomalie{background:#fef3c7;color:#92400e}.stato-fermo_parziale{background:#fed7aa;color:#9a3412}.stato-fermo_totale{background:#fecaca;color:#991b1b}.intervento-footer{display:flex;justify-content:space-between;align-items:center;padding-top:var(--space-4);border-top:1px solid var(--color-border-default)}.intervento-meta{display:flex;gap:var(--space-4);flex-wrap:wrap}.documenti-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--space-4);padding:var(--space-5)}.documento-card{display:flex;align-items:center;gap:var(--space-3);background:var(--color-neutral-50);border:1px solid var(--color-border-default);border-radius:var(--radius-lg);padding:var(--space-4);transition:all var(--transition-base)}.documento-card:hover{box-shadow:var(--shadow-md);border-color:var(--color-primary-200)}.documento-icon{flex-shrink:0;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--color-primary-50);border-radius:var(--radius-md)}.documento-icon svg{width:24px;height:24px;stroke:var(--color-primary-600)}.documento-info{flex:1;min-width:0}.documento-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:var(--space-1)}.documento-meta{font-size:var(--font-size-xs);color:var(--color-text-tertiary)}.btn-icon{flex-shrink:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--color-primary-50);border:none;border-radius:var(--radius-md);color:var(--color-primary-600);cursor:pointer;transition:all var(--transition-base)}.btn-icon:hover{background:var(--color-primary-100)}.comunicazioni-list{display:flex;flex-direction:column;gap:var(--space-4);padding:var(--space-5)}.comunicazione-card{background:var(--color-neutral-50);border:1px solid var(--color-border-default);border-radius:var(--radius-lg);padding:var(--space-5);transition:all var(--transition-base)}.comunicazione-card:hover{box-shadow:var(--shadow-md);border-color:var(--color-primary-200)}.comunicazione-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-3)}.comunicazione-title{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.comunicazione-date{font-size:var(--font-size-xs);color:var(--color-text-tertiary)}.comunicazione-preview{font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:1.6;margin-bottom:var(--space-3)}.comunicazione-footer{display:flex;justify-content:flex-end}@media (max-width: 768px){.commessa-title{font-size:var(--font-size-xl)}.commessa-stats-row{grid-template-columns:repeat(2,1fr)}.tabs-navigation{overflow-x:auto}.intervento-header,.intervento-footer{flex-direction:column;gap:var(--space-3)}.intervento-meta{flex-direction:column;gap:var(--space-2)}.documenti-grid{grid-template-columns:1fr}}.calendar-nav{display:flex;gap:var(--space-3)}.calendar-nav-btn{padding:var(--space-2) var(--space-3);background:var(--color-neutral-100);border:none;border-radius:var(--radius-sm);cursor:pointer;color:var(--color-text-secondary);transition:background var(--transition-base)}.calendar-nav-btn:hover{background:var(--color-neutral-200)}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px;background:var(--color-border-default);border:1px solid var(--color-border-default);border-radius:var(--radius-md);overflow:hidden}.calendar-day-header{background:var(--color-neutral-50);padding:var(--space-3);text-align:center;font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);font-size:var(--font-size-xs);text-transform:uppercase}.calendar-day-cell{background:var(--color-bg-surface);min-height:80px;padding:var(--space-2);position:relative}.calendar-day-number{font-size:var(--font-size-sm);color:var(--color-text-primary);font-weight:var(--font-weight-medium);margin-bottom:var(--space-1)}.calendar-event{background:var(--color-primary-50);border-left:3px solid var(--color-primary-500);padding:2px var(--space-2);margin:2px 0;font-size:11px;border-radius:2px}.calendar-event-title{color:var(--color-primary-700);font-weight:var(--font-weight-semibold)}.calendar-event-subtitle{color:var(--color-text-secondary);font-size:10px}.checkup-detail-container{max-width:var(--content-max-width);margin:0 auto;padding:var(--space-6)}@media (max-width: 768px){.checkup-detail-container{padding:var(--space-4)}}.checkup-list-container{display:flex;flex-direction:column;min-height:calc(100vh - 140px);max-width:var(--content-max-width);margin:0 auto;padding:var(--space-6)}.checkup-list-header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-4);margin-bottom:var(--space-6)}.checkup-list-header-left{flex:1;min-width:0}.checkup-list-title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin:0 0 var(--space-2) 0;line-height:var(--line-height-tight)}.checkup-list-subtitle{font-size:var(--font-size-base);color:var(--color-text-secondary);margin:0}.btn-primary{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:#fff;background:var(--color-brand-gradient);border:none;border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);box-shadow:var(--shadow-sm);white-space:nowrap}.btn-primary:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-primary svg{width:18px;height:18px}.empty-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-16);text-align:center}.empty-state-icon{display:flex;align-items:center;justify-content:center;width:80px;height:80px;background:var(--color-neutral-100);color:var(--color-neutral-400);border-radius:var(--radius-full);margin-bottom:var(--space-6)}.empty-state-icon svg{width:40px;height:40px}.empty-state-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0 0 var(--space-2) 0}.empty-state-text{font-size:var(--font-size-base);color:var(--color-text-secondary);margin:0 0 var(--space-6) 0}.checkup-list-card{flex:1;background:transparent}.checkup-table-wrapper{overflow-x:auto}.checkup-table{border-spacing:0 var(--space-3);border-collapse:separate}.checkup-table{width:100%;table-layout:fixed;font-size:var(--font-size-sm)}.checkup-table thead{background:linear-gradient(135deg,#dc2626,#991b1b);border-bottom:none}.checkup-th{color:#fff}.checkup-th-numero{width:200px}.checkup-th-data{width:110px}.checkup-th-cantiere{width:auto;min-width:250px}.checkup-th-tipo{width:140px}.checkup-th-stato{width:150px;text-align:center}.checkup-tr{cursor:pointer;transition:all var(--transition-fast)}.checkup-tr td{background:var(--color-bg-surface);border-top:1px solid var(--color-border-default);border-bottom:1px solid var(--color-border-default);box-shadow:var(--shadow-sm)}.checkup-tr td:first-child{border-left:1px solid var(--color-border-default);border-top-left-radius:var(--radius-lg);border-bottom-left-radius:var(--radius-lg)}.checkup-tr td:last-child{border-right:1px solid var(--color-border-default);border-top-right-radius:var(--radius-lg);border-bottom-right-radius:var(--radius-lg)}.checkup-tr:hover td{background:var(--color-bg-hover);border-color:var(--color-primary-500);box-shadow:var(--shadow-md);transform:translateY(-1px)}.checkup-td-numero{font-weight:var(--font-weight-semibold);padding-left:var(--space-6)}.checkup-th-numero{padding-left:var(--space-6)}.checkup-numero{color:var(--color-primary-600);font-weight:var(--font-weight-semibold)}.checkup-td-data{color:var(--color-text-secondary)}.checkup-td-cantiere{font-weight:var(--font-weight-medium)}.checkup-cantiere{display:flex;flex-direction:column;gap:var(--space-1)}.checkup-cantiere-name{color:var(--color-text-primary);font-weight:var(--font-weight-semibold);font-size:var(--font-size-base)}.checkup-cantiere-secondary{font-size:var(--font-size-xs);color:var(--color-text-tertiary);font-weight:var(--font-weight-normal)}.checkup-td-tipo{color:var(--color-text-secondary)}.checkup-td-stato{text-align:center}.checkup-td-stato .status-badge{display:inline-flex;padding:var(--space-1) var(--space-3);font-size:var(--font-size-xs)}.checkup-pagination{margin-top:auto;flex-shrink:0;display:flex;justify-content:center;padding:var(--space-5) 0}.checkup-pagination nav{display:flex;align-items:center;gap:var(--space-2)}.checkup-pagination a,.checkup-pagination span{display:inline-flex;align-items:center;justify-content:center;min-width:40px;height:40px;padding:var(--space-2) var(--space-3);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);background:var(--color-bg-surface);border:1px solid var(--color-border-default);border-radius:var(--radius-md);text-decoration:none;transition:all var(--transition-fast)}.checkup-pagination a:hover{background:var(--color-bg-hover);border-color:var(--color-border-dark);color:var(--color-text-primary)}.checkup-pagination span[aria-current=page]{background:var(--color-primary-500);color:#fff;border-color:var(--color-primary-500)}.status-badge{display:inline-flex;align-items:center;padding:var(--space-2) var(--space-4);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);border-radius:var(--radius-full);text-transform:capitalize}.status-badge.status-bozza{background:#ffedd5;color:#ea580c;white-space:nowrap}.status-badge.status-completato{background:var(--color-success-light);color:var(--color-success-dark)}.status-badge.status-inviato{background:#d1fae5;color:#065f46;white-space:nowrap}.status-badge{display:inline-flex;align-items:center;padding:var(--space-2) var(--space-4);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);border-radius:var(--radius-full);text-transform:capitalize;white-space:nowrap}.status-badge-success{background:var(--color-success-light);color:var(--color-success-dark)}.status-badge-warning{background:var(--color-warning-light);color:#92400e}.status-badge-info{background:var(--color-info-light);color:#1e40af}@media (max-width: 768px){.checkup-list-container{padding:var(--space-4)}.checkup-list-header{flex-direction:column;align-items:stretch}.checkup-list-title{font-size:var(--font-size-xl)}.btn-primary{width:100%;justify-content:center}.checkup-table{width:100%;table-layout:fixed;font-size:var(--font-size-sm);border-spacing:0 var(--space-3);border-collapse:separate}.checkup-th,.checkup-td{padding:var(--space-3) var(--space-4)}.checkup-th-tipo,.checkup-td-tipo{display:none}}.alert{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4);border-radius:var(--radius-lg);margin-bottom:var(--space-6);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.alert-icon{width:20px;height:20px;flex-shrink:0}.alert-success{background-color:var(--color-success-light);color:var(--color-success-dark)}.alert-error{background-color:var(--color-danger-light);color:var(--color-danger-dark)}.checkup-detail-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);margin-bottom:var(--space-8);padding-bottom:var(--space-6);border-bottom:1px solid var(--color-border-default)}.checkup-detail-header-left{display:flex;align-items:center;gap:var(--space-4);flex:1;min-width:0}.btn-back{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);background:transparent;border:1px solid var(--color-border-default);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.btn-back:hover{background:var(--color-bg-hover);color:var(--color-text-primary);border-color:var(--color-border-dark)}.btn-back svg{width:16px;height:16px}.checkup-detail-header-info{flex:1;min-width:0}.checkup-detail-title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin:0;line-height:var(--line-height-tight)}.checkup-detail-subtitle{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:var(--space-1) 0 0 0}.checkup-detail-header-right{flex-shrink:0}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:var(--space-4);margin-bottom:var(--space-8)}.info-card{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-5);background:var(--color-bg-surface);border:1px solid var(--color-border-default);border-radius:var(--radius-lg);transition:all var(--transition-fast)}.info-card:hover{box-shadow:var(--shadow-md);border-color:var(--color-border-dark)}.info-card-alert{border-color:var(--color-danger);background:var(--color-danger-light)}.info-card-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:var(--radius-md);flex-shrink:0}.info-card-icon svg{width:24px;height:24px}.info-card-icon-primary{background:var(--color-primary-50);color:var(--color-primary-600)}.info-card-icon-success{background:var(--color-success-light);color:var(--color-success)}.info-card-icon-warning{background:var(--color-warning-light);color:var(--color-warning)}.info-card-icon-danger{background:var(--color-danger-light);color:var(--color-danger)}.info-card-content{flex:1;min-width:0}.info-card-label{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-1)}.info-card-value{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);line-height:var(--line-height-tight)}.info-card-meta{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-top:var(--space-1)}.section-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:var(--space-6);margin-bottom:var(--space-8)}.section-card{background:var(--color-bg-surface);border:1px solid var(--color-border-default);border-radius:var(--radius-xl);overflow:hidden;transition:box-shadow var(--transition-fast);margin-bottom:var(--space-6)}.section-card:hover{box-shadow:var(--shadow-lg)}.section-card-header{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-5) var(--space-6);background:var(--color-bg-hover);border-bottom:1px solid var(--color-border-default)}.section-card-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:var(--color-primary-50);color:var(--color-primary-600);border-radius:var(--radius-md);flex-shrink:0}.section-card-icon svg{width:20px;height:20px}.section-card-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0;flex:1}.section-card-count{display:flex;align-items:center;justify-content:center;min-width:28px;height:28px;padding:0 var(--space-2);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-primary-600);background:var(--color-primary-50);border-radius:var(--radius-full)}.section-card-body{padding:var(--space-6)}.entity-name{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin:0 0 var(--space-4) 0}.entity-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);margin-bottom:var(--space-5)}.entity-badge{display:inline-flex;align-items:center;padding:var(--space-1) var(--space-3);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);background:var(--color-neutral-100);border-radius:var(--radius-full)}.detail-list{display:flex;flex-direction:column;gap:var(--space-4)}.detail-item{display:flex;gap:var(--space-3)}.detail-icon{width:20px;height:20px;color:var(--color-text-tertiary);flex-shrink:0;margin-top:2px}.detail-content{flex:1;min-width:0}.detail-label{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-1)}.detail-value{font-size:var(--font-size-base);color:var(--color-text-primary);word-break:break-word}.detail-meta{display:block;font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-top:var(--space-1)}.specs-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--space-4)}.spec-item{display:flex;flex-direction:column;gap:var(--space-1)}.spec-label{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.05em}.spec-value{font-size:var(--font-size-base);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.tecnici-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--space-4)}.tecnico-card{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4);background:var(--color-bg-hover);border-radius:var(--radius-lg);transition:all var(--transition-fast)}.tecnico-card:hover{background:var(--color-neutral-100)}.tecnico-avatar{display:flex;align-items:center;justify-content:center;width:48px;height:48px;font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:#fff;background:linear-gradient(135deg,var(--color-primary-500),var(--color-primary-600));border-radius:var(--radius-full);flex-shrink:0}.tecnico-info{flex:1;min-width:0}.tecnico-name{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--space-1)}.tecnico-email{font-size:var(--font-size-sm);color:var(--color-text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.table-container{overflow-x:auto;border-radius:var(--radius-md);border:1px solid var(--color-border-default)}.data-table{width:100%;border-collapse:collapse;font-size:var(--font-size-sm)}.data-table thead{background:var(--color-bg-hover)}.data-table th{padding:var(--space-3) var(--space-4);text-align:left;font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em;font-size:var(--font-size-xs);border-bottom:1px solid var(--color-border-default)}.data-table th.text-center{text-align:center}.data-table td{padding:var(--space-4);border-bottom:1px solid var(--color-border-light);color:var(--color-text-primary)}.data-table tbody tr:last-child td{border-bottom:none}.data-table tbody tr:hover{background:var(--color-bg-hover)}.data-table .font-medium{font-weight:var(--font-weight-medium)}.data-table .text-center{text-align:center}.data-table .text-secondary{color:var(--color-text-secondary)}.quantity-badge{display:inline-flex;align-items:center;justify-content:center;min-width:32px;padding:var(--space-1) var(--space-2);font-weight:var(--font-weight-semibold);background:var(--color-primary-50);color:var(--color-primary-600);border-radius:var(--radius-sm)}.lavori-list{display:flex;flex-direction:column;gap:var(--space-3)}.lavoro-item{padding:var(--space-4);background:var(--color-bg-hover);border-radius:var(--radius-lg);border-left:3px solid var(--color-success)}.lavoro-header{display:flex;gap:var(--space-3)}.lavoro-icon{display:flex;align-items:center;justify-content:center;width:24px;height:24px;background:var(--color-success);color:#fff;border-radius:var(--radius-full);flex-shrink:0}.lavoro-icon svg{width:14px;height:14px}.lavoro-content{flex:1}.lavoro-title{font-size:var(--font-size-base);font-weight:var(--font-weight-medium);color:var(--color-text-primary);margin-bottom:var(--space-1)}.lavoro-note{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.segnalazioni-list{display:flex;flex-direction:column;gap:var(--space-3)}.segnalazione-item{padding:var(--space-4);background:var(--color-bg-hover);border-radius:var(--radius-lg);border-left:3px solid var(--color-warning)}.segnalazione-item.severity-critica{border-left-color:var(--color-danger);background:var(--color-danger-light)}.segnalazione-item.severity-alta{border-left-color:var(--color-warning)}.segnalazione-badge{display:inline-flex;padding:var(--space-1) var(--space-3);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-warning);background:#fff;border-radius:var(--radius-full);margin-bottom:var(--space-2)}.segnalazione-item.severity-critica .segnalazione-badge{color:var(--color-danger)}.segnalazione-content{margin-top:var(--space-2)}.segnalazione-title{font-size:var(--font-size-base);font-weight:var(--font-weight-medium);color:var(--color-text-primary);margin-bottom:var(--space-2)}.segnalazione-action{font-size:var(--font-size-sm);color:var(--color-text-secondary);padding:var(--space-3);background:#fff;border-radius:var(--radius-md);margin-top:var(--space-2)}.segnalazione-action strong{color:var(--color-text-primary)}.segnalazione-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:var(--space-3);margin-top:var(--space-4)}.gallery-item{position:relative;border-radius:var(--radius-md);overflow:hidden;background:#fff;border:1px solid var(--color-border-default)}.gallery-img{width:100%;height:150px;-o-object-fit:cover;object-fit:cover;cursor:pointer;transition:transform var(--transition-fast)}.gallery-img:hover{transform:scale(1.05)}.gallery-caption{padding:var(--space-2);font-size:var(--font-size-xs);color:var(--color-text-secondary);background:#fff;border-top:1px solid var(--color-border-light)}.test-list{display:flex;flex-direction:column;gap:var(--space-3)}.test-item{display:flex;gap:var(--space-3);padding:var(--space-4);background:var(--color-bg-hover);border-radius:var(--radius-lg)}.test-status{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-full);flex-shrink:0}.test-status svg{width:18px;height:18px}.test-status.status-pass{background:var(--color-success);color:#fff}.test-status.status-fail{background:var(--color-danger);color:#fff}.test-content{flex:1}.test-name{font-size:var(--font-size-base);font-weight:var(--font-weight-medium);color:var(--color-text-primary);margin-bottom:var(--space-1)}.test-note{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.giornate-list{display:flex;flex-direction:column;gap:var(--space-3)}.giornata-item{display:flex;gap:var(--space-4);padding:var(--space-4);background:var(--color-bg-hover);border-radius:var(--radius-lg)}.giornata-date{display:flex;flex-direction:column;align-items:center;justify-content:center;width:56px;height:56px;background:var(--color-primary-50);color:var(--color-primary-600);border-radius:var(--radius-md);flex-shrink:0}.giornata-day{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);line-height:1}.giornata-month{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);text-transform:uppercase;margin-top:var(--space-1)}.giornata-content{flex:1}.giornata-hours{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--space-1)}.giornata-note{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.text-block{padding:var(--space-5);background:var(--color-bg-hover);border-radius:var(--radius-lg);margin-bottom:var(--space-4)}.text-block:last-child{margin-bottom:0}.text-block-highlight{background:var(--color-warning-light);border-left:3px solid var(--color-warning)}.text-block-title{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0 0 var(--space-3) 0}.text-block-content{font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:var(--line-height-relaxed)}.pdf-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--space-4);margin-bottom:var(--space-6)}.pdf-card{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-5);background:var(--color-bg-hover);border:1px solid var(--color-border-default);border-radius:var(--radius-lg);text-decoration:none;transition:all var(--transition-fast);cursor:pointer}.pdf-card:hover{background:#fff;border-color:var(--color-primary-500);box-shadow:var(--shadow-md);transform:translateY(-1px)}.pdf-card-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;background:var(--color-primary-50);color:var(--color-primary-600);border-radius:var(--radius-md);flex-shrink:0}.pdf-card-icon-secondary{background:var(--color-success-light);color:var(--color-success)}.pdf-card-icon svg{width:24px;height:24px}.pdf-card-content{flex:1;min-width:0}.pdf-card-title{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--space-1)}.pdf-card-meta{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.pdf-card-arrow{width:20px;height:20px;color:var(--color-text-tertiary);flex-shrink:0;transition:transform var(--transition-fast)}.pdf-card:hover .pdf-card-arrow{transform:translate(4px);color:var(--color-primary-600)}.pdf-generate-section{padding:var(--space-6);background:var(--color-bg-hover);border-radius:var(--radius-lg);border:1px dashed var(--color-border-dark)}.pdf-generate-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0 0 var(--space-2) 0}.pdf-generate-desc{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0 0 var(--space-5) 0}.pdf-lang-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:var(--space-3)}.pdf-lang-btn{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);padding:var(--space-4);background:#fff;border:1px solid var(--color-border-default);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast)}.pdf-lang-btn:hover:not(:disabled){border-color:var(--color-primary-500);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.pdf-lang-btn:disabled{opacity:.6;cursor:not-allowed}.pdf-lang-flag{font-size:32px;line-height:1}.pdf-lang-text{display:flex;flex-direction:column;align-items:center;gap:var(--space-1)}.pdf-lang-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.pdf-lang-loading{font-size:var(--font-size-xs);color:var(--color-primary-600);font-weight:var(--font-weight-medium)}@media (max-width: 768px){.checkup-detail-header{flex-direction:column;align-items:flex-start}.checkup-detail-title{font-size:var(--font-size-xl)}.info-grid,.section-grid,.tecnici-grid,.pdf-grid{grid-template-columns:1fr}.pdf-lang-grid{grid-template-columns:repeat(2,1fr)}}.cliente-page-container{max-width:var(--content-max-width);margin:0 auto;padding:var(--space-6)}.create-header{display:flex;align-items:center;gap:var(--space-4);margin-bottom:var(--space-8);padding-bottom:var(--space-6);border-bottom:1px solid var(--color-border-default)}.create-back-btn{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);background:transparent;border:1px solid var(--color-border-default);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.create-back-btn:hover{background:var(--color-bg-hover);color:var(--color-text-primary);border-color:var(--color-border-dark)}.create-back-btn svg{width:16px;height:16px}.create-title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin:0;line-height:var(--line-height-tight)}.create-form{display:flex;flex-direction:column;gap:var(--space-8)}.form-section{background:var(--color-bg-surface);border:1px solid var(--color-border-default);border-radius:var(--radius-xl);padding:var(--space-6)}.form-section-title{display:flex;align-items:center;gap:var(--space-3);font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0 0 var(--space-5) 0}.form-section-title svg{width:20px;height:20px;color:var(--color-primary-600)}.form-label{display:block;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);margin-bottom:var(--space-2)}.form-label.required:after{content:" *";color:var(--color-danger)}.form-select,.form-textarea{width:100%;padding:var(--space-3) var(--space-4);font-size:var(--font-size-base);color:var(--color-text-primary);background:var(--color-bg-surface);border:1px solid var(--color-border-default);border-radius:var(--radius-md);transition:all var(--transition-fast)}.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--color-primary-500);box-shadow:0 0 0 3px #3b82f61a}.form-hint{display:block;font-size:var(--font-size-xs);color:var(--color-text-tertiary);margin-top:var(--space-1)}.form-radio-group{display:flex;flex-direction:column;gap:var(--space-3)}.form-radio{display:flex;align-items:center;gap:var(--space-3);cursor:pointer}.form-radio input[type=radio]{width:18px;height:18px;cursor:pointer}.urgenza-badge{display:inline-flex;padding:var(--space-2) var(--space-4);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);border-radius:var(--radius-full);transition:all var(--transition-fast)}.urgenza-bassa{background:#dbeafe;color:#1e40af}.urgenza-normale{background:#d1fae5;color:#065f46}.urgenza-alta{background:#fed7aa;color:#c2410c}.urgenza-critica{background:#fecaca;color:#991b1b}.form-radio:has(input:checked) .urgenza-badge{box-shadow:0 0 0 2px var(--color-primary-500)}.form-checkbox{display:flex;align-items:center;gap:var(--space-3);cursor:pointer}.form-checkbox input[type=checkbox]{width:18px;height:18px;cursor:pointer}.form-checkbox-label{display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-size-base);color:var(--color-text-primary)}.form-checkbox-label svg{width:18px;height:18px;color:var(--color-danger)}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:var(--space-4)}.form-actions{display:flex;justify-content:flex-end;gap:var(--space-3);padding-top:var(--space-6);border-top:1px solid var(--color-border-default)}.btn-secondary{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);background:var(--color-bg-surface);border:1px solid var(--color-border-default);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast)}.btn-secondary:hover{background:var(--color-bg-hover);border-color:var(--color-border-dark);color:var(--color-text-primary)}@media (max-width: 768px){.cliente-page-container{padding:var(--space-4)}.create-title{font-size:var(--font-size-xl)}.form-section{padding:var(--space-4)}.form-actions{flex-direction:column-reverse}.form-actions button{width:100%;justify-content:center}}.empty-cantieri-warning{padding:var(--space-8);background:var(--color-warning-light);border-radius:var(--radius-lg);margin-bottom:var(--space-4)}.empty-cantieri-warning p{margin:0 0 var(--space-3) 0;color:var(--color-text-primary)}.btn-inline{display:inline-flex}.btn-inline svg{width:18px;height:18px}.form-hint-icon{width:14px;height:14px;display:inline-block;vertical-align:middle}.form-hint-block{display:block;margin-bottom:var(--space-3)}.upload-loading{margin-top:var(--space-3);color:var(--color-primary-600);font-size:var(--font-size-sm);display:flex;align-items:center;gap:var(--space-2)}.upload-spinner{width:16px;height:16px;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.attachments-preview{margin-top:var(--space-4)}.attachments-preview-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);margin:0 0 var(--space-3) 0}.attachments-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--space-3)}.attachment-card{position:relative;border:1px solid var(--color-border-default);border-radius:var(--radius-lg);overflow:hidden;background:var(--color-bg-surface)}.attachment-remove-btn{position:absolute;top:var(--space-2);right:var(--space-2);z-index:10;width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:var(--color-danger);color:#fff;border:none;border-radius:var(--radius-full);cursor:pointer;transition:all var(--transition-fast);box-shadow:var(--shadow-md)}.attachment-remove-btn:hover{background:var(--color-danger-dark);transform:scale(1.1)}.attachment-remove-btn svg{width:14px;height:14px}.attachment-preview{width:100%;height:150px;display:flex;align-items:center;justify-content:center;background:var(--color-neutral-100)}.attachment-preview-image{overflow:hidden}.attachment-preview-image img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.attachment-preview-file svg{width:48px;height:48px;color:var(--color-text-tertiary)}.attachment-info{padding:var(--space-3)}.attachment-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary);margin:0 0 var(--space-1) 0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.attachment-meta{display:flex;align-items:center;justify-content:space-between}.attachment-size{font-size:var(--font-size-xs);color:var(--color-text-secondary)}.attachment-type{display:inline-flex;align-items:center;gap:var(--space-1);font-size:var(--font-size-xs)}.attachment-type svg{width:14px;height:14px}.attachment-type-image{color:var(--color-success)}.attachment-type-pdf{color:var(--color-danger)}.attachment-type-doc{color:var(--color-text-tertiary)}.tecnici-list{display:flex;flex-direction:column;gap:var(--space-2)}.tecnico-toggle-btn{display:flex;align-items:center;gap:var(--space-3);width:100%;padding:var(--space-3);background:var(--color-bg-surface);border:2px solid var(--color-border-default);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);text-align:left}.tecnico-toggle-btn:hover{background:var(--color-bg-hover);border-color:var(--color-primary-500)}.tecnico-toggle-btn.active{background:var(--color-primary-50);border-color:var(--color-primary-500)}.tecnico-toggle-avatar{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:linear-gradient(135deg,var(--color-primary-500),var(--color-primary-600));color:#fff;font-weight:var(--font-weight-bold);font-size:var(--font-size-sm);border-radius:var(--radius-full);flex-shrink:0}.tecnico-toggle-info{flex:1;min-width:0}.tecnico-toggle-name{display:block;font-size:var(--font-size-base);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.tecnico-toggle-role{display:block;font-size:var(--font-size-xs);color:var(--color-text-tertiary);margin-top:var(--space-1)}.tecnico-toggle-checkbox{width:24px;height:24px;flex-shrink:0}.tecnico-toggle-checkbox svg{width:100%;height:100%;color:var(--color-text-tertiary)}.tecnico-toggle-btn.active .tecnico-toggle-checkbox svg{color:var(--color-primary-600)}.tecnici-selected-info{margin-top:var(--space-3);padding:var(--space-3);background:var(--color-primary-50);border-radius:var(--radius-md);font-size:var(--font-size-sm);color:var(--color-primary-700)}.upload-zone{border:2px dashed #e5e7eb;border-radius:12px;padding:32px;text-align:center;transition:all .3s ease;background:#f9fafb;cursor:pointer}.upload-zone:hover{border-color:#3b82f6;background:#eff6ff}.upload-zone.dragover{border-color:#3b82f6;background:#eff6ff;border-style:solid}.upload-zone-icon{width:48px;height:48px;margin:0 auto 16px;color:#6b7280}.upload-zone-title{font-size:16px;font-weight:600;color:#111827;margin-bottom:8px}.upload-zone-hint{font-size:14px;color:#6b7280}.upload-previews{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:12px;margin-top:20px}.upload-preview-item{position:relative;border-radius:8px;overflow:hidden;border:1px solid #e5e7eb;background:#fff}.upload-preview-image{width:100%;height:120px;-o-object-fit:cover;object-fit:cover}.upload-preview-file{width:100%;height:120px;display:flex;align-items:center;justify-content:center;background:#f9fafb}.upload-preview-file svg{width:40px;height:40px;color:#6b7280}.upload-preview-remove{position:absolute;top:4px;right:4px;width:24px;height:24px;background:#ef4444e6;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}.upload-preview-remove:hover{background:#dc2626}.upload-preview-remove svg{width:14px;height:14px}.upload-preview-name{padding:8px;font-size:12px;color:#111827;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.checkup-stats{display:flex;gap:var(--space-6);align-items:center}.checkup-stat-item{display:flex;flex-direction:column;align-items:flex-end;padding:var(--space-3) var(--space-4);background:var(--color-neutral-50);border-radius:var(--radius-md)}.checkup-stat-label{font-size:var(--font-size-xs);color:var(--color-text-secondary);text-transform:uppercase;font-weight:var(--font-weight-semibold);letter-spacing:.5px;margin-bottom:var(--space-1)}.checkup-stat-value{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-primary-600)}.checkup-group-header{background:var(--color-neutral-50)}.checkup-group-header td{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-border-default)}.checkup-group-title{display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.checkup-group-icon{width:16px;height:16px;color:var(--color-primary-500)}.checkup-table tbody .checkup-td{padding:var(--space-5) var(--space-4)}.rapportino-data{display:flex;flex-direction:column;gap:var(--space-2)}.rapportino-data-day{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);line-height:var(--line-height-relaxed)}.rapportino-tecnico{display:flex;flex-direction:column;gap:var(--space-2)}.rapportino-tecnico-name{font-size:var(--font-size-base);font-weight:var(--font-weight-medium);color:var(--color-text-primary);line-height:var(--line-height-relaxed)}.rapportino-tecnico .badge-warning,.rapportino-tecnico .badge-neutral{font-size:10px;padding:2px var(--space-2);align-self:flex-start}.rapportino-ore{display:flex;flex-direction:column;gap:var(--space-2)}.rapportino-ore-value{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);line-height:var(--line-height-relaxed)}.rapportino-km{font-size:var(--font-size-base);font-weight:var(--font-weight-medium);color:var(--color-text-primary);line-height:var(--line-height-relaxed)}.rapportino-descrizione{font-size:var(--font-size-base);color:var(--color-text-secondary);line-height:var(--line-height-relaxed);padding-right:var(--space-3)}.checkup-cantiere{line-height:var(--line-height-relaxed)}.checkup-cantiere-name{font-size:var(--font-size-base);line-height:var(--line-height-relaxed)}.checkup-cantiere-secondary{font-size:var(--font-size-sm);line-height:var(--line-height-relaxed)}.checkup-list-footer{margin-top:var(--space-6);padding:var(--space-5);background:var(--color-neutral-50);border-radius:var(--radius-lg);border:1px solid var(--color-border-default)}.checkup-footer-summary{display:flex;justify-content:space-between;align-items:center;gap:var(--space-4)}.checkup-footer-text{font-size:var(--font-size-sm);color:var(--color-text-secondary);font-weight:var(--font-weight-medium)}.checkup-footer-totals{display:flex;align-items:center;gap:var(--space-3)}.checkup-footer-total{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-primary-600)}.checkup-footer-separator{color:var(--color-neutral-300);font-weight:var(--font-weight-medium)}.text-neutral{color:var(--color-text-tertiary)}.rapportini-tabs{display:flex;gap:var(--space-2);margin-bottom:var(--space-6);border-bottom:2px solid var(--color-border-default)}.rapportini-tab{padding:var(--space-3) var(--space-5);background:none;border:none;border-bottom:3px solid transparent;color:var(--color-text-secondary);font-size:var(--font-size-base);font-weight:var(--font-weight-medium);cursor:pointer;transition:all var(--transition-base);position:relative;margin-bottom:-2px}.rapportini-tab:hover{color:var(--color-primary-600);background:var(--color-neutral-50)}.rapportini-tab.active{color:var(--color-primary-600);border-bottom-color:var(--color-primary-600);font-weight:var(--font-weight-semibold)}.rapportini-tab-badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 var(--space-2);margin-left:var(--space-2);background:var(--color-primary-500);color:#fff;border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold)}.rapportini-filter-bar{margin-bottom:var(--space-6);padding:var(--space-5);background:var(--color-neutral-50);border-radius:var(--radius-lg);border:1px solid var(--color-border-default)}.rapportini-filter-group{display:flex;flex-direction:column;gap:var(--space-2)}.rapportini-filter-label{display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.rapportini-filter-icon{width:18px;height:18px;color:var(--color-primary-500)}.rapportini-filter-select{padding:var(--space-3) var(--space-4);font-size:var(--font-size-base);border:1px solid var(--color-border-default);border-radius:var(--radius-md);background:#fff;cursor:pointer;transition:all var(--transition-base)}.rapportini-filter-select:focus{outline:none;border-color:var(--color-primary-500);box-shadow:0 0 0 3px #3b82f61a}@media (max-width: 1024px){.checkup-stats{flex-direction:column;align-items:stretch;gap:var(--space-3)}.checkup-stat-item{flex-direction:row;justify-content:space-between;align-items:center}}@media (max-width: 768px){.checkup-list-header{flex-direction:column;align-items:stretch}.checkup-footer-summary{flex-direction:column;align-items:flex-start;gap:var(--space-3)}.checkup-table th:nth-child(5),.checkup-table td:nth-child(5){display:none}}@media (max-width: 640px){.checkup-table th:nth-child(6),.checkup-table td:nth-child(6){display:none}}.auth-body{background:linear-gradient(135deg,var(--color-neutral-800) 0%,var(--color-neutral-700) 100%);min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--space-5)}.login-box{background:var(--color-bg-surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-2xl);width:100%;max-width:440px;padding:var(--space-12)}.logo-section{text-align:center;margin-bottom:var(--space-10)}.logo-section .logo{height:50px;margin-bottom:var(--space-5)}.logo-section h2{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin-bottom:var(--space-2)}.logo-section .subtitle{font-size:var(--font-size-base);color:var(--color-text-secondary)}.form-group{margin-bottom:var(--space-5)}.form-input{width:100%;padding:var(--space-3) var(--space-4);font-size:var(--font-size-base);border:1px solid var(--color-border-default);border-radius:var(--radius-md);transition:all var(--transition-base)}.form-input:focus{outline:none;border-color:var(--color-primary-500);box-shadow:0 0 0 3px #3b82f61a}.error-text{color:var(--color-danger);font-size:var(--font-size-sm);margin-top:var(--space-1);display:block}.remember-me{display:flex;align-items:center;gap:var(--space-2);margin:var(--space-5) 0}.remember-me-label{color:var(--color-text-secondary);font-size:var(--font-size-sm)}.btn-login{width:100%;padding:var(--space-3) var(--space-6);background:linear-gradient(135deg,var(--color-primary-500) 0%,var(--color-primary-600) 100%);color:#fff;font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-base)}.btn-login:hover{transform:translateY(-1px);box-shadow:0 4px 12px #3b82f64d}.divider{text-align:center;margin:var(--space-8) 0 var(--space-5);padding-top:var(--space-5);border-top:1px solid var(--color-border-default)}.divider-text{color:var(--color-text-secondary);font-size:var(--font-size-sm)}.link{color:var(--color-primary-500);text-decoration:none;font-weight:var(--font-weight-medium)}.link:hover{text-decoration:underline}.welcome-container{min-height:100vh;background:var(--color-brand-gradient);display:flex;align-items:center;justify-content:center;padding:var(--space-5)}.welcome-card{background:var(--color-bg-surface);border-radius:var(--radius-xl);box-shadow:0 20px 60px #0000004d;max-width:600px;width:100%;overflow:hidden}.welcome-header{background:var(--color-brand-gradient);padding:var(--space-10);text-align:center;color:#fff}.welcome-logo-box{display:inline-block;background:#fff;border-radius:var(--radius-full);padding:var(--space-4);margin-bottom:var(--space-4)}.welcome-logo{height:64px;width:64px;-o-object-fit:contain;object-fit:contain}.welcome-icon{height:64px;width:64px;color:var(--color-brand-primary)}.welcome-title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);margin:0 0 var(--space-2) 0}.welcome-subtitle{font-size:var(--font-size-base);opacity:.9;margin:0}.welcome-body{padding:var(--space-8)}.welcome-form-group{margin-bottom:var(--space-6)}.welcome-label{display:block;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--space-2)}.welcome-label-required{color:var(--color-danger)}.welcome-input{width:100%;padding:var(--space-3) var(--space-4);border:2px solid var(--color-border-default);border-radius:var(--radius-md);font-size:var(--font-size-base);transition:all var(--transition-base)}.welcome-input:focus{outline:none;border-color:var(--color-brand-primary);box-shadow:0 0 0 3px #667eea1a}.welcome-help-text{font-size:var(--font-size-xs);color:var(--color-text-secondary);margin-top:var(--space-1)}.welcome-error{font-size:var(--font-size-sm);color:var(--color-danger);margin-top:var(--space-1)}.welcome-submit-btn{width:100%;padding:var(--space-4);background:var(--color-brand-gradient);color:#fff;border:none;border-radius:var(--radius-md);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);cursor:pointer;transition:all var(--transition-base)}.welcome-submit-btn:hover:not(:disabled){transform:scale(1.02);box-shadow:0 4px 12px #667eea66}.welcome-submit-btn:disabled{opacity:.5;cursor:not-allowed}.welcome-footer{background:var(--color-neutral-50);padding:var(--space-4) var(--space-8);text-align:center;font-size:var(--font-size-xs);color:var(--color-text-secondary)}.welcome-loading-text{color:var(--color-neutral-400)}@media (max-width: 480px){.login-box{padding:var(--space-8) var(--space-6)}}.welcome-avatar-preview{display:flex;align-items:center;gap:var(--space-4);margin-bottom:var(--space-3)}.welcome-avatar-circle{height:80px;width:80px;border-radius:var(--radius-full);overflow:hidden;border:2px solid var(--color-brand-primary)}.welcome-avatar-circle img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.welcome-avatar-placeholder{height:80px;width:80px;border-radius:var(--radius-full);background:var(--color-neutral-200);display:flex;align-items:center;justify-content:center}.welcome-avatar-icon{height:40px;width:40px;color:var(--color-neutral-400)}.welcome-upload-btn{display:inline-block;padding:var(--space-3) var(--space-5);background:var(--color-neutral-100);border:1px solid var(--color-border-default);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary);cursor:pointer;transition:all var(--transition-base)}.welcome-upload-btn:hover{background:var(--color-neutral-200)}.welcome-info-box{padding:var(--space-4);background:var(--color-primary-50);border:1px solid #bfdbfe;border-radius:var(--radius-md);margin-bottom:var(--space-6)}.welcome-info-title{font-weight:var(--font-weight-semibold);color:var(--color-primary-700);margin:0 0 var(--space-2) 0;font-size:var(--font-size-sm)}.welcome-info-list{list-style:none;padding:0;margin:0}.welcome-info-list li{font-size:var(--font-size-sm);color:var(--color-primary-700);padding:var(--space-1) 0}.welcome-checkbox-group{display:flex;align-items:start;gap:var(--space-3);margin-bottom:var(--space-6)}.welcome-checkbox{margin-top:var(--space-1);height:20px;width:20px;flex-shrink:0}.welcome-checkbox-label{font-size:var(--font-size-sm);color:var(--color-text-primary);line-height:var(--line-height-normal)}.welcome-checkbox-label a{color:var(--color-brand-primary);text-decoration:none}.welcome-checkbox-label a:hover{text-decoration:underline}.welcome-privacy-box{padding:var(--space-4);background:var(--color-neutral-50);border:1px solid var(--color-border-default);border-radius:var(--radius-md);font-size:var(--font-size-xs);color:var(--color-text-secondary);margin-bottom:var(--space-6)}.welcome-privacy-box strong{color:var(--color-text-primary)}.welcome-privacy-box p{margin:0 0 var(--space-2) 0}.welcome-privacy-box p:last-child{margin:0}.notification-banner{background:linear-gradient(to right,var(--color-primary-50),var(--color-primary-100));border:1px solid var(--color-primary-200);border-radius:var(--radius-lg);padding:var(--space-4);margin-bottom:var(--space-6)}.notification-banner-content{display:flex;align-items:center;gap:var(--space-4)}.notification-banner-icon{flex-shrink:0;width:48px;height:48px;background:var(--color-bg-surface);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:var(--color-primary-500)}.notification-banner-icon svg{width:24px;height:24px}.notification-banner-text{flex:1}.notification-banner-message{margin:0;color:var(--color-primary-700);font-size:var(--font-size-sm)}.notification-banner-action{flex-shrink:0}.notification-banner-btn{padding:var(--space-3) var(--space-5);background:var(--color-primary-500);color:#fff;border:none;border-radius:var(--radius-md);font-weight:var(--font-weight-semibold);font-size:var(--font-size-sm);cursor:pointer;transition:background var(--transition-base)}.notification-banner-btn:hover{background:var(--color-primary-600)}.notification-banner-btn:disabled{opacity:.6;cursor:not-allowed}.dashboard-chart-full{margin-bottom:var(--space-8)}.dashboard-chart-card-full{background:var(--color-bg-surface);border:1px solid var(--color-border-default);border-radius:var(--radius-lg);padding:var(--space-6);transition:all var(--transition-base)}.dashboard-chart-card-full:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.dashboard-chart-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin:0 0 var(--space-5) 0}.dashboard-chart-container-full{width:100%;height:400px;min-height:400px;position:relative}.dashboard-kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--space-5);margin-bottom:var(--space-8)}.dashboard-kpi-card{background:var(--color-bg-surface);border:1px solid var(--color-border-default);border-radius:var(--radius-lg);padding:var(--space-5);transition:all var(--transition-base)}.dashboard-kpi-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.dashboard-kpi-content{display:flex;justify-content:space-between;align-items:start}.dashboard-kpi-label{font-size:var(--font-size-sm);color:var(--color-text-secondary);font-weight:var(--font-weight-medium);margin-bottom:var(--space-2)}.dashboard-kpi-value{font-size:32px;font-weight:var(--font-weight-bold);color:var(--color-text-primary);line-height:1}.dashboard-kpi-icon{width:48px;height:48px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.dashboard-kpi-icon svg{width:24px;height:24px;stroke:currentColor;fill:none}.dashboard-kpi-icon.blue{background:#3b82f61a;color:#3b82f6}.dashboard-kpi-icon.green{background:#22c55e1a;color:#22c55e}.dashboard-kpi-icon.yellow{background:#f59e0b1a;color:#f59e0b}.dashboard-kpi-icon.purple{background:#a855f71a;color:#a855f7}.dashboard-kpi-icon.pink{background:#ec48991a;color:#ec4899}.dashboard-kpi-icon.red{background:#ef44441a;color:#ef4444}.dashboard-activities{background:var(--color-bg-surface);border:1px solid var(--color-border-default);border-radius:var(--radius-lg);padding:var(--space-6);margin-bottom:var(--space-6)}.dashboard-activities-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-4)}.dashboard-activities-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin:0}.dashboard-activities-link{color:var(--color-primary-500);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);background:none;border:none;cursor:pointer;transition:color var(--transition-base)}.dashboard-activities-link:hover{color:var(--color-primary-600);text-decoration:underline}.dashboard-activities-table{width:100%;border-collapse:collapse}.dashboard-activities-table thead{border-bottom:2px solid var(--color-border-default)}.dashboard-activities-table th{text-align:left;padding:var(--space-3) var(--space-4);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);text-transform:uppercase}.dashboard-activities-table tbody tr{border-bottom:1px solid var(--color-neutral-100);cursor:pointer;transition:background var(--transition-base)}.dashboard-activities-table tbody tr:hover{background:var(--color-neutral-50)}.dashboard-activities-table tbody tr:last-child{border-bottom:none}.dashboard-activities-table td{padding:var(--space-4)}.dashboard-activities-number{font-weight:var(--font-weight-semibold);color:var(--color-text-primary);font-size:var(--font-size-sm)}.dashboard-activities-cantiere,.dashboard-activities-date{color:var(--color-text-secondary);font-size:var(--font-size-sm)}.dashboard-activities-badge{display:inline-flex;align-items:center;padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold)}.dashboard-activities-badge-success{background:var(--color-success-light);color:var(--color-success-dark)}.dashboard-activities-badge-warning{background:var(--color-warning-light);color:#92400e}.dashboard-activities-badge-info{background:var(--color-info-light);color:#1e40af}.dashboard-activities-empty{text-align:center;padding:var(--space-12) var(--space-4);color:var(--color-text-secondary);font-size:var(--font-size-sm)}#chartOreLavorate text,#chartOreLavorate .apexcharts-text,#chartOreLavorate .apexcharts-xaxis-label,#chartOreLavorate .apexcharts-yaxis-label,#chartOreLavorate .apexcharts-yaxis-title-text{font-weight:lighter;font-family:Roboto,Arial,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;font-smooth:always;font-optical-sizing:auto}@media (max-width: 1024px){.dashboard-chart-container-full{height:350px;min-height:350px}}@media (max-width: 768px){.dashboard-kpi-grid{grid-template-columns:1fr}.dashboard-chart-container-full{height:300px;min-height:300px}.dashboard-chart-card-full,.dashboard-activities{padding:var(--space-4)}.dashboard-activities-table{font-size:var(--font-size-sm)}.dashboard-activities-table th,.dashboard-activities-table td{padding:var(--space-2) var(--space-3)}}@media (max-width: 480px){.dashboard-kpi-value{font-size:28px}.dashboard-chart-container-full{height:280px;min-height:280px}}.tecnici-container{max-width:1400px;margin:0 auto}.tecnici-header{margin-bottom:var(--space-8)}.tecnici-title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin:0 0 var(--space-2) 0}.tecnici-subtitle{font-size:var(--font-size-base);color:var(--color-text-secondary);margin:0}.tecnici-toolbar{display:flex;justify-content:space-between;align-items:center;gap:var(--space-4);margin-bottom:var(--space-6);flex-wrap:wrap}.tecnici-search-container{position:relative;flex:1;max-width:450px;min-width:250px}.tecnici-search-input{width:100%;padding:var(--space-3) var(--space-4) var(--space-3) var(--space-10);border:1px solid var(--color-border-default);border-radius:var(--radius-md);font-size:var(--font-size-sm);transition:all var(--transition-base)}.tecnici-search-input:focus{outline:none;border-color:var(--color-primary-500);box-shadow:0 0 0 3px #2563eb1a}.tecnici-search-icon{position:absolute;left:var(--space-3);top:50%;transform:translateY(-50%);width:20px;height:20px;color:var(--color-neutral-400);pointer-events:none}.tecnici-view-toggle{display:flex;gap:var(--space-1);background:var(--color-neutral-100);padding:var(--space-1);border-radius:var(--radius-md)}.tecnici-view-btn{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:transparent;border:none;border-radius:var(--radius-sm);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-base)}.tecnici-view-icon{width:18px;height:18px}.tecnici-view-btn.active{background:#fff;color:var(--color-primary-500);box-shadow:var(--shadow-sm)}.tecnici-view-btn:hover:not(.active){color:var(--color-text-primary)}.tecnici-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--space-5)}.tecnici-card{background:var(--color-bg-surface);border:1px solid var(--color-border-default);border-radius:var(--radius-lg);padding:var(--space-5);cursor:pointer;transition:all var(--transition-base)}.tecnici-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px);border-color:var(--color-primary-200)}.tecnici-card-header{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-4)}.tecnici-avatar{width:56px;height:56px;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--color-primary-500),var(--color-primary-600));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:var(--font-weight-bold);font-size:var(--font-size-lg);text-transform:uppercase;flex-shrink:0}.tecnici-avatar-img{width:56px;height:56px;border-radius:var(--radius-full);-o-object-fit:cover;object-fit:cover;flex-shrink:0}.tecnici-card-name{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0 0 var(--space-1) 0}.tecnici-card-role{font-size:var(--font-size-sm);color:var(--color-primary-600);margin:0;font-weight:var(--font-weight-medium)}.tecnici-stats{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-3);margin-bottom:var(--space-4)}.tecnici-stat-box{text-align:center;padding:var(--space-4);background:var(--color-neutral-50);border-radius:var(--radius-md);transition:all var(--transition-base)}.tecnici-card:hover .tecnici-stat-box{background:var(--color-primary-50)}.tecnici-stat-value{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-primary-600);margin-bottom:var(--space-1)}.tecnici-stat-label{font-size:var(--font-size-xs);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px}.tecnici-card-footer{border-top:1px solid var(--color-border-default);padding-top:var(--space-3);display:flex;justify-content:space-between;align-items:center}.tecnici-footer-info{display:flex;flex-direction:column;gap:var(--space-1);flex:1}.tecnici-footer-label{font-size:var(--font-size-xs);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px}.tecnici-footer-value{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.tecnici-contact-icon{width:32px;height:32px;background:var(--color-primary-50);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:var(--color-primary-600);transition:all var(--transition-base)}.tecnici-contact-icon svg{width:18px;height:18px}.tecnici-card:hover .tecnici-contact-icon{background:var(--color-primary-600);color:#fff}.tecnici-list-container{background:#fff;border-radius:var(--radius-lg);border:1px solid var(--color-border-default);overflow:hidden}.tecnici-table{width:100%;border-collapse:collapse}.tecnici-table thead{background:var(--color-neutral-50);border-bottom:2px solid var(--color-border-default)}.tecnici-table th{text-align:left;padding:var(--space-4);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px}.tecnici-table th.center{text-align:center}.tecnici-table tbody tr{border-bottom:1px solid var(--color-neutral-100);transition:background var(--transition-base)}.tecnici-table tbody tr:last-child{border-bottom:none}.tecnici-table tbody tr:hover{background:var(--color-neutral-50)}.tecnici-table td{padding:var(--space-4)}.tecnici-table-avatar-cell{display:flex;align-items:center;gap:var(--space-3)}.tecnici-avatar-small{width:40px;height:40px;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--color-primary-500),var(--color-primary-600));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:var(--font-weight-semibold);font-size:var(--font-size-sm);text-transform:uppercase;flex-shrink:0}.tecnici-avatar-small-img{width:40px;height:40px;border-radius:var(--radius-full);-o-object-fit:cover;object-fit:cover;flex-shrink:0}.tecnici-table-name{display:block;font-weight:var(--font-weight-medium);color:var(--color-text-primary);margin-bottom:var(--space-1)}.tecnici-table-role{display:block;font-size:var(--font-size-xs);color:var(--color-primary-600);font-weight:var(--font-weight-medium)}.tecnici-table-email{color:var(--color-text-secondary);font-size:var(--font-size-sm)}.tecnici-table-center{text-align:center}.tecnici-table-date{color:var(--color-text-secondary);font-size:var(--font-size-sm)}.tecnici-badge{display:inline-flex;align-items:center;justify-content:center;padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);min-width:32px}.tecnici-badge-primary{background:var(--color-primary-100);color:var(--color-primary-700)}.tecnici-badge-secondary{background:var(--color-purple-100);color:var(--color-purple-700)}.tecnici-action-btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--color-primary-50);color:var(--color-primary-600);border:none;border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:all var(--transition-base)}.tecnici-action-btn svg{width:16px;height:16px}.tecnici-action-btn:hover{background:var(--color-primary-600);color:#fff}.tecnici-empty{padding:var(--space-16) var(--space-8);text-align:center;color:var(--color-text-secondary)}.tecnici-empty-full{grid-column:1 / -1}.tecnici-empty-icon{width:64px;height:64px;margin:0 auto var(--space-4);color:var(--color-neutral-300)}.tecnici-empty-text{font-size:var(--font-size-base);color:var(--color-text-secondary);margin:0 0 var(--space-4) 0}.tecnici-empty-button{padding:var(--space-2) var(--space-4);background:var(--color-primary-500);color:#fff;border:none;border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:all var(--transition-base)}.tecnici-empty-button:hover{background:var(--color-primary-600)}.tecnici-modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:var(--z-modal, 9999);padding:var(--space-4);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.tecnici-modal-content{position:relative;background:#fff;border-radius:var(--radius-xl);padding:var(--space-8);max-width:600px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-xl)}.tecnici-modal-close-icon{position:absolute;top:var(--space-4);right:var(--space-4);width:32px;height:32px;background:var(--color-neutral-100);border:none;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-base)}.tecnici-modal-close-icon svg{width:18px;height:18px;color:var(--color-text-secondary)}.tecnici-modal-close-icon:hover{background:var(--color-neutral-200)}.tecnici-modal-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0 0 var(--space-6) 0}.tecnici-modal-header{display:flex;align-items:center;gap:var(--space-4);margin-bottom:var(--space-6);padding-bottom:var(--space-6);border-bottom:1px solid var(--color-border-default)}.tecnici-avatar-large{width:80px;height:80px;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--color-primary-500),var(--color-primary-600));color:#fff;display:flex;align-items:center;justify-content:center;font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);text-transform:uppercase;flex-shrink:0;box-shadow:var(--shadow-md)}.tecnici-avatar-large-img{width:80px;height:80px;border-radius:var(--radius-full);-o-object-fit:cover;object-fit:cover;flex-shrink:0;box-shadow:var(--shadow-md)}.tecnici-modal-name{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0 0 var(--space-1) 0}.tecnici-modal-role{font-size:var(--font-size-sm);color:var(--color-primary-600);font-weight:var(--font-weight-medium);margin:0 0 var(--space-2) 0}.tecnici-modal-email{display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0}.tecnici-modal-email-icon{width:16px;height:16px}.tecnici-modal-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-4);margin-bottom:var(--space-6)}.tecnici-modal-stat{text-align:center;padding:var(--space-4);background:var(--color-neutral-50);border-radius:var(--radius-lg)}.tecnici-modal-stat-icon{width:48px;height:48px;margin:0 auto var(--space-3);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center}.tecnici-modal-stat-icon svg{width:24px;height:24px}.tecnici-modal-stat-icon.blue{background:var(--color-primary-100);color:var(--color-primary-600)}.tecnici-modal-stat-icon.green{background:var(--color-success-light);color:var(--color-success-dark)}.tecnici-modal-stat-icon.purple{background:var(--color-purple-100);color:var(--color-purple-600)}.tecnici-modal-stat-value{font-size:32px;font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin-bottom:var(--space-2)}.tecnici-modal-stat-label{font-size:var(--font-size-xs);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px}.tecnici-modal-footer{margin-bottom:var(--space-6)}.tecnici-modal-info-box{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4);background:var(--color-neutral-50);border-radius:var(--radius-lg)}.tecnici-modal-info-icon{width:40px;height:40px;background:var(--color-primary-100);border-radius:var(--radius-md);padding:var(--space-2);color:var(--color-primary-600);flex-shrink:0}.tecnici-modal-info-label{font-size:var(--font-size-xs);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:var(--space-1)}.tecnici-modal-info-value{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.tecnici-modal-close-btn{width:100%;padding:var(--space-3) var(--space-4);background:var(--color-primary-500);color:#fff;border:none;border-radius:var(--radius-md);font-weight:var(--font-weight-semibold);font-size:var(--font-size-base);cursor:pointer;transition:all var(--transition-base)}.tecnici-modal-close-btn:hover{background:var(--color-primary-600)}@media (max-width: 1024px){.tecnici-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}}@media (max-width: 768px){.tecnici-toolbar{flex-direction:column;align-items:stretch}.tecnici-search-container{max-width:none}.tecnici-grid,.tecnici-modal-stats{grid-template-columns:1fr}.tecnici-table{font-size:var(--font-size-sm)}.tecnici-table th,.tecnici-table td{padding:var(--space-2) var(--space-3)}}@media (max-width: 640px){.tecnici-modal-content{padding:var(--space-6)}.tecnici-avatar-large,.tecnici-avatar-large-img{width:64px;height:64px}}.tecnici-contact-btn{width:44px;height:44px;background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;color:#fff;cursor:pointer;transition:all var(--transition-base);flex-shrink:0;box-shadow:0 2px 8px #10b9814d}.tecnici-contact-btn svg{width:24px;height:24px}.tecnici-contact-btn:hover{background:linear-gradient(135deg,#059669,#047857);color:#fff;transform:scale(1.1);box-shadow:0 4px 12px #10b98180}.tecnici-contact-btn:active{transform:scale(1.05)}.tecnici-actions-group{display:flex;gap:var(--space-2);justify-content:center}.tecnici-action-btn-info{background:var(--color-primary-50);color:var(--color-primary-600)}.tecnici-action-btn-info:hover{background:var(--color-primary-100)}.tecnici-action-btn-message{background:var(--color-success-light);color:var(--color-success-dark)}.tecnici-action-btn-message:hover{background:var(--color-success);color:#fff}.tecnici-modal-actions{display:flex;gap:var(--space-3)}.tecnici-modal-action-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);border:none;border-radius:var(--radius-md);font-weight:var(--font-weight-semibold);font-size:var(--font-size-base);cursor:pointer;transition:all var(--transition-base)}.tecnici-modal-action-btn svg{width:20px;height:20px}.tecnici-modal-action-message{background:var(--color-success);color:#fff}.tecnici-modal-action-message:hover{background:var(--color-success-dark, #059669)}.tecnici-modal-close-btn{flex:1}.tecnici-contact-btn-with-text{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:var(--radius-lg);color:#fff;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);cursor:pointer;transition:all var(--transition-base);flex-shrink:0;box-shadow:0 2px 8px #10b9814d;white-space:nowrap}.tecnici-contact-btn-with-text svg{width:20px;height:20px;flex-shrink:0}.tecnici-contact-btn-with-text:hover{background:linear-gradient(135deg,#059669,#047857);transform:translateY(-2px);box-shadow:0 4px 12px #10b98180}.tecnici-contact-btn-with-text:active{transform:translateY(0)}.tecnici-contact-btn-text{display:inline-block}@media (max-width: 1200px){.tecnici-contact-btn-text{display:none}.tecnici-contact-btn-with-text{padding:var(--space-2);width:44px;height:44px;justify-content:center}}.settings-section{margin-bottom:var(--space-8);padding-bottom:var(--space-6);border-bottom:1px solid var(--color-border-default)}.settings-section:last-child{border-bottom:none}.settings-section-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0 0 var(--space-6)}.avatar-settings-container{display:flex;flex-direction:column;align-items:center;gap:var(--space-6);padding:var(--space-6) 0}.avatar-preview-large{width:160px;height:160px;border-radius:50%;overflow:hidden;border:4px solid var(--color-border-default);background:var(--color-bg-hover);box-shadow:0 4px 12px #0000001a}.avatar-preview-image{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.avatar-preview-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--color-brand-gradient);color:#fff;font-size:64px;font-weight:var(--font-weight-bold)}.avatar-actions{display:flex;gap:var(--space-3);justify-content:center;flex-wrap:wrap}.form-group{margin-bottom:var(--space-5);max-width:500px}.form-group label{display:block;font-weight:var(--font-weight-medium);color:var(--color-text-primary);margin-bottom:var(--space-2)}.form-input{width:100%;padding:var(--space-3);border:1px solid var(--color-border-default);border-radius:var(--radius-md);font-size:var(--font-size-base);transition:border-color .2s}.form-input:focus{outline:none;border-color:var(--color-brand-primary);box-shadow:0 0 0 3px #3b82f61a}.error-message{color:var(--color-danger);font-size:var(--font-size-sm);margin-top:var(--space-2)}.btn-primary,.btn-secondary{padding:var(--space-3) var(--space-6);border-radius:var(--radius-md);font-weight:var(--font-weight-medium);cursor:pointer;transition:all .2s;border:none}.btn-primary{background:var(--color-brand-gradient);color:#fff}.btn-primary:hover{opacity:.9;transform:translateY(-1px)}.btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-secondary{background:var(--color-bg-hover);color:var(--color-text-primary);border:1px solid var(--color-border-default)}.btn-secondary:hover{background:var(--color-bg-surface)}.btn-danger{background:transparent;color:var(--color-danger);border-color:var(--color-danger)}.btn-danger:hover{background:#ef44441a}.notifiche-device-title{font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0}.notifiche-device-status{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:var(--space-1) 0 0 0}.notifiche-section-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:var(--space-4) 0}.notifiche-device-item{display:flex;justify-content:space-between;align-items:start;padding:var(--space-4);border-bottom:1px solid var(--color-border-default)}.notifiche-device-info{flex:1}.notifiche-device-name{font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0}.notifiche-device-user{font-size:var(--font-size-sm);color:var(--color-primary-500);margin:var(--space-1) 0 0 0}.notifiche-device-date{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:var(--space-1) 0 0 0}.notifiche-device-agent{font-size:var(--font-size-xs);color:var(--color-neutral-400);margin:var(--space-1) 0 0 0}.notifiche-delete-btn{padding:var(--space-2);background:transparent;border:none;cursor:pointer;color:var(--color-danger);transition:all var(--transition-base)}.notifiche-delete-btn:hover{background:var(--color-danger-light);border-radius:var(--radius-sm)}.notifiche-delete-btn svg{width:20px;height:20px}.notifiche-empty-devices{text-align:center;padding:var(--space-8);color:var(--color-neutral-400)}.notifiche-modal-overlay{position:fixed;inset:0;z-index:var(--z-modal);overflow-y:auto}.notifiche-modal-backdrop{position:fixed;inset:0;background:#00000080}.notifiche-modal-wrapper{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:var(--space-4)}.notifiche-modal-container{position:relative;background:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow-2xl);max-width:448px;width:100%;padding:var(--space-6)}.notifiche-modal-header-section{text-align:center;margin-bottom:var(--space-6)}.notifiche-modal-title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin:0}.notifiche-modal-subtitle{color:var(--color-text-secondary);margin-top:var(--space-2)}.notifiche-modal-field{margin-bottom:var(--space-6)}.notifiche-modal-label{display:block;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--space-3)}.notifiche-icon-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:var(--space-2)}.notifiche-icon-btn{padding:var(--space-3);background:var(--color-neutral-50);border:2px solid transparent;border-radius:var(--radius-lg);transition:all var(--transition-base);font-size:var(--font-size-2xl);cursor:pointer}.notifiche-icon-btn:hover{background:var(--color-neutral-100)}.notifiche-icon-btn.selected{border-color:var(--color-primary-500);background:var(--color-primary-50)}.notifiche-modal-input{width:100%;padding:var(--space-3) var(--space-4);border:1px solid var(--color-border-default);border-radius:var(--radius-lg);font-size:var(--font-size-base);transition:all var(--transition-base)}.notifiche-modal-input:focus{outline:none;border-color:var(--color-primary-500);box-shadow:0 0 0 3px #3b82f61a}.notifiche-modal-preview{padding:var(--space-4);background:var(--color-neutral-50);border-radius:var(--radius-lg);margin-bottom:var(--space-6)}.notifiche-modal-preview-label{font-size:var(--font-size-xs);color:var(--color-text-secondary);margin:0 0 var(--space-2) 0}.notifiche-modal-preview-content{display:flex;align-items:center;gap:var(--space-3)}.notifiche-modal-preview-icon{font-size:var(--font-size-2xl)}.notifiche-modal-preview-name{font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.notifiche-modal-submit{width:100%;background:var(--color-primary-500);color:#fff;padding:var(--space-3);border-radius:var(--radius-lg);font-weight:var(--font-weight-semibold);border:none;cursor:pointer;transition:all var(--transition-base)}.notifiche-modal-submit:hover:not(.disabled){background:var(--color-primary-600)}.notifiche-modal-submit.disabled{opacity:.5;cursor:not-allowed}
