@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&family=JetBrains+Mono:wght@400;500;600&display=swap');
@import url('https://cdn.jsdelivr.net/gh/orioncactus/pretendard@v1.3.9/dist/web/static/pretendard.min.css');
/* =========================================================
   부정선거 아카이브 — Halo 디자인 시스템
   architectural near-black 캔버스 · 3단 차콜 표면 · 헤어라인 보더
   electric indigo(#5B6BFF) 단일 액션 + 시그널(lime/amber/cyan/magenta)
   Inter(라틴) + Pretendard(한글) · JetBrains Mono(수치/코드) · 미니멀
   * 클래스명·변수명은 기존(coke.css)과 동일 → 게임 HTML 무수정 호환.
   참조: design.uiverse.io/systems/halo
   ========================================================= */
:root{
  /* base — near-black + 3단 차콜 표면 */
  --bg:#0A0B0F; --bg-2:#14151C; --bg-3:#1E2029; --bg-4:#262A36;
  --paper:#0A0B0F; --paper-2:#14151C;          /* 별칭 유지 */
  --line:#2A2D38; --line-2:#353A47;            /* 헤어라인 */
  /* 일렉트릭 인디고 액센트 (구 --red* 슬롯 = 주 액션 컬러) */
  --red:#5B6BFF; --red-2:#4A59E6; --red-3:#3A47C0; --red-hi:#7C88FF;
  --red-soft:rgba(91,107,255,.12); --red-line:rgba(91,107,255,.34); --red-glow:rgba(91,107,255,.40);
  /* 텍스트 */
  --ink:#F2F4F8; --ink-2:#C2C7D2; --ink-3:#8A90A0; --ink-4:#4A4F5C;
  /* 보조 */
  --zero:#2A2D38; --zero-2:#14151C; --silver:#14151C; --gold:#F5D547;
  --sprite:#2BE08C; --sprite-soft:rgba(43,224,140,.12);   /* 라임 시그널 */
  /* 검증상태 → Halo 시그널 (확인=라임 / 일부=앰버 / 약함·기각=마젠타 / 미규명=시안) */
  --st-fact:#2BE08C;    --st-fact-bg:rgba(43,224,140,.12);
  --st-partial:#F5D547; --st-partial-bg:rgba(245,213,71,.12);
  --st-weak:#FF3A5C;    --st-weak-bg:rgba(255,58,92,.12);
  --st-open:#3DD7E5;    --st-open-bg:rgba(61,215,229,.12);
  /* 형태 — 미니멀(살짝 라운드) */
  --r:12px; --r-sm:8px;
  --shadow:0 0 0 1px var(--line);
  --shadow-red:0 0 0 1px var(--red-line),0 10px 36px var(--red-glow);
  --maxw:1000px;
  /* 폰트 — Inter(라틴) + Pretendard(한글), JetBrains Mono(수치) */
  --sans:"Inter","Pretendard","Apple SD Gothic Neo","Malgun Gothic",system-ui,sans-serif;
  --mono:"JetBrains Mono",ui-monospace,"SFMono-Regular",monospace;
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;text-rendering:optimizeLegibility}
html,body{margin:0;padding:0}
body{
  font-family:var(--sans); background:var(--bg); color:var(--ink);
  line-height:1.72; font-size:15.5px; letter-spacing:normal; overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
/* Halo는 클린 substrate — 그레인 제거, 상단 미세 인디고 글로우만 */
body::before{content:"";position:fixed;inset:0;z-index:1;pointer-events:none;
  background:radial-gradient(120% 60% at 50% -20%,rgba(91,107,255,.07),transparent 60%)}
a{color:inherit}
.wrap{max-width:var(--maxw);margin:0 auto;padding:24px 18px 90px;position:relative;z-index:2}
h1,h2,h3,h4{line-height:1.18;margin:0;font-weight:700;letter-spacing:-.02em}
.muted{color:var(--ink-2)}
.center{text-align:center}
.hide{display:none !important}
.ser{color:var(--red-hi);font-weight:700}   /* 강조 = 인디고 */
.num,.stat,.lbl,.vl{font-variant-numeric:tabular-nums;font-family:var(--mono)}
button{font-family:inherit;cursor:pointer;border:none}
::selection{background:var(--red);color:#fff}
:focus-visible{outline:1.5px solid var(--red-hi);outline-offset:3px}

/* ---------- 버튼 ---------- */
.btn{display:inline-flex;align-items:center;gap:8px;background:var(--red);color:#fff;font-weight:600;font-size:14.5px;
  padding:12px 22px;border-radius:10px;transition:.16s}
.btn:hover{background:var(--red-hi);transform:translateY(-1px);box-shadow:0 8px 28px var(--red-glow)}
.btn.ghost{background:transparent;color:var(--ink);border:1px solid var(--line-2)}
.btn.ghost:hover{border-color:var(--red-hi);color:var(--red-hi);background:var(--red-soft)}
.btn.dark{background:var(--bg-3);border:1px solid var(--line)}
.btn.dark:hover{background:var(--bg-4)}
.btn.sprite{background:var(--sprite);color:#06160e}
.btn.line{background:transparent;color:var(--ink);border:1px solid var(--line-2)}
.btn.line:hover{border-color:var(--red-hi);color:var(--red-hi)}

/* ---------- 헤더 ---------- */
.top{position:sticky;top:0;z-index:30;background:rgba(10,11,15,.82);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.top .inner{max-width:var(--maxw);margin:0 auto;padding:13px 18px;display:flex;align-items:center;gap:12px}
.logo{display:flex;align-items:center;gap:10px;font-weight:700;text-decoration:none;color:var(--ink);letter-spacing:-.01em}
.logo .dot{width:22px;height:22px;border-radius:50%;background:var(--red);position:relative;flex:none;
  box-shadow:0 0 0 3px rgba(91,107,255,.18),0 0 18px var(--red-glow)}   /* halo ring */
.logo .dot::after{content:"";position:absolute;left:6px;top:5px;width:6px;height:6px;border-radius:50%;background:#fff;opacity:.92}
.top .sp{flex:1}
.top a.nav{font-size:13.5px;font-weight:500;color:var(--ink-2);text-decoration:none}
.top a.nav:hover{color:var(--red-hi)}

/* ---------- 히어로 ---------- */
.hero{position:relative;overflow:hidden;border:1px solid var(--line);border-radius:var(--r);color:var(--ink);
  background:radial-gradient(120% 80% at 25% -10%,var(--red-soft),transparent 55%),var(--bg-2);padding:64px 34px 72px}
.hero h1{font-size:clamp(38px,6.2vw,74px);font-weight:800;letter-spacing:-.03em;line-height:1.06;color:var(--ink)}
.hero .kicker{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:12px;font-weight:600;
  letter-spacing:.06em;text-transform:uppercase;color:var(--ink-2);background:var(--bg-3);
  border:1px solid var(--line-2);padding:7px 13px;border-radius:999px;margin-bottom:18px}
.hero .kicker i{color:var(--red-hi)}
.hero p{max-width:640px;margin:16px auto 0;font-size:16px;color:var(--ink-2);line-height:1.7}
.hero .cta{margin-top:28px;display:flex;gap:10px;justify-content:center;flex-wrap:wrap}
.hero .btn{background:var(--red);color:#fff}
.hero .btn:hover{background:var(--red-hi)}
.bubbles,.wave{display:none}

/* ---------- 카드 그리드 ---------- */
.grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
@media(max-width:640px){.grid{grid-template-columns:1fr}.hero h1{font-size:32px}}
.card{background:var(--bg-2);border:1px solid var(--line);border-radius:var(--r);padding:22px;transition:.16s;position:relative;overflow:hidden}
.card.link{cursor:pointer;text-decoration:none;color:inherit;display:block}
.card.link:hover{border-color:var(--red-line);background:var(--bg-3);transform:translateY(-2px)}
.card .ico{width:42px;height:42px;border-radius:10px;display:grid;place-items:center;font-size:18px;
  background:var(--red-soft);border:1px solid var(--red-line);color:var(--red-hi);margin-bottom:14px}
.card h3{font-size:18.5px;margin-bottom:6px;letter-spacing:-.01em}
.card .desc{font-size:14px;color:var(--ink-2);margin-bottom:14px;line-height:1.65}
.card .meta{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.card .go{position:absolute;right:18px;top:20px;font-family:var(--mono);font-size:11px;font-weight:500;
  color:var(--red-hi);text-transform:uppercase;letter-spacing:.06em}
.card.soon{opacity:.55}
.ribbon{position:absolute;right:-34px;top:14px;transform:rotate(38deg);background:var(--bg-4);color:var(--ink-2);
  font-size:10px;font-weight:600;padding:5px 40px;letter-spacing:.08em;text-transform:uppercase}

/* ---------- 섹션/배지/칩 ---------- */
.section-h{display:flex;align-items:center;gap:10px;margin:44px 0 16px}
.section-h .bar{width:3px;height:20px;background:var(--red);border-radius:2px}
.section-h h2{font-size:21px;letter-spacing:-.02em}
.chip{display:inline-flex;align-items:center;gap:6px;font-family:var(--mono);font-size:11.5px;font-weight:500;
  letter-spacing:.03em;padding:5px 10px;border-radius:var(--r-sm);background:var(--bg-3);color:var(--ink-2);border:1px solid var(--line)}
.badge{display:inline-flex;align-items:center;gap:7px;font-size:12.5px;font-weight:600;padding:5px 11px;border-radius:999px}
.badge .d{width:7px;height:7px;border-radius:50%;flex:none}
.st-fact{background:var(--st-fact-bg);color:var(--st-fact);border:1px solid rgba(43,224,140,.28)}.st-fact .d{background:var(--st-fact)}
.st-partial{background:var(--st-partial-bg);color:var(--st-partial);border:1px solid rgba(245,213,71,.28)}.st-partial .d{background:var(--st-partial)}
.st-weak{background:var(--st-weak-bg);color:var(--st-weak);border:1px solid rgba(255,58,92,.28)}.st-weak .d{background:var(--st-weak)}
.st-open{background:var(--st-open-bg);color:var(--st-open);border:1px solid rgba(61,215,229,.28)}.st-open .d{background:var(--st-open)}

/* ---------- 패널 ---------- */
.panel{background:var(--bg-2);border:1px solid var(--line);border-radius:var(--r);padding:22px}
.panel.l-fact{border-left:2px solid var(--st-fact)}
.panel.l-partial{border-left:2px solid var(--st-partial)}
.panel.l-weak{border-left:2px solid var(--st-weak)}
.panel.l-open{border-left:2px solid var(--st-open)}

/* ---------- 진행바 ---------- */
.progress{display:flex;align-items:center;gap:14px;margin:6px 0 20px}
.progress .track{flex:1;height:4px;background:var(--bg-4);overflow:hidden;border-radius:999px}
.progress .track>i{display:block;height:100%;width:0;background:var(--red);transition:width .45s}
.progress .lbl{font-family:var(--mono);font-size:12.5px;font-weight:500;color:var(--ink-2);white-space:nowrap}

/* ---------- 차트 ---------- */
.chart{background:var(--bg);border:1px solid var(--line);border-radius:var(--r);padding:14px;margin:14px 0}
.chart .cap{font-size:12.5px;color:var(--ink-2);margin-bottom:10px}
.chart .row{display:flex;align-items:center;gap:10px;margin:8px 0;font-size:13.5px}
.chart .row .nm,.chart .row .cn{width:120px;flex:none;color:var(--ink-2)}
.chart .row .tr{flex:1;height:18px;background:var(--bg-4);overflow:hidden;border-radius:6px}
.chart .row .tr>i{display:block;height:100%}
.chart .row .vl{width:62px;text-align:right;flex:none;font-family:var(--mono);font-weight:500}

/* ---------- 옵션 ---------- */
.opts{display:grid;gap:8px;margin-top:6px}
.opt{display:flex;gap:12px;align-items:center;text-align:left;background:var(--bg);border:1px solid var(--line-2);
  color:var(--ink);padding:14px 16px;border-radius:10px;font-size:15px;font-weight:500;transition:.14s}
.opt:hover{border-color:var(--red-hi);background:var(--red-soft)}
.opt.sel{border-color:var(--red-hi);background:var(--red-soft)}
.opt .k{width:24px;height:24px;border-radius:var(--r-sm);background:var(--bg-4);display:grid;place-items:center;
  font-family:var(--mono);font-weight:600;font-size:12px;flex:none}
.opt.sel .k{background:var(--red);color:#fff}

/* ---------- 푸터 ---------- */
.foot{margin-top:48px;padding-top:22px;border-top:1px solid var(--line);font-size:12.5px;color:var(--ink-2);line-height:1.85}
.foot a{color:var(--red-hi);text-decoration:none}
.foot a:hover{text-decoration:underline}

/* ---------- 유틸 ---------- */
.tag{font-family:var(--mono);font-size:11.5px;color:var(--ink-2);border:1px solid var(--line);padding:4px 9px;border-radius:var(--r-sm);background:var(--bg)}
.note{background:var(--sprite-soft);border:1px solid rgba(43,224,140,.24);border-radius:var(--r);padding:13px 15px;font-size:14px;color:var(--ink)}
.note b{color:var(--sprite)}
.warn{background:var(--st-partial-bg);border:1px solid rgba(245,213,71,.24);border-radius:var(--r);padding:13px 15px;font-size:14px}
.kbd{font-family:var(--mono);font-size:12px;background:var(--bg-4);color:var(--ink);padding:2px 7px;border-radius:var(--r-sm)}

/* ---------- 아이콘 (Lucide) ---------- */
.lucide,[data-lucide]{width:1em;height:1em;display:inline-block;vertical-align:-.125em;stroke-width:2;flex:none}
svg.lucide{width:1em;height:1em}

/* ---------- 반응형 ---------- */
img,svg,video{max-width:100%;height:auto}
@media(max-width:600px){
  .wrap{padding:18px 14px 72px}
  .hero{padding:46px 22px 56px}
  .hero p{font-size:15px}
  .btn{