/* =====================================================================
   Scrutinio 2027 — Simulatore seggi Municipi di Milano
   Sessione B (UI/UX). Stile "Liquid Glass" POL.AI: vetro solo sulla
   navigazione (mini-barra sticky), contenuto su card piene, tinta teal
   per le azioni + accento ambra. Mobile-first, AA, prefers-reduced-motion.
   ===================================================================== */

:root{
  --font-ui:'Archivo',-apple-system,BlinkMacSystemFont,'SF Pro Text',system-ui,sans-serif;
  --font-mono:'IBM Plex Mono',ui-monospace,SFMono-Regular,Menlo,monospace;

  --bg:#eef1ee; --bg-deep:#e4e8e3;
  --surface:#ffffff; --surface-2:#f4f6f3;
  --border:rgba(24,34,37,.12); --hairline:rgba(24,34,37,.08);
  --text:#152023; --text-2:#4a5a5c; --text-3:#6f7e7c;

  --brand:#0e5460; --brand-deep:#0a3c45; --brand-soft:#e0edee; --brand-mid:#3e7e8a;
  --alert:#c73e1d; --alert-soft:#fbe9e3;
  --amber:#9a6a0e; --amber-soft:#f7efdb;
  --green:#256e49; --green-soft:#e3f0e8;

  /* colori politici (dato; restano per legibilità, AA sul testo scuro) */
  --csx:#C2362F; --cdx:#1C3D6E; --m5s:#B58F00; --altro:#7d8896;

  --glass-bg:rgba(255,255,255,.72);
  --glass-border:rgba(255,255,255,.65);
  --glass-shadow:0 10px 28px rgba(10,40,46,.16),0 2px 8px rgba(10,40,46,.08);
  --card-shadow:0 1px 2px rgba(16,32,36,.05),0 10px 24px -14px rgba(16,32,36,.16);
  --card-radius:20px; --r:14px; --pill:99px;

  --spring:cubic-bezier(.32,1.45,.38,1);
  --ease:cubic-bezier(.22,.85,.3,1);
  --sat:env(safe-area-inset-top,0px);
  --sab:env(safe-area-inset-bottom,0px);
}
@media (prefers-color-scheme: dark){
  :root:not([data-theme="light"]){
    --bg:#0b1213; --bg-deep:#070d0e; --surface:#141d1f; --surface-2:#1a2527;
    --border:rgba(236,243,242,.14); --hairline:rgba(236,243,242,.09);
    --text:#e9f0ee; --text-2:#a8b8b6; --text-3:#7d8e8c;
    --brand:#5da7b4; --brand-deep:#0a3c45; --brand-soft:rgba(93,167,180,.18); --brand-mid:#4f96a3;
    --alert:#e8765a; --alert-soft:rgba(224,96,61,.18);
    --amber:#e0b25a; --amber-soft:rgba(214,164,64,.16);
    --green:#6cc295; --green-soft:rgba(92,178,134,.16);
    --csx:#e06b63; --cdx:#6f9bd6; --m5s:#d9b100; --altro:#9aa6b2;
    --glass-bg:rgba(18,26,28,.66); --glass-border:rgba(255,255,255,.14);
    --glass-shadow:0 12px 32px rgba(0,0,0,.5),0 2px 8px rgba(0,0,0,.3);
    --card-shadow:0 1px 2px rgba(0,0,0,.25),0 12px 28px -16px rgba(0,0,0,.55);
  }
}

*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0; background:var(--bg); color:var(--text);
  font-family:var(--font-ui); font-size:16px; line-height:1.5;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  padding-bottom:calc(40px + var(--sab));
}
a{color:var(--brand)}
:focus-visible{outline:2.5px solid var(--brand); outline-offset:2px; border-radius:6px}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}
.shell{max-width:680px;margin:0 auto;padding:0 16px}

/* ---------- mini-barra sticky (vetro, solo navigazione) ---------- */
.sky{
  position:sticky; top:0; z-index:40;
  padding-top:var(--sat);
  background:var(--glass-bg);
  -webkit-backdrop-filter:blur(20px) saturate(180%);
  backdrop-filter:blur(20px) saturate(180%);
  border-bottom:1px solid var(--glass-border);
  box-shadow:var(--glass-shadow);
  transform:translateY(-100%); opacity:0; pointer-events:none;
  transition:transform .28s var(--ease), opacity .28s var(--ease);
}
.sky.show{transform:translateY(0); opacity:1; pointer-events:auto}
.sky-in{max-width:680px;margin:0 auto;padding:9px 16px;display:flex;align-items:center;gap:10px}
.sky button.sky-top{all:unset;cursor:pointer;display:flex;align-items:center;gap:9px;flex:1;min-width:0;border-radius:10px;padding:3px}
.sky .sky-glyph{width:30px;height:18px;flex:0 0 auto}
.sky .sky-zone{font-family:var(--font-ui);font-weight:800;font-size:15px;letter-spacing:-.01em;white-space:nowrap}
.sky .sky-out{font-size:12.5px;color:var(--text-2);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.sky .sky-pill{margin-left:auto;flex:0 0 auto;font-family:var(--font-mono);font-size:11px;font-weight:600;
  letter-spacing:.02em;padding:4px 9px;border-radius:var(--pill);background:var(--surface);border:1px solid var(--border)}
.sky .sky-pill.maj{background:var(--green-soft);color:var(--green);border-color:transparent}
.sky .sky-pill.ball{background:var(--amber-soft);color:var(--amber);border-color:transparent}

/* ---------- brand header ---------- */
.masthead{display:flex;align-items:center;gap:12px;padding:20px 0 14px}
.ballot{width:40px;height:40px;flex:0 0 auto}
.masthead h1{font-family:var(--font-ui);font-weight:800;font-size:21px;letter-spacing:-.02em;margin:0;line-height:1.05}
.masthead .sub{font-size:12.5px;color:var(--text-2);margin-top:2px}
.eyebrow{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--brand);font-weight:600}

