:root {
  --blu:#1F4E79;--blu-l:#E6F1FB;--blu-m:#185FA5;
  --verde:#0F6E56;--verde-l:#E1F5EE;
  --rosso:#A32D2D;--rosso-l:#FCEBEB;
  --grigio:#5F5E5A;--grigio-l:#F1EFE8;
  --bordo:#BFBFBF;--testo:#1a1a1a;--sfondo:#f8f8f6;--b:#fff;--r:6px;
}
*{box-sizing:border-box;margin:0;padding:0;}
body{font-family:'Segoe UI',system-ui,sans-serif;font-size:13px;background:var(--sfondo);color:var(--testo);}

/* ── HEADER ── */
header{background:var(--blu);color:#fff;padding:11px 20px;display:flex;align-items:center;justify-content:space-between;}
header h1{font-size:15px;font-weight:600;}
.hdr-r{display:flex;align-items:center;gap:12px;}
.hdr-stat{font-size:11px;opacity:.75;}
.admin-btn{padding:4px 12px;background:rgba(255,255,255,.15);border:none;border-radius:20px;color:#fff;cursor:pointer;font-size:12px;font-weight:600;}
.admin-btn:hover{background:rgba(255,255,255,.25);}

/* ── LAYOUT ── */
.main{padding:13px;display:flex;flex-direction:column;gap:11px;}

/* ── FILTRI ── */
.filtri-card{background:var(--b);border:1px solid var(--bordo);border-radius:var(--r);padding:12px;}
.filtri-grid{display:flex;flex-wrap:wrap;gap:8px;align-items:flex-end;}
.filtri-grid label{font-size:11px;color:var(--grigio);display:block;margin-bottom:3px;}
.filtri-grid input,.filtri-grid select{padding:5px 8px;border:1px solid var(--bordo);border-radius:4px;font-size:12px;background:var(--b);}
.filtri-grid input:focus,.filtri-grid select:focus{outline:none;border-color:var(--blu-m);}
.btn-cerca{padding:6px 16px;background:var(--blu);color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:12px;font-weight:600;}
.btn-cerca:hover{opacity:.85;}
.btn-reset{padding:6px 12px;background:none;border:1px solid var(--bordo);border-radius:4px;cursor:pointer;font-size:12px;color:var(--grigio);}
.btn-reset:hover{background:var(--grigio-l);}
.tag-filter-wrap{display:flex;flex-wrap:wrap;gap:5px;align-items:center;}
.tag-pill-filter{padding:3px 10px;border-radius:12px;font-size:11px;font-weight:600;cursor:pointer;border:2px solid transparent;opacity:.5;transition:opacity .15s,border-color .15s;}
.tag-pill-filter.sel{opacity:1;border-color:rgba(0,0,0,.25);}

/* ── TABELLA ── */
.table-card{background:var(--b);border:1px solid var(--bordo);border-radius:var(--r);overflow:hidden;}
.tb-top{padding:9px 13px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--bordo);}
.tb-count{font-size:12px;color:var(--grigio);}
table{width:100%;border-collapse:collapse;}
th{background:var(--blu);color:#fff;padding:7px 10px;text-align:left;font-size:11px;font-weight:600;white-space:nowrap;}
th.sortable{cursor:pointer;user-select:none;}
th.sortable:hover{background:var(--blu-m);}
.sort-icon{opacity:.4;font-size:10px;margin-left:3px;}
.sort-icon.active{opacity:1;}
td{padding:6px 10px;border-bottom:1px solid #f0f0f0;font-size:12px;vertical-align:middle;}
tr:last-child td{border-bottom:none;}
tr:hover td{background:var(--blu-l);cursor:pointer;}
.td-cf{font-family:monospace;font-size:10px;color:var(--grigio);}
.td-cf-link{cursor:pointer;text-decoration:underline dotted;color:var(--blu-m);}
.td-cf-link:hover{color:var(--blu);}
.modal-wide{width:900px;}
.td-data{white-space:nowrap;font-size:11px;color:var(--grigio);}
.td-oggetto{max-width:260px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.td-note{max-width:180px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-style:italic;color:var(--grigio);}
.empty{padding:36px;text-align:center;color:var(--grigio);}
.tag-pill{display:inline-block;padding:2px 8px;border-radius:10px;font-size:10px;font-weight:600;margin:1px 2px;}
.stato-pill{display:inline-block;padding:2px 9px;border-radius:10px;font-size:10px;font-weight:600;}

/* ── MODALE NOTA ── */
.modal-bg{display:none;position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:1000;align-items:flex-start;justify-content:center;padding-top:40px;}
.modal-bg.open{display:flex;}
.modal{background:var(--b);border-radius:var(--r);width:620px;max-width:96vw;max-height:88vh;
       display:flex;flex-direction:column;border:1px solid var(--bordo);overflow:hidden;}
.modal-header{background:var(--blu);color:#fff;padding:13px 18px;display:flex;align-items:center;justify-content:space-between;}
.modal-header h2{font-size:14px;font-weight:600;margin:0;}
.modal-close{background:none;border:none;color:#fff;font-size:18px;cursor:pointer;opacity:.8;}
.modal-close:hover{opacity:1;}
.modal-body{padding:18px;overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:14px;}
.modal-info{background:var(--grigio-l);border-radius:4px;padding:10px 12px;font-size:12px;display:grid;grid-template-columns:auto 1fr;gap:4px 12px;}
.modal-info .lbl{font-size:10px;color:var(--grigio);font-weight:600;text-transform:uppercase;align-self:center;}
.modal-info .val{font-size:12px;word-break:break-word;}
.modal-section-title{font-size:10px;font-weight:700;color:var(--grigio);text-transform:uppercase;letter-spacing:.6px;margin-bottom:6px;}
textarea{width:100%;padding:8px;border:1px solid var(--bordo);border-radius:4px;font-size:12px;font-family:inherit;resize:vertical;min-height:80px;}
textarea:focus{outline:none;border-color:var(--blu-m);}
.tags-edit{display:flex;flex-wrap:wrap;gap:6px;}
.tag-toggle{padding:4px 12px;border-radius:12px;font-size:11px;font-weight:600;cursor:pointer;border:2px solid transparent;opacity:.45;transition:all .15s;}
.tag-toggle.sel{opacity:1;border-color:rgba(0,0,0,.2);}
.stato-edit{display:flex;flex-wrap:wrap;gap:6px;}
.stato-toggle{padding:4px 14px;border-radius:12px;font-size:11px;font-weight:600;cursor:pointer;border:2px solid transparent;opacity:.45;transition:all .15s;}
.stato-toggle.sel{opacity:1;border-color:rgba(0,0,0,.2);}
.modal-footer{padding:12px 18px;border-top:1px solid var(--bordo);display:flex;justify-content:flex-end;gap:8px;}
.btn-salva{padding:7px 20px;background:var(--verde);color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:12px;font-weight:600;}
.btn-salva:hover{opacity:.85;}
.btn-ann{padding:7px 14px;background:none;border:1px solid var(--bordo);border-radius:4px;cursor:pointer;font-size:12px;color:var(--testo);}
.btn-ann:hover{background:var(--grigio-l);}

/* ── ADMIN MODAL ── */
.admin-bg{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:3000;align-items:flex-start;justify-content:center;padding-top:40px;}
.admin-bg.open{display:flex;}
.admin-modal{background:var(--b);border-radius:var(--r);width:600px;max-width:96vw;max-height:85vh;
             display:flex;flex-direction:column;border:1px solid var(--bordo);overflow:hidden;}
.admin-header{background:var(--blu);color:#fff;padding:14px 18px;display:flex;align-items:center;justify-content:space-between;}
.admin-header h2{font-size:14px;font-weight:600;margin:0;}
.admin-close{background:none;border:none;color:#fff;font-size:18px;cursor:pointer;opacity:.8;}
.admin-close:hover{opacity:1;}
.admin-tabs{display:flex;border-bottom:1px solid var(--bordo);background:var(--grigio-l);}
.admin-tab{padding:9px 18px;font-size:12px;font-weight:600;cursor:pointer;border:none;
           background:none;color:var(--grigio);border-bottom:2px solid transparent;}
.admin-tab:hover{color:var(--blu);}
.admin-tab.active{color:var(--blu);border-bottom-color:var(--blu);background:var(--b);}
.admin-body{padding:18px;overflow-y:auto;flex:1;}
.admin-section{display:none;}
.admin-section.active{display:block;}
.admin-section-title{font-size:11px;font-weight:700;color:var(--grigio);text-transform:uppercase;letter-spacing:.6px;margin-bottom:10px;}
.tag-edit-row{display:flex;gap:6px;align-items:center;margin-bottom:6px;}
.tag-edit-row input[type=text]{flex:1;padding:5px 8px;border:1px solid var(--bordo);border-radius:4px;font-size:12px;}
.tag-edit-row input[type=color]{width:36px;height:28px;padding:1px;border:1px solid var(--bordo);border-radius:4px;cursor:pointer;}
.tag-edit-row .del{padding:3px 8px;border:1px solid var(--bordo);border-radius:4px;cursor:pointer;background:none;color:var(--rosso);font-size:11px;}
.btn-add-tag{width:100%;padding:6px;border:1px dashed var(--bordo);border-radius:4px;background:none;cursor:pointer;font-size:12px;color:var(--grigio);margin-top:4px;}
.btn-add-tag:hover{background:var(--grigio-l);}
.btn-salva-admin{padding:7px 16px;background:var(--verde);color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:12px;font-weight:600;margin-top:10px;}
.btn-salva-admin:hover{opacity:.85;}

/* ── UTILS ── */
.status{font-size:11px;min-height:15px;margin-top:6px;}
.status.ok{color:var(--verde);}
.status.err{color:var(--rosso);}
