﻿/* ============================================================
   FREECOIN - Minimalist Monochrome (Inter)
   Light mode · white & black · zero radius · hairlines · sharp.
   ============================================================ */

:root{
  --bg:#ffffff;
  --bg-2:#fafafa;
  --muted:#f5f5f5;
  --ink:#000000;
  --ink-2:#525252;
  --ink-3:#737373;
  --ink-4:#a3a3a3;
  --line:#e5e5e5;          /* hairline */
  --line-2:#000000;         /* standard border */
  --line-3:#000000;
  --rule:4px solid #000;
  --rule-thick:8px solid #000;
  --ease:cubic-bezier(.2,.7,.2,1);
  --ease-out:cubic-bezier(.16,1,.3,1);
  --radius:0;
}

*{box-sizing:border-box;margin:0;padding:0;border-radius:0 !important}
[hidden]{display:none !important}
*::selection{background:#000;color:#fff}

html,body{
  background:#fff;
  color:var(--ink);
  font-family:'Inter',system-ui,sans-serif;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  font-feature-settings:"ss01" 1, "cv11" 1, "tnum" 1;
}
body{min-height:100vh;line-height:1.55;letter-spacing:-.005em;font-weight:400}

a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}
input,textarea{font:inherit;color:inherit}
.mono{font-family:'Inter',sans-serif;font-variant-numeric:tabular-nums;letter-spacing:0}

/* ============================================================
   GLOBAL TEXTURE - subtle horizontal lines so it's not flat
   ============================================================ */
