:root{color:#172033;background:#f3f6fb;--ink: #172033;--muted: #64748b;--line: #dbe3ef;--line-strong: #c7d4e5;--surface: rgba(255, 255, 255, .92);--surface-solid: #ffffff;--wash: #f7f9fd;--accent: #173b63;--accent-soft: rgba(23, 59, 99, .12);--danger: #b42318;--danger-soft: #fff1f0;--radius-sm: 10px;--radius-md: 14px;--radius-lg: 18px;--shadow-sm: 0 10px 28px rgba(15, 23, 42, .06);--shadow-md: 0 24px 70px rgba(15, 23, 42, .1);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background:radial-gradient(circle at top left,rgba(20,184,166,.12),transparent 34vw),radial-gradient(circle at top right,rgba(37,99,235,.1),transparent 32vw),linear-gradient(180deg,#f8fbff,#eef3f9),#f3f6fb}button,input,select{font:inherit}button{cursor:pointer}.mode-shell{min-height:100vh;display:grid;place-content:center;gap:28px;padding:32px}.mode-intro{max-width:880px}.brand-logo{width:46px;height:46px;border-radius:12px;object-fit:cover;box-shadow:0 12px 34px #0f172a1f}.hero-logo{width:92px;height:92px;border-radius:24px;margin-bottom:18px}.app-brand{display:flex;align-items:center;gap:12px;margin-bottom:18px}.app-brand strong{display:block;color:#172033;font-size:14px;font-weight:950;letter-spacing:.16em}.app-brand span,.mode-subtitle{color:#64748b;font-size:13px;font-weight:800}.app-brand.small{margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid #dbe3ef}.mode-intro p{color:#0f766e;font-weight:900;letter-spacing:.18em;text-transform:uppercase}.mode-intro h1{max-width:800px;margin:0;color:#0f172a;font-size:clamp(40px,6vw,72px);line-height:.98;letter-spacing:-.055em}.mode-subtitle{display:block;margin-top:16px;font-size:18px}.mode-grid{display:grid;grid-template-columns:repeat(2,minmax(260px,1fr));gap:18px;max-width:900px}.policy-links{display:flex;align-items:center;justify-content:center;gap:16px;color:var(--muted);font-size:13px;font-weight:800}.policy-links.compact{justify-content:flex-start;gap:12px;margin:10px 0 18px;font-size:12px}.policy-links a{color:#173b63;text-decoration:none}.policy-links a:hover{text-decoration:underline}.mode-card{min-height:210px;display:grid;align-content:center;justify-items:start;gap:14px;border:1px solid #dbe3ef;border-radius:var(--radius-lg);padding:36px;background:#ffffffdb;color:#172033;text-align:left;box-shadow:var(--shadow-md);transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}.mode-card:hover{transform:translateY(-3px);border-color:#9bb6d6;box-shadow:0 28px 90px #1f29371f}.mode-card span{font-size:26px;font-weight:900}.mode-card small{max-width:330px;color:#64748b;font-size:15px;line-height:1.45}.app-shell{min-height:100vh;display:grid;grid-template-columns:300px minmax(0,1fr) 380px;background:linear-gradient(135deg,rgba(255,255,255,.62),transparent 36%),#f3f6fb}.sidebar,.results-panel{background:var(--surface);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.sidebar{border-right:1px solid #dbe3ef;padding:22px}.results-panel{border-left:1px solid #dbe3ef;padding:22px}.workspace{min-width:0;padding:26px}.ghost,.primary,.panel-title button,.coalition-header button,.runoff-choice button{min-height:38px;display:inline-flex;align-items:center;justify-content:center;gap:8px;border:1px solid #cfd9e6;border-radius:999px;padding:0 12px;background:#fff;color:#172033;font-weight:800;box-shadow:0 1px #0f172a0a;transition:transform .16s ease,background .16s ease,border-color .16s ease,box-shadow .16s ease}.ghost:hover,.panel-title button:hover,.coalition-header button:hover,.runoff-choice button:hover{transform:translateY(-1px);background:#f8fafc;border-color:#9bb6d6;box-shadow:0 10px 24px #0f172a14}.primary{border-color:#172033;background:#172033;color:#fff}.sidebar h1,.results-panel h2{margin:22px 0 18px;color:#172033;font-size:28px;letter-spacing:-.03em}.field{position:relative;display:grid;gap:8px;margin-top:18px}.field span,.row.header,.topbar p{color:#64748b;font-size:12px;font-weight:900;letter-spacing:.16em;text-transform:uppercase}.field input,.field select,.row input,.coalition-row input,.live-strip input{min-height:42px;width:100%;border:1px solid #cfd9e6;border-radius:var(--radius-sm);padding:0 12px;background:#fff;color:#172033;outline:none}.field input:focus,.field select:focus,.row input:focus,.coalition-row input:focus,.live-strip input:focus{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-soft)}.facts{display:grid;gap:9px;margin-top:18px}.facts span,.metrics span{border:1px solid var(--line);border-radius:var(--radius-md);padding:12px;background:var(--surface-solid);color:#64748b;box-shadow:var(--shadow-sm)}.facts strong,.metrics strong{display:block;margin-top:4px;color:#172033}.eligendo-tools{margin-top:18px;border:1px solid var(--line);border-radius:var(--radius-md);padding:12px;background:#f8fafcdb}.topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:18px}.topbar-actions{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:8px}.topbar h2{margin:3px 0 0;color:#172033;font-size:34px;letter-spacing:-.04em}.metrics{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-bottom:18px}.live-strip,.runoff-blocker{border:1px solid #fed7aa;border-radius:var(--radius-md);padding:12px;background:#fff7ed;color:#9a3412;font-weight:800}.live-strip{display:flex;flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:16px}.live-strip.loaded{border-color:#99f6e4;background:#f0fdfa;color:#0f766e}.live-strip input{width:92px}.runoff-blocker{margin-bottom:16px}.runoff-choice{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}.runoff-choice button{border-width:2px}.runoff-choice button.selected{background:#172033;color:#fff}.tables{display:grid;gap:16px}.panel{border:1px solid var(--line);border-radius:var(--radius-lg);padding:18px;background:var(--surface-solid);box-shadow:var(--shadow-sm)}.panel-title{display:flex;align-items:center;justify-content:space-between;gap:12px}.panel-title h2{margin:0;color:#172033;letter-spacing:-.02em}.table{display:grid;gap:8px;margin-top:14px}.row{min-height:46px;display:grid;grid-template-columns:132px minmax(180px,1fr) 110px 70px;gap:8px;align-items:center}.candidate-name-input{font-weight:800}.row strong{justify-self:end;color:var(--ink);font-variant-numeric:tabular-nums}.palette{display:flex;flex-wrap:wrap;gap:5px;width:132px}.palette button{width:20px;height:20px;border:2px solid transparent;border-radius:50%;padding:0}.palette button.active{border-color:#172033;box-shadow:0 0 0 2px #fff,0 0 0 3px #172033}.palette button:disabled{opacity:.45}.readonly-value{min-height:42px;display:flex;align-items:center;overflow-wrap:anywhere;border:1px solid #dbe3ef;border-radius:var(--radius-sm);padding:0 12px;background:#f8fafc;color:#172033;font-weight:700}.candidate-readonly{border-width:2px}.total-line{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:12px;border:1px solid #e3eaf4;border-radius:var(--radius-md);padding:10px 12px;background:#f8fafc;color:#475569}.total-line em{color:#9a3412;font-style:normal;font-weight:800}.total-line.compact{font-size:12px;padding:8px 10px}.coalition-grid{display:grid;gap:14px;margin-top:14px}.coalition-card{overflow:hidden;border:1px solid var(--line-strong);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.coalition-header{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:13px 14px;border-bottom:1px solid rgba(15,23,42,.06)}.coalition-header strong{overflow-wrap:anywhere;font-size:15px}.coalition-list{display:grid;gap:9px;padding:12px}.coalition-row{display:grid;grid-template-columns:24px minmax(180px,1fr) 110px 56px minmax(92px,auto);align-items:center;gap:8px;border:1px solid rgba(203,213,225,.72);border-radius:var(--radius-md);padding:8px;background:#ffffffc7;transition:border-color .16s ease,box-shadow .16s ease,transform .16s ease}.coalition-row.readonly{grid-template-columns:24px minmax(180px,1fr) 110px minmax(56px,auto)}.coalition-row.readonly strong{justify-self:end;min-width:56px;text-align:right}.coalition-row:hover{border-color:#b7c7dc;box-shadow:0 12px 28px #0f172a12}.remove-list-button{min-height:34px;display:inline-flex;align-items:center;justify-content:center;gap:5px;border:1px solid #f3b6b2;border-radius:999px;padding:0 11px;background:#fff;color:var(--danger);font-size:12px;font-weight:900;white-space:nowrap;transition:transform .16s ease,background .16s ease,border-color .16s ease,box-shadow .16s ease}.remove-list-button span{width:16px;height:16px;display:inline-grid;place-items:center;border-radius:999px;background:var(--danger-soft);font-size:14px;line-height:1}.remove-list-button:hover{transform:translateY(-1px);border-color:#ef4444;background:var(--danger-soft);box-shadow:0 10px 22px #b423181a}.auto-color{width:14px;height:14px;border-radius:50%;box-shadow:inset 0 0 0 1px #00000024}.list-symbol{width:22px;height:22px;border-radius:999px;object-fit:cover;background:#fff;border:1px solid rgba(148,163,184,.55);box-shadow:0 2px 6px #0f172a1a}.hidden-symbol-fallback{display:none}.winner{display:flex;justify-content:center;gap:12px;margin:18px 0;border:1px solid #b7ead7;border-radius:var(--radius-md);padding:16px;background:#ecfdf5}.winner span{font-weight:800;text-align:center}.cookie-banner{position:fixed;left:18px;right:18px;bottom:18px;z-index:50;display:grid;grid-template-columns:minmax(0,1fr) auto;gap:18px;align-items:center;max-width:980px;margin:0 auto;border:1px solid rgba(199,212,229,.9);border-radius:18px;padding:16px 18px;background:#fffffff5;box-shadow:0 24px 70px #0f172a29;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.cookie-banner strong{display:block;margin-bottom:4px;color:var(--ink);font-size:14px}.cookie-banner p{margin:0;color:var(--muted);font-size:13px;line-height:1.45}.cookie-actions{display:flex;align-items:center;gap:10px;white-space:nowrap}.cookie-actions a{color:#173b63;font-size:12px;font-weight:900;text-decoration:none}.cookie-actions a:hover{text-decoration:underline}.cookie-actions button{min-height:38px;border:0;border-radius:999px;padding:0 16px;background:var(--accent);color:#fff;font-size:13px;font-weight:900}.hemicycle{position:relative;min-height:226px;border:1px solid var(--line);border-radius:var(--radius-lg);padding:14px 8px 6px;background:linear-gradient(180deg,#fff,#f7f9fd);box-shadow:inset 0 1px #fffc}.hemicycle svg{display:block;width:100%;height:auto}.hemicycle-total{font-size:13px;font-weight:900;fill:#172033}.hemicycle-label{font-size:4px;font-weight:800;fill:#64748b;text-transform:uppercase}.hemicycle path{stroke:#ffffffe0;stroke-width:.45}.hemicycle path:hover{opacity:.82}.legend{display:flex;flex-wrap:wrap;gap:8px 12px;margin-top:12px}.legend span{display:inline-flex;align-items:center;gap:6px;color:#475569;font-size:12px}.legend i{width:10px;height:10px;border-radius:50%}.muted{color:#64748b;line-height:1.45}.empty-state{display:grid;place-content:center;min-height:70vh;color:#64748b;text-align:center}.empty-state h1,.empty-state h2{margin:0 0 8px;color:#172033;font-size:32px}.suggestions{position:absolute;top:64px;left:0;right:0;z-index:20;display:grid;gap:4px;max-height:310px;overflow:auto;border:1px solid #cfd9e6;border-radius:8px;padding:6px;background:#fff;box-shadow:0 18px 48px #1f293724}.suggestions button{display:grid;gap:3px;border:0;border-radius:6px;padding:10px;background:transparent;color:#172033;text-align:left}.suggestions button:hover{background:#eef6ff}.suggestions small,.selected-comune{color:#64748b}@media(max-width:1100px){.app-shell{grid-template-columns:260px 1fr}.results-panel{grid-column:1 / -1;border-left:0;border-top:1px solid #dbe3ef}}@media(max-width:760px){.mode-grid,.app-shell,.metrics{grid-template-columns:1fr}.sidebar,.results-panel{border:0;border-bottom:1px solid #dbe3ef}.row,.coalition-row{grid-template-columns:1fr}.row.header{display:none}.cookie-banner{grid-template-columns:1fr}.cookie-actions{flex-wrap:wrap}}
