:root{
  --bg:#f4f5f7; --panel:#fff; --ink:#1f2430; --muted:#6b7280; --line:#e5e7eb;
  --accent:#1d6fb8; --accent-d:#155a96;
  --shadow:0 1px 3px rgba(0,0,0,.08),0 1px 2px rgba(0,0,0,.04);
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;font:15px/1.45 system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
  color:var(--ink);background:var(--bg);display:flex;flex-direction:column
}

#banner-file{background:#fff3cd;color:#664d03;border-bottom:1px solid #ffe69c;padding:10px 16px;font-size:13px}
#banner-file code{background:rgba(0,0,0,.06);padding:1px 5px;border-radius:4px}

#testata{display:flex;align-items:center;gap:18px;flex-wrap:wrap;padding:12px 18px;background:var(--panel);border-bottom:1px solid var(--line)}
.brand h1{margin:0;font-size:18px;letter-spacing:.2px}
.brand .sub{font-size:12px;color:var(--muted)}
#cerca{display:flex;gap:8px;flex:1;min-width:260px;max-width:560px}
#indirizzo{flex:1;padding:9px 12px;border:1px solid var(--line);border-radius:8px;font-size:14px}
#indirizzo:focus{outline:none;border-color:var(--accent)}
#cerca button{padding:9px 16px;border:0;border-radius:8px;background:var(--accent);color:#fff;font-weight:600;cursor:pointer}
#cerca button:hover{background:var(--accent-d)}
.hint{margin:0;font-size:12px;color:var(--muted);width:100%}

#contenuto{flex:1;display:flex;min-height:0}
#mappa{flex:1;min-width:0}
#pannello{width:380px;max-width:42vw;background:var(--panel);border-left:1px solid var(--line);overflow-y:auto;padding:16px}
@media(max-width:760px){
  html,body{height:auto}              /* la pagina scorre invece di essere bloccata a 100vh */
  body{display:block}
  #testata{position:sticky;top:0;z-index:1100}  /* barra di ricerca sempre raggiungibile */
  #contenuto{display:block;min-height:0}
  #mappa{height:52vh;min-height:260px}          /* mappa ad altezza fissa, non tutto lo schermo */
  #pannello{width:auto;max-width:none;border-left:0;border-top:1px solid var(--line);overflow:visible}
}

.placeholder{color:var(--muted);font-size:14px;line-height:1.6}
.titolo-ris{margin:0 0 2px;font-size:16px}
.coord{margin:0 0 12px;font-size:12px}
.muted{color:var(--muted)}

.card{background:#fff;border:1px solid var(--line);border-radius:10px;padding:12px 14px;margin-bottom:14px;box-shadow:var(--shadow)}
.card h3{margin:0 0 8px;font-size:14px}

table.omi{width:100%;border-collapse:collapse;font-size:13px}
table.omi th,table.omi td{text-align:left;padding:5px 6px;border-bottom:1px solid var(--line)}
table.omi th{color:var(--muted);font-weight:600;font-size:11px;vertical-align:bottom}
table.omi td:not(:first-child){text-align:right;font-variant-numeric:tabular-nums;white-space:nowrap}

.score{display:flex;align-items:baseline;gap:4px;margin:2px 0 10px}
.score-num{font-size:42px;font-weight:800;line-height:1;color:var(--accent)}
.score-den{font-size:16px;color:var(--muted)}

ul.breakdown{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:9px}
.bd-top{display:flex;justify-content:space-between;font-size:13px;margin-bottom:3px}
.sat{font-size:11px}
.bar{height:8px;background:#eef0f3;border-radius:5px;overflow:hidden}
.bar-fill{height:100%;border-radius:5px;transition:width .3s}

.nota{margin:8px 0 0;font-size:11px;color:var(--muted)}
.nota code,.fonti code{background:rgba(0,0,0,.05);padding:0 4px;border-radius:4px}
.fonti{font-size:11px;color:var(--muted);border-top:1px solid var(--line);padding-top:10px;margin-top:4px}
.errore{color:#b91c1c;font-size:13px}
.loader{color:var(--muted);font-size:14px}

#piede{padding:8px 16px;background:var(--panel);border-top:1px solid var(--line);font-size:11px;color:var(--muted)}

.legenda{background:#fff;padding:8px 10px;border-radius:8px;box-shadow:var(--shadow);font-size:11px;line-height:1.7}
.legenda b{display:block;margin-bottom:4px}
.legenda span{display:flex;align-items:center;gap:6px}
.legenda i{width:12px;height:12px;border-radius:3px;display:inline-block}
