/* ===== Design system Portale IT Meditel — "Direzione 2" ===== */
@import url('https://fonts.googleapis.com/css2?family=Figtree:wght@400;500;600;700;800&display=swap');

:root{
  color-scheme: light;
  --navy:#213A64; --navy-hover:#2A4A7F; --navy-dark:#16294A;
  --blue:#2E5BD7; --blue-pill-bg:#E8EEFB; --blue-soft:#8FA9E3; --blue-light:#C5D3F1;
  --green:#17915B; --green-pill-bg:#E2F4EB; --green-dot:#3DD68C;
  --amber:#D99A1B; --amber-text:#B07A12; --amber-pill-bg:#FBF3E0;
  --red:#C2453A; --red-pill-bg:#F9E8E6;
  --ink:#222B3F; --ink-2:#6B7488; --ink-3:#98A1B2; --ink-mid:#36415A;
  --bg:#F2F4F8; --pill-neutral:#EEF1F6; --bd-input:#DDE2EA; --bd-input-2:#D4DAE4;
  --divider:#E8EBF1; --divider-2:#F0F2F6;
  --shadow:0 1px 3px rgba(16,24,40,.07);
  --shadow-hover:0 10px 28px rgba(16,24,40,.13);
}
*{box-sizing:border-box}
body{margin:0;background:var(--bg);color:var(--ink);
  font-family:"Figtree",ui-sans-serif,system-ui,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;-webkit-font-smoothing:antialiased}
a{color:var(--blue);text-decoration:none}
a:hover{text-decoration:underline}

