/* ============================================================
   Stili condivisi DEMO — palette e componenti della piattaforma ARIA
   (ripresi da app-commesse per coerenza visiva)
   ============================================================ */
:root{
  /* Palette ARIA — allineata al sito (assets/css/styles.css del sito) */
  --bg:#F5F7FA;--panel:#fff;--ink:#16203A;--muted:#6B7689;--line:#E6EAF1;
  --brand:#011F4F;--brand-d:#0A2E66;--brand-900:#01163a;--accent:#0693E3;--steel:#B5C4DB;
  --green:#0a8f5b;--green-brand:#00D084;--amber:#f59e0b;--red:#dc2626;--slate:#5A5A5A;
  --shadow:0 1px 3px rgba(1,31,79,.06),0 1px 2px rgba(1,31,79,.05);
  --shadow-lg:0 12px 34px rgba(1,31,79,.12);
  --radius:12px;
  --ring:rgba(6,147,227,.28);   /* anello di focus, blu ARIA */
  --f-head:'Ubuntu',system-ui,sans-serif;
  --f-body:'Inter',system-ui,-apple-system,sans-serif;
}
*{box-sizing:border-box}
:root{accent-color:var(--accent)}   /* checkbox, date picker, ecc. nativi */
body{margin:0;font-family:var(--f-body);background:var(--bg);color:var(--ink);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
h1,h2,h3,h4{font-family:var(--f-head);letter-spacing:-.01em}
a{color:var(--accent)}

/* ---- focus & placeholder: ogni controllo ha uno stato di focus chiaro ---- */
::placeholder{color:var(--muted);opacity:1}                                   /* contrasto leggibile, non grigio slavato */
button:focus-visible,.btn:focus-visible,a:focus-visible,.tabs .tab:focus-visible,.nav a:focus-visible,[tabindex]:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:6px}

