.profilo-page{max-width:900px}.profilo-grid{display:grid;gap:20px}.profilo-card{background:#fff;border-radius:10px;box-shadow:0 2px 8px #00000014}.profilo-card .card-header{font-size:1rem;font-weight:600;color:var(--gray-700)}.profilo-card .card-body{padding:24px}.user-info-display{display:flex;align-items:center;gap:20px}.user-avatar-large{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);color:#fff;display:flex;align-items:center;justify-content:center;font-size:2rem;font-weight:600}.user-info-details h3{margin:0 0 4px;font-size:1.25rem;color:var(--gray-900)}.user-info-details .user-email{margin:0 0 8px;color:var(--gray-500)}.badge-admin{background:var(--primary);color:#fff}.badge-tecnico{background:var(--success);color:#fff}.badge-cliente{background:var(--info);color:#fff}.profilo-card .form-group{margin-bottom:16px}.profilo-card .form-group label{display:block;margin-bottom:6px;font-weight:500;color:var(--gray-700);font-size:.9rem}.profilo-card .form-control{width:100%;padding:10px 12px;border:1px solid var(--gray-300);border-radius:6px;font-size:.95rem;transition:border-color .2s,box-shadow .2s}.profilo-card .form-control:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #0077b61a}.profilo-card .btn{margin-top:8px}.alert{padding:12px 16px;border-radius:6px;margin-bottom:16px;font-size:.9rem}.alert-success{background-color:#d4edda;color:#155724;border:1px solid #c3e6cb}.alert-error{background-color:#f8d7da;color:#721c24;border:1px solid #f5c6cb}@media (min-width: 768px){.profilo-grid{grid-template-columns:repeat(2,1fr)}.profilo-card:first-child{grid-column:1 / -1}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1976d2,#64b5f6)}.login-card{background:#fff;padding:40px;border-radius:10px;box-shadow:0 10px 40px #0003;width:100%;max-width:400px}.login-card h1{text-align:center;color:#333;margin-bottom:10px}.login-title{display:flex;align-items:center;justify-content:center;gap:8px;font-size:2rem}.login-subtitle{text-align:center;color:#666;margin-bottom:30px}.login-card .form-group{margin-bottom:20px}.login-card .form-group label{display:block;margin-bottom:8px;font-weight:500;color:#333}.login-card .form-group input{width:100%;padding:12px;border:1px solid #ddd;border-radius:6px;font-size:1rem;transition:border-color .2s;box-sizing:border-box}.login-card .form-group input:focus{outline:none;border-color:#1976d2;box-shadow:0 0 0 3px #1976d21a}.btn-block{width:100%;margin-top:10px;padding:12px;font-size:1rem;font-weight:600;border:none;border-radius:6px;cursor:pointer;transition:background-color .2s}.btn-primary{background-color:#1976d2;color:#fff}.btn-primary:hover:not(:disabled){background-color:#1565c0}.btn-primary:disabled{background-color:#90caf9;cursor:not-allowed}.alert{padding:12px 16px;border-radius:6px;margin-bottom:20px}.alert-error{background-color:#ffebee;color:#c62828;border:1px solid #ef9a9a}*{margin:0;padding:0;box-sizing:border-box}:root{--primary: #0077b6;--primary-dark: #005f8a;--dnv-color: #0077b6;--sgs-color: #f5a623;--kiwa-color: #dc3545;--success: #28a745;--warning: #ffc107;--danger: #dc3545;--info: #17a2b8;--gray-100: #f8f9fa;--gray-200: #e9ecef;--gray-300: #dee2e6;--gray-500: #6c757d;--gray-700: #495057;--gray-900: #212529}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;background-color:var(--gray-100);color:var(--gray-900);line-height:1.5}.app-container{display:flex;flex-direction:column;min-height:100vh}.navbar{display:flex;align-items:center;justify-content:space-between;background:linear-gradient(90deg,var(--primary) 0%,var(--primary-dark) 100%);color:#fff;padding:0 20px;height:56px;position:sticky;top:0;z-index:100;box-shadow:0 2px 4px #0000001a}.navbar-brand{display:flex;align-items:center;gap:10px}.navbar-brand h1{font-size:1.25rem;font-weight:600;margin:0}.navbar-nav{display:flex;align-items:center;gap:4px}.navbar-nav a{display:flex;align-items:center;gap:6px;padding:8px 14px;color:#ffffffd9;text-decoration:none;border-radius:6px;font-size:.9rem;font-weight:500;transition:all .2s}.navbar-nav a:hover{background:#ffffff26;color:#fff}.navbar-nav a.active{background:#fff3;color:#fff}.navbar-user{display:flex;align-items:center;gap:12px}.navbar-user .user-info{display:flex;align-items:center;gap:8px}.navbar-user .user-avatar{width:32px;height:32px;border-radius:50%;background:#fff3;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.9rem}.navbar-user .user-name{font-size:.85rem;font-weight:500}.main-content{flex:1;padding:20px 24px}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;position:sticky;top:56px;z-index:90;background-color:var(--gray-100);padding:12px 0;margin-top:-12px}.page-header h2{font-size:1.5rem;color:var(--gray-700)}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border:none;border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dark)}.btn-success{background:var(--success);color:#fff}.btn-danger{background:var(--danger);color:#fff}.btn-secondary{background:var(--gray-500);color:#fff}.btn-sm{padding:4px 10px;font-size:.8rem}.card{background:#fff;border-radius:10px;box-shadow:0 2px 8px #00000014;overflow:hidden}.card-header{padding:16px 20px;border-bottom:1px solid var(--gray-200);font-weight:600}.card-body{padding:20px}.table-container{overflow:auto;max-height:calc(100vh - 200px)}table{width:100%;border-collapse:collapse;font-size:.85rem}th,td{padding:6px 8px;text-align:left;border-bottom:1px solid var(--gray-200)}th{background:#e3f2fd;font-weight:600;color:var(--gray-700);white-space:nowrap;position:sticky;top:0;z-index:10}th.col-narrow,td.col-narrow{padding:6px 4px;text-align:center;width:40px;min-width:40px}th.col-ragione,td.col-ragione{min-width:200px}th.col-icon,td.col-icon{width:30px;text-align:center;cursor:default}tr:hover{background:var(--gray-100)}tr.month-separator{background:var(--gray-200)}tr.month-separator td{font-weight:600;color:var(--gray-700);padding:8px 12px;font-size:.85rem;text-transform:uppercase;letter-spacing:.5px}tr.month-separator:hover{background:var(--gray-200)}.badge{display:inline-block;padding:3px 8px;border-radius:4px;font-size:.75rem;font-weight:600}.badge-dnv,.badge-sgs,.badge-kiwa{min-width:50px;text-align:center}.badge-dnv{background:var(--dnv-color);color:#fff}.badge-sgs{background:var(--sgs-color);color:#fff}.badge-kiwa{background:var(--kiwa-color);color:#fff}.badge-success{background:#d4edda;color:#155724}.badge-warning{background:#fff3cd;color:#856404}.badge-danger{background:#f8d7da;color:#721c24}.badge-info{background:#d1ecf1;color:#0c5460}.form-group{margin-bottom:16px}.form-group label{display:block;margin-bottom:6px;font-weight:500;color:var(--gray-700)}.form-control{width:100%;padding:8px 12px;border:1px solid var(--gray-300);border-radius:6px;font-size:.9rem;transition:border-color .2s}.form-control:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #0077b61a}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.form-check{display:flex;align-items:center;gap:8px}.form-check input[type=checkbox]{width:18px;height:18px}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal{background:#fff;border-radius:10px;width:90%;max-width:700px;max-height:90vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--gray-200)}.modal-header h3{margin:0}.modal-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--gray-500)}.modal-body{padding:20px}.modal-footer{padding:16px 20px;border-top:1px solid var(--gray-200);display:flex;justify-content:flex-end;gap:10px}.filters{display:flex;gap:12px;margin-bottom:20px;flex-wrap:wrap}.filters .form-control{width:auto;min-width:150px}.totali-container{display:flex;align-items:center;gap:8px;margin-left:auto}.totale-item{padding:6px 10px;background:#fff;border:1px solid var(--gray-300);border-radius:6px;font-size:.85rem;font-weight:600}.totale-finale{background:var(--gray-700);color:#fff;border-color:var(--gray-700)}.status-in-attesa-da-la,.status-da-pianificare,.status-pianificato,.status-in-corso,.status-in-commissione,.status-nc1-aperta,.status-completato{white-space:nowrap}.status-in-attesa-da-la{background:#fff3cd;color:#856404}.status-da-pianificare{background:#dc3545;color:#fff}.status-pianificato{background:#ffc107;color:#212529}.status-in-corso{background:#fff3cd;color:#856404}.status-in-commissione{background:#90ee90;color:#155724}.status-nc1-aperta{background:#fd7e14;color:#fff}.status-completato{background:#28a745;color:#fff}.badge-cds-rosso{background:#dc3545;color:#fff;white-space:nowrap}.badge-cds-giallo{background:#ffc107;color:#212529;white-space:nowrap}.badge-cds-verde{background:#d4edda;color:#155724;white-space:nowrap}.indicator{display:inline-block;padding:2px 8px;border-radius:3px;font-size:.75rem;font-weight:600}.indicator-yes{background:#d4edda;color:#155724}.indicator-no{background:#f8d7da;color:#721c24}.btn-cliente-link{background:none;border:none;cursor:pointer;color:var(--gray-500);padding:2px;border-radius:3px;display:inline-flex;align-items:center;flex-shrink:0;transition:color .2s}.btn-cliente-link:hover{color:var(--primary)}.actions{display:flex;gap:6px}.btn-logout{background:#ffffff1a;border:none;color:#fff;padding:8px;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.btn-logout:hover{background:#fff3}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:16px;color:var(--gray-500)}.loading-spinner{width:40px;height:40px;border:3px solid var(--gray-200);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.inline-select{padding:3px 16px 3px 6px;border:1px solid transparent;border-radius:4px;font-size:.75rem;font-weight:600;cursor:pointer;background-color:inherit;color:inherit;appearance:none;-webkit-appearance:none;-moz-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='8' height='8' viewBox='0 0 8 8'%3E%3Cpath fill='%23666' d='M0 2l4 4 4-4z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 4px center;min-width:90px}.inline-select:hover{border-color:var(--gray-300)}.inline-select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px #0077b633}.inline-select-small{min-width:70px}select.status-in-attesa-da-la{background-color:#fff3cd;color:#856404}select.status-da-pianificare{background-color:#dc3545;color:#fff}select.status-pianificato{background-color:#ffc107;color:#212529}select.status-in-corso{background-color:#fff3cd;color:#856404}select.status-in-commissione{background-color:#90ee90;color:#155724}select.status-nc1-aperta{background-color:#fd7e14;color:#fff}select.status-completato{background-color:#28a745;color:#fff}select.indicator-yes{background-color:#d4edda;color:#155724}select.indicator-no{background-color:#f8d7da;color:#721c24}select.badge-cds-rosso{background-color:#dc3545;color:#fff}select.badge-cds-giallo{background-color:#ffc107;color:#212529}select.badge-cds-verde{background-color:#d4edda;color:#155724}@media (max-width: 768px){.navbar{flex-wrap:wrap;height:auto;padding:10px 16px;gap:10px}.navbar-nav{order:3;width:100%;justify-content:center;flex-wrap:wrap}.navbar-nav a{padding:6px 10px;font-size:.8rem}.navbar-user .user-name{display:none}.main-content{padding:16px}}