/* topbar condivisa */
.topbar{height:60px;background:var(--navy);display:flex;align-items:center;gap:18px;padding:0 28px;position:sticky;top:0;z-index:100}
.topbar .brand{height:30px;flex:none;display:flex;align-items:center}
.topbar .brand img{height:30px;width:auto;display:block}
.topbar nav{display:flex;gap:4px;align-items:center}
.topbar nav a{color:rgba(255,255,255,.65);font-size:13.5px;font-weight:500;padding:7px 14px;border-radius:8px;text-decoration:none}
.topbar nav a:hover{color:#fff;background:rgba(255,255,255,.08)}
.topbar nav a.active{color:#fff;font-weight:700;background:rgba(255,255,255,.14)}
.topbar nav a.disabled{color:rgba(255,255,255,.4);pointer-events:none}
.topbar .spacer{flex:1}
.topbar .stpill{display:inline-flex;align-items:center;gap:7px;font-size:12.5px;font-weight:600;color:#C9F2DF;
  background:rgba(46,200,130,.16);padding:5px 12px;border-radius:999px}
.topbar .stpill .dot{width:8px;height:8px;border-radius:50%;background:var(--green-dot)}
.topbar .stpill.amber{color:#F4E3BF;background:rgba(217,154,27,.18)}.topbar .stpill.amber .dot{background:var(--amber)}
.topbar .stpill.red{color:#F6D3CF;background:rgba(194,69,58,.2)}.topbar .stpill.red .dot{background:var(--red)}
.topbar .avatar{width:30px;height:30px;border-radius:50%;background:rgba(255,255,255,.16);color:#fff;
  display:flex;align-items:center;justify-content:center;font-size:11.5px;font-weight:700;flex:none}

/* layout pagina */
.page{max-width:1240px;margin:0 auto;padding:34px 28px 48px}
.phead{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:22px}
.phead h1{margin:0;font-size:25px;font-weight:800;color:var(--navy);letter-spacing:-.2px}
.phead .desc{margin:5px 0 0;color:var(--ink-2);font-size:13.5px}
.phead .desc b{color:var(--ink-mid);font-weight:700}
.phead .who{font-size:13px;color:var(--ink-2)}
.phead .who b{color:var(--ink-mid)}

/* card */
.card{background:#fff;border-radius:16px;box-shadow:var(--shadow);padding:18px 20px}
.card.kpi{border-radius:14px}
.card h2{margin:0 0 12px;font-size:14.5px;font-weight:700;color:var(--navy)}
.grid{display:grid;gap:16px}
.g2{grid-template-columns:1fr 1fr}.g3{grid-template-columns:repeat(3,1fr)}.g4{grid-template-columns:repeat(4,1fr)}
@media(max-width:900px){.g2,.g3,.g4{grid-template-columns:1fr}}

/* KPI */
.kpi .lbl{font-size:13px;font-weight:600;color:var(--ink-2)}
.kpi .num{font-size:28px;font-weight:800;color:var(--navy);line-height:1.1;margin-top:3px}
.kpi .num .u{font-size:14px;font-weight:600;color:var(--ink-3)}
.kpi .num.blue{color:var(--blue)} .kpi .num.green{color:var(--green)} .kpi .num.amber{color:var(--amber)} .kpi .num.red{color:var(--red)}
.kpi .sub{font-size:12.5px;font-weight:600;color:var(--green);margin-top:2px}
.kpi .sub.muted{color:var(--ink-3);font-weight:500}

/* pill / badge */
.pill{display:inline-block;font-size:10.5px;font-weight:700;padding:3px 9px;border-radius:999px;text-transform:uppercase;letter-spacing:.02em}
.pill.green{background:var(--green-pill-bg);color:var(--green)}
.pill.grey{background:var(--pill-neutral);color:var(--ink-2)}
.pill.amber{background:var(--amber-pill-bg);color:var(--amber-text)}
.pill.red{background:var(--red-pill-bg);color:var(--red)}
.pill.blue{background:var(--blue-pill-bg);color:var(--blue)}

/* card modulo (home) */
.module{display:block;background:#fff;border-radius:16px;box-shadow:var(--shadow);padding:24px 26px;text-decoration:none;color:inherit;
  transition:box-shadow .15s,transform .15s}
.module:hover{box-shadow:var(--shadow-hover);transform:translateY(-2px);text-decoration:none}
.module h3{margin:0;font-size:17px;font-weight:800;color:var(--navy);display:flex;align-items:center;gap:9px}
.module p{margin:8px 0 0;color:var(--ink-2);font-size:13px;line-height:1.5;min-height:40px}
.module .foot{display:flex;align-items:center;justify-content:space-between;margin-top:14px;padding-top:13px;border-top:1px solid var(--divider-2);font-size:13px}
.module .foot .v{font-weight:700;color:var(--ink-mid)}
.module .foot .open{color:var(--blue);font-weight:700}
.module.soon{opacity:.62;pointer-events:none}

/* tabelle */
table{width:100%;border-collapse:collapse;font-size:13.5px}
th,td{text-align:left;padding:8px;border-bottom:1px solid var(--divider)}
th{color:var(--ink-2);font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.04em}
.muted{color:var(--ink-2);font-size:12.5px}

/* form / bottoni */
input.f,textarea.f,select.f{font:inherit;font-size:14px;padding:11px 14px;border-radius:10px;border:1px solid var(--bd-input);background:#F8F9FB;outline:none;width:100%;color:var(--ink)}
input.f:focus,textarea.f:focus,select.f:focus{border-color:var(--blue);background:#fff}
.btn{font:inherit;font-weight:700;font-size:14px;padding:11px 18px;border-radius:10px;border:1px solid var(--navy);background:var(--navy);color:#fff;cursor:pointer}
.btn:hover{background:var(--navy-hover)}
.btn.sec{background:#fff;color:var(--navy);border-color:var(--bd-input-2)}
.btn.sec:hover{background:#F4F6FA}
.btn.sm{padding:6px 12px;font-size:12.5px;border-radius:8px}

/* segmented (periodo) */
.segmented{display:inline-flex;gap:0;background:#fff;border-radius:10px;padding:4px;box-shadow:var(--shadow)}
.segmented button{font:inherit;font-size:12.5px;font-weight:600;color:#5A6478;background:none;border:none;padding:6px 14px;border-radius:8px;cursor:pointer}
.segmented button.cur{background:var(--navy);color:#fff}

/* barra metrica */
.bar{height:5px;border-radius:3px;background:var(--pill-neutral);overflow:hidden;margin-top:6px}
.bar>i{display:block;height:100%;border-radius:3px;background:var(--green)}
.bar>i.amber{background:var(--amber)} .bar>i.blue{background:var(--blue-light)}

.foot-note{color:var(--ink-3);font-size:12.5px;text-align:center;margin-top:26px}
.banner{display:none;margin:0 0 14px;padding:10px 14px;border-radius:10px;font-size:13px}
.banner.show{display:block}
.banner.info{background:var(--blue-pill-bg);color:#1f3f86;border:1px solid #c7d6f3}
.banner.err{background:var(--red-pill-bg);color:#9a2f26;border:1px solid #f0c3bd}
.banner.ok{background:var(--green-pill-bg);color:#106243;border:1px solid #bfe6cc}
.spin{display:inline-block;width:13px;height:13px;border:2px solid #cdd6e0;border-top-color:var(--navy);border-radius:50%;animation:sp .7s linear infinite;vertical-align:-2px}
@keyframes sp{to{transform:rotate(360deg)}}