/* ---------- zona selector (pill scroller) ---------- */
.zona{display:flex;gap:8px;overflow-x:auto;padding:4px 0 12px;scroll-snap-type:x proximity;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.zona::-webkit-scrollbar{display:none}
.zona button{scroll-snap-align:start;flex:0 0 auto;min-height:44px;border:1px solid var(--border);background:var(--surface);
  border-radius:var(--pill);padding:0 16px;font-family:var(--font-ui);font-weight:700;font-size:14px;color:var(--text-2);
  cursor:pointer;transition:transform .15s var(--spring),border-color .15s,background .15s,color .15s;display:flex;align-items:center;gap:7px}
.zona button .zn{font-family:var(--font-mono);font-size:11px;color:var(--text-3);font-weight:600}
.zona button:hover{border-color:var(--brand-mid)}
.zona button:active{transform:scale(.95)}
.zona button.on{background:var(--brand);border-color:var(--brand);color:#fff}
.zona button.on .zn{color:rgba(255,255,255,.75)}

/* ---------- sezioni / card ---------- */
section.sec{scroll-margin-top:64px;margin:0 0 16px}
.card{background:var(--surface);border-radius:var(--card-radius);box-shadow:var(--card-shadow);
  border:1px solid var(--hairline);padding:18px}
.sec-h{display:flex;align-items:center;gap:10px;margin:0 0 4px}
.sec-h .num{font-family:var(--font-mono);font-size:11px;font-weight:600;color:#fff;background:var(--brand);
  width:22px;height:22px;border-radius:7px;display:grid;place-items:center;flex:0 0 auto}
.sec-h h2{font-family:var(--font-ui);font-weight:800;font-size:17px;letter-spacing:-.01em;margin:0}
.sec-sub{font-size:13.5px;color:var(--text-2);margin:0 0 14px;line-height:1.45}
.sec-intro{padding:6px 2px 2px}

/* ---------- HERO ---------- */
.hero{padding:16px 16px 18px}
.hero .muni-line{display:flex;align-items:baseline;justify-content:space-between;gap:10px;margin-bottom:2px}
.hero .muni-name{font-family:var(--font-ui);font-weight:800;font-size:18px;letter-spacing:-.01em}
.hero .muni-meta{font-family:var(--font-mono);font-size:11px;color:var(--text-3)}
.emiciclo-wrap{position:relative;margin:2px 0 6px}
.emiciclo{width:100%;display:block;height:auto}
.seat{transition:fill .35s var(--ease)}
.verdict{display:flex;flex-direction:column;gap:3px;align-items:center;text-align:center;padding:6px 4px 2px}
.verdict .v-main{font-family:var(--font-ui);font-weight:800;font-size:21px;letter-spacing:-.01em;line-height:1.15}
.verdict .v-seats{font-variant-numeric:tabular-nums}
.verdict .v-badge{font-family:var(--font-mono);font-size:11px;font-weight:600;letter-spacing:.03em;
  padding:4px 11px;border-radius:var(--pill);text-transform:uppercase}
.v-badge.maj{background:var(--green-soft);color:var(--green)}
.v-badge.ball{background:var(--amber-soft);color:var(--amber)}
.verdict .v-pres{font-size:14px;color:var(--text-2)}
.verdict .v-pres b{color:var(--text)}

.legend{display:flex;flex-wrap:wrap;gap:6px 14px;justify-content:center;margin-top:12px;padding-top:12px;border-top:1px solid var(--hairline)}
.legend .li{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-2)}
.legend .dot{width:10px;height:10px;border-radius:3px;flex:0 0 auto}

.metrics{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;margin-top:14px}
@media(max-width:420px){.metrics{grid-template-columns:1fr 1fr}}
.metric{background:var(--surface-2);border:1px solid var(--hairline);border-radius:14px;padding:12px}
.metric.flag{background:linear-gradient(180deg,var(--brand-soft),var(--surface-2));border-color:transparent}
.metric .k{font-family:var(--font-mono);font-size:9.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--text-3);display:flex;align-items:center;gap:5px}
.metric .v{font-family:var(--font-ui);font-weight:800;font-size:30px;line-height:1.05;margin-top:3px;font-variant-numeric:tabular-nums}
.metric.flag .v{color:var(--brand-deep)}
.metric .d{font-size:12px;font-weight:700;margin-top:2px}
.metric .note{font-size:11px;color:var(--text-3);margin-top:3px;line-height:1.35}
.delta-pos{color:var(--green)} .delta-neg{color:var(--alert)} .delta-zero{color:var(--text-3)}

