:root{--bg: #f4f5f7;--surface: #ffffff;--surface-muted: #f7f8fa;--border: #e3e6ec;--border-strong: #cdd3dc;--text: #14181f;--text-muted: #5b6573;--text-soft: #828d9b;--brand: #1c6b5a;--brand-strong: #145244;--brand-soft: #e6f3ee;--warn: #8a4b00;--warn-soft: #fff4dd;--danger: #a4231f;--danger-soft: #fbe4e3;--gold: #c28b18;--gold-soft: #fff5d8;color:var(--text);background:var(--bg);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;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}button,input{font:inherit}a{color:var(--brand)}.topbar{position:sticky;top:0;z-index:30;display:flex;align-items:center;gap:12px;flex-wrap:wrap;padding:14px 20px;background:#ffffffeb;-webkit-backdrop-filter:saturate(140%) blur(10px);backdrop-filter:saturate(140%) blur(10px);border-bottom:1px solid var(--border)}.topbar-brand{display:flex;align-items:center;gap:10px;font-weight:800;font-size:1.05rem;color:var(--text)}.topbar-brand:before{content:"";width:10px;height:10px;border-radius:999px;background:var(--brand);box-shadow:0 0 0 4px var(--brand-soft)}.topbar-spacer{flex:1}.topbar-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.app-shell{width:min(1080px,calc(100% - 32px));margin:0 auto;padding:28px 0 64px;display:grid;gap:20px}.network-banner{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;padding:12px 16px;border:1px solid #f1c97b;border-radius:10px;background:var(--warn-soft);color:var(--warn);font-weight:600}.metamask-banner{border-color:var(--border-strong);background:var(--surface);color:var(--text)}.panel{padding:24px;border:1px solid var(--border);border-radius:14px;background:var(--surface);box-shadow:0 1px 2px #14202d0a}.panel-header{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:16px}.panel-header h2{margin:0;font-size:1.25rem}.panel-eyebrow{margin:0 0 4px;color:var(--brand);font-size:.75rem;font-weight:800;letter-spacing:.04em;text-transform:uppercase}.panel-body>*+*{margin-top:16px}.panel-hint{margin:0;color:var(--text-muted);font-size:.92rem}.panel-warning{margin:0;color:var(--warn);font-weight:600}.panel-error{margin:0;color:var(--danger)}.panel-empty{padding:32px 16px;border:1px dashed var(--border-strong);border-radius:10px;background:var(--surface-muted);color:var(--text-muted);text-align:center}button{padding:10px 16px;border:1px solid var(--brand);border-radius:8px;background:var(--brand);color:#fff;font-weight:600;line-height:1.3;cursor:pointer;transition:filter .12s ease,background .12s ease,border-color .12s ease}button:hover:not(:disabled){filter:brightness(1.05)}button:disabled{opacity:.55;cursor:not-allowed}.secondary-button{border-color:var(--border-strong);background:var(--surface);color:var(--text)}.danger-button{border-color:var(--danger);background:var(--danger)}.ghost-button{padding:6px 12px;border:1px solid var(--border-strong);background:var(--surface);color:var(--text);font-size:.85rem}.cta-button{padding:14px 24px;font-size:1rem;border-radius:10px}.badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;font-size:.78rem;font-weight:700;line-height:1;white-space:nowrap}.badge-ok{background:var(--brand-soft);color:var(--brand-strong)}.badge-warn{background:var(--warn-soft);color:var(--warn)}.badge-danger{background:var(--danger-soft);color:var(--danger)}.badge-muted{background:#eef1f4;color:var(--text-muted)}.badge-gold{background:var(--gold-soft);color:var(--gold)}.badge-soft{background:var(--surface-muted);color:var(--text-muted);border:1px solid var(--border)}.form-grid{display:grid;gap:14px}.field{display:grid;gap:6px}.field span{color:var(--text);font-size:.88rem;font-weight:600}input{width:100%;padding:10px 12px;border:1px solid var(--border-strong);border-radius:8px;background:var(--surface);color:var(--text)}input:focus{outline:2px solid var(--brand-soft);outline-offset:1px;border-color:var(--brand)}input:disabled{background:var(--surface-muted);color:var(--text-soft)}.panel-actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.panel-actions .panel-hint{flex:1 1 240px}.results-panel{background:linear-gradient(180deg,#ffffff 0%,var(--surface-muted) 100%)}.winner-card{display:grid;grid-template-columns:160px minmax(0,1fr);gap:20px;padding:20px;border:1px solid var(--gold);border-radius:14px;background:linear-gradient(135deg,var(--gold-soft) 0%,#ffffff 70%);box-shadow:0 4px 18px #c28b181f}.winner-photo{width:160px;height:160px;border-radius:12px;background:var(--surface-muted);object-fit:cover;border:1px solid var(--border)}.winner-photo-fallback{display:grid;place-items:center;color:var(--text-soft);font-weight:700}.winner-body{display:grid;align-content:center;gap:10px;min-width:0}.winner-rank{display:inline-flex;align-items:center;gap:6px;color:var(--gold);font-size:.85rem;font-weight:800;letter-spacing:.05em;text-transform:uppercase}.winner-name{margin:0;font-size:2rem;line-height:1.1;overflow-wrap:anywhere}.winner-stats{display:flex;align-items:baseline;gap:16px;flex-wrap:wrap}.winner-share{font-size:2.25rem;font-weight:800;color:var(--brand);line-height:1}.winner-votes{color:var(--text-muted);font-weight:600}.results-summary{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.results-summary div{padding:14px 16px;border:1px solid var(--border);border-radius:10px;background:var(--surface)}.results-summary dt{margin:0 0 4px;color:var(--text-soft);font-size:.78rem;font-weight:700}.results-summary dd{margin:0;font-size:1.35rem;font-weight:800}.results-toolbar{display:flex;align-items:center;gap:8px;flex-wrap:wrap;color:var(--text-soft);font-size:.85rem;font-weight:600}.results-list{display:grid;gap:10px}.result-row{display:grid;grid-template-columns:56px 56px minmax(0,1fr);gap:14px;align-items:center;padding:14px;border:1px solid var(--border);border-radius:10px;background:var(--surface)}.result-row-top{border-color:var(--gold);background:var(--gold-soft)}.result-rank{display:grid;place-items:center;height:40px;border-radius:8px;background:var(--text);color:#fff;font-weight:800;font-size:.95rem}.result-row-top .result-rank{background:var(--gold)}.result-photo{width:56px;height:56px;border-radius:8px;background:var(--surface-muted);object-fit:cover;border:1px solid var(--border)}.result-photo-fallback{display:grid;place-items:center;color:var(--text-soft);font-size:.7rem;font-weight:700}.result-main{display:grid;gap:8px;min-width:0}.result-line{display:flex;align-items:center;justify-content:space-between;gap:12px}.result-line strong{overflow-wrap:anywhere;font-size:1.05rem}.result-share{font-weight:800;color:var(--brand)}.result-meter{height:10px;border-radius:999px;background:#eaeef3;overflow:hidden}.result-meter-fill{height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--brand),#2f7fa7);transition:width .24s ease}.result-row-top .result-meter-fill{background:linear-gradient(90deg,var(--gold),var(--brand))}.result-votes{color:var(--text-muted);font-size:.88rem;font-weight:600}.vote-instructions{margin:0;color:var(--text-muted)}.candidate-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px}.candidate-card{display:grid;gap:10px;padding:14px;border:1px solid var(--border);border-radius:12px;background:var(--surface);text-align:left;transition:border-color .12s ease,background .12s ease,transform .12s ease}.candidate-card.is-selectable{cursor:pointer}.candidate-card.is-selectable:hover{border-color:var(--brand);transform:translateY(-1px)}.candidate-card.is-selected{border-color:var(--brand);background:var(--brand-soft);box-shadow:0 0 0 2px var(--brand-soft)}.candidate-photo{width:100%;aspect-ratio:1 / 1;border-radius:10px;background:var(--surface-muted);object-fit:cover;border:1px solid var(--border)}.candidate-photo-fallback{display:grid;place-items:center;color:var(--text-soft);font-size:.85rem;font-weight:700}.candidate-name{margin:0;font-size:1.05rem;font-weight:700;overflow-wrap:anywhere}.candidate-meta{display:flex;align-items:center;justify-content:space-between;gap:8px}.candidate-votes{color:var(--brand);font-weight:700}.candidate-select-mark{font-size:.8rem;font-weight:700;color:var(--text-soft)}.candidate-card.is-selected .candidate-select-mark{color:var(--brand)}.vote-submit-bar{display:flex;justify-content:flex-end;flex-wrap:wrap;gap:12px}.vote-submit-bar .panel-hint{flex:1 1 240px;align-self:center}.admin-summary{display:flex;align-items:center;gap:10px;flex-wrap:wrap;padding:12px 14px;border:1px solid var(--border);border-radius:10px;background:var(--surface-muted);font-size:.92rem}.admin-summary strong{font-weight:700}.admin-section{display:grid;gap:12px;padding:16px;border:1px solid var(--border);border-radius:10px;background:var(--surface-muted)}.admin-section h3{margin:0;font-size:1rem}.admin-section .panel-hint{font-size:.88rem}.collapsible{border:1px solid var(--border);border-radius:12px;background:var(--surface);padding:0;overflow:hidden}.collapsible[open]{background:var(--surface)}.collapsible summary{list-style:none;cursor:pointer;padding:14px 18px;font-weight:700;display:flex;align-items:center;justify-content:space-between;gap:8px}.collapsible summary::-webkit-details-marker{display:none}.collapsible summary:after{content:"▾";color:var(--text-soft);transition:transform .16s ease}.collapsible[open] summary:after{transform:rotate(180deg)}.collapsible-body{padding:0 18px 18px;display:grid;gap:14px}.dev-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}.dev-grid div{padding:12px;border:1px solid var(--border);border-radius:8px;background:var(--surface-muted)}.dev-grid dt{margin:0 0 4px;color:var(--text-soft);font-size:.78rem;font-weight:700}.dev-grid dd{margin:0;overflow-wrap:anywhere;font-size:.92rem}.dev-grid a{display:inline-block;margin-top:4px;font-size:.82rem}.modal-backdrop{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;padding:16px;background:#14202d80;z-index:50}.modal{width:min(520px,100%);max-height:calc(100vh - 32px);overflow:auto;padding:22px;border-radius:14px;background:var(--surface);box-shadow:0 16px 40px #14202d2e}.modal-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px}.modal-header h3{margin:0;font-size:1.15rem}.modal-close{padding:6px 12px;border:1px solid var(--border-strong);background:var(--surface);color:var(--text);font-size:.85rem}.modal-steps{margin:0 0 14px;padding:0;list-style:none}.modal-step{display:grid;grid-template-columns:70px 1fr auto;gap:12px;padding:10px 12px;border:1px solid var(--border);border-radius:8px;background:var(--surface-muted);font-size:.92rem}.modal-step+.modal-step{margin-top:8px}.modal-step-index{color:var(--text-soft);font-weight:700}.modal-step-status{font-weight:700}.modal-step-done{border-color:#b5e1d2;background:var(--brand-soft)}.modal-step-done .modal-step-status{color:var(--brand)}.modal-step-current{border-color:#f1c97b;background:var(--warn-soft)}.modal-step-current .modal-step-status{color:var(--warn)}.modal-step-failed{border-color:#f3b4b1;background:var(--danger-soft)}.modal-step-failed .modal-step-status{color:var(--danger)}.modal-line{margin:8px 0 0;font-size:.9rem;overflow-wrap:anywhere}.modal-line a{margin-left:8px}.modal-error{color:var(--danger)}.modal-success{color:var(--brand);font-weight:700}@media(max-width:760px){.app-shell{padding:20px 0 56px;gap:16px}.panel{padding:18px}.winner-card{grid-template-columns:1fr;text-align:center}.winner-photo{width:100%;height:auto;aspect-ratio:1 / 1;max-width:220px;margin:0 auto}.winner-stats{justify-content:center}.results-summary{grid-template-columns:1fr}.modal-step{grid-template-columns:1fr;gap:4px}}@media(max-width:520px){.topbar{padding:12px 14px}.topbar-brand{font-size:1rem}.candidate-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.result-row{grid-template-columns:44px 44px minmax(0,1fr);gap:10px;padding:12px}.result-photo{width:44px;height:44px}.result-rank{height:36px;font-size:.85rem}.winner-name{font-size:1.6rem}.winner-share{font-size:1.85rem}.vote-submit-bar button{width:100%}.panel-header>button,.panel-actions>button{flex:1 1 100%}}
