:root {
  --bg: #f5f3ee;
  --surface: #ffffff;
  --surface-soft: #f9f7f4;
  --border: #e2ddd5;
  --accent: #2d5be3;
  --accent-strong: #1e4bcc;
  --accent-soft: #f0f4ff;
  --accent2: #e8533f;
  --success: #2ea84b;
  --success-soft: #f0faf3;
  --warning-soft: #fff7ea;
  --text: #1a1814;
  --muted: #8a8580;
  --shadow: 0 10px 30px rgba(0,0,0,0.07);
  --radius: 16px;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{min-height:100%}
body{font-family:'Noto Sans KR',sans-serif;background:var(--bg);color:var(--text)}
a{text-decoration:none;color:inherit}
button,input{font:inherit}
.header{background:var(--text);color:#fff;padding:18px 28px;display:flex;align-items:center;justify-content:space-between;gap:18px;border-bottom:3px solid var(--accent);position:sticky;top:0;z-index:20}
.brand{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.brand h1{font-family:'Space Grotesk',sans-serif;font-size:1.25rem}
.badge{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;border-radius:999px;font-size:.72rem;font-weight:800;letter-spacing:1px;text-transform:uppercase;color:#fff}
.badge.admin{background:var(--accent)}
.badge.vote{background:var(--accent2)}
.badge.results{background:var(--success)}
.badge.qr{background:#6c55df}
.nav-links{display:flex;gap:10px;flex-wrap:wrap}
.nav-links a{color:#c5c5c5;font-size:.85rem;font-weight:600;padding:7px 14px;border:1px solid #3a3a3a;border-radius:10px;transition:.18s}
.nav-links a:hover,.nav-links a.active{background:#fff;color:var(--text);border-color:#fff}
.main{max-width:1100px;margin:0 auto;padding:36px 22px 72px}
.narrow{max-width:760px}
.mobile{max-width:520px}
.section-label{font-size:.72rem;font-weight:800;letter-spacing:2px;text-transform:uppercase;color:var(--muted);margin-bottom:10px}
.card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow)}
.card + .card{margin-top:22px}
.grid-2{display:grid;grid-template-columns:1.1fr .9fr;gap:22px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.field{margin-bottom:18px}
.label{display:block;font-size:.84rem;font-weight:700;color:var(--muted);margin-bottom:7px}
.input,.option-input{width:100%;padding:13px 15px;border:1.5px solid var(--border);border-radius:12px;background:var(--surface-soft);color:var(--text);outline:none;transition:.18s}
.input:focus,.option-input:focus{background:#fff;border-color:var(--accent);box-shadow:0 0 0 4px rgba(45,91,227,.12)}
.actions{display:flex;gap:12px;flex-wrap:wrap;align-items:center}
.btn{padding:12px 18px;border:none;border-radius:12px;font-weight:800;cursor:pointer;transition:.18s;display:inline-flex;align-items:center;justify-content:center;gap:8px}
.btn:hover{transform:translateY(-1px)}
.btn.primary{background:var(--accent);color:#fff;box-shadow:0 6px 18px rgba(45,91,227,.22)}
.btn.primary:hover{background:var(--accent-strong)}
.btn.success{background:var(--success);color:#fff;box-shadow:0 6px 18px rgba(46,168,75,.22)}
.btn.success:hover{background:#248a3d}
.btn.outline{background:#fff;border:1.5px solid var(--accent);color:var(--accent)}
.btn.outline:hover{background:var(--accent);color:#fff}
.btn.danger{background:#fff;border:1.5px solid #f1b7ae;color:var(--accent2)}
.btn.danger:hover{background:var(--accent2);color:#fff;border-color:var(--accent2)}
.btn.ghost{background:transparent;border:1.5px solid var(--border);color:var(--muted)}
.btn.ghost:hover{background:var(--surface-soft);color:var(--text)}
.status{padding:14px 16px;border-radius:12px;border:1.5px solid #c8d6ff;background:var(--accent-soft);color:var(--accent);font-size:.92rem;font-weight:700;margin-bottom:18px}
.status.warning{border-color:#ffd4cc;background:#fff5f2;color:var(--accent2)}
.status.success{border-color:#cdeed6;background:#f1fbf4;color:var(--success)}
.helper{font-size:.82rem;color:var(--muted);line-height:1.65}
.hero{padding:28px 24px;border-radius:18px;border:1.5px solid #c5d3f8;background:linear-gradient(135deg,#f0f4ff 0%, #fff 100%);margin-bottom:22px;text-align:center}
.hero-title{font-size:1.9rem;font-weight:900;line-height:1.3;margin-bottom:10px}
.live-indicator{display:inline-flex;align-items:center;gap:8px;padding:7px 16px;border-radius:999px;border:1.5px solid #c5d3f8;background:#fff;color:var(--success);font-size:.84rem;font-weight:800}
.live-dot,.status-dot{width:8px;height:8px;border-radius:50%;background:var(--success);animation:pulse 1.4s infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.35;transform:scale(1.35)}}
.toast{position:fixed;right:24px;bottom:24px;background:var(--text);color:#fff;padding:13px 18px;border-radius:14px;box-shadow:0 10px 30px rgba(0,0,0,.24);transform:translateY(80px);opacity:0;transition:.25s;z-index:100}
.toast.show{transform:translateY(0);opacity:1}
.toast.success{border-left:4px solid var(--success)}
.toast.error{border-left:4px solid var(--accent2)}
.toast.info{border-left:4px solid var(--accent)}
.empty-state{text-align:center;padding:60px 20px;color:var(--muted)}
.empty-state .icon{font-size:3rem;margin-bottom:14px}
.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:22px}
.stat-card{background:#fff;border:1.5px solid var(--border);border-radius:14px;padding:18px;text-align:center;box-shadow:0 4px 14px rgba(0,0,0,.04)}
.stat-card .num{font-family:'Space Grotesk',sans-serif;font-size:2.2rem;font-weight:700;color:var(--accent);line-height:1;margin-bottom:6px}
.stat-card .label{font-size:.8rem;font-weight:700;color:var(--muted)}
.option-row{display:flex;gap:10px;align-items:center;margin-bottom:10px}
.option-index{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--accent);color:#fff;font-size:.84rem;font-weight:800;flex-shrink:0}
.preview-panel{background:var(--surface-soft);border:1.5px dashed var(--border);border-radius:14px;padding:18px}
.preview-item{display:flex;align-items:center;gap:10px;padding:10px 12px;background:#fff;border-radius:10px;border:1px solid var(--border);margin-top:8px}
.preview-dot{width:8px;height:8px;border-radius:50%;background:var(--accent)}
.qr-wrapper{display:inline-block;position:relative;padding:20px;border-radius:18px;background:#fff;border:2px solid var(--border);box-shadow:0 10px 30px rgba(0,0,0,.08)}
.qr-corner{position:absolute;width:20px;height:20px;border-style:solid;border-color:var(--accent)}
.qr-corner.tl{top:8px;left:8px;border-width:3px 0 0 3px}.qr-corner.tr{top:8px;right:8px;border-width:3px 3px 0 0}.qr-corner.bl{left:8px;bottom:8px;border-width:0 0 3px 3px}.qr-corner.br{right:8px;bottom:8px;border-width:0 3px 3px 0}
.url-box{display:flex;align-items:center;justify-content:space-between;gap:10px;background:var(--accent-soft);border:1.5px solid #c5d3f8;border-radius:12px;padding:12px 14px;color:var(--accent);font-size:.86rem;font-weight:700;word-break:break-all}
.chips{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin:18px 0}
.chip{padding:7px 14px;border-radius:999px;background:var(--accent-soft);border:1.5px solid #c5d3f8;color:var(--accent);font-size:.88rem;font-weight:700}
.result-item{position:relative;background:var(--surface-soft);border:1.5px solid var(--border);border-radius:14px;padding:18px 18px;overflow:hidden}
.result-item + .result-item{margin-top:14px}
.result-item.first{background:var(--success-soft);border-color:#cfe8d6}
.result-progress{position:absolute;left:0;top:0;bottom:0;background:rgba(45,91,227,.07);border-right:2px solid rgba(45,91,227,.15);transition:width .5s}
.result-item.first .result-progress{background:rgba(46,168,75,.09);border-right-color:rgba(46,168,75,.2)}
.result-content{position:relative;display:flex;align-items:center;gap:14px}
.rank-badge{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:800;flex-shrink:0;background:#ece7e0;color:var(--muted)}
.rank-badge.top{background:var(--success);color:#fff}
.rank-badge.second{background:#dfe7ff;color:var(--accent)}
.result-name{font-size:1rem;font-weight:800;margin-bottom:6px}
.result-meta{display:flex;align-items:center;gap:10px}
.bar-bg{flex:1;height:8px;background:#ddd6cf;border-radius:999px;overflow:hidden}.bar-fill{height:100%;background:var(--accent);border-radius:999px}.result-item.first .bar-fill{background:var(--success)}
.result-count{min-width:86px;text-align:right;font-family:'Space Grotesk',sans-serif;font-size:1.4rem;font-weight:700;color:var(--accent)}
.result-item.first .result-count{color:var(--success)}
.result-count small{display:block;font-size:.68rem;font-family:'Noto Sans KR',sans-serif;color:var(--muted);font-weight:700}
.table-wrap{overflow:auto}
table{width:100%;border-collapse:collapse;font-size:.9rem} thead{background:var(--accent-soft)} th,td{padding:12px 14px;border-bottom:1px solid var(--border)} th{text-align:left;color:var(--accent);font-size:.8rem;text-transform:uppercase;letter-spacing:.5px}
.option-card{background:#fff;border:2px solid var(--border);border-radius:16px;padding:18px 18px;cursor:pointer;display:flex;align-items:center;gap:14px;transition:.2s;position:relative;overflow:hidden;box-shadow:0 3px 10px rgba(0,0,0,.04)}
.option-card::before{content:'';position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--accent);transform:scaleY(0);transition:.18s}
.option-card:hover,.option-card.selected{border-color:var(--accent);background:var(--accent-soft);transform:translateY(-1px);box-shadow:0 10px 24px rgba(45,91,227,.14)}
.option-card:hover::before,.option-card.selected::before{transform:scaleY(1)}
.option-radio{width:24px;height:24px;border:2px solid var(--border);border-radius:50%;background:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.option-card.selected .option-radio{border-color:var(--accent);background:var(--accent)}
.option-card.selected .option-radio::after{content:'';width:8px;height:8px;border-radius:50%;background:#fff}
.option-num{width:32px;height:32px;border-radius:10px;background:var(--accent-soft);color:var(--accent);font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.option-card.selected .option-num{background:var(--accent);color:#fff}
.option-text{flex:1;font-size:1.02rem;font-weight:700;line-height:1.4}
.success-screen,.already-voted,.no-poll-screen{text-align:center;padding:30px 20px}
.success-icon{width:86px;height:86px;background:var(--success);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:2.4rem;margin:0 auto 24px;box-shadow:0 10px 28px rgba(46,168,75,.26)}
.selected-option{background:var(--accent-soft);border:1.5px solid #c5d3f8;border-radius:14px;padding:15px 18px;font-weight:700;color:var(--accent);display:flex;align-items:center;justify-content:center;gap:10px;margin:20px 0}
.confetti{position:fixed;inset:0;pointer-events:none;overflow:hidden;z-index:1000}.confetti-piece{position:absolute;width:10px;height:10px;animation:confettiFall linear forwards}@keyframes confettiFall{0%{transform:translateY(-20px) rotate(0);opacity:1}100%{transform:translateY(100vh) rotate(720deg);opacity:0}}
.small-note{font-size:.82rem;color:var(--muted)}
@media (max-width: 860px){.grid-2,.chart-grid,.grid-3,.stats-grid{grid-template-columns:1fr}.header{padding:16px 18px;align-items:flex-start}.main{padding:28px 16px 56px}.card{padding:22px}.nav-links{gap:8px}.nav-links a{font-size:.8rem;padding:6px 10px}.hero-title{font-size:1.55rem}.result-content{align-items:flex-start}.result-count{min-width:70px;font-size:1.2rem}.url-box{flex-direction:column;align-items:stretch}.option-row{align-items:stretch}.option-index{margin-top:2px}}
