/* Trasparenza 2.0 — foglio di stile principale (look moderno) */
/* Font di sistema (niente chiamate esterne: privacy/GDPR per sito pubblico). */

:root{
  --brand:#c8102e;          /* rosso CNA */
  --brand-dark:#9b0c23;
  --brand-soft:#fdecef;
  --ink:#0f172a;
  --muted:#64748b;
  --line:#e2e8f0;
  --bg:#f1f5f9;
  --card:#ffffff;
  --ok:#059669; --ok-bg:#d1fae5;
  --wait:#d97706; --wait-bg:#fef3c7;
  --no:#dc2626;  --no-bg:#fee2e2;
  --draft:#64748b; --draft-bg:#e2e8f0;
  --radius:14px;
  --shadow:0 1px 2px rgba(15,23,42,.06), 0 8px 24px -12px rgba(15,23,42,.15);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  color:var(--ink);background:var(--bg);line-height:1.55;
  -webkit-font-smoothing:antialiased;
}
a{color:var(--brand);text-decoration:none}
a:hover{text-decoration:underline}

/* Header */
.topbar{
  background:rgba(255,255,255,.85);backdrop-filter:saturate(160%) blur(8px);
  border-bottom:1px solid var(--line);position:sticky;top:0;z-index:20;
}
.topbar .inner{
  max-width:1080px;margin:0 auto;padding:14px 22px;display:flex;
  align-items:center;justify-content:space-between;gap:16px;
}
.brand{display:flex;align-items:center;gap:12px;font-weight:700;color:var(--ink)}
.brand:hover{text-decoration:none}
.brand .mark{
  width:38px;height:38px;border-radius:10px;background:var(--brand);
  color:#fff;display:grid;place-items:center;font-size:18px;font-weight:800;
  box-shadow:0 4px 12px -4px rgba(200,16,46,.6);
}
.brand-logo{height:40px;width:auto;border-radius:8px;display:block}
.brand .name{line-height:1.1}
.brand .name small{display:block;font-weight:500;font-size:11px;color:var(--muted)}
.nav{display:flex;align-items:center;gap:8px}
.nav a{color:var(--muted);padding:8px 12px;border-radius:9px;font-size:14px;font-weight:500}
.nav a:hover{background:var(--bg);color:var(--ink);text-decoration:none}
.nav .who{color:var(--muted);font-size:14px;padding:0 6px}
/* I link/pulsanti .btn nella nav mantengono i colori del bottone (vincono su .nav a) */
.nav a.btn{color:#fff}
.nav a.btn:hover{color:#fff;background:var(--brand-dark)}
.nav a.btn.ghost{color:var(--brand)}
.nav a.btn.neutral{color:var(--ink)}

/* Layout */
.container{max-width:1080px;margin:0 auto;padding:30px 22px 60px}
.page-head{margin-bottom:22px}
.page-head h1{font-size:26px;margin:0 0 4px;letter-spacing:-.02em}
.page-head p{margin:0;color:var(--muted)}

.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow)}
.card.pad{padding:22px}