body::before{
  content:"";
  position:fixed;inset:0;z-index:0;pointer-events:none;
  background-image:repeating-linear-gradient(0deg,transparent,transparent 1px,#000 1px,#000 2px);
  background-size:100% 4px;
  opacity:.018;
}
main,header,footer{position:relative;z-index:1}

/* Kill the old canvas/grain/vignette/godrays - they were for dark mode */
#bg-scene,.grain,.vignette,.godrays,.scanlines{display:none !important}

/* ============================================================
   NAV
   ============================================================ */
.nav{position:sticky;top:0;z-index:50;background:#fff;border-bottom:1px solid #000}
.nav-inner{max-width:1280px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:32px;padding:18px 32px}
.brand{display:flex;align-items:center;gap:12px;font-weight:700;letter-spacing:-.01em}
.brand-img{width:80px;height:80px;object-fit:contain;filter:invert(1);transition:transform .1s var(--ease)}
.brand:hover .brand-img{transform:rotate(4deg)}
.brand-text{font-size:13px;display:flex;gap:8px;align-items:baseline;text-transform:uppercase;letter-spacing:.18em}
.brand-ticker{color:var(--ink-2);font-size:11px}

.nav-links{display:flex;gap:36px}
.nav-links a{font-size:11px;font-weight:500;color:#000;text-transform:uppercase;letter-spacing:.22em;position:relative;padding:4px 0;transition:none}
.nav-links a::after{content:"";position:absolute;left:0;right:0;bottom:-3px;height:2px;background:#000;transform:scaleX(0);transform-origin:left;transition:transform .1s var(--ease)}
.nav-links a:hover::after,.nav-links a:focus-visible::after{transform:scaleX(1)}
.nav-links a:focus-visible{outline:none}
@media (max-width:760px){.nav-links{display:none}}

.nav-wallet{display:flex;align-items:center;gap:12px;min-width:360px}
.nav-wallet input{flex:1;background:#fff;border:0;border-bottom:2px solid #000;padding:8px 0;font-size:12px;color:#000;outline:none;letter-spacing:0;font-variant-numeric:tabular-nums;width:100%;transition:border-bottom-width .1s var(--ease)}
.nav-wallet input::placeholder{color:var(--ink-3);text-transform:uppercase;letter-spacing:.18em;font-size:10px}
.nav-wallet input:focus,.nav-wallet input:focus-visible{border-bottom-width:4px}
.nav-wallet input.valid{font-weight:600}
.nav-wallet input.invalid{border-bottom-color:#000;border-bottom-style:dashed}
.wallet-pill{font-size:10px;letter-spacing:.18em;text-transform:uppercase;padding:5px 12px;border:1px solid #000;color:#000;background:#fff;white-space:nowrap;font-weight:500}
@media (max-width:760px){.nav-wallet{min-width:0;flex:1}}

/* ============================================================
   BUTTONS  -  hard rectangular, color inversion on hover
   ============================================================ */
.btn{position:relative;display:inline-flex;align-items:center;gap:10px;padding:16px 32px;font-size:11px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;border:2px solid #000;cursor:pointer;background:#fff;color:#000;transition:background .1s linear,color .1s linear}
.btn:hover{background:#000;color:#fff}
.btn:focus-visible{outline:3px solid #000;outline-offset:3px}
.btn:active{transform:none}
.btn:disabled{opacity:.3;cursor:not-allowed}
.btn-label{color:inherit}
.btn-glow{display:none}
.btn-primary{background:#000;color:#fff}
.btn-primary:hover{background:#fff;color:#000}
.btn-ghost{background:transparent;border:0;color:#000;padding:8px 0;font-size:11px}
.btn-ghost::after{content:"";position:absolute;left:0;right:0;bottom:4px;height:1px;background:#000;transform:scaleX(0);transform-origin:left;transition:transform .1s var(--ease)}
.btn-ghost:hover::after{transform:scaleX(1)}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;max-width:1280px;margin:0 auto;padding:80px 32px 120px;display:grid;align-content:start}
.hero-inner{max-width:1100px;position:relative;z-index:2;margin:0 auto}

.logo-wrap{display:flex;justify-content:center;align-items:center;margin:24px auto 64px;width:100%;position:relative;perspective:1600px}
.logo-wrap::before{display:none}
.logo-img{position:relative;z-index:1;width:clamp(260px,38vw,460px);height:auto;filter:invert(1);transform-style:preserve-3d;animation:spin3d 16s linear infinite;transform-origin:50% 50%;will-change:transform;image-rendering:pixelated}
@keyframes spin3d{
  0%   {transform:rotateY(0deg)   rotateX(4deg)}
  50%  {transform:rotateY(180deg) rotateX(-4deg)}
  100% {transform:rotateY(360deg) rotateX(4deg)}
}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}

.title{font-size:clamp(48px,10vw,160px);font-weight:900;line-height:.88;letter-spacing:-.045em;margin:0 0 32px;text-align:center}
.title-line{display:block;color:#000}
.title-line.gradient{color:#000;font-style:italic;font-weight:400;letter-spacing:-.03em}

.lede{font-size:clamp(16px,1.4vw,19px);color:var(--ink-2);max-width:680px;margin:0 auto 36px;line-height:1.65;text-align:center}
.lede em{color:#000;font-style:italic;font-weight:500;border:0;padding:0 2px}

/* Launch banner */
.launch-banner{display:inline-flex;align-items:center;gap:10px;margin:0 auto 14px;padding:8px 16px;background:#000;color:#fff;font-size:10px;letter-spacing:.2em;text-transform:uppercase;font-weight:600}
.launch-banner .launch-dot{color:#22c55e;animation:pulse 1.6s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}

/* CA bar */
.ca-bar{display:inline-flex;align-items:center;gap:10px;max-width:100%;margin:0 auto 56px;padding:10px 16px;border:1px solid #000;background:#fff;font-size:12px;flex-wrap:wrap;justify-content:center}
.ca-bar .ca-label{font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-3);font-weight:600}
.ca-bar .ca-value{font-family:'JetBrains Mono','SF Mono',ui-monospace,monospace;font-size:12px;color:#000;letter-spacing:0;word-break:break-all}
.ca-bar .ca-copy{padding:5px 12px;border:1px solid #000;background:#000;color:#fff;font-size:10px;letter-spacing:.18em;text-transform:uppercase;cursor:pointer;font-family:inherit;transition:opacity .15s}
.ca-bar .ca-copy:hover{opacity:.7}
.ca-bar .ca-copy.copied{background:#fff;color:#000}
.ca-bar .ca-link{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3);text-decoration:none;border-bottom:1px solid var(--line);padding-bottom:1px}
.ca-bar .ca-link:hover{color:#000;border-color:#000}
@media (max-width:640px){.ca-bar{font-size:10px}.ca-bar .ca-value{font-size:10px}}

/* Center the inline-flex CA bar inside the hero */
.hero-inner{text-align:center}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:80px;justify-content:center}

/* Stats row - thin black-bordered grid */
.hero-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-top:1px solid #000;border-bottom:1px solid #000;background:#fff}
.stat{display:flex;flex-direction:column;gap:8px;padding:28px 24px;position:relative;border-right:1px solid var(--line)}
.stat:last-child{border-right:0}
.stat::after{display:none}
.stat-label{font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-3);font-weight:500}
.stat-value{font-size:clamp(28px,3vw,40px);font-weight:900;letter-spacing:-.03em;color:#000;font-variant-numeric:tabular-nums;line-height:1}
.stat-unit{font-size:10px;color:var(--ink-3);letter-spacing:.18em;text-transform:uppercase}
@media (max-width:760px){.hero-stats{grid-template-columns:repeat(2,1fr)}.stat{border-bottom:1px solid var(--line)}.stat:nth-child(2){border-right:0}}

/* ROUND HERO - the big countdown widget */
.round-hero{max-width:760px;margin:80px auto 32px;padding:48px 56px;border:2px solid #000;background:#fff;text-align:center;position:relative}
.round-hero::before{display:none}
.round-hero-label{font-size:10px;letter-spacing:.32em;text-transform:uppercase;color:#000;margin-bottom:16px;font-weight:600;display:flex;align-items:center;justify-content:center;gap:14px}
.round-hero-label::before,.round-hero-label::after{content:"";flex:1;max-width:60px;height:1px;background:#000}
.round-hero-countdown{font-size:clamp(80px,14vw,160px);font-weight:900;letter-spacing:-.06em;line-height:.85;color:#000;margin-bottom:36px;font-variant-numeric:tabular-nums;text-shadow:none}
.round-hero-countdown.imminent{animation:imminentpulse 1s ease-in-out infinite}
@keyframes imminentpulse{0%,100%{opacity:1}50%{opacity:.5}}
.round-hero-meta{display:grid;grid-template-columns:repeat(3,1fr);gap:0;padding-top:28px;border-top:1px solid #000}
.round-hero-meta div{display:flex;flex-direction:column;gap:6px;align-items:center;padding:0 16px;border-right:1px solid var(--line)}
.round-hero-meta div:last-child{border-right:0}
.round-hero-meta b{font-size:20px;font-weight:700;color:#000;font-variant-numeric:tabular-nums;letter-spacing:-.01em}
.round-hero-meta span{font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-3);font-weight:500}
.round-hero-cta{display:inline-block;margin-top:28px;font-size:10px;letter-spacing:.28em;text-transform:uppercase;color:#000;font-weight:600;border-bottom:1px solid #000;padding-bottom:3px}
.round-hero-cta:hover{color:#000}

/* Trust strip below hero */
.trust-strip{max-width:1280px;margin:48px auto 0;text-align:center;font-size:10px;letter-spacing:.28em;text-transform:uppercase;color:#000;padding:24px 32px;border-top:4px solid #000;border-bottom:4px solid #000;font-weight:500;display:flex;align-items:center;justify-content:center;gap:18px;flex-wrap:wrap}
.trust-strip span,.trust-strip a{display:inline-block}
.trust-strip .dot{color:var(--ink-3);opacity:.5}
.trust-strip a{color:#000;transition:none;border-bottom:1px solid transparent}
.trust-strip a:hover{border-bottom-color:#000}

/* CONTRACT BLOCK - replaces trust strip */
.contract-block{max-width:1100px;margin:64px auto 0;padding:0 32px;text-align:left}
.contract-head{display:flex;flex-direction:column;align-items:center;gap:16px;margin-bottom:48px}
.contract-label{font-size:10px;letter-spacing:.28em;text-transform:uppercase;color:var(--ink-3);font-weight:600}
.contract-btn{display:inline-flex;flex-direction:column;align-items:center;gap:8px;padding:22px 40px;background:#000;color:#fff;border:2px solid #000;text-decoration:none;transition:transform .12s var(--ease)}
.contract-btn:hover{background:#fff;color:#000;transform:translateY(-2px)}
.contract-btn-label{font-size:18px;font-weight:600;letter-spacing:-.01em}
.contract-btn-id{font-family:'JetBrains Mono','SF Mono',ui-monospace,monospace;font-size:10px;letter-spacing:0;opacity:.7}

.contract-body{border-top:1px solid var(--line);padding-top:48px}
.contract-body > h3{font-size:clamp(22px,2.6vw,32px);font-weight:500;letter-spacing:-.02em;margin:0 0 16px;color:#000}
.contract-body > p{font-size:15px;line-height:1.65;color:var(--ink-2);max-width:760px;margin:0 0 40px}

.contract-steps{list-style:none;padding:0;margin:0 0 48px;display:grid;gap:32px}
.contract-steps li{padding-left:0}
.contract-steps h4{font-size:14px;font-weight:600;letter-spacing:.02em;margin:0 0 10px;color:#000;text-transform:none}
.contract-steps p{font-size:14px;line-height:1.7;color:var(--ink-2);margin:0;max-width:780px}
.contract-steps code{background:#f3f3f3;padding:1px 6px;font-size:12px;font-family:'JetBrains Mono',ui-monospace,monospace;color:#000}
.contract-steps strong{color:#000;font-weight:600}

.contract-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:0;border:1px solid #000}
.contract-cell{padding:18px 22px;border-right:1px solid var(--line);border-bottom:1px solid var(--line);display:flex;flex-direction:column;gap:6px}
.contract-cell:last-child{border-right:0}
.cell-label{font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-3);font-weight:600}
.cell-val{font-size:13px;color:#000;text-decoration:none;border-bottom:1px solid transparent;width:fit-content}
.cell-val.mono{font-family:'JetBrains Mono',ui-monospace,monospace;font-size:12px}
a.cell-val:hover{border-bottom-color:#000}
@media (max-width:640px){.contract-cell{border-right:0}}

/* ============================================================
   SECTIONS
   ============================================================ */
.section{max-width:1280px;margin:0 auto;padding:160px 32px 80px;position:relative;border-top:4px solid #000}
.section:first-of-type{border-top:0}
.section + .section{padding-top:160px}
.section-head{margin-bottom:72px;max-width:780px;padding-top:0}
.section-head{border-top:0}
.section-tag{display:none}
.section h2{font-size:clamp(40px,6vw,88px);font-weight:900;letter-spacing:-.045em;line-height:.95;margin-bottom:24px;color:#000}
.section h2 em{font-style:italic;font-weight:400}
.section-sub{color:var(--ink-2);font-size:17px;max-width:680px;line-height:1.7}
.section-sub b{color:#000;font-weight:600}

/* ============================================================
   GRID + CARD
   ============================================================ */
.grid{display:grid;gap:0}
.grid-3{grid-template-columns:repeat(3,1fr);border-left:1px solid #000;border-top:1px solid #000}
.grid-3 > *{border-right:1px solid #000;border-bottom:1px solid #000}
.grid-4{grid-template-columns:repeat(4,1fr);border-left:1px solid #000;border-top:1px solid #000}
.grid-4 > *{border-right:1px solid #000;border-bottom:1px solid #000}
@media (max-width:1000px){.grid-3{grid-template-columns:1fr 1fr}.grid-4{grid-template-columns:1fr 1fr}}
@media (max-width:640px){.grid-3,.grid-4{grid-template-columns:1fr}}

.card{position:relative;padding:40px 32px;background:#fff;overflow:hidden;transition:background .1s linear,color .1s linear}
.card::before,.card::after{display:none}
.card:hover{background:#000;color:#fff}
.card:hover .card-num,.card:hover .card-meta,.card:hover p{color:rgba(255,255,255,.7)}
.card:hover h3{color:#fff}
.card-num{font-size:11px;letter-spacing:.22em;color:#000;margin-bottom:24px;display:block;font-weight:600;text-transform:uppercase}
.card h3{font-size:22px;font-weight:700;letter-spacing:-.02em;margin-bottom:12px;color:#000;line-height:1.15}
.card p{font-size:14px;color:var(--ink-2);line-height:1.6}
.card-meta{margin-top:24px;font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-3);font-weight:500}

/* ============================================================
   PANEL
   ============================================================ */
.panel{padding:32px;border:1px solid #000;background:#fff;position:relative}
.panel-title{font-size:11px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;margin-bottom:24px;color:#000}
.panel-sub{font-size:12px;color:var(--ink-3);margin:-14px 0 22px;line-height:1.5}
.panel-row{display:flex;justify-content:space-between;gap:16px;padding:14px 0;border-bottom:1px solid var(--line)}
.panel-row:last-of-type{border-bottom:0}
.panel-key{font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-3);font-weight:500}
.panel-val{font-size:13px;color:#000;text-align:right;font-variant-numeric:tabular-nums;font-weight:500}
.panel-bar{margin-top:22px;height:2px;background:var(--line);position:relative}
.panel-bar-fill{height:100%;background:#000;transition:width .4s var(--ease)}
.panel-bar-fill::after{display:none}
.panel-foot{margin-top:18px;font-size:11px;color:var(--ink-3);line-height:1.55;letter-spacing:0}

/* ============================================================
   CLAIM FORM
   ============================================================ */
.claim-wrap{display:grid;grid-template-columns:340px 1fr;gap:0;align-items:start;border:1px solid #000}
@media (max-width:900px){.claim-wrap{grid-template-columns:1fr}}
.claim-status{position:sticky;top:108px;padding:32px;border-right:1px solid #000;border-radius:0 !important}
.claim-status.panel{border:0}
@media (max-width:900px){.claim-status{position:static;border-right:0;border-bottom:1px solid #000}}

.claim-wallet-block{display:flex;flex-direction:column;gap:10px;padding-bottom:18px;margin-bottom:6px;border-bottom:1px solid var(--line)}
.claim-wallet-block .btn{width:100%}
.claim-wallet-or{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3);text-align:center}
.claim-wallet-paste{width:100%;padding:10px 12px;border:1px solid var(--line);background:#fff;font-size:12px;color:var(--ink);outline:none;transition:border-color .15s}
.claim-wallet-paste:focus{border-color:#000}
.claim-wallet-paste.valid{border-color:#000}
.claim-wallet-paste.invalid{border-color:#c00}
.claim-wallet-block.is-connected{padding-bottom:14px}
.claim-wallet-block.is-connected .btn{background:#f3f3f3;color:#000;border:1px solid var(--line)}
.claim-wallet-block.is-connected .claim-wallet-or,
.claim-wallet-block.is-connected .claim-wallet-paste{display:none}
.claim-wallet-mode{display:inline-block;margin-left:6px;padding:2px 6px;font-size:9px;letter-spacing:.16em;text-transform:uppercase;background:#000;color:#fff;vertical-align:middle}
.claim-wallet-mode.preview{background:#e9e9e9;color:#444}
.claim-form.panel{border:0;padding:32px}

.field{display:flex;flex-direction:column;gap:10px;margin-bottom:24px}
.field-label{display:flex;justify-content:space-between;font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:#000;font-weight:600}
.field-hint{color:var(--ink-3);font-weight:400}
.field-hint.warn,.field-hint.bad{color:#000;font-weight:600}
.field-input{display:flex;align-items:center;gap:8px;background:#fff;border:0;border-bottom:2px solid #000;padding:0;transition:border-bottom-width .1s var(--ease)}
.field-input:focus-within{border-bottom-width:4px}
.field-input input{flex:1;background:none;border:0;outline:none;padding:14px 0;font-size:16px;color:#000;font-weight:500}
.field-suffix{font-size:11px;color:var(--ink-3);letter-spacing:.22em;text-transform:uppercase;font-weight:500}

.amount-readout{padding:18px 0;font-size:clamp(32px,4vw,48px);font-weight:900;color:#000;letter-spacing:-.04em;font-variant-numeric:tabular-nums;line-height:1;border-bottom:2px solid #000}
.amount-readout span::after{content:" SOL";font-size:14px;color:var(--ink-3);font-weight:500;margin-left:8px;letter-spacing:.22em;text-transform:uppercase}
.amount-readout.muted{color:var(--ink-3);font-size:18px;font-weight:500;letter-spacing:.05em}
.amount-readout.muted span::after{display:none}

.field textarea{background:#fff;border:1px solid #000;padding:18px;font-size:15px;line-height:1.65;resize:vertical;outline:none;min-height:160px;color:#000;font-family:inherit;transition:border-width .1s var(--ease)}
.field textarea:focus,.field textarea:focus-visible{border-width:2px}
.field input[type="text"],.field input[type="number"],.field input[type="url"]{background:#fff;border:0;border-bottom:2px solid #000;padding:14px 0;font-size:15px;outline:none;color:#000;font-family:inherit;transition:border-bottom-width .1s var(--ease)}
.field input:focus,.field input:focus-visible{border-bottom-width:4px}
.field-meter{height:2px;background:var(--line);overflow:hidden;margin-top:10px}
.field-meter-fill{height:100%;background:#000;transition:width .4s var(--ease)}
.field-meter-fill.warn,.field-meter-fill.bad{background:#000}
.claim-actions{display:flex;align-items:center;gap:18px;flex-wrap:wrap;margin-top:14px;padding-top:24px;border-top:1px solid var(--line)}
.claim-hint{font-size:11px;color:var(--ink-3);letter-spacing:0}

/* ============================================================
   VOTE CARDS
   ============================================================ */
.vote-list{display:flex;flex-direction:column;gap:0;border-top:1px solid #000;border-bottom:1px solid #000}
.vote-card{display:grid;grid-template-columns:1fr auto;gap:32px;align-items:center;padding:28px 32px;border-bottom:1px solid var(--line);background:#fff;transition:background .1s linear,color .1s linear}
.vote-card:last-child{border-bottom:0}
.vote-card:hover{background:#000;color:#fff}
.vote-card:hover .vote-wallet,.vote-card:hover .vote-controls button{color:#fff;border-color:#fff}
.vote-text{font-size:17px;color:#000;line-height:1.55;margin-bottom:10px;font-weight:400;letter-spacing:-.005em}
.vote-card:hover .vote-text{color:#fff}
.vote-wallet{font-size:10px;color:var(--ink-3);font-variant-numeric:tabular-nums;letter-spacing:.18em;text-transform:uppercase;font-weight:500}
.vote-controls{display:flex;gap:0}
.vote-controls button{padding:10px 22px;border:1px solid #000;border-right-width:0;font-size:10px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:#000;background:#fff;transition:background .1s linear,color .1s linear}
.vote-controls button:last-child{border-right-width:1px}
.vote-controls .yes:hover{background:#000;color:#fff}
.vote-controls .no:hover{background:#000;color:#fff}
.vote-controls button.active{background:#000;color:#fff}
.vote-card:hover .vote-controls button{background:transparent;color:#fff}
.vote-card:hover .vote-controls button:hover,.vote-card:hover .vote-controls button.active{background:#fff;color:#000}
.vote-card.paid{opacity:.5}
.vote-pager{display:flex;align-items:center;justify-content:center;gap:32px;padding:32px 0 0;margin-top:24px;border-top:1px solid var(--line)}
.vote-page-btn{padding:10px 22px;border:1px solid #000;font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:#000;background:#fff;font-weight:600;transition:background .1s linear,color .1s linear}
.vote-page-btn:hover:not(:disabled){background:#000;color:#fff}
.vote-page-btn:disabled{opacity:.3;cursor:not-allowed}
.vote-page-info{font-size:11px;color:var(--ink-3);letter-spacing:.18em;text-transform:uppercase;font-weight:500}

.rounds-panel{margin-top:48px;padding:28px 32px;border:1px solid #000;background:#fff}
.ticker-list{list-style:none;display:flex;flex-direction:column;gap:0;font-size:12px;color:var(--ink-2);border-top:1px solid var(--line)}
.ticker-list li{display:flex;justify-content:space-between;padding:14px 0;border-bottom:1px solid var(--line);transition:none;background:transparent}
.ticker-list li:last-child{border-bottom:0}
.ticker-list li:hover{background:transparent}
.ticker-list li b{color:#000;font-weight:600;font-variant-numeric:tabular-nums}
.ticker-list a{display:contents}

/* ============================================================
   PROOF / DOCS CAROUSEL
   ============================================================ */
.docs-carousel{position:relative;margin:0 -32px}
.docs-track{display:flex;gap:0;overflow-x:auto;scroll-snap-type:x mandatory;padding:8px 32px 32px;scroll-behavior:smooth;scrollbar-width:none;-ms-overflow-style:none}
.docs-track::-webkit-scrollbar{display:none}
.doc-slide{flex:0 0 min(560px,82vw);scroll-snap-align:center;display:flex;flex-direction:column;gap:18px;user-select:none;margin-right:32px}
.doc-frame{width:100%;aspect-ratio:8.5/11;border:2px solid #000;background:#fff;overflow:hidden;position:relative;transition:border-width .1s var(--ease)}
.doc-frame iframe{width:100%;height:100%;border:0;display:block;background:#fff}
.doc-slide:hover .doc-frame{border-width:4px}
.doc-caption{display:flex;align-items:center;justify-content:space-between;gap:18px;font-size:10px;color:#000;padding:0 4px;border-top:1px solid #000;padding-top:18px;letter-spacing:.18em;text-transform:uppercase}
.doc-caption span{color:var(--ink-3);font-weight:500}
.doc-caption b{color:#000;font-weight:700;flex:1;text-align:left;padding-left:18px;letter-spacing:.12em}
.doc-caption a{color:#000;text-decoration:none;font-weight:600;border-bottom:1px solid #000;padding-bottom:2px}
.docs-arrow{position:absolute;top:calc(50% - 60px);width:56px;height:56px;border:2px solid #000;background:#fff;color:#000;font-size:24px;font-weight:300;cursor:pointer;z-index:5;display:grid;place-items:center;transition:background .1s linear,color .1s linear;line-height:1}
.docs-arrow:hover{background:#000;color:#fff}
.docs-arrow:focus-visible{outline:3px solid #000;outline-offset:3px}
.docs-arrow.prev{left:32px}
.docs-arrow.next{right:32px}
@media (max-width:640px){.docs-arrow{display:none}}
.docs-foot{margin:32px 0 0;padding:24px 28px;border:1px solid #000;background:#fff;display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;font-size:13px;color:var(--ink-2)}
.docs-foot b{color:#000;font-weight:700}
.docs-foot-link{color:#000;font-size:10px;letter-spacing:.22em;text-transform:uppercase;border-bottom:1px solid #000;padding-bottom:3px;font-weight:600;transition:none}
.docs-foot-link:hover{background:#000;color:#fff;padding:4px 8px}

/* ============================================================
   POOL - minimal strip, framed by black border
   ============================================================ */
.pool-section-minimal .section-head{margin-bottom:48px}
.pool-strip{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:1px solid #000;background:#fff}
@media (max-width:760px){.pool-strip{grid-template-columns:1fr}}
.pool-strip-cell{padding:36px 32px;background:#fff;display:flex;flex-direction:column;gap:10px;border-right:1px solid var(--line)}
.pool-strip-cell:last-child{border-right:0}
@media (max-width:760px){.pool-strip-cell{border-right:0;border-bottom:1px solid var(--line)}.pool-strip-cell:last-child{border-bottom:0}}
.pool-strip-cell span{font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-3);font-weight:500}
.pool-strip-cell b{font-size:32px;font-weight:900;color:#000;font-variant-numeric:tabular-nums;word-break:break-all;letter-spacing:-.025em;line-height:1}
.pool-strip-cell .mono{font-size:13px;font-weight:500}

/* ============================================================
   HOW IT WORKS  -  numbered editorial list
   ============================================================ */
.how-list{list-style:none;display:flex;flex-direction:column;gap:0;border-top:1px solid #000}
.how-list li{display:grid;grid-template-columns:80px 1fr;gap:32px;padding:48px 0;border-bottom:1px solid #000;align-items:start}
.how-num{font-size:clamp(56px,8vw,96px);color:#000;font-weight:900;letter-spacing:-.05em;line-height:.85;font-variant-numeric:tabular-nums}
.how-list h3{font-size:24px;font-weight:700;letter-spacing:-.02em;margin-bottom:10px;color:#000;line-height:1.2}
.how-list p{font-size:15px;color:var(--ink-2);max-width:680px;line-height:1.65}

/* ============================================================
   NONPROFIT (legacy, used in hidden admin path)
   ============================================================ */
.nonprofit-wrap{display:grid;grid-template-columns:1.1fr .9fr;gap:0;border:1px solid #000}
@media (max-width:900px){.nonprofit-wrap{grid-template-columns:1fr}}
.nonprofit-card{position:relative;overflow:hidden;border-right:1px solid #000}
@media (max-width:900px){.nonprofit-card{border-right:0;border-bottom:1px solid #000}}
.nonprofit-card::after{display:none}
.badge{display:inline-flex;align-items:center;gap:10px;font-size:10px;letter-spacing:.22em;text-transform:uppercase;padding:8px 14px;border:1px solid #000;color:#000;margin-bottom:24px;background:#fff;font-weight:600}
.badge-dot{width:6px;height:6px;background:#000;animation:pulse 1.6s var(--ease) infinite}
.nonprofit-card h3{font-size:36px;font-weight:900;letter-spacing:-.035em;margin-bottom:14px;color:#000;line-height:1.05}
.np-rows{display:flex;flex-direction:column;gap:0;margin-bottom:30px}
.np-rows div{display:flex;justify-content:space-between;gap:20px;padding:16px 0;border-bottom:1px solid var(--line);font-size:14px}
.np-rows div span{color:var(--ink-3);font-size:10px;letter-spacing:.22em;text-transform:uppercase;font-weight:500}
.np-rows div b{text-align:right;max-width:60%;word-break:break-all;font-weight:500;color:#000}
.np-actions{display:flex;gap:0;flex-wrap:wrap}

/* ============================================================
   INFRA (admin only)
   ============================================================ */
.infra{display:flex;flex-direction:column;gap:0;margin-top:4px;border:1px solid #000}
.infra-row{display:flex;justify-content:space-between;align-items:center;gap:14px;padding:14px 16px;background:#fff;border-bottom:1px solid var(--line);font-size:13px;transition:none}
.infra-row:last-child{border-bottom:0}
.infra-row b{font-size:11px;color:#000;font-variant-numeric:tabular-nums;letter-spacing:0;font-weight:500}
.infra-pill{display:inline-flex;align-items:center;gap:8px;padding:4px 10px;font-size:9px;letter-spacing:.22em;text-transform:uppercase;border:1px solid #000;background:#fff;color:#000;font-weight:600}
.infra-pill.live{background:#000;color:#fff}
.infra-pill.local{background:#fff;color:#000}
.infra-pill.missing{background:#fff;color:var(--ink-3);border-color:var(--ink-3)}
.infra-pill::before{display:none}
.infra-notes{list-style:none;display:flex;flex-direction:column;gap:14px;font-size:13px;color:var(--ink-2);line-height:1.6}
.infra-notes b{color:#000;font-weight:600}
.infra-notes li{padding-left:22px;position:relative}
.infra-notes li::before{content:"-";position:absolute;left:0;top:0;color:#000;font-weight:700}

.danger-banner{margin:12px 0 24px;padding:18px 20px;border:2px solid #000;background:#fff;color:#000;font-size:12px;line-height:1.55}
.danger-banner b{display:block;font-size:11px;letter-spacing:.22em;margin-bottom:6px;font-weight:700;text-transform:uppercase}
.danger-banner u{text-decoration:underline;text-decoration-style:dashed}
.toggle-row{display:flex;align-items:center;gap:14px;margin:14px 0;padding:14px 16px;border:1px solid #000;font-size:13px;cursor:pointer;color:#000}
.toggle-row b{color:#000;font-weight:700}
.toggle-row input{width:18px;height:18px;accent-color:#000;cursor:pointer}
.route-input{width:60px;background:#fff;border:0;border-bottom:1px solid #000;padding:4px 6px;font-size:12px;text-align:right;color:#000;outline:none;margin-right:4px;font-variant-numeric:tabular-nums;font-weight:600;transition:border-bottom-width .1s var(--ease)}
.route-input:focus{border-bottom-width:2px}
#route-sum.warn{color:#000;font-weight:700}

/* ============================================================
   FOOTER
   ============================================================ */
.foot{border-top:8px solid #000;margin-top:120px;background:#000;color:#fff}
.foot-inner{max-width:1280px;margin:0 auto;padding:80px 32px 40px;display:grid;grid-template-columns:1fr 2fr;gap:64px}
@media (max-width:760px){.foot-inner{grid-template-columns:1fr}}
.brand-foot{margin-bottom:20px}
.brand-foot .brand-img{filter:none}
.foot-tag{color:rgba(255,255,255,.6);font-size:13px;max-width:340px;line-height:1.6}
.foot-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:40px}
.foot-cols h5{font-size:10px;letter-spacing:.28em;text-transform:uppercase;color:rgba(255,255,255,.5);margin-bottom:18px;font-weight:600}
.foot-cols a{display:block;padding:8px 0;font-size:13px;color:#fff;border-bottom:1px solid transparent;transition:none}
.foot-cols a:hover{border-bottom-color:#fff}
.foot-bar{max-width:1280px;margin:0 auto;padding:24px 32px;border-top:1px solid rgba(255,255,255,.15);display:flex;justify-content:space-between;font-size:10px;color:rgba(255,255,255,.5);letter-spacing:.22em;text-transform:uppercase;font-weight:500}

/* ============================================================
   POOL RING / Route bars (legacy in admin section)
   ============================================================ */
.pool-panel{display:flex;flex-direction:column;align-items:center;gap:24px}
.pool-ring{position:relative;width:180px;height:180px}
.pool-ring svg{transform:rotate(-90deg);width:100%;height:100%}
.pool-ring-label{position:absolute;inset:0;display:grid;place-items:center;text-align:center}
.pool-ring-pct{display:block;font-size:36px;font-weight:900;letter-spacing:-.03em;color:#000}
.pool-ring-cap{font-size:10px;color:var(--ink-3);text-transform:uppercase;letter-spacing:.22em;font-weight:500}
.pool-rows{width:100%;display:flex;flex-direction:column;gap:0}
.pool-rows div{display:flex;justify-content:space-between;font-size:13px;padding:12px 0;border-bottom:1px solid var(--line)}
.pool-rows div span{color:var(--ink-3);font-size:10px;letter-spacing:.22em;text-transform:uppercase;font-weight:500}
.pool-rows div b{color:#000;font-weight:600}
.route{display:flex;flex-direction:column;gap:18px}
.route-row{display:grid;grid-template-columns:1fr auto;gap:8px 14px;align-items:center}
.route-row span:first-child{font-size:13px;color:#000;font-weight:500}
.route-pct{font-size:11px;color:var(--ink-2);display:flex;align-items:center;letter-spacing:.18em;text-transform:uppercase;font-weight:600}
.route-bar{grid-column:1/-1;height:2px;background:var(--line);overflow:hidden;position:relative}
.route-bar i{display:block;height:100%;background:#000 !important;animation:slidein 1s var(--ease)}
@keyframes slidein{from{width:0!important;opacity:.3}}

/* ============================================================
   REVEAL + TOAST
   ============================================================ */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .8s var(--ease-out),transform .8s var(--ease-out)}
.reveal.in{opacity:1;transform:none}

.toast{position:fixed;bottom:32px;left:50%;transform:translateX(-50%) translateY(20px);padding:18px 28px;background:#000;color:#fff;border:0;font-size:11px;z-index:100;opacity:0;transition:opacity .15s var(--ease),transform .15s var(--ease);max-width:90vw;letter-spacing:.18em;text-transform:uppercase;font-weight:600}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast.ok{background:#000}
.toast.err{background:#fff;color:#000;border:2px solid #000}

/* ============================================================
   PROOF FOOT (compat)
   ============================================================ */
.np-config-mini{margin-top:24px;padding-top:24px;border-top:1px solid #000}

@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.001s !important;transition-duration:.001s !important}
}
