:root{
  --ink:#12100e; --gold:#e8541a; --navy:#1d3a8a;
  --bg:#f6f7f9; --line:#e3e6ea; --muted:#6b7280;
}
*{box-sizing:border-box}
body{margin:0;font-size:14px;color:var(--ink);background:var(--bg);
  font-family:-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif}

header{display:flex;align-items:center;gap:16px;padding:14px 20px;background:#fff;
  border-bottom:1px solid var(--line);position:sticky;top:0;z-index:6}
header h1{font-size:18px;margin:0;font-weight:700}
header h1 span{color:var(--gold)}
.btn-primario{background:var(--gold);color:#fff;border:0;border-radius:8px;
  padding:9px 16px;font-weight:600;cursor:pointer}
.btn-primario:hover{filter:brightness(1.05)}
.btn-primario:disabled{opacity:.55;cursor:default}
.stato-genera{color:var(--muted);font-size:13px}
.ultima-gen{margin-left:auto;color:var(--muted);font-size:13px;text-align:right;white-space:nowrap}

/* Toggle HOST (offrono) / CERCA-SPAZIO (domanda) */
.modo-toggle{display:flex;gap:8px;padding:12px 20px 0}
.modo-btn{border:1px solid var(--line);background:#fff;border-radius:999px;
  padding:8px 16px;font-size:13px;font-weight:700;cursor:pointer;color:var(--muted)}