/* Bottoni */
.btn{
  display:inline-flex;align-items:center;gap:7px;border:1px solid transparent;
  background:var(--brand);color:#fff;padding:10px 18px;border-radius:10px;
  font-size:14px;font-weight:600;cursor:pointer;transition:.15s;text-decoration:none;
}
.btn:hover{background:var(--brand-dark);text-decoration:none;transform:translateY(-1px)}
.btn:active{transform:none}
.btn.ghost{background:#fff;color:var(--brand);border-color:var(--brand)}
.btn.ghost:hover{background:var(--brand-soft)}
.btn.neutral{background:#fff;color:var(--ink);border-color:var(--line)}
.btn.neutral:hover{background:var(--bg)}
.btn.ok{background:var(--ok)}.btn.ok:hover{filter:brightness(.94)}
.btn.warn{background:var(--wait)}.btn.warn:hover{filter:brightness(.94)}
.btn.danger{background:#fff;color:var(--no);border-color:var(--no)}
.btn.danger:hover{background:var(--no-bg)}
.btn.sm{padding:7px 12px;font-size:13px}

/* Search */
.searchbar{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:18px}
.searchbar .campo{flex:1;min-width:240px}
.input,.campo,select.campo{
  width:100%;padding:11px 14px;border:1px solid var(--line);border-radius:10px;
  font-size:14px;font-family:inherit;background:#fff;transition:.15s;color:var(--ink);
}
.input:focus,.campo:focus{outline:none;border-color:var(--brand);
  box-shadow:0 0 0 3px var(--brand-soft)}

/* Tabelle */
.table-wrap{overflow-x:auto;border-radius:var(--radius)}
table{width:100%;border-collapse:collapse;font-size:14px;background:#fff}
thead th{
  text-align:left;padding:12px 14px;background:#f8fafc;border-bottom:1px solid var(--line);
  font-size:11.5px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);font-weight:600;
}
tbody td{padding:13px 14px;border-bottom:1px solid var(--line);vertical-align:middle}
tbody tr:last-child td{border-bottom:none}
tbody tr:hover{background:#fcfdff}
.imp{font-variant-numeric:tabular-nums;font-weight:600;white-space:nowrap}
.company{font-weight:600}
.count{font-size:13px;color:var(--muted);margin:0 2px 10px}

/* Badge di stato */
.pill{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;font-weight:700;
  padding:3px 10px;border-radius:999px;white-space:nowrap;letter-spacing:.02em}
.pill::before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor}
.pill.ok{background:var(--ok-bg);color:var(--ok)}
.pill.wait{background:var(--wait-bg);color:var(--wait)}
.pill.no{background:var(--no-bg);color:var(--no)}
.pill.draft{background:var(--draft-bg);color:var(--draft)}
.tag{font-size:11px;background:#eef2ff;color:#3730a3;padding:1px 8px;border-radius:6px;
  margin-right:4px;font-weight:600}

/* Form a griglia */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-grid .full{grid-column:1/-1}
.form-grid label{display:block;font-size:13px;font-weight:600;margin-bottom:6px;color:#334155}
.help{font-size:12px;color:var(--muted);margin-top:5px}
.check-row{display:flex;gap:10px;align-items:flex-start;background:#f8fafc;
  border:1px solid var(--line);border-radius:10px;padding:12px 14px}
.check-row input{margin-top:3px}
.errorlist{color:var(--no);font-size:12.5px;margin:6px 0 0;padding-left:18px}

/* Note / avvisi */
.note{border-radius:10px;padding:12px 16px;font-size:13.5px;margin:14px 0}
.note.info{background:#eff6ff;border:1px solid #bfdbfe;color:#1e40af}
.note.warn{background:var(--wait-bg);border:1px solid #fcd34d;color:#92400e}
.messages{list-style:none;padding:0;margin:0 0 18px;display:grid;gap:10px}
.messages li{border-radius:10px;padding:12px 16px;font-size:14px;border:1px solid}
.messages li.success{background:var(--ok-bg);border-color:#6ee7b7;color:#065f46}
.messages li.error{background:var(--no-bg);border-color:#fca5a5;color:#991b1b}
.messages li.warning{background:var(--wait-bg);border-color:#fcd34d;color:#92400e}

/* Box CNA di riferimento */
.cna-box{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;margin-top:18px}
.cna-box .h{background:#0f172a;color:#fff;padding:11px 16px;font-size:13.5px;font-weight:600}
.cna-box .c{padding:14px 16px;font-size:14px}

/* Paginazione */
.pager{display:flex;gap:8px;align-items:center;justify-content:center;margin-top:22px;
  font-size:14px;color:var(--muted)}
.pager a{color:var(--brand);border:1px solid var(--line);padding:7px 12px;border-radius:9px}
.pager a:hover{background:var(--brand-soft);text-decoration:none}

/* Empty state */
.empty{text-align:center;padding:50px 20px;color:var(--muted)}
.empty .big{font-size:34px;margin-bottom:6px}

.footer{max-width:1080px;margin:24px auto 0;padding:26px 22px 46px;color:var(--muted);
  font-size:13.5px;border-top:1px solid var(--line)}
.footer .footer-cols{display:flex;flex-wrap:wrap;gap:40px;align-items:flex-start}
.footer .fcol{flex:1;min-width:180px}
.footer .fcol.about{flex:2;min-width:260px}
.footer .fcol h4{margin:0 0 10px;font-size:12px;font-weight:700;text-transform:uppercase;
  letter-spacing:.5px;color:var(--ink)}
.footer .fcol a,.footer .fcol span{display:block;padding:3px 0;color:var(--brand)}
.footer .fcol span{color:var(--muted)}
.footer .fbrand{display:flex;align-items:center;gap:9px;color:var(--ink);font-size:16px;margin-bottom:8px}
.footer .fbrand .mark{width:28px;height:28px;border-radius:8px;background:var(--brand);color:#fff;
  display:grid;place-items:center;font-weight:800;font-size:14px}
.footer .about p{margin:0;line-height:1.6;max-width:420px}
.footer .footer-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;
  gap:8px;margin-top:24px;padding-top:16px;border-top:1px solid var(--line)}
.footer .version{font-family:ui-monospace,Menlo,Consolas,monospace;font-size:12px;opacity:.7}

/* Statistiche / cruscotto */
.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;margin-bottom:20px}
.stat{background:#fff;border:1px solid var(--line);border-radius:14px;padding:18px 20px;box-shadow:var(--shadow)}
.stat .num{font-size:28px;font-weight:700;letter-spacing:-.02em}
.stat .lbl{font-size:13px;color:var(--muted);margin-top:2px}
.stat.accent{background:var(--brand);color:#fff;border-color:var(--brand)}
.stat.accent .lbl{color:rgba(255,255,255,.85)}
.bars{display:flex;flex-direction:column;gap:9px}
.bar-row{display:grid;grid-template-columns:120px 1fr auto;gap:12px;align-items:center;font-size:13px}
.bar-track{background:var(--bg);border-radius:6px;height:20px;overflow:hidden}
.bar-fill{background:var(--brand);height:100%;border-radius:6px;min-width:2px}
.bar-val{font-variant-numeric:tabular-nums;font-weight:600;white-space:nowrap}
.bar-row .muted{font-weight:400;color:var(--muted)}

/* Banner cookie — barra a piena larghezza alla base della pagina (nel flusso) */
.cookie-banner{
  background:#0f172a;color:#e2e8f0;padding:16px 22px;
  display:flex;gap:16px;align-items:center;flex-wrap:wrap;justify-content:center;
}
.cookie-banner .cookie-text{font-size:13.5px;max-width:820px;line-height:1.5}
.cookie-banner a{color:#fca5a5}
/* L'attributo hidden deve avere la precedenza sul display:flex del banner */
.cookie-banner[hidden]{display:none}

@media (max-width:640px){
  .form-grid{grid-template-columns:1fr}
  .nav a{padding:8px 9px}
}
