/* SHOW10 — stile mobile-first, icone colorate, poche scritte */
/* l'attributo [hidden] deve sempre nascondere, anche su elementi con display:flex
   (es. .pos-modal, .install-banner) altrimenti il display della classe lo sovrascrive */
[hidden]{display:none!important}
:root{
  --bg:#0d1117; --bg2:#161b22; --card:#1c2430; --line:#2a3340;
  --txt:#e8edf2; --muted:#9aa7b4; --accent:#7c5cff; --good:#34d399; --bad:#f87171;
  --radius:16px;
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;padding:0;overflow-x:hidden;max-width:100%;width:100%}
body{
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;
  background:var(--bg); color:var(--txt); padding-bottom:84px;
}
a{color:inherit}

/* ---------- HEADER ---------- */
.app-header{
  position:sticky; top:0; z-index:30; background:rgba(13,17,23,.92);
  backdrop-filter:blur(8px); border-bottom:1px solid var(--line);
}
.brand{display:flex; align-items:center; gap:10px; padding:10px 14px}
.brand .logo{
  width:38px;height:38px;border-radius:11px;display:grid;place-items:center;
  background:linear-gradient(135deg,#7c5cff,#ec4899); font-weight:800; font-size:14px;
  box-shadow:0 4px 14px rgba(124,92,255,.45);
}
.brand h1{font-size:18px;margin:0;letter-spacing:.5px}
.brand .sub{font-size:11px;color:var(--muted);margin-top:1px}
.brand .spacer{flex:1}
.lang-toggle{
  border:1px solid var(--line); background:var(--bg2); color:var(--txt);
  border-radius:999px; padding:6px 12px; font-size:12px; font-weight:700; cursor:pointer;
}
/* riga icone sezioni: va a capo su mobile (tutte visibili) */
.nav-icons{display:flex; flex-wrap:wrap; gap:7px; justify-content:center; padding:0 12px 9px}
.nav-icons .lang-toggle{font-size:17px; line-height:1; padding:6px 11px}
/* bandierine lingua, in alto a destra */
.lang-flags{display:flex; gap:5px; flex:0 0 auto}
.flag{background:transparent; border:1px solid transparent; border-radius:9px;
  padding:3px 5px; font-size:19px; line-height:1; cursor:pointer; opacity:.5}
.flag:hover{opacity:.85}
.flag.on{opacity:1; border-color:var(--accent); background:var(--bg2)}
.geo-pill{
  display:flex;align-items:center;gap:6px;font-size:11px;color:var(--muted);
  padding:2px 14px 8px;
}
.geo-pill b{color:var(--good)}

/* ---------- STRISCIA ICONE ROTANTI ---------- */
.ticker{
  overflow:hidden; border-bottom:1px solid var(--line); background:var(--bg2);
  padding:8px 0; position:relative;
}
.ticker-track{
  display:flex; gap:10px; width:max-content; padding:0 10px;
  animation:scroll-x 38s linear infinite;
}
/* in pausa (categoria aperta o etichetta rivelata): si può scorrere col dito */
.ticker.paused{overflow-x:auto; -webkit-overflow-scrolling:touch; scrollbar-width:none}
.ticker.paused::-webkit-scrollbar{display:none}
.ticker.paused .ticker-track{animation:none; width:max-content}
@keyframes scroll-x{from{transform:translateX(0)} to{transform:translateX(-50%)}}

.chip{
  flex:0 0 auto; display:flex; align-items:center; gap:0;
  background:var(--card); border:1px solid var(--line); border-radius:999px;
  height:44px; width:44px; justify-content:center; overflow:hidden;
  transition:width .28s ease, background .2s; cursor:pointer; user-select:none;
}
.chip .ic{font-size:20px; line-height:1; flex:0 0 auto; width:44px; text-align:center}
.chip .lbl{
  white-space:nowrap; font-size:13px; font-weight:700; opacity:0;
  max-width:0; transition:max-width .28s ease, opacity .2s, padding .2s; padding:0;
}
.chip.revealed{width:auto; padding-right:14px}
.chip.revealed .lbl{opacity:1; max-width:200px; padding-right:2px}
.chip.active{border-color:transparent; box-shadow:0 0 0 2px var(--accent) inset}

/* ---------- GRIGLIA QUADRATINI CATEGORIE ---------- */
.cat-grid-wrap{background:var(--bg2);border-bottom:1px solid var(--line);padding:10px;
  animation:slideDown .18s ease}
@keyframes slideDown{from{opacity:0;transform:translateY(-6px)} to{opacity:1;transform:none}}
.cat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
@media(min-width:520px){.cat-grid{grid-template-columns:repeat(6,1fr)}}
.tile{
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;
  aspect-ratio:1/1;border-radius:14px;cursor:pointer;user-select:none;
  background:var(--card);border:1px solid var(--line);transition:transform .1s,border-color .15s;
  padding:4px;text-align:center;
}
.tile:active{transform:scale(.94)}
.tile .tic{font-size:24px;line-height:1}
.tile .tlbl{font-size:10px;font-weight:600;color:var(--muted);line-height:1.1;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.tile.active{border-width:2px}
.tile.all{background:linear-gradient(135deg,#7c5cff33,#ec489933)}
#gridBtn{font-size:16px;line-height:1}
#gridBtn.on{background:var(--accent);color:#fff;border-color:var(--accent)}

/* ---------- BARRA STATO FILTRO ---------- */
.filter-bar{
  display:none; align-items:center; gap:8px; padding:10px 14px;
  background:var(--bg2); border-bottom:1px solid var(--line); font-size:13px;
}
.filter-bar.show{display:flex}
.filter-bar .x{margin-left:auto;background:var(--card);border:1px solid var(--line);
  color:var(--txt);border-radius:999px;padding:4px 10px;cursor:pointer;font-size:12px}

/* ---------- LISTA EVENTI ---------- */
main{padding:6px 12px 20px}
.day-group{margin-top:18px}
.day-head{
  display:flex; align-items:baseline; gap:8px; position:sticky; top:54px; z-index:10;
  padding:6px 4px; background:linear-gradient(var(--bg),var(--bg) 70%,transparent);
}
.day-head .dnum{font-size:22px;font-weight:800}
.day-head .dname{font-size:13px;color:var(--muted);text-transform:capitalize}
.day-head .count{margin-left:auto;font-size:11px;color:var(--muted)}

.event{
  background:var(--card); border:1px solid var(--line); border-radius:var(--radius);
  padding:12px; margin:10px 0; display:flex; gap:12px;
}
.event .cat{
  flex:0 0 auto; width:48px; height:48px; border-radius:14px; display:grid; place-items:center;
  font-size:24px; background:var(--bg2);
}
.event .body{flex:1; min-width:0}
.event .title{font-size:15px; font-weight:700; margin:0 0 3px}
.event .meta{display:flex; flex-wrap:wrap; gap:8px 12px; font-size:12px; color:var(--muted); margin:4px 0}
.event .meta span{display:inline-flex; align-items:center; gap:4px}
.event .desc{font-size:13px; color:#cdd6df; margin:6px 0 4px; line-height:1.4}
.event .contacts{display:flex; gap:8px; flex-wrap:wrap; margin-top:6px}
.event .contacts a{
  font-size:12px; text-decoration:none; background:var(--bg2); border:1px solid var(--line);
  border-radius:999px; padding:5px 10px; display:inline-flex; gap:5px; align-items:center;
  max-width:100%; overflow:hidden; text-overflow:ellipsis; white-space:nowrap;
}
.event .title,.event .desc,.event .info-line,.event .meta span{overflow-wrap:anywhere; word-break:break-word}
.event .meta{max-width:100%}
.badge-serie{
  display:inline-block;font-size:10px;font-weight:700;color:var(--accent);
  background:rgba(124,92,255,.12);border:1px solid rgba(124,92,255,.35);
  border-radius:999px;padding:1px 8px;margin-left:6px;vertical-align:middle;
}
.dist{font-size:11px;color:var(--good);font-weight:700}

/* ---------- VOTO ---------- */
.vote{display:flex; align-items:center; gap:6px; margin-top:8px}
.vote button{
  border:1px solid var(--line); background:var(--bg2); color:var(--txt);
  border-radius:999px; width:38px; height:32px; font-size:15px; cursor:pointer;
}
.vote button.on.up{background:rgba(52,211,153,.18); border-color:var(--good); color:var(--good)}
.vote button.on.down{background:rgba(248,113,113,.18); border-color:var(--bad); color:var(--bad)}
.vote .score{font-size:12px; color:var(--muted); margin-left:2px}

.event .info-line{font-size:12.5px;color:#b9c4cf;margin:2px 0 4px;line-height:1.45;
  background:var(--bg2);border:1px solid var(--line);border-radius:10px;padding:7px 10px}
.event .src{font-size:11px;color:var(--muted);margin-top:6px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.event .src a{color:#7c9bff;text-decoration:none}
.event.is-next{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent) inset, 0 6px 22px rgba(124,92,255,.18)}
.next-tag{display:inline-block;font-size:11px;font-weight:800;color:var(--accent);
  background:rgba(124,92,255,.12);border:1px solid rgba(124,92,255,.4);
  border-radius:999px;padding:2px 10px;margin-bottom:6px}

/* ---------- VISTA CATEGORIA / PROGRAMMA ---------- */
.cat-hero{display:flex;align-items:center;gap:12px;margin:12px 2px 6px;
  border:1px solid var(--line);border-radius:var(--radius);padding:12px;background:var(--card)}
.cat-hero-ic{width:52px;height:52px;border-radius:14px;display:grid;place-items:center;font-size:26px}
.cat-hero h2{margin:0;font-size:18px}
.section-h{font-size:13px;color:var(--muted);text-transform:uppercase;letter-spacing:.6px;
  margin:18px 4px 8px}
.prog-block{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:10px 12px;margin:8px 0}
.prog-title{margin:0 0 8px;font-size:14px}
.occ-row{display:flex;align-items:center;gap:10px;padding:7px 0;border-top:1px dashed var(--line);font-size:13px}
.occ-row:first-of-type{border-top:none}
.occ-date{flex:0 0 auto;font-weight:700;min-width:104px;text-transform:capitalize}
.occ-place{flex:1;min-width:0;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.occ-dist{flex:0 0 auto;font-size:11px;color:var(--good);font-weight:700}
.occ-more{font-size:12px;color:var(--accent);padding-top:8px;font-weight:600}

/* ---------- EMPTY ---------- */
.empty{text-align:center; color:var(--muted); padding:60px 20px}
.empty .big{font-size:48px}

/* ---------- SPONSOR FOOTER ---------- */
.sponsors{
  position:fixed; bottom:0; left:0; right:0; z-index:25;
  background:rgba(22,27,34,.96); backdrop-filter:blur(8px);
  border-top:1px solid var(--line); padding:8px 10px;
  display:flex; gap:8px; overflow:hidden; align-items:center;
}
.sponsors .lab{font-size:10px;color:var(--muted);align-self:center;flex:0 0 auto;padding-right:4px}
.spon-track{display:flex; gap:8px; align-items:center; min-width:0}
.spon-track.spon-scroll{width:max-content; animation:scroll-x 26s linear infinite}
.sponsors:hover .spon-track.spon-scroll,
.sponsors:active .spon-track.spon-scroll{animation-play-state:paused}
.sponsor{
  flex:0 0 auto; display:flex; align-items:center; gap:6px; text-decoration:none; white-space:nowrap;
  background:var(--card); border:1px solid var(--line); border-radius:12px;
  padding:6px 12px; font-size:12px; font-weight:600;
  color:var(--txt); font-family:inherit; cursor:pointer;
}
.sponsor .si{font-size:18px}

/* scheda sponsor (descrizione + link verso il sito) */
.spon-modal{position:fixed; inset:0; z-index:60; display:flex; align-items:center; justify-content:center;
  background:rgba(0,0,0,.55); padding:20px}
.spon-modal[hidden]{display:none}
.spon-card{position:relative; background:var(--card); border:1px solid var(--line); border-radius:16px;
  padding:18px; max-width:340px; width:100%; box-shadow:0 12px 40px rgba(0,0,0,.5)}
.spon-close{position:absolute; top:8px; right:10px; background:none; border:none; color:var(--muted);
  font-size:18px; cursor:pointer; line-height:1}
.spon-head{display:flex; align-items:center; gap:10px; font-size:16px; margin-bottom:6px; padding-right:20px}
.spon-bic{font-size:24px}
.spon-desc{font-size:13.5px; color:var(--muted); line-height:1.45; margin:6px 0 12px}
.spon-go{display:inline-block; text-decoration:none}
/* descrizione informativa limitata a 2 righe nella riga chiusa */
.info-clamp{display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden}

/* legenda della mappa (spiega il colore dei punti) */
.map-legend{display:flex; flex-wrap:wrap; gap:6px 12px; padding:8px 10px; margin:0 0 8px;
  background:var(--card); border:1px solid var(--line); border-radius:12px}
.ml-item{display:inline-flex; align-items:center; gap:6px; font-size:12px; color:var(--txt)}
.ml-dot{width:11px; height:11px; border-radius:50%; border:2px solid #0b0f15; flex:0 0 auto}

/* ---------- ADMIN ---------- */
.admin-wrap{max-width:920px;margin:0 auto;padding:20px;width:100%}
.admin-grid{display:grid;grid-template-columns:1fr;gap:16px;min-width:0}
.panel{min-width:0}
.field input,.field select,.field textarea{width:100%;max-width:100%}
.type-picker{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.tpick{display:flex;flex-direction:column;align-items:center;gap:3px;font-size:11px;font-weight:600;
  background:var(--bg2);border:1px solid var(--line);color:var(--txt);border-radius:12px;
  padding:10px 4px;cursor:pointer;text-align:center;font-family:inherit}
.tpick .e{font-size:20px;line-height:1}
.tpick:active{transform:scale(.96)}
.tpick.active{border-color:var(--accent);background:rgba(124,92,255,.14);
  box-shadow:0 0 0 1px var(--accent) inset}
/* filtro fonti per tipo + sezioni per zona */
.fchips{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}
.fchip{font-size:11px;font-weight:600;background:var(--bg2);border:1px solid var(--line);
  color:var(--txt);border-radius:999px;padding:5px 11px;cursor:pointer;font-family:inherit}
.fchip b{opacity:.75}
.fchip.on{background:var(--accent);border-color:var(--accent);color:#fff}
.grp-head{display:flex;align-items:center;gap:8px;cursor:pointer;font-weight:700;font-size:13px;
  padding:9px 11px;margin:8px 0 4px;background:var(--bg2);border:1px solid var(--line);border-radius:10px}
.grp-head .arr{font-size:11px;color:var(--accent);width:12px}
.grp-head .cnt{margin-left:auto;font-size:11px;color:var(--muted);font-weight:600;
  background:var(--card);border:1px solid var(--line);border-radius:999px;padding:1px 9px}
@media(min-width:760px){.admin-grid{grid-template-columns:1fr 1fr}}
/* schede (tab) della dashboard admin */
.tabbar{display:flex;flex-wrap:wrap;gap:8px;margin:14px 0 16px}
.tab{appearance:none;border:1px solid var(--line);background:var(--card);color:var(--muted);
  border-radius:999px;padding:9px 14px;font-size:14px;font-weight:700;cursor:pointer;
  display:inline-flex;gap:6px;align-items:center}
.tab:hover{color:#e6edf3}
.tab.on{color:#fff;border-color:transparent;box-shadow:0 0 0 2px var(--accent) inset}
.tab .b{background:#fb7185;color:#fff;border-radius:999px;font-size:11px;font-weight:700;padding:1px 7px;min-width:18px;text-align:center}
.tab-pane[hidden]{display:none}
/* card delle segnalazioni */
.rep-card{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:12px 14px;margin-bottom:10px}
.rep-card.done{opacity:.6}
.rep-meta{display:flex;justify-content:space-between;align-items:center;font-size:12px;color:var(--muted);margin-bottom:6px}
.rep-new{color:#fb7185;font-weight:700}
.rep-done{color:#3fb950;font-weight:700}
.rep-text{font-size:14px;line-height:1.5;white-space:normal}
.rep-cont{margin-top:6px;font-size:13px}
.panel{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:16px}
.panel h2{margin:0 0 12px;font-size:16px}
.field{display:flex;flex-direction:column;gap:4px;margin-bottom:10px}
.field label{font-size:12px;color:var(--muted)}
.field input,.field select,.field textarea{
  background:var(--bg2);border:1px solid var(--line);color:var(--txt);
  border-radius:10px;padding:9px 11px;font-size:14px;font-family:inherit;
}
.btn{background:var(--accent);color:#fff;border:none;border-radius:10px;
  padding:10px 16px;font-weight:700;cursor:pointer;font-size:14px}
.btn.ghost{background:var(--bg2);border:1px solid var(--line);color:var(--txt)}
.btn.sm{padding:5px 10px;font-size:12px}
.row{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.list-item{display:flex;gap:10px;align-items:center;padding:10px;border:1px solid var(--line);
  border-radius:12px;margin-bottom:8px;background:var(--bg2)}
.list-item .grow{flex:1;min-width:0}
.list-item small{color:var(--muted);display:block;font-size:11px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.tag{font-size:10px;padding:1px 8px;border-radius:999px;border:1px solid var(--line)}
.tag.ok{color:var(--good);border-color:var(--good)}
.tag.wait{color:#fbbf24;border-color:#fbbf24}
.login-box{max-width:340px;margin:80px auto;text-align:center}
.muted{color:var(--muted);font-size:12px}
.note{background:rgba(124,92,255,.08);border:1px solid rgba(124,92,255,.3);
  border-radius:12px;padding:10px 12px;font-size:12px;color:#cdd6df;margin-top:10px}

/* ---------- SPLASH INIZIALE + LOGO ---------- */
.splash{position:fixed;inset:0;z-index:100;background:linear-gradient(160deg,#0d1117,#1a1030);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;
  text-align:center;padding:24px;transition:opacity .5s ease}
.splash.hide{opacity:0;pointer-events:none}
.splash-logo{width:160px;height:160px;border-radius:34px;object-fit:cover;
  box-shadow:0 14px 44px rgba(124,92,255,.5)}
.splash-loc{font-size:16px;color:var(--txt);margin-top:8px;max-width:420px}
.splash-loc b{color:#fff}
.splash-sub{font-size:13px;color:var(--muted);max-width:420px}
.splash-spin{width:26px;height:26px;border:3px solid rgba(255,255,255,.18);border-top-color:var(--accent);
  border-radius:50%;animation:spin 1s linear infinite;margin-top:6px}
@keyframes spin{to{transform:rotate(360deg)}}
.logo-img{width:40px;height:40px;border-radius:11px;object-fit:cover;box-shadow:0 4px 14px rgba(124,92,255,.45)}

/* badge "evento di richiamo" (lontano ma importante) */
.badge-far{display:inline-block;font-size:10px;font-weight:800;color:#fbbf24;
  background:rgba(251,191,36,.12);border:1px solid rgba(251,191,36,.4);border-radius:999px;
  padding:1px 8px;margin-left:6px;vertical-align:middle}
/* avviso geolocalizzazione disattivata */
.geo-pill a{color:#fbbf24;font-weight:700;text-decoration:underline}
.geo-warn{color:#fbbf24}

/* tag priorità/affidabilità (admin) */
.tag.prio-P1{color:#34d399;border-color:#34d399}
.tag.prio-P2{color:#fbbf24;border-color:#fbbf24}
.tag.prio-P3{color:#9aa7b4;border-color:#9aa7b4}
.tag.uff{color:#34d399;border-color:#34d399}
.tag.sec{color:#fbbf24;border-color:#fbbf24}
.tag.radar{color:#f87171;border-color:#f87171}

/* ---------- PULSANTI NAV ATTIVI (calendario / segnala) ---------- */
.lang-toggle.on{background:var(--accent);color:#fff;border-color:var(--accent)}

/* ---------- COPERTINE FB SULLE CARD ---------- */
.event{flex-direction:column}
.event-row{display:flex;gap:12px}
.ev-cover{border:1px solid var(--line);border-radius:12px;overflow:hidden;background:var(--bg2);line-height:0}
.ev-cover img{width:100%;height:auto;max-height:230px;object-fit:cover;display:block}

/* ---------- CALENDARIO COLORATO ---------- */
.cal-nav{display:flex;align-items:center;justify-content:space-between;gap:10px;margin:10px 2px 8px}
.cal-month{font-size:17px;font-weight:800;text-transform:capitalize}
.cal-arrow{width:40px;height:40px;border-radius:12px;border:1px solid var(--line);
  background:var(--card);color:var(--txt);font-size:22px;line-height:1;cursor:pointer}
.cal-arrow:disabled{opacity:.3;cursor:default}
.cal-wd{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;margin:0 2px 6px;
  font-size:11px;color:var(--muted);text-align:center;font-weight:700}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;margin:0 2px}
.cal-cell{position:relative;aspect-ratio:1/1;border-radius:12px;border:1px solid var(--line);
  background:var(--bg2);display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:4px;font-size:14px;color:var(--muted)}
.cal-cell.empty{border:none;background:transparent}
.cal-cell.has{background:var(--card);color:var(--txt);cursor:pointer;font-weight:700}
.cal-cell.has:active{transform:scale(.95)}
.cal-cell.past{opacity:.4}
.cal-cell.today{box-shadow:0 0 0 2px var(--accent) inset}
.cal-cell.sel{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent) inset,0 4px 16px rgba(124,92,255,.3)}
.cal-cell .cal-d{font-size:15px}
.cal-dots{display:flex;gap:3px;height:7px}
.cal-dots .dot{width:7px;height:7px;border-radius:50%}
.cal-cell .cal-n{position:absolute;top:3px;right:5px;font-size:9px;color:var(--muted);font-weight:700}
.cal-hint{text-align:center;color:var(--muted);font-size:13px;padding:26px 16px}
.cal-day{margin-top:8px}

/* ---------- FORM SEGNALA EVENTO ---------- */
.report{max-width:560px;margin:0 auto;padding:6px 2px 24px}
.report .rep-back{margin-bottom:10px}
.report .rep-h{font-size:20px;margin:4px 0 6px}
.report .rep-sub{font-size:13px;color:var(--muted);margin:0 0 16px;line-height:1.5}
.report .field{margin-bottom:12px}
.report .btn{width:100%;margin-top:6px;padding:13px}
.rep-msg{font-size:13px;margin:6px 0;min-height:18px}
.rep-msg.err{color:var(--bad)}
.rep-msg.ok{color:var(--good)}

/* ---------- AGENDA MENSILE COMPATTA + MINIATURA INTERA ---------- */
.month{margin-top:6px}
.month-h{position:sticky;top:0;z-index:3;margin:0 0 4px;padding:9px 4px 7px;
  background:var(--bg);font-size:17px;font-weight:800;text-transform:capitalize;
  display:flex;align-items:center;border-bottom:2px solid var(--accent)}
.month-n{font-size:11px;font-weight:700;color:var(--muted);background:var(--bg2);
  border:1px solid var(--line);border-radius:999px;padding:1px 9px;margin-left:8px;vertical-align:middle}
.agenda-day{display:flex;align-items:baseline;gap:8px;margin:14px 4px 6px;padding-bottom:4px;border-bottom:1px solid var(--line)}
.agenda-day .ad-num{font-size:18px;font-weight:800}
.agenda-day .ad-name{font-size:12px;color:var(--muted);text-transform:capitalize}
.agenda-day .ad-c{margin-left:auto;font-size:11px;color:var(--muted)}

.ev-item{background:var(--card);border:1px solid var(--line);border-radius:14px;margin:7px 0;overflow:hidden}
.ev-item.open{border-color:var(--accent)}
.ev-row{display:flex;align-items:center;gap:10px;width:100%;text-align:left;
  background:none;border:none;color:var(--txt);padding:8px;cursor:pointer;font:inherit}
.ev-row:active{background:rgba(255,255,255,.03)}
.ev-thumb{width:48px;height:66px;flex:0 0 auto;border-radius:8px;object-fit:contain;
  background:#0b0f15;border:1px solid var(--line)}
.ev-thumb.noimg{display:grid;place-items:center;font-size:22px}
.ev-time{flex:0 0 auto;font-size:12px;font-weight:800;min-width:42px;text-align:center}
.ev-main{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}
.ev-title{font-size:14px;font-weight:700;line-height:1.25;overflow-wrap:anywhere;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.ev-sub{font-size:11.5px;color:var(--muted);line-height:1.3;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.ev-chev{flex:0 0 auto;color:var(--muted);font-size:22px;transition:transform .2s;line-height:1}
.ev-item.open .ev-chev{transform:rotate(90deg)}
.ev-detail{display:none;padding:2px 12px 14px;border-top:1px dashed var(--line)}
.ev-item.open .ev-detail{display:block}
.ev-poster{margin:12px 0;text-align:center;background:#0b0f15;border-radius:12px;border:1px solid var(--line);padding:6px}
.ev-poster img{max-width:100%;max-height:74vh;border-radius:8px;display:inline-block}
.ev-detail .ev-meta{display:flex;flex-wrap:wrap;gap:6px 14px;font-size:12.5px;color:var(--muted);margin:8px 0}
.ev-detail .ev-meta span{display:inline-flex;align-items:center;gap:4px;overflow-wrap:anywhere}
.ev-desc{font-size:13.5px;color:#cdd6df;line-height:1.45;margin:8px 0}
.ev-info{font-size:12.5px;color:#cdd6df;line-height:1.45;margin:6px 0;
  background:rgba(124,92,255,.08);border:1px solid rgba(124,92,255,.25);border-radius:10px;padding:8px 10px}
.ev-contacts{display:flex;gap:8px;flex-wrap:wrap;margin:8px 0}
.ev-contacts a{font-size:12px;color:#7c9bff;text-decoration:none;border:1px solid var(--line);border-radius:999px;padding:4px 11px}
.cal-month .month-n{margin-left:8px}

/* ---------- SEZIONI SERVIZIO (Sante Messe · Numeri Utili · Info) ---------- */
.sec-hero{display:flex;align-items:center;gap:12px;margin:10px 2px 10px;padding:12px;
  background:var(--card);border:1px solid var(--line);border-radius:16px}
.sec-ic{width:48px;height:48px;flex:0 0 auto;border-radius:14px;display:grid;place-items:center;font-size:24px}
.sec-hero h2{margin:0;font-size:18px}
.sec-group{font-size:13px;font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;margin:16px 4px 6px}
.sec-foot{font-size:11.5px;color:var(--muted);line-height:1.5;margin:16px 4px 0;text-align:center}
/* intestazioni di gruppo nella sezione Monumenti 🏛️ */
.mon-group{display:flex;align-items:center;gap:9px;margin:18px 2px 8px;padding:8px 12px;
  background:var(--card);border:1px solid var(--line);border-left:3px solid #c9a227;border-radius:12px}
.mon-group-ic{font-size:18px;flex:0 0 auto}
.mon-group-tt{font-size:14px;font-weight:800;color:#c9a227;letter-spacing:.01em;flex:1;min-width:0}
.mon-group-n{font-size:11px;font-weight:700;color:var(--muted);background:#c9a22722;
  border-radius:999px;padding:2px 9px;flex:0 0 auto}
/* banner installazione PWA (📲 Aggiungi a Home) */
.install-banner{position:fixed;left:10px;right:10px;bottom:calc(10px + env(safe-area-inset-bottom));
  z-index:1200;display:flex;align-items:center;gap:11px;padding:11px 12px;
  background:var(--card);border:1px solid var(--line);border-radius:16px;
  box-shadow:0 10px 30px rgba(0,0,0,.45);animation:instUp .35s ease}
@keyframes instUp{from{transform:translateY(120%);opacity:0}to{transform:translateY(0);opacity:1}}
.inst-ic{font-size:26px;flex:0 0 auto}
.inst-txt{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}
.inst-txt b{font-size:14px}
.inst-txt span{font-size:12px;color:var(--muted);line-height:1.35}
.inst-go{flex:0 0 auto;border:0;border-radius:11px;padding:9px 14px;font-size:13px;font-weight:800;
  color:#0d1117;background:#c9a227;cursor:pointer}
.inst-go:active{transform:scale(.96)}
.inst-x{flex:0 0 auto;width:30px;height:30px;border-radius:50%;border:1px solid var(--line);
  background:transparent;color:var(--muted);font-size:14px;cursor:pointer}
@media(min-width:560px){.install-banner{left:auto;right:16px;max-width:420px}}
/* Sante Messe */
.mass-card{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:10px 12px;margin:7px 0}
.mass-h{display:flex;align-items:center;gap:8px}
.mass-name{font-size:14px;font-weight:700;flex:1;min-width:0}
.mass-map{flex:0 0 auto;text-decoration:none;font-size:17px}
.mass-via{font-size:11.5px;color:var(--muted);margin:2px 0 7px}
.mass-r{display:flex;justify-content:space-between;gap:10px;font-size:13px;padding:3px 0;border-top:1px dashed var(--line)}
.mass-r span{color:var(--muted)}
.mass-r b{color:var(--txt);text-align:right}
.mass-note{font-size:12px;color:#cdd6df;margin-top:6px;line-height:1.4}
/* Numeri utili / Info — usano .ev-item + .ev-detail */
.num-row{padding:9px 0;border-top:1px dashed var(--line)}
.num-row:first-child{border-top:none}
.num-name{font-size:13.5px;font-weight:700;line-height:1.3}
.num-sub{font-size:12px;color:var(--muted);margin-top:3px;overflow-wrap:anywhere}
.num-sub a{color:#7c9bff;text-decoration:none}
.num-note{font-size:12px;color:#b9c4cf;margin-top:4px;line-height:1.4}
.num-tel{display:flex;flex-wrap:wrap;gap:7px;margin-top:5px}
.num-tel a{font-size:13px;font-weight:700;color:#34d399;text-decoration:none;
  border:1px solid rgba(52,211,153,.4);border-radius:999px;padding:3px 11px}

/* ---------- ADMIN: locandine da collocare ---------- */
.loc-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}
.loc-card{background:var(--bg2);border:1px solid var(--line);border-radius:12px;padding:8px;display:flex;flex-direction:column;gap:7px}
.loc-card.done{border-color:var(--good);box-shadow:0 0 0 1px var(--good) inset}
.loc-card img{width:100%;height:150px;object-fit:contain;background:#0b0f15;border-radius:8px;border:1px solid var(--line)}
.loc-name{font-size:11.5px;color:var(--muted);line-height:1.3;overflow-wrap:anywhere;min-height:30px}
.loc-sel{width:100%;padding:7px;border-radius:9px;border:1px solid var(--line);background:var(--card);color:var(--txt);font-size:12.5px}
.loc-cats{display:flex;flex-wrap:wrap;gap:4px;min-height:20px}
.loc-chip{display:inline-flex;align-items:center;gap:5px;background:rgba(52,211,153,.15);
  border:1px solid var(--good);color:var(--txt);border-radius:999px;padding:2px 8px;font-size:11px;cursor:pointer}
.loc-chip b{color:var(--muted);font-weight:700}
.loc-chip:hover b{color:var(--bad)}
.loc-empty{font-size:11px;color:var(--muted)}

/* Dove mangiare: sotto-gruppi per tipo locale */
.food-grp{margin:6px 0 12px}
.food-grp-h{margin:10px 0 6px;font-size:13px;color:#f4a259;border-bottom:1px solid var(--line);padding-bottom:4px}
.food-grp .num-row{padding:7px 0;border-bottom:1px dashed var(--line)}
.food-grp .num-row:last-child{border-bottom:none}
/* selezione categorie multiple (admin) */
select[multiple]{min-height:120px}
/* archivio locandine */
.arc-evs{margin:6px 0;max-height:150px;overflow:auto;text-align:left;width:100%}
.arc-evs .num-row{padding:4px 0;border-bottom:1px dashed var(--line)}
.arc-del[disabled]{opacity:.55;cursor:not-allowed}
/* mappa eventi (Leaflet) */
#mapBox{height:72vh;min-height:380px;margin:10px 0;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line)}
.leaflet-popup-content{font-size:13px;line-height:1.4}
/* data di riferimento sulla scheda evento (vista categoria) */
.ev-when{display:block;font-size:12px;font-weight:700;color:#cdd6df;margin-top:2px}
/* "altre date" sotto la scheda di un evento ricorrente in categoria */
.more-dates{font-size:11.5px;color:var(--muted);margin:-4px 4px 10px;padding-left:6px;line-height:1.4}
/* programmazione cinema (Cinepark Comacchio) */
.cine-prog{margin:4px 0 10px}
.cine-day{margin:8px 0 14px}
.cine-date{font-weight:800;font-size:13px;color:#4dd0e1;text-transform:capitalize;margin:6px 0}
.cine-film{display:flex;gap:11px;background:var(--card);border:1px solid var(--line);
  border-radius:12px;padding:9px;margin:7px 0}
.cine-poster{width:52px;height:74px;flex:0 0 auto;border-radius:8px;object-fit:cover;border:1px solid var(--line)}
.cine-fb{display:flex;flex-direction:column;gap:3px;min-width:0;flex:1}
.cine-fb b{font-size:13.5px;line-height:1.25}
.cine-genre{font-size:11px;color:var(--muted)}
.cine-times{display:flex;flex-wrap:wrap;gap:6px;margin-top:3px}
.cine-time{font-size:12px;font-weight:700;background:#4dd0e122;border:1px solid #4dd0e155;
  color:#e8edf2;border-radius:8px;padding:2px 8px}
.cine-book{font-size:11.5px;color:#4dd0e1;text-decoration:none;font-weight:700;margin-top:3px}
/* attribuzione "a cura di Comacchio Events" */
.src-ce{font-size:11.5px;color:var(--muted);margin-top:5px}
.src-ce a{color:#7c9bff;text-decoration:none;font-weight:600}
/* meteo Comacchio (sezione ⛅) */
.wx-now{display:flex;align-items:center;gap:14px;background:var(--card);border:1px solid var(--line);
  border-radius:14px;padding:14px 16px;margin:6px 0 12px}
.wx-now-ic{font-size:44px;line-height:1}
.wx-now b{font-size:30px}.wx-now span{display:block;font-size:13px;color:var(--muted)}
.wx-days{display:flex;flex-direction:column;gap:8px}
.wx-day{display:grid;grid-template-columns:64px 34px 1fr;align-items:center;gap:10px;
  background:var(--card);border:1px solid var(--line);border-radius:12px;padding:9px 12px}
.wx-dname{font-weight:700;font-size:13px;text-transform:capitalize}
.wx-dic{font-size:22px;text-align:center}
.wx-temp{font-size:14px}.wx-temp .wx-min{color:var(--muted)}
.wx-extra{grid-column:3;font-size:11.5px;color:var(--muted);justify-self:end}
@media(max-width:380px){.wx-day{grid-template-columns:54px 30px 1fr}.wx-extra{display:none}}
/* schede "sempre disponibili" in cima alle categorie (realtà senza data) */
.sh-hint{font-weight:400;font-size:11px;color:var(--muted);margin-left:6px}
.info-cards{display:flex;flex-direction:column;gap:9px;margin:6px 0 14px}
.info-card{display:flex;gap:11px;background:var(--card);border:1px solid var(--line);
  border-radius:14px;padding:10px}
.info-thumb{position:relative;width:64px;height:64px;flex:0 0 auto;border-radius:10px;
  display:flex;align-items:center;justify-content:center;font-size:26px;overflow:hidden;border:1px solid var(--line)}
.info-thumb img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.info-b{display:flex;flex-direction:column;gap:3px;min-width:0;flex:1}
.info-b b{font-size:14px;line-height:1.25}
.info-place{font-size:11.5px;color:var(--muted)}
.info-desc{font-size:12px;color:var(--muted);line-height:1.35;
  display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.info-links{display:flex;flex-wrap:wrap;gap:6px 14px;margin-top:3px}
.info-links a{font-size:12px;color:#7c9bff;text-decoration:none;font-weight:600}
/* credito pagina Facebook sorgente */
.ce-credit{text-align:center;color:var(--muted);font-size:12px;padding:18px 14px 28px;line-height:1.5}
.ce-credit a{color:#4dabf7;text-decoration:none}
.ce-ver{display:block;margin-top:6px;font-size:11px;opacity:.65}
.ce-disclaimer{max-width:560px;margin:10px auto 0;font-size:11.5px;line-height:1.5;opacity:.8}
.ce-disclaimer a{color:#4dabf7;text-decoration:none;font-weight:700}
/* modale "posiziona sulla mappa" (admin) */
.pos-modal{position:fixed;inset:0;z-index:2000;display:flex;align-items:center;justify-content:center;
  background:rgba(0,0,0,.6);padding:16px}
.pos-card{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:14px;
  width:100%;max-width:640px;box-shadow:0 20px 60px rgba(0,0,0,.5)}
.pos-head{display:flex;align-items:center;justify-content:space-between;gap:10px}
.pos-head b{font-size:15px}
.pos-map{height:52vh;min-height:300px;border-radius:12px;overflow:hidden;border:1px solid var(--line)}
.cat-checks{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:8px;max-height:50vh;overflow:auto}
.cat-check{display:flex;align-items:center;gap:7px;background:var(--bg);border:1px solid var(--line);
  border-radius:10px;padding:8px 10px;font-size:13px;cursor:pointer}
.cat-check input{width:16px;height:16px}