.modo-btn small{font-weight:400;opacity:.85}
.modo-btn:hover{border-color:var(--gold)}
.modo-btn.attivo{background:var(--gold);color:#fff;border-color:var(--gold)}
.modo-btn.attivo small{opacity:.95}

.filtri{display:flex;flex-wrap:wrap;gap:10px;align-items:center;padding:12px 20px}
.filtri input,.filtri select{padding:7px 10px;border:1px solid var(--line);
  border-radius:7px;font-size:13px;background:#fff}
.filtri #cerca{min-width:240px;flex:1;max-width:360px}
.conteggio{color:var(--muted);font-size:13px;margin-left:auto}

table{width:100%;border-collapse:collapse;background:#fff}
thead th{position:sticky;top:57px;background:#fbfbfc;text-align:left;
  font-size:12px;text-transform:uppercase;letter-spacing:.03em;color:var(--muted);
  padding:9px 10px;border-bottom:2px solid var(--line);z-index:1}
tbody td{padding:8px 10px;border-bottom:1px solid var(--line);vertical-align:top}
tbody tr:hover{background:#fafbfc}

/* colonne strette di default; "Annuncio" e' la sola che va a capo verso il basso */
td.comune{white-space:nowrap;font-weight:600}
td.comune small{display:block;color:var(--muted);font-weight:400}
td.tipo,td.prezzo,td.mq,td.inserzionista{white-space:nowrap}
td.data{white-space:nowrap;color:var(--muted);cursor:help}  /* tooltip = data esatta */
td.annuncio{max-width:280px}
td.annuncio a{color:var(--navy);text-decoration:none;font-weight:600;
  word-break:break-word}              /* link blu, cliccabile subito */
td.annuncio a:hover{text-decoration:underline}

.tel-input,.nota-input{width:100%;border:1px solid transparent;background:#f4f5f7;
  border-radius:6px;padding:5px 7px;font:inherit}
.tel-input{min-width:110px}
.nota-input{min-width:130px}
.tel-input:focus,.nota-input:focus{border-color:var(--gold);background:#fff;outline:none}

.stato-sel{border:1px solid var(--line);border-radius:999px;padding:5px 8px;
  font-size:12px;font-weight:600;cursor:pointer}
.s-da_contattare{background:#fff4e6;color:#b4540a}
.s-contattato{background:#e7f0ff;color:#1d3a8a}
.s-non_interessato{background:#f1f1f3;color:#6b7280}
.s-iscritto{background:#e6f6ec;color:#137a3b}

.copie{display:flex;flex-direction:column;gap:5px;align-items:stretch}
.btn-copia{border:1px solid var(--line);background:#fff;border-radius:6px;
  padding:5px 9px;cursor:pointer;font-size:12px;white-space:nowrap;text-align:left}
.btn-copia:hover{border-color:var(--gold);color:var(--gold)}
.btn-copia.fatto{background:#e6f6ec;border-color:#137a3b;color:#137a3b}

.vuoto{color:var(--muted);text-align:center;padding:40px}
.hidden{display:none}

.badge-ag{display:inline-block;background:#fde8e8;color:#b42318;border:1px solid #f3c0c0;
  border-radius:999px;padding:1px 7px;font-size:11px;font-weight:600;margin-left:4px;
  cursor:help;white-space:nowrap}
.badge-azienda{display:inline-block;background:#e7f0ff;color:#1d3a8a;border:1px solid #b9cdf2;
  border-radius:999px;padding:1px 7px;font-size:11px;font-weight:700;margin-left:4px;white-space:nowrap}
.btn-classe{display:block;margin-top:5px;border:1px solid var(--line);background:#fff;
  border-radius:6px;padding:3px 8px;font-size:11px;cursor:pointer;white-space:nowrap}
.btn-classe:hover{border-color:var(--navy);color:var(--navy)}
.fonti{font-size:11px;color:var(--muted);margin-top:3px}
.fonti a{color:var(--navy);text-decoration:none}
.fonti a:hover{text-decoration:underline}
.doppione{margin-top:5px;display:flex;flex-direction:column;align-items:flex-start;gap:4px}
.badge-dup{background:rgba(255,255,255,.82);color:#7a3000;border:1px solid rgba(0,0,0,.18);
  border-radius:999px;padding:1px 7px;font-size:11px;font-weight:600;white-space:nowrap}
.dup-gemello{font-size:11px;line-height:1.35}
.dup-gemello a{color:var(--navy);text-decoration:none;font-weight:600}
.dup-gemello a:hover{text-decoration:underline}
.dup-meta{color:var(--muted)}
.dup-azioni{display:flex;gap:6px;margin-top:1px}
.doppione button{border:1px solid var(--line);background:#fff;border-radius:6px;
  padding:2px 8px;font-size:11px;cursor:pointer}
.doppione .btn-unisci{font-weight:600}
.doppione .btn-unisci:hover{border-color:#137a3b;color:#137a3b;background:#e6f6ec}
.doppione .btn-separa:hover{border-color:var(--muted)}

/* righe della stessa coppia "possibile doppione": arancione tenue, piu' forte al
   passaggio del mouse (cosi' si vede subito QUALI due annunci vanno insieme). */
/* colore della coppia: --pc impostato da JS (una tinta diversa per coppia) */
tr.riga-dup > td{background:var(--pc,#ffecd4)}
tr.riga-dup:hover > td{filter:brightness(.95)}
tr.riga-dup.evidenzia > td{filter:brightness(.88)}
tr.riga-dup > td:first-child{box-shadow:inset 4px 0 0 rgba(0,0,0,.22)}
.dup-coppia{margin-top:5px;font-size:11px;font-weight:600;color:#7a3000;
  background:rgba(255,255,255,.82);border:1px solid rgba(0,0,0,.18);border-radius:999px;
  padding:1px 7px;display:inline-block;cursor:help}

/* conferma fugace (toast) dopo unisci/diversi */
#toast{position:fixed;left:50%;bottom:24px;transform:translateX(-50%) translateY(12px);
  background:#137a3b;color:#fff;padding:10px 16px;border-radius:10px;font-weight:600;
  font-size:13px;box-shadow:0 8px 22px rgba(0,0,0,.18);opacity:0;pointer-events:none;
  transition:opacity .18s,transform .18s;z-index:50}
#toast.mostra{opacity:1;transform:translateX(-50%) translateY(0)}

/* ---- MOBILE: la tabella diventa una lista di schede (per lavorare i lead dal telefono) ---- */
@media (max-width:760px){
  header{flex-wrap:wrap;gap:10px;padding:12px 14px}
  header h1{font-size:17px}
  .ultima-gen{margin-left:0;width:100%;text-align:left}
  .modo-toggle{padding:10px 14px 0;flex-wrap:wrap}
  .filtri{padding:10px 14px}
  .filtri #cerca{min-width:0;max-width:none;width:100%;flex:1 1 100%}
  .conteggio{margin-left:0}

  table,thead,tbody,tr,td{display:block}
  thead{display:none}                 /* niente intestazioni: ogni campo ha la sua etichetta */
  #tabella{background:transparent}
  tbody tr{background:#fff;border:1px solid var(--line);border-radius:12px;
    margin:10px 12px;padding:6px 12px;box-shadow:0 1px 3px rgba(0,0,0,.06)}
  tbody td{border:0;padding:8px 0;display:flex;gap:10px;align-items:flex-start;
    border-bottom:1px solid #f1f2f4}
  tbody tr td:last-child{border-bottom:0}
  tbody td::before{content:attr(data-l);flex:0 0 84px;color:var(--muted);
    font-size:11px;text-transform:uppercase;letter-spacing:.03em;font-weight:700;padding-top:6px}
  td.data{cursor:auto}
  /* annuncio e messaggio: campo a tutta larghezza (link lungo / bottone grande) */
  td.annuncio{display:block}
  td.annuncio::before{display:block;margin-bottom:4px;flex:none}
  .tel-input,.nota-input{width:100%;font-size:16px;padding:9px 10px}  /* 16px: no zoom iOS */
  .stato-sel{font-size:15px;padding:9px 10px;width:100%}
  .btn-copia{width:100%;padding:12px;font-size:15px}
  td[data-l="Messaggio"]{display:block}
  td[data-l="Messaggio"]::before{display:block;margin-bottom:4px;flex:none}

  /* colore del gruppo doppione sulla scheda intera (su mobile la riga è la card) */
  tr.riga-dup>td{background:transparent}
  tbody tr.riga-dup{background:var(--pc,#ffecd4)}
}
.chk{display:flex;align-items:center;gap:5px;font-size:13px;color:var(--muted)}
.chk input{margin:0}
