.layout-wrapper{display:flex;flex-direction:column;min-height:100vh}.top-navbar{position:fixed;top:0;left:0;right:0;z-index:200;background-color:#fff;display:flex;align-items:stretch;height:60px;box-shadow:0 4px #4a9ec8}.navbar-user-left{background:#253d5b;display:flex;align-items:center;gap:12px;padding:0 16px;width:220px;min-width:220px;max-width:220px;box-sizing:border-box;overflow:hidden;transition:width .25s ease,min-width .25s ease}.sidebar-collapsed .navbar-user-left{width:68px;min-width:68px;max-width:68px;padding:0 8px;justify-content:center}.user-info{display:flex;align-items:center;gap:8px;font-size:13px;color:#94a3b8;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role-badge{text-transform:capitalize;background:#ffffff26;color:#f8fafc;padding:2px 8px;border-radius:10px;font-size:11px;white-space:nowrap}.navbar-center{flex:1;display:flex;align-items:center;padding:0 20px}.navbar-brand a{color:#283546;text-decoration:none;font-size:24px;font-weight:700;display:flex;align-items:center;gap:10px}.navbar-logo{height:50px;width:auto;border-radius:4px}.navbar-right{display:flex;align-items:center;gap:15px;padding:0 20px}.nav-link-top{color:#555;text-decoration:none;font-size:14px;padding:8px 12px;border-radius:4px;transition:background-color .2s,color .2s;display:flex;align-items:center;gap:6px}.nav-link-top:hover{background-color:#e0f4fc;color:#1a7aa8}.status-dot{display:inline-block;width:8px;height:8px;border-radius:50%}.navbar-esci-btn{background-color:#4a9ec8;color:#fff;border:none;padding:6px 16px;border-radius:4px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s}.navbar-esci-btn:hover{background-color:#3a8ab5}.sidebar{width:220px;min-width:220px;background:#253d5b;display:flex;flex-direction:column;position:fixed;top:64px;left:0;bottom:0;z-index:100;transition:width .25s ease,min-width .25s ease;overflow:hidden}.sidebar-collapsed .sidebar{width:68px;min-width:68px}.sidebar-collapse-bar{display:flex;justify-content:flex-end;padding:8px 12px 4px}.sidebar-toggle{background:#ffffff0f;border:none;color:#5a6e84;cursor:pointer;padding:4px 10px;border-radius:6px;font-size:12px;letter-spacing:-2px;transition:all .2s ease}.sidebar-toggle:hover{background:#ffffff1f;color:#94a3b8}.sidebar-collapsed .sidebar-collapse-bar{justify-content:center}.sidebar-nav{flex:1;overflow-y:auto;padding:4px 0}.sidebar-nav::-webkit-scrollbar{width:4px}.sidebar-nav::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:4px}.nav-section{margin-bottom:0}.nav-section-title{display:flex;align-items:center;justify-content:space-between;padding:6px 18px 1px;font-size:11px;font-weight:700;color:#e2e8f0;text-transform:uppercase;letter-spacing:1px;cursor:pointer;-webkit-user-select:none;user-select:none;transition:color .15s ease}.nav-section-title:hover{color:#fff}.nav-section-arrow{font-size:14px;color:#4a9ec8;transition:transform .25s ease}.nav-section-arrow.collapsed{transform:rotate(-90deg)}.nav-section-divider{height:1px;background:#ffffff0f;margin:8px 16px}.nav-item{display:flex;align-items:center;gap:12px;padding:1px 18px;color:#89a;text-decoration:none;font-size:14px;font-weight:500;transition:all .15s ease;margin:0 6px;border-radius:8px;white-space:nowrap}.nav-item:hover{background:#ffffff0f;color:#c5d3e0}.nav-item.active{background:#4a9ec826;color:#fff}.nav-item.active .nav-icon{color:#4a9ec8}.nav-icon{font-size:26px;width:28px;text-align:center;flex-shrink:0}.nav-label{overflow:hidden;text-overflow:ellipsis}.sidebar-collapsed .nav-item{padding:10px;justify-content:center;margin:1px 8px}.sidebar-collapsed .nav-icon{font-size:28px}.main-content{flex:1;margin-left:220px;margin-top:64px;transition:margin-left .25s ease;min-height:calc(100vh - 64px)}.sidebar-collapsed .main-content{margin-left:68px}@media (max-width: 768px){.sidebar{transform:translate(-100%);width:220px!important;min-width:220px!important}.sidebar.open{transform:translate(0)}.main-content{margin-left:0!important}.navbar-user-left{width:68px!important;min-width:68px!important;max-width:68px!important}.user-info{display:none}}:root{--color-primary: #4a9ec8;--color-primary-hover: #3a8ab5;--color-primary-light: #e0f4fc;--color-sidebar: #1a1f2e;--color-sidebar-hover: #252b3d;--color-sidebar-active: rgba(74, 158, 200, .15);--color-sidebar-text: #8892a4;--color-sidebar-text-active: #4a9ec8;--color-bg: #f5f6fa;--color-card: #ffffff;--color-text: #2d3748;--color-text-light: #718096;--color-border: #e2e8f0;--color-success: #38a169;--color-warning: #d69e2e;--color-danger: #e53e3e;--color-info: #3182ce;--color-muted: #a0aec0;--color-completata: #38a169;--color-in-corso: #d69e2e;--color-sospesa: #e53e3e;--color-aperta: #3182ce;--color-da-fare: #a0aec0;--color-approvato: #38a169;--color-in-attesa: #d69e2e;--color-rifiutato: #e53e3e;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .08);--shadow-md: 0 4px 12px rgba(0, 0, 0, .1);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .12);--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--transition: .2s ease}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;background-color:var(--color-bg);color:var(--color-text);line-height:1.6;font-size:14px}.container{max-width:100%;margin:0 auto;padding:24px}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border:none;border-radius:var(--radius-md);cursor:pointer;font-size:13px;font-weight:500;text-decoration:none;transition:all var(--transition);white-space:nowrap}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background-color:var(--color-primary);color:#fff}.btn-primary:hover:not(:disabled){background-color:var(--color-primary-hover);transform:translateY(-1px);box-shadow:0 4px 12px #f47b204d}.btn-icon{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:4px;cursor:pointer;transition:all .15s ease;padding:0}.btn-icon-edit{background:#4a5568;color:#fff}.btn-icon-edit:hover{background:#2d3748}.btn-icon-delete{background:#c53030;color:#fff}.btn-icon-delete:hover{background:#9b2c2c}.btn-secondary{background-color:#edf2f7;color:var(--color-text)}.btn-secondary:hover:not(:disabled){background-color:#e2e8f0}.btn-danger{background-color:var(--color-danger);color:#fff}.btn-danger:hover:not(:disabled){background-color:#c53030}.btn-success{background-color:var(--color-success);color:#fff}.btn-success:hover:not(:disabled){background-color:#2f855a}.btn-info{background-color:var(--color-info);color:#fff}.btn-info:hover:not(:disabled){background-color:#2b6cb0}.btn-outline{background-color:transparent;border:1px solid var(--color-border);color:var(--color-text)}.btn-outline:hover:not(:disabled){border-color:var(--color-primary);color:var(--color-primary)}.btn-small{padding:5px 10px;font-size:12px}.btn-block{display:block;width:100%;text-align:center}.btn-icon{padding:6px 8px;font-size:16px;line-height:1}.form-group{margin-bottom:16px}.form-group label{display:block;margin-bottom:4px;font-weight:500;font-size:13px;color:var(--color-text)}.form-group input,.form-group select,.form-group textarea{width:100%;padding:9px 12px;border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:14px;color:var(--color-text);background:#fff;transition:border-color var(--transition),box-shadow var(--transition)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #4a9ec826}.form-group textarea{min-height:80px;resize:vertical}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}.card{background:var(--color-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:20px;margin-bottom:20px}.card-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:16px;margin-bottom:16px;border-bottom:1px solid var(--color-border)}.card-header h2{font-size:16px;font-weight:600;color:var(--color-text)}.summary-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-bottom:24px}.summary-card{background:var(--color-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:20px;display:flex;align-items:center;gap:16px;transition:all var(--transition)}.summary-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.summary-card .icon{width:48px;height:48px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0}.summary-card .icon.orange{background:#4a9ec81a;color:var(--color-primary)}.summary-card .icon.blue{background:#3182ce1a;color:var(--color-info)}.summary-card .icon.green{background:#38a1691a;color:var(--color-success)}.summary-card .icon.red{background:#e53e3e1a;color:var(--color-danger)}.summary-card .icon.purple{background:#805ad51a;color:#805ad5}.summary-card .icon.yellow{background:#d69e2e1a;color:var(--color-warning)}.summary-card .info h3{font-size:24px;font-weight:700;color:var(--color-text);line-height:1.2}.summary-card .info p{font-size:12px;color:var(--color-text-light);margin-top:2px}.table-wrapper{overflow-x:auto;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.table-scroll-wrapper{overflow:auto;max-height:calc(100vh - 300px);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.table{width:100%;border-collapse:separate;border-spacing:0;background:#fff}.table th,.table td{padding:10px 14px;text-align:left;border-bottom:1px solid var(--color-border);font-size:13px}.table th{background:var(--color-sidebar);color:#fff;font-weight:500;position:sticky;top:0;z-index:10;white-space:nowrap}.table thead tr th:first-child{border-top-left-radius:var(--radius-lg)}.table thead tr th:last-child{border-top-right-radius:var(--radius-lg)}.table tbody tr{background:#fff;transition:background var(--transition)}.table tbody tr:hover{background-color:#f7fafc}.table tbody tr:nth-child(2n){background-color:#fafbfc}.table tbody tr:nth-child(2n):hover{background-color:#f0f2f5}.table tbody tr.clickable{cursor:pointer}.table tbody tr.clickable:hover{background-color:var(--color-primary-light)}.table .totals-row{background:#edf2f7!important;font-weight:600}.table .totals-row:hover{background:#e2e8f0!important}.table tbody tr.margin-high{border-left:3px solid var(--color-success)}.table tbody tr.margin-mid{border-left:3px solid var(--color-warning)}.table tbody tr.margin-low{border-left:3px solid var(--color-danger)}.badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;white-space:nowrap}.badge-completata,.badge-approvato,.badge-pagata,.badge-attivo{background-color:#38a1691a;color:var(--color-completata)}.badge-in_corso,.badge-in-corso,.badge-in_attesa,.badge-in-attesa{background-color:#d69e2e1a;color:var(--color-in-corso)}.badge-sospesa,.badge-rifiutato,.badge-scaduta{background-color:#e53e3e1a;color:var(--color-sospesa)}.badge-aperta,.badge-in_avvio{background-color:#3182ce1a;color:var(--color-aperta)}.badge-da_fare,.badge-da-fare{background-color:#a0aec01a;color:var(--color-da-fare)}.badge-admin{background-color:#e53e3e1a;color:var(--color-danger)}.badge-tecnico{background-color:#3182ce1a;color:var(--color-info)}.badge-commerciale{background-color:#805ad51a;color:#805ad5}.badge-non_pagata{background-color:#e53e3e1a;color:var(--color-danger)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal{background:#fff;border-radius:var(--radius-lg);padding:24px;max-width:600px;width:90%;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg)}.modal.modal-lg{max-width:800px}.modal.modal-xl{max-width:1000px}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.modal-header h2{font-size:18px;font-weight:600}.modal-close{background:none;border:none;font-size:24px;cursor:pointer;color:var(--color-muted);transition:color var(--transition);line-height:1;padding:4px}.modal-close:hover{color:var(--color-text)}.modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:24px;padding-top:16px;border-top:1px solid var(--color-border)}.loading{text-align:center;padding:60px;color:var(--color-text-light)}.spinner{display:inline-block;width:40px;height:40px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-container{display:flex;flex-direction:column;align-items:center;gap:12px;padding:60px}.alert{padding:12px 16px;border-radius:var(--radius-md);margin-bottom:16px;font-size:13px}.alert-error{background-color:#fed7d7;color:#9b2c2c;border:1px solid #feb2b2}.alert-success{background-color:#c6f6d5;color:#276749;border:1px solid #9ae6b4}.alert-info{background-color:#bee3f8;color:#2a4365;border:1px solid #90cdf4}.alert-warning{background-color:#fefcbf;color:#744210;border:1px solid #faf089}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.page-header h1{font-size:22px;font-weight:700;color:var(--color-text)}.page-header .header-actions{display:flex;gap:10px;align-items:center}.filters-bar{display:flex;gap:12px;align-items:center;margin-bottom:20px;flex-wrap:wrap}.filters-bar .search-input{flex:1;min-width:200px;max-width:350px;padding:9px 12px;border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:14px;transition:border-color var(--transition)}.filters-bar .search-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #4a9ec826}.filters-bar select{padding:9px 12px;border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:13px;background:#fff;cursor:pointer;transition:border-color var(--transition)}.filters-bar select:focus{outline:none;border-color:var(--color-primary)}.filters-bar select.filter-active,.filters-bar .search-input.filter-active{border-color:#4a9ec8;box-shadow:0 0 0 2px #4a9ec833}.filters-bar .count{font-size:13px;color:var(--color-text-light);margin-left:auto}.year-tabs{display:flex;gap:4px;margin-bottom:20px}.year-tab{padding:6px 16px;border:1px solid var(--color-border);border-radius:var(--radius-md);background:#fff;cursor:pointer;font-size:13px;font-weight:500;transition:all var(--transition)}.year-tab:hover{border-color:var(--color-primary);color:var(--color-primary)}.year-tab.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.actions{display:flex;gap:4px}.empty-state{text-align:center;padding:60px 20px;color:var(--color-text-light)}.empty-state p{margin-bottom:16px;font-size:15px}.grid{display:grid;gap:20px}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}@media (max-width: 1200px){.grid-4,.grid-3{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.grid-2,.grid-3,.grid-4,.form-row,.form-row-3{grid-template-columns:1fr}.page-header{flex-direction:column;gap:12px;align-items:flex-start}.filters-bar{flex-direction:column}.filters-bar .search-input{max-width:100%}.summary-cards{grid-template-columns:repeat(2,1fr)}}@media (max-width: 480px){.summary-cards{grid-template-columns:1fr}.container{padding:12px}}.text-right{text-align:right}.text-center{text-align:center}.text-muted{color:var(--color-text-light)}.text-success{color:var(--color-success)}.text-danger{color:var(--color-danger)}.text-warning{color:var(--color-warning)}.text-primary{color:var(--color-primary)}.font-bold{font-weight:600}.font-mono{font-family:SF Mono,Fira Code,monospace}.mt-1{margin-top:8px}.mt-2{margin-top:16px}.mb-1{margin-bottom:8px}.mb-2{margin-bottom:16px}.nowrap{white-space:nowrap}.currency{font-variant-numeric:tabular-nums;font-weight:500}.currency.positive{color:var(--color-success)}.currency.negative{color:var(--color-danger)}.inline-edit{display:flex;gap:6px;align-items:center}.inline-edit input{padding:4px 8px;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:13px;width:120px}.detail-header{background:var(--color-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:24px;margin-bottom:24px}.detail-header h1{font-size:22px;font-weight:700;margin-bottom:8px}.detail-header .meta{display:flex;gap:24px;flex-wrap:wrap;color:var(--color-text-light);font-size:13px}.detail-header .meta span{display:flex;align-items:center;gap:4px}.section-title{font-size:16px;font-weight:600;color:var(--color-text);margin-bottom:16px;padding-bottom:8px;border-bottom:2px solid var(--color-primary);display:inline-block}.kpi-section{background:var(--color-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:20px;margin-bottom:20px}.kpi-section h3{font-size:14px;font-weight:600;color:var(--color-text-light);text-transform:uppercase;letter-spacing:.5px;margin-bottom:16px;padding-bottom:8px;border-bottom:1px solid var(--color-border)}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px}.kpi-item{text-align:center;padding:16px;background:var(--color-bg);border-radius:var(--radius-md)}.kpi-item .value{font-size:28px;font-weight:700;color:var(--color-text);line-height:1.2}.kpi-item .label{font-size:12px;color:var(--color-text-light);margin-top:4px}.workload-grid{width:100%;border-collapse:separate;border-spacing:0}.workload-grid th,.workload-grid td{padding:10px 14px;text-align:center;border:1px solid var(--color-border);font-size:13px}.workload-grid th{background:var(--color-sidebar);color:#fff;font-weight:500}.workload-cell{font-weight:600}.workload-cell.critical{background:#e53e3e26;color:var(--color-danger)}.workload-cell.overload{background:#f47b2026;color:var(--color-primary)}.workload-cell.optimal{background:#38a16926;color:var(--color-success)}.workload-cell.underload{background:#d69e2e26;color:var(--color-warning)}.workload-cell.low{background:#e53e3e1a;color:var(--color-danger)}
