:root{
  --blu:#1f3a5f; --blu2:#2c5282; --bg:#f4f6f9; --bordo:#dde3ea;
  --testo:#1f2933; --grigio:#6b7785; --rosso:#cc2b2b; --giallo:#e6a700; --verde:#1f8a4c;
}
*{box-sizing:border-box}
body{margin:0;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  background:var(--bg);color:var(--testo);font-size:15px;line-height:1.45}
a{color:var(--blu2);text-decoration:none}
a:hover{text-decoration:underline}

.topbar{background:var(--blu);color:#fff;display:flex;align-items:center;gap:24px;
  padding:0 20px;height:56px;box-shadow:0 1px 4px rgba(0,0,0,.15)}
.brand{font-weight:700;font-size:17px}
.topbar nav{display:flex;gap:6px;flex-wrap:wrap}
.topbar nav a{color:#dbe6f3;padding:8px 12px;border-radius:6px;font-size:14px}
.topbar nav a:hover{background:rgba(255,255,255,.12);color:#fff;text-decoration:none}

.container{max-width:1150px;margin:24px auto;padding:0 18px}
h1{font-size:24px;margin:.2em 0 .6em}
h2.sez{font-size:18px;margin-top:28px;border-bottom:2px solid var(--bordo);padding-bottom:6px}
.sub{color:var(--grigio);font-size:13.5px;margin:.2em 0 1em}
.vuoto{color:var(--grigio);padding:14px;background:#fff;border:1px dashed var(--bordo);border-radius:8px}
.vuoto.small{padding:8px 12px;font-size:13px;margin:6px 0}

.riga-titolo{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px}
.toolbar{display:flex;gap:8px;flex-wrap:wrap}

.cards{display:flex;gap:14px;flex-wrap:wrap;margin:18px 0}
.card{background:#fff;border:1px solid var(--bordo);border-radius:10px;padding:16px 20px;min-width:130px;
  box-shadow:0 1px 3px rgba(0,0,0,.04)}
.card .num{font-size:30px;font-weight:700;color:var(--blu)}
.card .lbl{color:var(--grigio);font-size:13px}
.alert-card{background:#fff5f5;border-color:#f3c0c0}.alert-card .num{color:var(--rosso)}
.warn-card{background:#fffaf0;border-color:#f0dca8}.warn-card .num{color:var(--giallo)}

.tab{width:100%;border-collapse:collapse;background:#fff;border:1px solid var(--bordo);
  border-radius:10px;overflow:hidden;margin:8px 0 18px}
.tab th{background:var(--blu);color:#fff;text-align:left;padding:10px 12px;font-size:13px;font-weight:600}
.tab td{padding:9px 12px;border-top:1px solid var(--bordo);font-size:14px}
.tab tbody tr:hover{background:#f8fafc}
.tab .note{color:var(--grigio);font-size:13px}
.tab-form th{background:#5a6b80}
.riga-scaduto{background:#ffe9e9 !important}
.riga-scadenza{background:#fff6e0 !important}

.azioni{white-space:nowrap;text-align:right}
.link{background:none;border:none;color:var(--blu2);cursor:pointer;font-size:13.5px;padding:2px 6px}
.link:hover{text-decoration:underline}
.link.danger{color:var(--rosso)}

.btn{display:inline-block;background:#fff;border:1px solid var(--bordo);color:var(--testo);
  padding:8px 14px;border-radius:7px;cursor:pointer;font-size:14px;text-decoration:none}
.btn:hover{background:#eef2f7;text-decoration:none}
.btn-primary{background:var(--blu);color:#fff;border-color:var(--blu)}
.btn-primary:hover{background:var(--blu2)}
.btn:disabled{opacity:.5;cursor:not-allowed}

.badge{display:inline-block;padding:2px 9px;border-radius:20px;font-size:12px;background:#e6ebf1;color:#445}
.badge.ok{background:#e3f5ea;color:var(--verde)}
.badge.warn{background:#fef0cf;color:#9a7400}
.badge.bad{background:#fbdada;color:var(--rosso)}

.info-azienda{display:flex;gap:18px;flex-wrap:wrap;color:var(--grigio);font-size:13.5px;margin-bottom:10px}
.lav-box{background:#fff;border:1px solid var(--bordo);border-radius:10px;padding:14px 16px;margin:12px 0}
.lav-head{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px}
.mansione{background:#eef2f7;color:#556;padding:1px 8px;border-radius:12px;font-size:12px;margin-left:8px}
.cf{color:var(--grigio);font-size:12px;margin-left:8px}

.alert{padding:11px 16px;border-radius:8px;margin-bottom:14px;font-size:14px}
.alert-ok{background:#e3f5ea;color:#176638;border:1px solid #b7e3c8}
.alert-err{background:#fbe4e4;color:#8a1f1f;border:1px solid #f0bcbc}

/* Modale */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:50;
  align-items:flex-start;justify-content:center;padding:40px 16px;overflow:auto}
.modal-overlay.show{display:flex}
.modal{background:#fff;border-radius:12px;padding:22px 24px;width:100%;max-width:560px;
  box-shadow:0 12px 40px rgba(0,0,0,.25)}
.modal h2{margin-top:0}
.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:18px}

label{display:block;margin:10px 0;font-size:13.5px;font-weight:600;color:#3a4654}
input,select,textarea{width:100%;padding:9px 11px;border:1px solid var(--bordo);border-radius:7px;
  font-size:14px;margin-top:4px;font-family:inherit;font-weight:400;color:var(--testo);background:#fff}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--blu2);box-shadow:0 0 0 3px rgba(44,82,130,.12)}
textarea{min-height:60px;resize:vertical}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:0 14px}
.form-impostazioni{background:#fff;border:1px solid var(--bordo);border-radius:10px;padding:8px 22px 22px;max-width:760px}
code{background:#eef2f7;padding:1px 5px;border-radius:4px;font-size:13px}

footer{text-align:center;color:var(--grigio);font-size:12.5px;padding:24px}
@media(max-width:560px){.grid2{grid-template-columns:1fr}.topbar{height:auto;padding:8px 12px;flex-direction:column;align-items:flex-start;gap:6px}}

/* Competenze raggruppate (base + aggiornamenti) */
.competenze{margin-top:8px}
.comp{border:1px solid var(--bordo);border-radius:8px;margin:8px 0;overflow:hidden}
.comp-head{display:flex;justify-content:space-between;align-items:center;gap:10px;
  padding:8px 12px;background:#eef2f7;flex-wrap:wrap}
.comp-nome{font-weight:600;color:var(--blu)}
.comp .tab-form{margin:0;border:none;border-radius:0}
.comp .tab-form td{border-top:1px solid #eceff3}
.evento-superato td{color:#9aa5b1;background:#fbfcfd}
.superato-lbl{font-size:12px;font-style:italic;color:#9aa5b1}

/* Avviso ore insufficienti e suggerimenti */
.alert-warn{background:#fff3cd;color:#856404;border:1px solid #ffe69c}
.ore-warn{color:#9a7400;background:#fef0cf;border-radius:10px;padding:0 7px;font-size:11px;margin-left:4px;white-space:nowrap}
.hint{display:block;color:var(--grigio);font-weight:400;font-size:12px;margin-top:3px}

/* Editor firma email */
.editor-toolbar{display:flex;gap:4px;align-items:center;flex-wrap:wrap;margin:4px 0;
  border:1px solid var(--bordo);border-bottom:none;border-radius:7px 7px 0 0;padding:6px 8px;background:#f7f9fb}
.editor-toolbar button{background:#fff;border:1px solid var(--bordo);border-radius:5px;
  width:32px;height:30px;cursor:pointer;font-size:13px}
.editor-toolbar button:hover{background:#eef2f7}
.editor-toolbar button[onclick*="Link"],.editor-toolbar button[onclick*="Clear"]{width:auto;padding:0 8px}
.editor-toolbar input[type=color]{width:34px;height:30px;border:1px solid var(--bordo);border-radius:5px;padding:1px;cursor:pointer}
.firma-editor{border:1px solid var(--bordo);border-radius:0 0 7px 7px;min-height:120px;
  padding:10px 12px;background:#fff;font-size:14px;overflow:auto}
.firma-editor:focus{outline:none;border-color:var(--blu2);box-shadow:0 0 0 3px rgba(44,82,130,.12)}

/* Login e barra utente */
.nav-user{color:#dbe6f3;font-size:13px;margin-left:10px;opacity:.85}
.login-body{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--blu)}
.login-card{background:#fff;border-radius:14px;padding:30px 32px;width:100%;max-width:360px;
  box-shadow:0 16px 50px rgba(0,0,0,.3)}
.login-brand{font-size:20px;font-weight:700;color:var(--blu);text-align:center;margin-bottom:18px}
.check{display:flex;align-items:center;gap:8px;font-weight:400}
.check input{width:auto;margin:0}
