/* focolai.it - main stylesheet (DARK THEME — deepened 2026-05-13) */
:root {
  --c-bg:        #04060c;
  --c-bg-elev:   #080b14;
  --c-card:      #0a0e1a;
  --c-card-2:    #131826;
  --c-fg:        #e2e8f0;
  --c-fg-soft:   #c7d0de;
  --c-muted:     #8a93a4;
  --c-line:      #161b29;
  --c-line-2:    #252d40;
  --c-accent:      #ef4444;
  --c-accent-soft: #fca5a5;
  --c-accent-dark: #b91c1c;
  --c-warn: #f59e0b;
  --c-ok:   #10b981;
  --c-info: #38bdf8;
  --max-w: 1180px;
  --shadow: 0 1px 3px rgba(0,0,0,.6), 0 2px 8px rgba(0,0,0,.4);
  --r: 10px;
  --font: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, "Helvetica Neue", sans-serif;
  color-scheme: dark;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body { font-family: var(--font); color: var(--c-fg); background: var(--c-bg); line-height: 1.55; }

.container { max-width: var(--max-w); margin: 0 auto; padding: 0 20px; }

a { color: var(--c-accent-soft); text-decoration: none; }
a:hover { color: var(--c-accent); text-decoration: underline; }

h1 { font-size: 2.1rem; margin: .3em 0 .4em; letter-spacing: -.5px; color: #fff; }
h2 { font-size: 1.4rem; margin: 1.5em 0 .6em; letter-spacing: -.3px; color: #fff; }
h3 { font-size: 1.05rem; margin: .4em 0; color: var(--c-fg); }

p { margin: .6em 0; }
p.lead { font-size: 1.15rem; color: var(--c-fg-soft); }
.prose p, .prose li, section.article p { text-align: justify; hyphens: auto; -webkit-hyphens: auto; }

/* Header */
.site-header { background: rgba(4,6,12,.88); backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px); border-bottom: 1px solid var(--c-line); position: sticky; top: 0; z-index: 100; }
.site-header .hflex { display: flex; align-items: center; justify-content: space-between; min-height: 60px; gap: 16px; flex-wrap: wrap; }
.brand { display: flex; align-items: center; gap: 10px; color: var(--c-fg); font-size: 1.15rem; }
.brand:hover { text-decoration: none; color: #fff; }
.brand strong { color: var(--c-accent); }
.topnav { display: flex; flex-wrap: wrap; gap: 4px 14px; font-size: .9rem; }
.topnav a { color: var(--c-fg-soft); padding: 4px 0; border-bottom: 2px solid transparent; }
.topnav a:hover { color: var(--c-accent-soft); border-bottom-color: var(--c-accent); text-decoration: none; }

/* Main */
.site-main { min-height: 60vh; padding-bottom: 50px; }

/* Hero */
.hero { background: radial-gradient(ellipse at top, rgba(127,29,29,.18) 0%, var(--c-bg) 65%); padding: 50px 0 30px; border-bottom: 1px solid var(--c-line); }
.hero h1 { max-width: 760px; }
.hero .lead { max-width: 760px; }

/* Cards grid (home) */
.grid-cards { display: grid; grid-template-columns: repeat(auto-fill, minmax(290px, 1fr)); gap: 18px; margin: 20px 0 40px; }
.card { display: block; background: var(--c-card); border: 1px solid var(--c-line); border-radius: var(--r); padding: 18px; transition: transform .15s, box-shadow .15s, border-color .15s; color: var(--c-fg); }
.card:hover { transform: translateY(-2px); box-shadow: var(--shadow); border-color: var(--c-line-2); text-decoration: none; }
.card-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 8px; }
.card-head h3 { margin: 0; font-size: 1.15rem; color: #fff; }
.card-summary { color: var(--c-muted); font-size: .92rem; margin: 8px 0 12px; min-height: 2.6em; }
.card-stats { list-style: none; padding: 0; margin: 0; display: grid; grid-template-columns: repeat(3, 1fr); gap: 6px; border-top: 1px solid var(--c-line); padding-top: 10px; }
.card-stats li { text-align: center; }
.card-stats strong { display: block; font-size: 1.05rem; color: var(--c-accent-soft); font-family: ui-monospace, SFMono-Regular, Menlo, monospace; }
.card-stats span { display: block; font-size: .72rem; color: var(--c-muted); text-transform: uppercase; letter-spacing: .04em; }
.card-foot { font-size: .8rem; color: var(--c-muted); margin: 10px 0 0; }

/* Badges (categorie malattia) — dark-saturated, una sola palette per tutto il sito */
.badge { display: inline-block; padding: 2px 8px; border-radius: 999px; font-size: .7rem; text-transform: uppercase; letter-spacing: .04em; background: #334155; color: #cbd5e1; }
.badge.big { font-size: .8rem; padding: 4px 12px; }
.cat-virale       { background: #78350f; color: #fde68a; }
.cat-arbovirosi   { background: #365314; color: #d9f99d; }
.cat-zoonotica    { background: #881337; color: #fecdd3; }
.cat-batterica    { background: #1e3a8a; color: #bfdbfe; }
.cat-parassitaria { background: #4c1d95; color: #ddd6fe; }
.cat-altro        { background: #334155; color: #cbd5e1; }

/* Malattia hero */
.malattia-hero { background: var(--c-card); border-bottom: 1px solid var(--c-line); padding: 30px 0 24px; }
.malattia-hero .hflex { display: flex; align-items: flex-start; gap: 20px; flex-wrap: wrap; }
.malattia-hero .grow { flex: 1 1 60%; min-width: 260px; }
.breadcrumb { font-size: .85rem; color: var(--c-muted); margin: 0 0 6px; }
.malattia-hero ul.meta { list-style: none; padding: 0; margin: 18px 0 0; display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); gap: 14px; }
.malattia-hero ul.meta li { display: flex; flex-direction: column; padding: 8px 12px; background: var(--c-card-2); border: 1px solid var(--c-line-2); border-radius: 8px; }
.malattia-hero ul.meta span { font-size: .72rem; color: var(--c-muted); text-transform: uppercase; letter-spacing: .04em; }
.malattia-hero ul.meta strong { font-size: .95rem; color: var(--c-fg); }

/* Stats strip */
.stats-strip { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: 14px; margin: 24px auto; }
.stat { background: var(--c-card); padding: 18px; border: 1px solid var(--c-line); border-radius: var(--r); text-align: center; }
.stat strong { display: block; font-size: 1.55rem; color: var(--c-accent-soft); font-family: ui-monospace, SFMono-Regular, Menlo, monospace; }
.stat span { font-size: .8rem; color: var(--c-muted); }

/* Map */
.world-map { height: 560px; width: 100%; border-radius: var(--r); border: 1px solid var(--c-line); background: #02030a; margin: 14px 0; }
.map-legend { background: rgba(4,6,12,.92); color: var(--c-fg-soft); padding: 10px 12px; border-radius: 6px; font-size: .8rem; box-shadow: var(--shadow); line-height: 1.6; border: 1px solid var(--c-line-2); }
.map-legend strong { color: #fff; }
.map-legend .sw { display: inline-block; width: 14px; height: 14px; margin-right: 6px; vertical-align: middle; border: 1px solid #2a3447; }
.map-info { background: rgba(4,6,12,.92); color: var(--c-fg-soft); padding: 10px 12px; border-radius: 6px; min-width: 180px; font-size: .85rem; box-shadow: var(--shadow); border: 1px solid var(--c-line-2); }
.map-info strong { color: #fff; }
.map-legend-note { font-size: .82rem; color: var(--c-muted); }
.map-error { color: var(--c-accent); padding: 30px; text-align: center; }

/* Leaflet popup dark override */
.leaflet-popup-content-wrapper { background: var(--c-card); color: var(--c-fg); border: 1px solid var(--c-line-2); box-shadow: var(--shadow); }
.leaflet-popup-tip { background: var(--c-card); }
.leaflet-popup-content a { color: var(--c-accent-soft); }
.leaflet-container .leaflet-control-attribution { background: rgba(4,6,12,.88); color: var(--c-muted); }
.leaflet-container .leaflet-control-attribution a { color: var(--c-fg-soft); }
.leaflet-bar a, .leaflet-bar a:hover { background: var(--c-card); color: var(--c-fg); border-bottom-color: var(--c-line-2); }

/* Pulsing pin (Leaflet divIcon) — ring lampeggiante + core fisso, severità → velocità */
.pulse-pin { position: relative; pointer-events: auto; }
.pulse-pin .pulse-core {
  position: absolute; top: 30%; left: 30%; width: 40%; height: 40%;
  border-radius: 50%;
  background: var(--pin-color, #ef4444);
  border: 1.5px solid #fff;
  box-shadow: 0 0 6px rgba(0,0,0,.6);
  z-index: 2;
}
.pulse-pin .pulse-ring {
  position: absolute; top: 0; left: 0; width: 100%; height: 100%;
  border-radius: 50%;
  background: var(--pin-color, #ef4444);
  opacity: .55;
  animation: pulse-ring var(--pin-speed, 2s) ease-out infinite;
  z-index: 1;
}
@keyframes pulse-ring {
  0%   { transform: scale(.35); opacity: .8; }
  70%  { opacity: 0; }
  100% { transform: scale(2.2); opacity: 0; }
}
@media (prefers-reduced-motion: reduce) {
  .pulse-pin .pulse-ring { animation: none; opacity: .4; }
}

/* Press signal pin — ring viola lampeggiante SENZA fill (segnale stampa non verificato) */
.press-pin { position: relative; pointer-events: auto; }
.press-pin .press-ring {
  position: absolute; top: 0; left: 0; width: 100%; height: 100%;
  border-radius: 50%;
  border: 2px solid #c084fc;
  background: rgba(192,132,252,.08);
  box-shadow: 0 0 8px rgba(192,132,252,.45) inset, 0 0 6px rgba(192,132,252,.35);
  animation: press-ring var(--press-speed, 3s) ease-out infinite;
}
@keyframes press-ring {
  0%   { transform: scale(.6); opacity: .25; }
  35%  { opacity: .9; }
  100% { transform: scale(1.6); opacity: 0; }
}
@media (prefers-reduced-motion: reduce) {
  .press-pin .press-ring { animation: none; opacity: .55; }
}

/* Section divider DATI UFFICIALI — separa il blocco stampa-prima dal resto */
.dati-ufficiali-divider { margin-top: 36px; }
.section-divider {
  display: flex; align-items: center; gap: 16px;
  padding: 14px 0;
  border-top: 1px solid var(--c-line);
}
.section-divider .div-label {
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
  font-size: .76rem; letter-spacing: .12em; font-weight: 700;
  color: #bfdbfe; background: #1e3a8a;
  padding: 4px 10px; border-radius: 4px;
}
.section-divider .div-note { font-size: .82rem; color: var(--c-muted); }

/* Wire press: leggermente più alto/respirante per dare peso visivo */
.wire-press { padding: 12px 18px; }
.wire-press .wire-item { font-size: .92rem; padding: 9px 0; }

/* Two-col */
.two-col { display: grid; grid-template-columns: 2fr 1fr; gap: 30px; margin: 30px auto; }
@media (max-width: 720px) { .two-col { grid-template-columns: 1fr; } }

/* Bollettini */
ul.bollettini { list-style: none; padding: 0; margin: 0; }
ul.bollettini li { padding: 10px 0; border-bottom: 1px solid var(--c-line); display: grid; grid-template-columns: 90px 1fr; gap: 10px; align-items: baseline; }
ul.bollettini time { font-size: .85rem; color: var(--c-muted); font-family: ui-monospace, SFMono-Regular, Menlo, monospace; }
ul.bollettini a { color: var(--c-fg); }
ul.bollettini a:hover { color: var(--c-accent-soft); }
ul.bollettini .fonte { display: block; font-size: .78rem; color: var(--c-muted); margin-top: 2px; }

/* Fonti */
.fonti-list { list-style: none; padding: 0; margin: 0; }
.fonti-list li { padding: 10px 0; border-bottom: 1px solid var(--c-line); }
.fonti-list small { display: block; color: var(--c-muted); font-size: .78rem; }

/* Alerts */
.alerts { list-style: none; padding: 0; margin: 0; }
.alert { padding: 10px 14px; border-left: 3px solid var(--c-info); margin: 6px 0; background: rgba(56,189,248,.08); border-radius: 4px; font-size: .92rem; color: var(--c-fg-soft); }
.alert-warning { border-color: var(--c-warn); background: rgba(245,158,11,.1); }
.alert-critical { border-color: var(--c-accent); background: rgba(239,68,68,.1); }
.alert time { color: var(--c-muted); font-size: .82rem; margin-right: 8px; font-family: ui-monospace, SFMono-Regular, Menlo, monospace; }
.alert .area { color: var(--c-muted); }

.empty { color: var(--c-muted); font-style: italic; }

/* Methodology / article */
.methodology { background: var(--c-card); padding: 22px; border: 1px solid var(--c-line); border-radius: var(--r); margin: 40px auto; }
.article { background: var(--c-card); padding: 28px; border: 1px solid var(--c-line); border-radius: var(--r); margin: 30px auto; }

/* Medical disclaimer */
.medical { font-size: .85rem; background: rgba(202,138,4,.12); border-left: 3px solid #ca8a04; padding: 10px 14px; border-radius: 4px; color: #fde68a; }
.medical strong { color: #fef3c7; }
.inline-medical { margin-top: 26px; }

/* Content article (deep content sulla dashboard malattia) */
.content-article { background: var(--c-card); border: 1px solid var(--c-line); border-radius: var(--r); padding: 28px 32px; margin: 14px 0 24px; }
.content-article h2 { font-size: 1.35rem; margin: 1.3em 0 .5em; color: #fff; border-bottom: 1px solid var(--c-line); padding-bottom: 6px; }
.content-article h2:first-child { margin-top: .2em; }
.content-article h3 { font-size: 1.05rem; margin: 1.2em 0 .3em; color: var(--c-fg); }
.content-article p { color: var(--c-fg-soft); }
.content-article ul, .content-article ol { color: var(--c-fg-soft); padding-left: 22px; }
.content-article li { margin: .3em 0; }
.content-article a { color: var(--c-accent-soft); border-bottom: 1px dotted var(--c-accent-dark); }
.content-article a:hover { color: var(--c-accent); text-decoration: none; border-bottom-color: var(--c-accent); }
.content-article .key-facts { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 10px; margin: 14px 0 22px; padding: 0; list-style: none; }
.content-article .key-facts li { background: var(--c-card-2); border: 1px solid var(--c-line-2); border-radius: 6px; padding: 8px 12px; font-size: .88rem; color: var(--c-fg); margin: 0; }
.content-article .key-facts li strong { display: block; font-size: .68rem; color: var(--c-muted); text-transform: uppercase; letter-spacing: .08em; margin-bottom: 2px; }
.content-article details.faq-q { background: var(--c-card-2); border: 1px solid var(--c-line); border-radius: 6px; padding: 4px 14px; margin: 8px 0; }
.content-article details.faq-q summary { cursor: pointer; font-weight: 600; padding: 8px 0; color: var(--c-fg); list-style: none; }
.content-article details.faq-q summary::before { content: '+'; display: inline-block; width: 1.2em; color: var(--c-accent); font-weight: 700; }
.content-article details.faq-q[open] summary::before { content: '−'; }
.content-article details.faq-q .faq-a { padding: 0 0 10px 0; color: var(--c-fg-soft); border-top: 1px dashed var(--c-line); margin-top: 4px; padding-top: 8px; }

.related-cards .card { min-height: 140px; }
.related-cards .card-summary { min-height: 3.6em; }

/* Footer multi-column grid (internal linking) */
.footer-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 24px; margin: 0 0 26px; padding: 0 0 24px; border-bottom: 1px solid var(--c-line); }
.footer-col h3.footer-h { font-size: .8rem; text-transform: uppercase; letter-spacing: .1em; color: var(--c-muted); margin: 0 0 10px; padding: 0; border: 0; }
.footer-col ul { list-style: none; padding: 0; margin: 0; }
.footer-col li { padding: 3px 0; font-size: .88rem; }
.footer-col a { color: var(--c-fg-soft); border-bottom: 0; }
.footer-col a:hover { color: #fcd34d; text-decoration: none; }

/* Footer */
.site-footer { background: #02030a; color: var(--c-fg-soft); padding: 30px 0; margin-top: 60px; font-size: .88rem; border-top: 1px solid var(--c-line); }
.site-footer a { color: #fcd34d; }
.site-footer .medical { background: rgba(255,255,255,0.04); color: #fcd34d; border-color: #ca8a04; }
.site-footer .copy { color: var(--c-muted); margin-top: 14px; }

/* =========================================================
   DASHBOARD STYLE (hantavirustracer-like)
   ========================================================= */

/* Live strip */
.live-strip { background: #02030a; color: var(--c-fg-soft); font-size: .8rem; letter-spacing: .04em; border-bottom: 1px solid var(--c-line); }
.live-strip .container { padding: 8px 20px; }
.live-strip .hflex { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }
.live-strip .grow { flex: 1; }
.live-strip .live { display: inline-flex; align-items: center; gap: 6px; color: #4ade80; font-weight: 700; text-transform: uppercase; }
.live-strip .live .dot { width: 8px; height: 8px; border-radius: 50%; background: #4ade80; box-shadow: 0 0 0 0 rgba(74,222,128,.7); animation: pulse 2s infinite; }
@keyframes pulse {
  0%   { box-shadow: 0 0 0 0 rgba(74,222,128,.7); }
  70%  { box-shadow: 0 0 0 10px rgba(74,222,128,0); }
  100% { box-shadow: 0 0 0 0 rgba(74,222,128,0); }
}
.live-strip .utc { font-family: ui-monospace, SFMono-Regular, Menlo, monospace; color: var(--c-muted); }
.live-strip .pill { background: var(--c-card-2); color: var(--c-fg); padding: 3px 8px; border-radius: 4px; font-size: .72rem; text-transform: uppercase; letter-spacing: .05em; font-weight: 600; }
.live-strip .pill.trend-up      { background: #7f1d1d; color: #fecaca; }
.live-strip .pill.trend-down    { background: #064e3b; color: #a7f3d0; }
.live-strip .pill.trend-stable  { background: #334155; color: #cbd5e1; }
.live-strip .pill.trend-unknown { background: #1e293b; color: #94a3b8; }
.live-strip .pill.cat-virale       { background: #78350f; color: #fde68a; }
.live-strip .pill.cat-arbovirosi   { background: #365314; color: #d9f99d; }
.live-strip .pill.cat-zoonotica    { background: #881337; color: #fecdd3; }
.live-strip .pill.cat-batterica    { background: #1e3a8a; color: #bfdbfe; }
.live-strip .pill.cat-parassitaria { background: #4c1d95; color: #ddd6fe; }
.live-strip .pill.cat-altro        { background: #334155; color: #cbd5e1; }
.live-strip .muted { color: var(--c-muted); }
.live-strip .back { color: #fcd34d; font-size: .78rem; }

/* Dash hero (compact) */
.dash-hero { padding: 28px 0 18px; background: var(--c-card); border-bottom: 1px solid var(--c-line); }
.dash-hero h1 { margin: 2px 0 6px; font-size: 2rem; }
.dash-hero .lead { margin: 0; max-width: 820px; }
.dash-hero .breadcrumb { margin: 0; font-size: .82rem; color: var(--c-muted); }

.dash-h2 { font-size: 1.05rem; text-transform: uppercase; letter-spacing: .08em; color: var(--c-muted); border-bottom: 1px solid var(--c-line); padding-bottom: 8px; margin: 28px 0 14px; }
.dash-h2 small { text-transform: none; letter-spacing: 0; color: var(--c-muted); }

/* Counter row */
.counter-row { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: 10px; margin: 18px 0 8px; }
.counter { background: var(--c-card); color: var(--c-fg); padding: 14px 16px; border-radius: 8px; border: 1px solid var(--c-line-2); }
.counter strong { display: block; font-family: ui-monospace, SFMono-Regular, Menlo, monospace; font-size: 1.7rem; line-height: 1.1; color: #fff; letter-spacing: -.02em; }
.counter span { display: block; font-size: .68rem; text-transform: uppercase; letter-spacing: .1em; color: var(--c-muted); margin-top: 6px; }
.counter span small { color: #64748b; font-size: .85em; margin-left: 4px; }
.counter.accent strong { color: var(--c-accent-soft); }

/* Map filter (home) */
.map-filter { display: flex; flex-wrap: wrap; gap: 6px; margin: 6px 0 10px; }
.mf-btn { padding: 6px 12px; border: 1px solid var(--c-line-2); background: var(--c-card); color: var(--c-fg-soft); border-radius: 999px; font-size: .82rem; cursor: pointer; transition: all .15s; }
.mf-btn:hover { border-color: var(--c-accent); color: var(--c-fg); }
.mf-btn.active { background: var(--c-fg); color: #04060c; border-color: var(--c-fg); }
.mf-btn.cat-virale.active       { background: #f59e0b; border-color: #f59e0b; color: #1c1917; }
.mf-btn.cat-arbovirosi.active   { background: #84cc16; border-color: #84cc16; color: #1a2e05; }
.mf-btn.cat-zoonotica.active    { background: #f43f5e; border-color: #f43f5e; color: #1f0a14; }
.mf-btn.cat-batterica.active    { background: #3b82f6; border-color: #3b82f6; color: #0b1224; }

/* Map enhancements */
.map-counters { background: rgba(2,3,10,.92); color: var(--c-fg); padding: 8px 12px; border-radius: 6px; display: flex; gap: 14px; font-size: .78rem; box-shadow: var(--shadow); border: 1px solid var(--c-line-2); }
.map-counters span { display: inline-flex; align-items: baseline; gap: 4px; }
.map-counters strong { font-family: ui-monospace, SFMono-Regular, Menlo, monospace; color: #fff; font-size: 1rem; }
.map-legend .legend-label { font-size: .78rem; color: var(--c-muted); margin-bottom: 4px; }

/* Situation brief */
.brief { background: var(--c-card); border: 1px solid var(--c-line); border-left: 4px solid var(--c-accent); border-radius: 8px; padding: 18px 22px; }
.brief-head { display: flex; align-items: center; gap: 10px; font-size: .82rem; color: var(--c-muted); margin-bottom: 8px; flex-wrap: wrap; }
.brief-head .pill { padding: 2px 8px; border-radius: 4px; font-size: .68rem; text-transform: uppercase; letter-spacing: .05em; font-weight: 600; background: var(--c-card-2); color: var(--c-fg-soft); }
.brief-head .pill.trend-up      { background: #7f1d1d; color: #fecaca; }
.brief-head .pill.trend-down    { background: #064e3b; color: #a7f3d0; }
.brief-head .pill.trend-stable  { background: #334155; color: #cbd5e1; }
.brief-head .pill.trend-unknown { background: #1e293b; color: #94a3b8; }
.brief h3 { margin: 4px 0 8px; font-size: 1.1rem; color: #fff; }
.brief-body { color: var(--c-fg-soft); }
.brief-source { font-size: .82rem; color: var(--c-muted); margin-top: 12px; padding-top: 10px; border-top: 1px dashed var(--c-line-2); display: flex; gap: 12px; flex-wrap: wrap; }
.source-tag { background: var(--c-card-2); color: var(--c-fg); padding: 2px 8px; border-radius: 4px; font-size: .7rem; text-transform: uppercase; letter-spacing: .05em; }

/* Signals grid */
.signals { list-style: none; padding: 0; margin: 0; display: grid; grid-template-columns: repeat(auto-fill, minmax(190px, 1fr)); gap: 10px; }
.signals li { background: var(--c-card); border: 1px solid var(--c-line); border-radius: 6px; padding: 10px 12px; }
.signals span { display: block; font-size: .68rem; color: var(--c-muted); text-transform: uppercase; letter-spacing: .08em; }
.signals strong { display: block; font-size: .95rem; margin-top: 4px; color: var(--c-fg); }

/* Timeline D-N */
.timeline { list-style: none; padding: 0; margin: 0; }
.timeline li { display: grid; grid-template-columns: 50px 90px auto 1fr auto; gap: 10px; align-items: baseline; padding: 9px 0; border-bottom: 1px solid var(--c-line); font-size: .92rem; }
.timeline .day { font-family: ui-monospace, SFMono-Regular, Menlo, monospace; font-weight: 700; color: var(--c-fg); background: var(--c-card-2); padding: 2px 6px; border-radius: 4px; text-align: center; font-size: .8rem; }
.timeline time { font-size: .82rem; color: var(--c-muted); font-family: ui-monospace, SFMono-Regular, Menlo, monospace; }
.timeline a { color: var(--c-fg); }
.timeline a:hover { color: var(--c-accent-soft); }
.timeline small { font-size: .78rem; color: var(--c-muted); }
@media (max-width: 720px) {
  .timeline li { grid-template-columns: 44px 1fr; }
  .timeline time, .timeline small { grid-column: 2; font-size: .78rem; }
  .timeline .src-tag { grid-column: 2; }
}

/* Source tags */
.src-tag { font-family: ui-monospace, SFMono-Regular, Menlo, monospace; font-size: .68rem; text-transform: uppercase; letter-spacing: .05em; padding: 2px 6px; border-radius: 3px; background: var(--c-card-2); color: var(--c-fg-soft); font-weight: 600; }
.src-official { background: #1e3a8a; color: #bfdbfe; }
.src-science  { background: #4c1d95; color: #ddd6fe; }
.src-media    { background: #701a75; color: #f5d0fe; }
.src-signal   { background: #78350f; color: #fde68a; }
.src-cases    { background: #7f1d1d; color: #fecaca; }
.src-response { background: #064e3b; color: #a7f3d0; }

/* Countries table */
.countries-table-wrap { overflow-x: auto; background: var(--c-card); border: 1px solid var(--c-line); border-radius: 8px; }
.countries-table { width: 100%; border-collapse: collapse; font-size: .92rem; color: var(--c-fg); }
.countries-table th { text-align: left; padding: 10px 12px; background: var(--c-card-2); border-bottom: 1px solid var(--c-line-2); font-size: .72rem; text-transform: uppercase; letter-spacing: .06em; color: var(--c-muted); font-weight: 600; }
.countries-table th.num, .countries-table td.num { text-align: right; }
.countries-table td { padding: 9px 12px; border-bottom: 1px solid var(--c-line); }
.countries-table tr:last-child td { border-bottom: none; }
.countries-table tr:hover td { background: rgba(30,41,59,.5); }
.countries-table td.flag { font-size: 1.2rem; width: 36px; }
.countries-table .mono { font-family: ui-monospace, SFMono-Regular, Menlo, monospace; }
.countries-table .muted { font-size: .82rem; color: var(--c-muted); }
.countries-table a { color: var(--c-fg); }
.countries-table a:hover { color: var(--c-accent-soft); }

/* News wire */
.wire-filters { display: flex; gap: 6px; margin: 0 0 12px; flex-wrap: wrap; }
.wf-btn { padding: 5px 12px; border: 1px solid var(--c-line-2); background: var(--c-card); color: var(--c-fg-soft); border-radius: 4px; font-size: .76rem; font-family: ui-monospace, SFMono-Regular, Menlo, monospace; text-transform: uppercase; letter-spacing: .05em; cursor: pointer; }
.wf-btn:hover { color: var(--c-fg); border-color: var(--c-accent); }
.wf-btn.active { background: var(--c-fg); color: #04060c; border-color: var(--c-fg); }
.wire { list-style: none; padding: 0; margin: 0; background: #02030a; border-radius: 8px; padding: 8px 14px; border: 1px solid var(--c-line); }
.wire-item { display: flex; flex-wrap: wrap; gap: 8px; align-items: baseline; padding: 7px 0; border-bottom: 1px solid var(--c-line); font-size: .88rem; color: var(--c-fg-soft); }
.wire-item .ago { min-width: 76px; }
.wire-item > a { flex: 1 1 280px; }
.wire-item:last-child { border-bottom: none; }
.wire-item .ago { font-family: ui-monospace, SFMono-Regular, Menlo, monospace; color: var(--c-muted); font-size: .76rem; }
.wire-item a { color: var(--c-fg); }
.wire-item a:hover { color: #fcd34d; text-decoration: none; }
.wire-item small { color: #64748b; font-size: .76rem; }
.wire-item .mal-chip { font-size: .68rem; padding: 2px 6px; border-radius: 3px; text-transform: uppercase; letter-spacing: .04em; font-weight: 600; }
.wire-item .mal-chip.cat-virale       { background: #78350f; color: #fde68a; }
.wire-item .mal-chip.cat-arbovirosi   { background: #365314; color: #d9f99d; }
.wire-item .mal-chip.cat-zoonotica    { background: #881337; color: #fecdd3; }
.wire-item .mal-chip.cat-batterica    { background: #1e3a8a; color: #bfdbfe; }
.wire-item .mal-chip.cat-parassitaria { background: #4c1d95; color: #ddd6fe; }
.wire-item .mal-chip.cat-altro        { background: #334155; color: #cbd5e1; }
.wire-item .src-tag { background: var(--c-card-2); color: var(--c-muted); }
.wire-item .src-tag.src-official { background: #1e3a8a; color: #bfdbfe; }
.wire-item .src-tag.src-science  { background: #4c1d95; color: #ddd6fe; }
.wire-item .src-tag.src-media    { background: #701a75; color: #f5d0fe; }
.wire-item .src-tag.src-signal   { background: #78350f; color: #fde68a; }
.wire-item .src-tag.src-cases    { background: #7f1d1d; color: #fecaca; }
.wire-item .src-tag.src-response { background: #064e3b; color: #a7f3d0; }
@media (max-width: 720px) {
  .wire-item { grid-template-columns: 70px 80px 1fr; row-gap: 4px; }
  .wire-item small, .wire-item .mal-chip { grid-column: 1 / -1; }
}

/* Virus profile (collapsible) */
.virus-profile { background: var(--c-card); border: 1px solid var(--c-line); border-radius: 8px; padding: 4px 18px; }
.virus-profile summary { cursor: pointer; font-weight: 600; padding: 12px 0; font-size: 1rem; color: var(--c-fg); list-style: none; }
.virus-profile summary::-webkit-details-marker { display: none; }
.virus-profile summary::before { content: '▸'; display: inline-block; margin-right: 8px; transition: transform .15s; color: var(--c-accent); }
.virus-profile[open] summary::before { transform: rotate(90deg); }
.virus-profile .vp-body { padding-bottom: 16px; color: var(--c-fg-soft); }

/* Event banner (malattie con solo aggregato globale, no per-country data) */
.event-banner { background: rgba(217,119,6,.08); border: 1px solid #78350f; border-left: 4px solid #d97706; border-radius: 8px; padding: 18px 22px; font-size: .95rem; color: #fde68a; }
.event-banner strong { color: #fef3c7; font-size: 1rem; }
.event-banner span { font-family: ui-monospace, SFMono-Regular, Menlo, monospace; font-weight: 600; margin: 0 4px; color: #fff; }
.event-banner small { color: #fcd34d; font-weight: normal; }
.event-banner p { margin: 10px 0 6px; color: #fde68a; }
.event-banner a { color: #fcd34d; font-weight: 600; }

/* Sources grid */
.sources-grid { list-style: none; padding: 0; margin: 0; display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 10px; }
.sources-grid li { background: var(--c-card); border: 1px solid var(--c-line); border-radius: 6px; padding: 10px 12px; }
.sources-grid small { display: block; color: var(--c-muted); font-size: .76rem; }

/* Pagine legali — tabelle privacy/cookie */
.table-simple { width: 100%; border-collapse: collapse; margin: 14px 0 20px; font-size: .88rem; background: var(--c-card-2); border: 1px solid var(--c-line-2); border-radius: 6px; overflow: hidden; }
.table-simple th { background: var(--c-card); padding: 9px 12px; text-align: left; font-size: .72rem; text-transform: uppercase; letter-spacing: .06em; color: var(--c-muted); font-weight: 600; border-bottom: 1px solid var(--c-line-2); }
.table-simple td { padding: 9px 12px; color: var(--c-fg-soft); border-bottom: 1px solid var(--c-line); vertical-align: top; }
.table-simple tr:last-child td { border-bottom: none; }
.table-simple code { background: var(--c-bg-elev); padding: 1px 6px; border-radius: 3px; font-size: .85em; color: var(--c-accent-soft); }
@media (max-width: 640px) {
  .table-simple { font-size: .8rem; }
  .table-simple th, .table-simple td { padding: 7px 9px; }
}

/* Cookie banner GDPR — fixed bottom, dark, compatto */
.cookie-banner {
  position: fixed; bottom: 16px; left: 16px; right: 16px; max-width: 520px;
  margin-left: auto;
  background: var(--c-card); color: var(--c-fg);
  border: 1px solid var(--c-line-2); border-radius: 10px;
  padding: 14px 18px;
  box-shadow: 0 6px 24px rgba(0,0,0,.55);
  z-index: 9999;
  font-size: .88rem;
}
.cookie-banner h3 { margin: 0 0 6px; font-size: .95rem; color: #fff; }
.cookie-banner p { margin: 0 0 10px; color: var(--c-fg-soft); font-size: .85rem; line-height: 1.45; }
.cookie-banner a { color: var(--c-accent-soft); border-bottom: 1px dotted var(--c-accent-dark); }
.cookie-banner a:hover { color: var(--c-accent); border-bottom-color: var(--c-accent); }
.cookie-banner .cookie-actions { display: flex; gap: 8px; flex-wrap: wrap; justify-content: flex-end; }
.cookie-banner button {
  border: 1px solid var(--c-line-2); background: var(--c-card-2); color: var(--c-fg);
  padding: 7px 14px; border-radius: 6px; font-size: .82rem; cursor: pointer;
  font-family: inherit; transition: all .15s;
}
.cookie-banner button.ck-reject:hover { border-color: var(--c-fg-soft); }
.cookie-banner button.ck-analytics { border-color: var(--c-line-2); }
.cookie-banner button.ck-analytics:hover { border-color: var(--c-info); color: var(--c-info); }
.cookie-banner button.ck-accept {
  background: var(--c-accent-dark); border-color: var(--c-accent-dark); color: #fff;
  font-weight: 600;
}
.cookie-banner button.ck-accept:hover { background: var(--c-accent); border-color: var(--c-accent); }
@media (max-width: 480px) {
  .cookie-banner { left: 8px; right: 8px; bottom: 8px; padding: 12px 14px; }
  .cookie-banner .cookie-actions { justify-content: stretch; }
  .cookie-banner button { flex: 1 1 0; }
}

/* Scrollbars dark */
::-webkit-scrollbar { width: 12px; height: 12px; }
::-webkit-scrollbar-track { background: var(--c-bg); }
::-webkit-scrollbar-thumb { background: var(--c-line-2); border-radius: 6px; border: 3px solid var(--c-bg); }
::-webkit-scrollbar-thumb:hover { background: #475569; }

/* =========================================================
   MOBILE RESPONSIVE (≤720px)
   Numeri grandi che debordano + grid che non si adatta sotto i 380px.
   ========================================================= */
@media (max-width: 720px) {
  .container { padding: 0 14px; }

  /* Hero / dash-hero: meno padding e h1 più piccolo */
  .hero       { padding: 30px 0 18px; }
  .dash-hero  { padding: 18px 0 12px; }
  .hero h1, .dash-hero h1 { font-size: 1.55rem; }
  h1 { font-size: 1.55rem; }
  h2 { font-size: 1.2rem; }
  p.lead { font-size: 1rem; }

  /* Live strip: stack su 2 righe, fonti più piccole */
  .live-strip { font-size: .72rem; }
  .live-strip .container { padding: 6px 14px; }
  .live-strip .hflex { gap: 8px; row-gap: 4px; }
  .live-strip .muted { display: none; } /* "Ultimo bollettino: 3h fa" ridondante su mobile */
  .live-strip .back { font-size: .72rem; }

  /* Counter row: 2 colonne fluide, numeri scalati su clamp */
  .counter-row { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 8px; }
  .counter { padding: 10px 12px; min-width: 0; overflow: hidden; }
  .counter strong {
    font-size: clamp(1rem, 5.2vw, 1.5rem);
    font-variant-numeric: tabular-nums;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    letter-spacing: -.04em;
  }
  .counter span { font-size: .6rem; letter-spacing: .06em; }
  .counter span small { display: none; } /* "12m" off-screen su mobile */

  /* Stat strip (legacy home) */
  .stats-strip { grid-template-columns: repeat(2, 1fr); gap: 8px; }
  .stat strong { font-size: 1.2rem; white-space: nowrap; }

  /* Card grid: una colonna piena */
  .grid-cards { grid-template-columns: 1fr; gap: 12px; }
  .card-stats { grid-template-columns: repeat(3, 1fr); }
  .card-stats strong { font-size: .92rem; white-space: nowrap; }

  /* Map: più bassa */
  .world-map { height: 380px; }
  .map-legend, .map-info, .map-counters { font-size: .68rem; padding: 6px 8px; }
  .map-counters { flex-wrap: wrap; max-width: calc(100vw - 24px); gap: 8px; }
  .map-counters strong { font-size: .82rem; }

  /* Brief */
  .brief { padding: 14px 16px; }
  .brief h3 { font-size: 1rem; }

  /* Signals (profilo agente) */
  .signals { grid-template-columns: 1fr 1fr; gap: 8px; }
  .signals li { padding: 8px 10px; }
  .signals strong { font-size: .85rem; }

  /* Countries table: pad ridotto, font giù */
  .countries-table { font-size: .82rem; }
  .countries-table th, .countries-table td { padding: 7px 8px; }
  .countries-table th { font-size: .62rem; }
  .countries-table td.flag { width: 24px; font-size: 1rem; }

  /* Malattia hero meta grid */
  .malattia-hero { padding: 18px 0 14px; }
  .malattia-hero ul.meta { grid-template-columns: 1fr 1fr; gap: 8px; margin-top: 12px; }
  .malattia-hero ul.meta li { padding: 6px 10px; }
  .malattia-hero ul.meta strong { font-size: .85rem; }

  /* Dash-h2 più compatto */
  .dash-h2 { font-size: .92rem; margin: 20px 0 10px; }

  /* Wire press */
  .wire-press { padding: 8px 12px; }
  .wire-item { font-size: .82rem; row-gap: 4px; }
  .wire-item .ago { min-width: 60px; }

  /* Section divider */
  .section-divider { gap: 10px; padding: 12px 0; flex-wrap: wrap; }
  .section-divider .div-label { font-size: .68rem; padding: 3px 8px; }
  .section-divider .div-note { font-size: .74rem; }

  /* Header / topnav */
  .site-header .hflex { gap: 8px; min-height: 50px; }
  .topnav { font-size: .82rem; gap: 2px 10px; }
  .brand { font-size: 1rem; }

  /* Event banner */
  .event-banner { padding: 14px 16px; font-size: .88rem; }
}

/* Phone stretto (≤380px): counters in colonna unica */
@media (max-width: 380px) {
  .counter-row { grid-template-columns: 1fr; }
  .counter { display: flex; align-items: baseline; justify-content: space-between; gap: 8px; }
  .counter strong { font-size: 1.1rem; }
  .counter span { margin-top: 0; }
  .signals { grid-template-columns: 1fr; }
}