/* header */
header.app{background:var(--brand);color:#fff;position:sticky;top:0;z-index:30}
.bar{max-width:1320px;margin:0 auto;padding:12px 18px;display:flex;align-items:center;gap:1.5rem;flex-wrap:wrap}
.logo .lbl{color:#fff;font-weight:700;font-size:1.1rem;font-family:var(--f-head);letter-spacing:.01em}
.spacer{flex:1}
.nav{display:flex;align-items:center;gap:1.1rem;flex-wrap:wrap}
.nav a{text-decoration:none;color:#cfe3f7;font-size:.95rem;font-weight:400}
.nav a:hover{color:#fff}
.nav a.active{color:#fff;font-weight:700}
.nav .newbtn{background:var(--accent);color:#fff;padding:.4rem .9rem;border-radius:999px;cursor:pointer;font-weight:600}
.nav .newbtn:hover{background:#0a7fc4}
.badge.demo{background:#fff7ed;color:#b45309;border:1px solid #fed7aa;font-size:12px;padding:4px 10px;border-radius:999px;font-weight:700}

/* buttons */
button,.btn{font:inherit;cursor:pointer;border:1px solid var(--line);background:#fff;color:var(--ink);padding:8px 13px;border-radius:9px;font-weight:600;display:inline-flex;align-items:center;gap:7px;transition:.15s}
button:hover,.btn:hover{background:#f8fafc}
.btn.primary{background:var(--accent);border-color:var(--accent);color:#fff}.btn.primary:hover{background:var(--brand-d)}
.btn.green{background:var(--green);border-color:var(--green);color:#fff}.btn.green:hover{background:#097a4d;border-color:#097a4d}
.btn.ghost{border-color:transparent;background:transparent}
.btn.danger{color:var(--red);border-color:#fecaca}.btn.danger:hover{background:#fef2f2}
.btn.danger.solid{background:var(--red);border-color:var(--red);color:#fff}.btn.danger.solid:hover{background:#b91c1c;border-color:#b91c1c}
.btn.sm{padding:5px 9px;font-size:12.5px}
.btn:disabled{opacity:.5;cursor:not-allowed}
button:active:not(:disabled),.btn:active:not(:disabled){transform:translateY(1px)}
@media (prefers-reduced-motion: reduce){*{transition-duration:.01ms!important;animation-duration:.01ms!important}}

main{max-width:1320px;margin:0 auto;padding:26px 22px}

/* stat cards */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}
.stat{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:17px 18px;box-shadow:var(--shadow)}
.stat .k{font-size:12px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.03em}
.stat .v{font-size:27px;font-weight:800;margin-top:6px;letter-spacing:-.01em}
.stat.b .v{color:var(--brand)}.stat.r .v{color:var(--red)}.stat.g .v{color:var(--green)}.stat.a .v{color:var(--amber)}

/* tabs */
.tabs{display:flex;gap:6px;margin-bottom:18px;border-bottom:2px solid var(--line)}
.tabs .tab{padding:10px 18px;border:0;background:none;border-bottom:3px solid transparent;border-radius:0;color:var(--muted);font-weight:700;margin-bottom:-2px}
.tabs .tab:hover{background:none;color:var(--ink)}
.tabs .tab.active{color:var(--brand);border-bottom-color:var(--accent)}
.tabs .tab .cnt{font-size:11px;background:#eef1f6;color:var(--slate);border-radius:999px;padding:1px 8px;margin-left:6px;font-weight:700}

/* toolbar */
.toolbar{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-bottom:18px}
.search{flex:1;min-width:200px;position:relative}
.search input{width:100%;padding:9px 12px 9px 34px;border:1px solid var(--line);border-radius:9px;font:inherit}
.search svg{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--muted)}
select.filter{padding:9px 11px;border:1px solid var(--line);border-radius:9px;font:inherit;background:#fff}

/* table */
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}
table{width:100%;border-collapse:collapse}
thead th{text-align:left;font-size:11.5px;text-transform:uppercase;letter-spacing:.03em;color:var(--muted);font-weight:700;padding:12px 16px;border-bottom:1px solid var(--line);background:#fafbfc;white-space:nowrap}
tbody td{padding:12px 16px;border-bottom:1px solid var(--line);vertical-align:middle}
tbody tr:last-child td{border-bottom:none}
tbody tr:hover{background:#fafbff}
tbody tr.part{background:#fffbeb}tbody tr.part:hover{background:#fef6da}
tbody tr.done{background:#f6fdf9}
.azienda{font-weight:700}
.sub{color:var(--muted);font-size:12.5px}
.mono{font-family:ui-monospace,Menlo,Consolas,monospace;font-size:12.5px}
.right{text-align:right}.nowrap{white-space:nowrap}

/* ---- Vocabolario etichette ----
   Due famiglie coerenti:
   • PILL (999px): classificazione/categoria e conteggi (.pill, .cnt)
   • TAG di STATO (rounded-rect 7px): indicatori di stato (.tag-icim, .tag-off, .tag-fatt, .quota .st, .tag-move)
   Metriche condivise: 11px / 700, padding 3px 8-10px, line-height 1.4. */
.pill{font-size:11px;font-weight:700;padding:3px 10px;border-radius:999px;white-space:nowrap;display:inline-flex;align-items:center;line-height:1.4}
.pill.scip{background:#eef2ff;color:#4338ca}.pill.cons{background:#e6f6fe;color:#0a6ba0}.pill.form{background:#fdf2f8;color:#a21caf}.pill.altro{background:#eef1f6;color:var(--slate)}
.pill.persa{background:#fef2f2;color:#b91c1c}
.tag-icim{font-size:11px;font-weight:700;color:#7c2d12;background:#ffedd5;border:1px solid #fed7aa;padding:3px 8px;border-radius:7px;margin-left:6px;white-space:nowrap;display:inline-flex;align-items:center;line-height:1.4}
.tag-off{font-size:11px;font-weight:700;color:#047857;background:#ecfdf5;border:1px solid #a7f3d0;padding:3px 8px;border-radius:7px;margin-left:6px;display:inline-flex;align-items:center;line-height:1.4}

/* fatturazione progress */
.prog{display:flex;align-items:center;gap:8px;min-width:150px}
.prog .track{flex:1;height:8px;background:#eef2f7;border-radius:99px;overflow:hidden}
.prog .fill{height:100%;border-radius:99px}
.prog .pct{font-size:12px;font-weight:700;width:38px;text-align:right}
.resid{font-size:11.5px;font-weight:700;margin-top:2px}
.resid.part{color:var(--amber)}.resid.done{color:var(--green)}.resid.zero{color:var(--muted)}

/* modal */
.overlay{position:fixed;inset:0;background:rgba(15,23,42,.45);display:none;align-items:flex-start;justify-content:center;z-index:50;padding:24px;overflow:auto}
.overlay.open{display:flex}
.modal{background:#fff;border-radius:14px;width:100%;max-width:680px;box-shadow:0 20px 60px rgba(0,0,0,.25)}
.modal.wide{max-width:920px}
.modal header{padding:16px 20px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between}
.modal header h2{margin:0;font-size:18px;color:var(--brand)}
.modal .body{padding:18px 20px}
.modal footer{padding:14px 20px;border-top:1px solid var(--line);display:flex;justify-content:flex-end;gap:10px;flex-wrap:wrap}
.form{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.field{display:flex;flex-direction:column;gap:5px}.field.full{grid-column:1/-1}
.field label{font-size:12.5px;font-weight:600;color:var(--slate)}
.field input,.field select,.field textarea{padding:9px 11px;border:1px solid var(--line);border-radius:9px;font:inherit;background:#fff;width:100%}
.field textarea{resize:vertical;min-height:64px}
.field .hint{font-size:11.5px;color:var(--muted)}

/* lista SAL / voci */
.sublist{margin:6px 0 0;border:1px solid var(--line);border-radius:9px;overflow:hidden}
.sublist .it{display:flex;align-items:center;gap:10px;padding:8px 11px;border-bottom:1px solid var(--line);font-size:13px}
.sublist .it:last-child{border-bottom:none}
.sublist .it .grow{flex:1}
.sublist .empty{padding:12px;color:var(--muted);text-align:center;font-size:13px}

.empty{padding:56px 20px;text-align:center;color:var(--muted)}.empty h3{color:var(--ink);margin:0 0 6px}

/* toast */
.toast{position:fixed;bottom:20px;left:50%;transform:translateX(-50%);background:#1f2a37;color:#fff;padding:11px 18px;border-radius:10px;font-weight:600;box-shadow:0 8px 24px rgba(0,0,0,.25);z-index:80;opacity:0;transition:.2s;pointer-events:none;max-width:90vw}
.toast.show{opacity:1}
.toast.err{background:#b91c1c}

@media(max-width:880px){.stats{grid-template-columns:repeat(2,1fr)}.form{grid-template-columns:1fr}.nav{gap:.7rem}.hide-sm{display:none}}

/* Anello di focus dei campi — in fondo al file: pari specificità dei base
   .field input / .search input, quindi vince per ordine sorgente. */
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--ring)}