.cta{display:flex;justify-content:center;margin-top:16px}
.cta button{all:unset;cursor:pointer;display:inline-flex;align-items:center;gap:8px;min-height:44px;padding:0 18px;
  border-radius:var(--pill);background:var(--brand);color:#fff;font-weight:700;font-size:15px;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.18),0 6px 16px -8px var(--brand);transition:transform .15s var(--spring)}
.cta button:active{transform:scale(.96)}
.cta .arrow{transition:transform .4s var(--spring)}

/* ---------- buttons ---------- */
.btn{all:unset;cursor:pointer;box-sizing:border-box;display:inline-flex;align-items:center;justify-content:center;gap:8px;
  min-height:44px;padding:0 16px;border-radius:var(--r);font-family:var(--font-ui);font-weight:700;font-size:14px;
  background:var(--surface-2);color:var(--text);border:1px solid var(--border);transition:transform .14s var(--spring),background .15s,border-color .15s}
.btn:active{transform:scale(.96)}
.btn.primary{background:var(--brand);color:#fff;border-color:transparent;box-shadow:inset 0 1px 0 rgba(255,255,255,.18)}
.btn.ghost{background:transparent}
.btn.small{min-height:38px;padding:0 12px;font-size:13px}
.btn.block{display:flex;width:100%}
.btn.danger{color:var(--alert);border-color:var(--alert-soft)}

/* ---------- LEVA ---------- */
.field{margin-bottom:16px}.field:last-child{margin-bottom:0}
.flabel{font-size:13px;font-weight:700;color:var(--text);margin-bottom:8px;display:flex;justify-content:space-between;align-items:baseline;gap:8px}
.flabel .val{font-family:var(--font-mono);font-size:12px;font-weight:600;color:var(--brand)}
.seg{display:flex;background:var(--surface-2);border:1px solid var(--border);border-radius:12px;padding:4px;gap:4px}
.seg button{flex:1;all:unset;cursor:pointer;text-align:center;min-height:40px;padding:6px 4px;border-radius:9px;
  font-weight:700;font-size:13.5px;color:var(--text-2);transition:background .15s,color .15s,transform .14s var(--spring)}
.seg button:active{transform:scale(.97)}
.seg button.on{background:var(--brand);color:#fff;box-shadow:0 1px 3px rgba(0,0,0,.18)}
.slider-row{display:flex;align-items:center;gap:12px}
input[type=range]{-webkit-appearance:none;appearance:none;height:6px;border-radius:6px;background:var(--surface-2);
  border:1px solid var(--border);flex:1;outline:none}
input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:26px;height:26px;border-radius:50%;
  background:var(--brand);cursor:pointer;border:3px solid var(--surface);box-shadow:0 2px 6px rgba(0,0,0,.25)}
input[type=range]::-moz-range-thumb{width:26px;height:26px;border-radius:50%;background:var(--brand);cursor:pointer;border:3px solid var(--surface)}
.preset{display:flex;flex-wrap:wrap;gap:8px}
.preset button{min-height:40px;border:1px solid var(--border);background:var(--surface);border-radius:var(--pill);
  padding:0 14px;font-weight:600;font-size:13px;color:var(--text-2);cursor:pointer;transition:transform .14s var(--spring),border-color .15s,color .15s,background .15s}
.preset button:hover{border-color:var(--brand-mid);color:var(--brand)}
.preset button:active{transform:scale(.96)}
.preset button.on{background:var(--brand-soft);border-color:var(--brand);color:var(--brand-deep)}

/* ---------- SEGGI per lista (barre) ---------- */
.bars{display:flex;flex-direction:column;gap:4px}
.bar-row{all:unset;cursor:pointer;display:grid;grid-template-columns:1fr auto;gap:4px 10px;align-items:center;
  padding:9px 8px;border-radius:12px;transition:background .15s}
.bar-row:hover{background:var(--surface-2)}
.bar-row:focus-visible{outline:2.5px solid var(--brand);outline-offset:-2px}
.bar-row.excluded{opacity:.5}
.bar-top{display:flex;align-items:center;gap:8px;min-width:0}
.bar-top .sw{width:10px;height:10px;border-radius:3px;flex:0 0 auto}
.bar-top .nm{font-size:13.5px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.bar-top .nm small{font-family:var(--font-mono);font-size:9.5px;color:var(--text-3);font-weight:500;margin-left:5px}
.bar-row.fdi .nm{color:var(--brand-deep);font-weight:800}
.bar-seats{display:flex;align-items:center;gap:8px;justify-self:end}
.bar-seats .pct{font-family:var(--font-mono);font-size:12px;color:var(--text-3);font-variant-numeric:tabular-nums}
.seatpill{font-family:var(--font-mono);font-weight:700;background:var(--text);color:var(--surface);border-radius:8px;
  padding:3px 10px;font-size:13px;min-width:34px;text-align:center;font-variant-numeric:tabular-nums}
.seatpill.zero{background:var(--surface-2);color:var(--text-3);border:1px solid var(--border)}
.seatpill.fdi{background:var(--brand)}
.bar-track{grid-column:1 / -1;height:6px;border-radius:6px;background:var(--surface-2);overflow:hidden}
.bar-fill{display:block;height:100%;width:0;border-radius:6px;transition:width .4s var(--ease)}
.pres-loser{display:flex;align-items:center;gap:8px;margin-top:8px;padding:10px;border-radius:12px;background:var(--amber-soft);font-size:12.5px;color:var(--amber)}
.pres-loser .seatpill{background:var(--amber);color:#fff}

/* ---------- PRESIDENZA & premio ---------- */
.pcards{display:flex;flex-direction:column;gap:10px}
.pcard{display:flex;align-items:flex-start;gap:12px;padding:13px;border-radius:14px;background:var(--surface-2);border:1px solid var(--hairline)}
.pcard .ic{width:34px;height:34px;border-radius:10px;flex:0 0 auto;display:grid;place-items:center;background:var(--surface);border:1px solid var(--border);font-size:17px}
.pcard .pc-body{flex:1;min-width:0}
.pcard .pc-k{font-family:var(--font-mono);font-size:10px;letter-spacing:.05em;text-transform:uppercase;color:var(--text-3)}
.pcard .pc-v{font-weight:800;font-size:16px;margin-top:1px;letter-spacing:-.01em}
.pcard .pc-note{font-size:12.5px;color:var(--text-2);margin-top:2px;line-height:1.4}

/* ---------- ELETTI (accordion per lista) ---------- */
.acc{border:1px solid var(--border);border-radius:14px;overflow:hidden;margin-bottom:8px;background:var(--surface)}
.acc-head{all:unset;cursor:pointer;display:flex;align-items:center;gap:10px;width:100%;box-sizing:border-box;padding:12px 14px;min-height:48px}
.acc-head:focus-visible{outline:2.5px solid var(--brand);outline-offset:-2px}
.acc-head .sw{width:10px;height:10px;border-radius:3px;flex:0 0 auto}
.acc-head .nm{font-weight:700;font-size:14px;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.acc-head .cnt{font-family:var(--font-mono);font-size:12px;color:var(--text-2)}
.acc-head .chev{transition:transform .25s var(--ease);color:var(--text-3)}
.acc.open .acc-head .chev{transform:rotate(90deg)}
.acc-body{display:none;padding:4px 10px 12px;border-top:1px solid var(--hairline)}
.acc.open .acc-body{display:block}
.acc-empty{font-size:12.5px;color:var(--text-3);padding:10px 4px}

.crow{display:flex;flex-direction:column;gap:7px;padding:9px 8px;border-radius:11px;position:relative;touch-action:pan-y}
.crow-l1{display:flex;align-items:center;gap:10px}
.crow-l2{display:flex;align-items:center;gap:8px;justify-content:flex-end}
.crow .rank{font-family:var(--font-mono);font-size:12px;color:var(--text-3);text-align:center;width:20px;flex:0 0 auto}
.crow.elected{background:var(--brand-soft)}
.crow.elected .rank{color:var(--brand-deep);font-weight:700}
.crow .cn{font-size:14px;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.crow.elected .cn{font-weight:600}
.crow .stat{font-family:var(--font-mono);font-size:10px;font-weight:700;letter-spacing:.03em;text-transform:uppercase;
  padding:3px 7px;border-radius:var(--pill)}
.crow .stat.in{background:var(--green-soft);color:var(--green)}
.crow .stat.out{background:var(--surface-2);color:var(--text-3)}
.cutline{display:flex;align-items:center;gap:8px;margin:6px 2px;color:var(--amber);font-family:var(--font-mono);font-size:10.5px;letter-spacing:.03em}
.cutline::before,.cutline::after{content:"";height:0;border-top:2px dashed var(--amber);flex:1;opacity:.6}

/* ---------- stepper (touch) ---------- */
.stepper{display:inline-flex;align-items:center;background:var(--surface);border:1px solid var(--border);border-radius:11px;overflow:hidden}
.stepper button{all:unset;cursor:pointer;width:40px;height:40px;display:grid;place-items:center;font-size:20px;font-weight:700;
  color:var(--brand);transition:background .12s}
.stepper button:active{background:var(--brand-soft)}
.stepper input{width:62px;height:40px;border:0;border-left:1px solid var(--border);border-right:1px solid var(--border);
  text-align:center;font-family:var(--font-mono);font-size:14px;color:var(--text);background:var(--surface);
  -moz-appearance:textfield;appearance:textfield}
.stepper input::-webkit-outer-spin-button,.stepper input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
.stepper input:focus{outline:none}
.stepper.sm input{width:54px;height:38px}
.stepper.sm button{width:36px;height:38px;font-size:18px}

/* ---------- MODIFICA liste (righe editabili) ---------- */
.editlist{display:flex;flex-direction:column;gap:8px}
.erow{position:relative;border-radius:14px;overflow:hidden;background:var(--surface)}
.erow .erow-del-bg{position:absolute;inset:0;background:var(--alert);display:flex;align-items:center;justify-content:flex-end;
  padding:0 20px;color:#fff;font-weight:700;font-size:14px;gap:8px}
.erow .erow-main{position:relative;display:flex;flex-direction:column;gap:10px;
  padding:11px 12px;background:var(--surface);border:1px solid var(--border);border-radius:14px;
  transition:transform .05s linear;will-change:transform}
.erow.fdi .erow-main{border-color:var(--brand);background:linear-gradient(180deg,var(--brand-soft),var(--surface))}
.erow-line1{display:flex;align-items:center;gap:10px}
.erow-line2{display:flex;align-items:center;gap:8px}
.erow .swatch{width:12px;height:26px;border-radius:5px;flex:0 0 auto}
.erow .e-name{flex:1;min-width:0}
.erow .e-name .nm{font-size:14px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.erow.fdi .e-name .nm{color:var(--brand-deep);font-weight:800}
.erow .meta{margin-left:auto;flex:0 0 auto;font-family:var(--font-mono);font-size:11px;color:var(--text-3);display:flex;gap:8px;align-items:center}
.erow .pct{color:var(--brand);font-weight:600}
.erow .spacer{flex:1}
.lockbtn{all:unset;cursor:pointer;width:34px;height:34px;border-radius:9px;display:grid;place-items:center;
  color:var(--text-3);border:1px solid transparent}
.lockbtn.on{color:var(--brand);background:var(--brand-soft)}
.lockbtn:focus-visible{outline:2px solid var(--brand);outline-offset:1px}
.delbtn{all:unset;cursor:pointer;width:34px;height:34px;border-radius:9px;display:grid;place-items:center;color:var(--alert)}
.delbtn:focus-visible{outline:2px solid var(--alert);outline-offset:1px}
.balance-row{display:flex;align-items:center;gap:10px;margin:2px 2px 12px;font-size:13px;color:var(--text-2)}
.switch{position:relative;width:46px;height:28px;flex:0 0 auto}
.switch input{position:absolute;opacity:0;width:100%;height:100%;margin:0;cursor:pointer}
.switch .track{position:absolute;inset:0;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--pill);transition:background .2s}
.switch .knob{position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:50%;background:#fff;box-shadow:0 1px 3px rgba(0,0,0,.3);transition:transform .2s var(--spring)}
.switch input:checked ~ .track{background:var(--brand)}
.switch input:checked ~ .knob{transform:translateX(18px)}
.switch input:focus-visible ~ .track{outline:2.5px solid var(--brand);outline-offset:2px}

/* ---------- WhyButton (explainability) ---------- */
.why-btn{all:unset;cursor:pointer;display:inline-flex;align-items:center;gap:3px;color:inherit;
  border-bottom:1.5px dotted currentColor;line-height:1.1;padding-bottom:1px}
.why-btn .why-i{font-family:var(--font-mono);font-size:.72em;font-weight:700;width:1.25em;height:1.25em;border-radius:50%;
  display:inline-grid;place-items:center;border:1.3px solid currentColor;flex:0 0 auto;opacity:.85}
.why-btn:focus-visible{outline:2.5px solid var(--brand);outline-offset:3px;border-radius:4px}
.why-inline{margin-top:8px;padding:10px 12px;border-radius:12px;background:var(--brand-soft);border:1px solid transparent;
  font-size:12.5px;color:var(--brand-deep);line-height:1.5}
.why-inline ul{margin:6px 0 0;padding-left:18px}
.why-inline li{margin:2px 0}

/* ---------- metodo & fonti / share ---------- */
.method p{font-size:13.5px;color:var(--text-2);line-height:1.55;margin:0 0 10px}
.method code{font-family:var(--font-mono);background:var(--surface-2);padding:1px 6px;border-radius:5px;font-size:12.5px}
.method ul{margin:0 0 10px;padding-left:18px;font-size:13px;color:var(--text-2);line-height:1.55}
.share-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:10px}
.share-row .btn{width:100%}
.sources{font-size:12px;color:var(--text-3);line-height:1.6;border-top:1px solid var(--hairline);padding-top:12px;margin-top:4px}
.sources b{color:var(--text-2)}

/* ---------- bottom sheet ---------- */
.sheet-scrim{position:fixed;inset:0;z-index:60;background:rgba(10,20,22,.42);opacity:0;pointer-events:none;transition:opacity .25s var(--ease)}
.sheet-scrim.show{opacity:1;pointer-events:auto}
.sheet{position:fixed;left:0;right:0;bottom:0;z-index:61;max-width:680px;margin:0 auto;
  background:var(--surface);border-radius:22px 22px 0 0;box-shadow:0 -12px 40px rgba(0,0,0,.28);
  padding:8px 18px calc(20px + var(--sab));transform:translateY(102%);transition:transform .32s var(--spring);
  max-height:86vh;display:flex;flex-direction:column}
.sheet.show{transform:translateY(0)}
.sheet-grip{width:40px;height:5px;border-radius:5px;background:var(--border);margin:6px auto 10px;flex:0 0 auto}
.sheet-head{display:flex;align-items:flex-start;gap:10px;margin-bottom:10px}
.sheet-head .t{font-family:var(--font-ui);font-weight:800;font-size:18px;letter-spacing:-.01em;flex:1;line-height:1.2}
.sheet-close{all:unset;cursor:pointer;width:36px;height:36px;border-radius:50%;background:var(--surface-2);display:grid;place-items:center;color:var(--text-2);flex:0 0 auto;font-size:18px}
.sheet-close:focus-visible{outline:2.5px solid var(--brand);outline-offset:2px}
.sheet-body{overflow-y:auto;-webkit-overflow-scrolling:touch}

/* why sheet content */
.why-value{font-family:var(--font-ui);font-weight:800;font-size:24px;letter-spacing:-.01em;color:var(--brand-deep);margin-bottom:8px}
.why-lvl{margin-bottom:14px}
.why-lvl .lvl-k{font-family:var(--font-mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--text-3);margin-bottom:6px;display:flex;align-items:center;gap:6px}
.why-lvl ul{margin:0;padding-left:18px}
.why-lvl li{margin:4px 0;font-size:14px;color:var(--text);line-height:1.5}
.why-inputs{display:flex;flex-direction:column;gap:0;border:1px solid var(--border);border-radius:12px;overflow:hidden}
.why-inputs .ip{display:flex;justify-content:space-between;gap:12px;padding:9px 12px;font-size:13px;border-bottom:1px solid var(--hairline)}
.why-inputs .ip:last-child{border-bottom:0}
.why-inputs .ip .lab{color:var(--text-2)}
.why-inputs .ip .vl{font-family:var(--font-mono);font-weight:600;font-variant-numeric:tabular-nums;text-align:right}
.why-inputs .ip .src{display:block;font-family:var(--font-ui);font-size:10.5px;color:var(--text-3);font-weight:400;margin-top:1px}
.why-inputs .ip .src.ph{color:var(--amber)}

/* sheet form (aggiungi lista/candidato) */
.sform{display:flex;flex-direction:column;gap:14px;padding:4px 0 8px}
.sform label{font-size:13px;font-weight:700;display:block;margin-bottom:6px}
.sform input[type=text],.sform input[type=number]{width:100%;min-height:46px;border:1px solid var(--border);border-radius:12px;
  padding:0 14px;font-family:var(--font-ui);font-size:16px;background:var(--surface);color:var(--text)}
.sform input:focus{outline:2.5px solid var(--brand);outline-offset:0;border-color:var(--brand)}
.coal-pick{display:flex;flex-wrap:wrap;gap:8px}
.coal-pick button{all:unset;cursor:pointer;min-height:40px;padding:0 14px;border-radius:var(--pill);border:1px solid var(--border);
  font-weight:700;font-size:13px;display:flex;align-items:center;gap:7px}
.coal-pick button .dot{width:11px;height:11px;border-radius:3px}
.coal-pick button.on{border-color:var(--brand);background:var(--brand-soft);color:var(--brand-deep)}

/* ---------- toast ---------- */
.toast-host{position:fixed;left:0;right:0;bottom:calc(18px + var(--sab));z-index:70;display:flex;flex-direction:column;align-items:center;gap:8px;pointer-events:none}
.toast{pointer-events:auto;display:flex;align-items:center;gap:14px;background:var(--text);color:var(--bg);
  border-radius:var(--pill);padding:10px 12px 10px 18px;font-size:13.5px;font-weight:600;box-shadow:0 10px 30px rgba(0,0,0,.35);
  transform:translateY(20px);opacity:0;transition:transform .25s var(--spring),opacity .25s var(--ease);max-width:calc(100% - 32px)}
.toast.show{transform:translateY(0);opacity:1}
.toast button{all:unset;cursor:pointer;color:var(--brand);font-weight:800;background:var(--surface);padding:6px 12px;border-radius:var(--pill);min-height:32px;display:inline-flex;align-items:center}

/* ---------- panorama città ---------- */
.panorama{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}
@media(max-width:420px){.panorama{grid-template-columns:1fr 1fr}}
.pcell{all:unset;cursor:pointer;box-sizing:border-box;background:var(--surface-2);border:1px solid var(--hairline);border-radius:14px;
  padding:12px;display:flex;flex-direction:column;gap:4px;transition:transform .15s var(--spring),border-color .15s}
.pcell:hover{border-color:var(--brand-mid)}
.pcell:active{transform:scale(.97)}
.pcell:focus-visible{outline:2.5px solid var(--brand);outline-offset:2px}
.pcell .pm{font-family:var(--font-mono);font-size:10.5px;color:var(--text-3)}
.pcell .pf{font-family:var(--font-ui);font-weight:800;font-size:26px;line-height:1;color:var(--brand-deep);font-variant-numeric:tabular-nums}
.pcell .pl{display:flex;align-items:center;gap:6px;font-size:11.5px;color:var(--text-2)}
.pcell .pl .dot{width:9px;height:9px;border-radius:3px}
.pcell .pd{font-size:11px;font-weight:700;margin-top:1px}
.city-verdict{background:linear-gradient(180deg,var(--brand-soft),var(--surface-2));border:1px solid transparent;border-radius:16px;padding:16px;margin-bottom:14px;text-align:center}
.city-verdict .cv-main{font-family:var(--font-ui);font-weight:800;font-size:19px;letter-spacing:-.01em;line-height:1.25}
.city-verdict .cv-sub{font-size:13px;color:var(--text-2);margin-top:6px}

.report-banner{background:var(--amber-soft);color:var(--amber);border-radius:14px;padding:12px 14px;margin:14px 0;
  display:flex;align-items:center;gap:10px;font-size:13.5px;font-weight:600}
.report-banner .btn{margin-left:auto}

.hidden{display:none !important}

/* ---------- avatar partito (logo o monogramma) ---------- */
.pavatar{flex:0 0 auto;border-radius:6px;object-fit:contain;background:#fff;border:1px solid var(--hairline);display:inline-block;vertical-align:middle}
img.pavatar{padding:1px}
.pavatar.mono{display:inline-grid;place-items:center;font-family:var(--font-ui);font-weight:800;font-size:10px;letter-spacing:.01em;border:0;border-radius:50%}

/* ---------- focus pill (partito in evidenza) ---------- */
.focus-pill{all:unset;cursor:pointer;box-sizing:border-box;display:flex;align-items:center;gap:10px;width:100%;
  margin:2px 0 10px;padding:8px 12px;border:1px solid var(--border);border-radius:14px;background:var(--surface-2);
  transition:transform .14s var(--spring),border-color .15s}
.focus-pill:active{transform:scale(.99)}
.focus-pill:hover{border-color:var(--brand-mid)}
.focus-pill:focus-visible{outline:2.5px solid var(--brand);outline-offset:2px}
.focus-pill .fp-txt{display:flex;flex-direction:column;line-height:1.15;min-width:0;flex:1;text-align:left}
.focus-pill .fp-lbl{font-family:var(--font-mono);font-size:9.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--text-3)}
.focus-pill .fp-name{font-weight:800;font-size:15px;letter-spacing:-.01em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.focus-pill .fp-seats{font-family:var(--font-mono);font-size:12px;font-weight:600;color:var(--brand);flex:0 0 auto}
.focus-pill .fp-chev{color:var(--text-3);flex:0 0 auto;font-size:13px}

/* ---------- selettore partito (sheet) ---------- */
.focus-list{display:flex;flex-direction:column;gap:6px}
.focus-opt{all:unset;cursor:pointer;box-sizing:border-box;display:flex;align-items:center;gap:12px;width:100%;
  padding:10px 12px;border:1px solid var(--border);border-radius:13px;min-height:56px;transition:border-color .12s,background .12s}
.focus-opt:focus-visible{outline:2.5px solid var(--brand);outline-offset:2px}
.focus-opt:active{background:var(--surface-2)}
.focus-opt.on{border-color:var(--brand);background:var(--brand-soft)}
.focus-opt .fo-name{flex:1;min-width:0}
.focus-opt .fo-name .nm{font-weight:700;font-size:14.5px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.focus-opt .fo-coal{font-family:var(--font-mono);font-size:10.5px;color:var(--text-3)}
.focus-opt .fo-seats{font-family:var(--font-mono);font-weight:700;font-size:15px;background:var(--surface-2);border-radius:9px;padding:5px 11px;min-width:38px;text-align:center;flex:0 0 auto}
.focus-opt.on .fo-seats{background:#fff}

/* ---------- focus highlight ---------- */
.bar-row.focus{background:var(--brand-soft)}
.bar-row.focus .nm{font-weight:800}
.seatpill.focus{background:var(--brand)}
.pcard .ic-avatar{border-radius:9px;width:34px;height:34px}
.pcell .pm{display:flex;align-items:center;gap:5px}
.pcell .pm .pavatar{border-radius:4px}

/* ---- candidato sindaco (arricchimento dalla stampa) ---- */
.sindaco-box:not(:empty){margin-top:10px;padding:12px;border:1px solid var(--border);border-radius:var(--r);background:var(--surface-2)}
.sindaco-note{font-size:13px;color:var(--text-3)}
.sindaco-head{display:flex;gap:10px;align-items:center}
.sindaco-thumb{width:46px;height:46px;border-radius:12px;object-fit:cover;flex:0 0 auto;background:var(--surface)}
.sindaco-thumb.ph{display:grid;place-items:center;font-family:var(--font-ui);font-weight:800;color:var(--text-2);border:1px solid var(--border)}
.sindaco-name{font-family:var(--font-ui);font-weight:800;font-size:15px;letter-spacing:-.01em}
.sindaco-meta{display:flex;align-items:center;gap:4px;flex-wrap:wrap;font-size:12.5px;margin-top:2px}
.coal-tag{font-size:11px;font-weight:700;padding:2px 8px;border-radius:var(--pill)}
.sindaco-bio{font-size:13px;color:var(--text-2);line-height:1.45;margin:8px 0 0}
.sindaco-links{margin-top:6px;font-size:13px}
.sindaco-links a,.news-item{color:var(--brand)}
.sindaco-news{display:flex;flex-direction:column;gap:6px;margin-top:6px}
.news-item{display:flex;flex-direction:column;text-decoration:none;padding:8px 10px;border:1px solid var(--border);border-radius:12px;background:var(--surface)}
.news-item:active{background:var(--surface-2)}
.news-title{font-size:13px;font-weight:600;color:var(--text);line-height:1.35}
.news-src{font-size:11px;color:var(--text-3);font-family:var(--font-mono);margin-top:2px}

/* ---- pulsante + pannello "Modifica le variabili" ---- */
.varbtn{margin:12px 0 4px;display:flex;align-items:center;justify-content:center;gap:9px;font-size:15px;font-weight:700}
.varbtn-ico{font-size:17px;line-height:1}
.panel-readout{position:sticky;top:0;z-index:2;display:flex;gap:8px;flex-wrap:wrap;padding:10px 2px 12px;margin-bottom:4px;background:linear-gradient(var(--surface),var(--surface) 70%,transparent);border-bottom:1px solid var(--hairline)}
.pr-item{display:flex;align-items:center;gap:6px;font-size:12.5px}
.pr-k{color:var(--text-3)}
.pr-v{font-weight:700}
.pr-pill{font-size:12px;font-weight:700;padding:3px 10px;border-radius:var(--pill);background:var(--surface-2)}
.pr-pill.ball{background:var(--amber-soft);color:var(--amber)}
.pblock{border:1px solid var(--border);border-radius:var(--r);margin-top:10px;overflow:hidden;background:var(--surface)}
.pblock-head{width:100%;display:flex;align-items:center;justify-content:space-between;gap:8px;padding:14px;background:none;border:0;cursor:pointer;font:inherit;text-align:left}
.pblock-title{font-family:var(--font-ui);font-weight:800;font-size:14.5px;letter-spacing:-.01em;color:var(--text)}
.pblock-chev{color:var(--text-3);transition:transform .2s var(--ease)}
.pblock.open .pblock-chev{transform:rotate(90deg)}
.pblock-sub{font-size:12.5px;color:var(--text-3);margin:0 14px 4px;display:none}
.pblock.open .pblock-sub{display:block}
.pblock-body{display:none;padding:4px 14px 14px}
.pblock.open .pblock-body{display:block}
.pslider{margin:10px 0}
.pslider-lab{display:flex;align-items:center;gap:7px;font-size:13px;margin-bottom:3px}
.pslider-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.pslider .pv{font-family:var(--font-mono);font-size:12.5px;font-weight:600;color:var(--text-2);margin-left:auto}
.pslider input[type=range]{width:100%}
.pmini-reset{margin-top:6px;background:none;border:0;color:var(--brand);font:inherit;font-size:12.5px;font-weight:600;cursor:pointer;padding:4px 0}
.travaso{display:flex;align-items:center;gap:8px}
.travaso select{flex:1;min-width:0;padding:9px 8px;border:1px solid var(--border);border-radius:10px;background:var(--surface);color:var(--text);font:inherit;font-size:14px}
.travaso .arrow{color:var(--text-3);flex:0 0 auto}
.coal-pick.wrap{display:flex;flex-wrap:wrap;gap:6px}
.coal-pick.wrap button{flex:0 0 auto}

@media (prefers-reduced-motion: reduce){
  *{scroll-behavior:auto !important}
  .seat,.bar-fill,.sheet,.toast,.sky,.cta .arrow,.acc-head .chev,.pblock-chev{transition:none !important}
}
