/* Homepage redesign adapted from templates/hoaballot.org/index.html. */
:root{
  --paper:#f8fafc;
  --paper-warm:#eef6f2;
  --paper-deep:#dbe6e2;
  --ink:#0d1411;
  --ink-soft:#3a443f;
  --ink-mute:#6a7770;
  --rule:#d7e2de;
  --rule-strong:#9aa9a3;
  --seal:#1f4d3a;        /* deep civic green */
  --seal-deep:#143527;
  --seal-soft:#dfeae0;
  --stamp:#b85838;       /* official red stamp */
  --gold:#2f6f62;
  --shadow: 0 1px 0 rgba(13,20,17,.04), 0 30px 60px -30px rgba(13,20,17,.18);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:#f8fafc;
  color:var(--ink);
  font-family:"Inter Tight", -apple-system, system-ui, sans-serif;
  font-size:16px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

.serif{font-family:"Instrument Serif", "Times New Roman", serif; font-weight:400; letter-spacing:0;}
.mono{font-family:"JetBrains Mono", ui-monospace, monospace;}

.sr-only{
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
  border:0;
}

a{color:var(--ink); text-decoration-color:var(--rule-strong); text-underline-offset:3px;}
a:hover{text-decoration-color:var(--seal);}

button{font-family:inherit; cursor:pointer;}

/* Skip link */
.skip{
  position:fixed; left:14px; top:14px;
  background:var(--ink); color:var(--paper);
  padding:10px 14px; border-radius:2px;
  z-index:200;
  transform:translateY(-200%);
  font-size:14px;
}
.skip:focus{transform:translateY(0);}

/* ───────────────────────── HEADER ───────────────────────── */
.bar-top{
  background:var(--ink);
  color:var(--paper);
  font-size:12px;
  letter-spacing:.04em;
}
.bar-top .wrap{
  max-width:1280px; margin:0 auto;
  padding:9px 28px;
  display:flex; justify-content:space-between; align-items:center;
  gap:24px;
}
.bar-top .pulse{
  display:inline-block; width:7px; height:7px; border-radius:50%;
  background:#5ecb96; margin-right:8px;
  box-shadow:0 0 0 0 rgba(94,203,150,.55);
  animation:pulse 2.2s ease-out infinite;
}
@keyframes pulse{
  0%{box-shadow:0 0 0 0 rgba(94,203,150,.55)}
  70%{box-shadow:0 0 0 10px rgba(94,203,150,0)}
  100%{box-shadow:0 0 0 0 rgba(94,203,150,0)}
}
.bar-top .muted{opacity:.6}
.bar-top a{color:var(--paper); text-decoration:none; opacity:.9}
.bar-top a:hover{opacity:1}

header.site{
  position:sticky; top:0; z-index:50;
  background:rgba(248,250,252,.94);
  backdrop-filter:saturate(140%) blur(10px);
  border-bottom:1px solid var(--rule);
}
.nav{
  max-width:1280px; margin:0 auto;
  padding:16px 28px;
  display:grid; grid-template-columns: auto 1fr auto; align-items:center;
  gap:32px;
}
.brand{
  display:flex; align-items:center; gap:12px;
  text-decoration:none; color:var(--ink);
}
.brand-mark{
  width:38px; height:38px; position:relative; flex:0 0 auto;
}
.brand-mark img,
.brand-mark svg{display:block; height:100%; object-fit:contain; width:100%}
.brand-name{
  font-family:"Instrument Serif", serif;
  font-size:24px; line-height:1; letter-spacing:0;
}
.brand-name b{font-weight:400}
.brand-name i{font-style:italic; color:var(--seal)}

.nav-links{
  display:flex; gap:28px; justify-content:center;
  font-size:14px; font-weight:500;
}
.nav-links a{text-decoration:none; color:var(--ink-soft);}
.nav-links a:hover{color:var(--seal);}

.nav-cta{display:flex; gap:10px; align-items:center;}

.portal-link{
  color:var(--ink-soft);
  font-size:13px;
  font-weight:700;
  text-decoration:none;
}
.portal-link:hover{
  color:var(--seal);
  text-decoration:underline;
}

.btn{
  display:inline-flex; align-items:center; gap:8px;
  font-size:14px; font-weight:600; letter-spacing:0;
  padding:11px 18px; border-radius:2px;
  text-decoration:none; border:1px solid transparent;
  transition: background .15s, color .15s, border-color .15s, transform .12s;
  white-space:nowrap;
}
.btn-primary{background:var(--ink); color:var(--paper); border-color:var(--ink);}
.btn-primary:hover{background:var(--seal); border-color:var(--seal);}
.btn-ghost{background:transparent; color:var(--ink); border-color:var(--ink);}
.btn-ghost:hover{background:var(--ink); color:var(--paper);}
.btn-link{
  background:transparent; border:none; color:var(--ink);
  font-weight:600; padding:10px 0;
  text-decoration:underline; text-decoration-color:var(--rule-strong); text-underline-offset:5px;
}
.btn-link:hover{text-decoration-color:var(--seal); color:var(--seal);}

.btn .arr{
  display:inline-block; transition:transform .2s;
}
.btn:hover .arr{transform:translateX(3px)}

/* ───────────────────────── HERO ───────────────────────── */
.hero{
  position:relative; z-index:1;
  max-width:1280px; margin:0 auto;
  padding:56px 28px 80px;
  display:grid; grid-template-columns: 1.05fr 1fr; gap:64px;
  align-items:start;
}

.eyebrow{
  display:inline-flex; align-items:center; gap:10px;
  font-size:12px; font-weight:600; letter-spacing:.14em; text-transform:uppercase;
  color:var(--ink-soft);
}
.eyebrow::before{
  content:""; width:24px; height:1px; background:var(--ink-soft);
}

h1.display{
  font-family:"Instrument Serif", serif;
  font-weight:400;
  font-size:clamp(46px, 6vw, 78px);
  line-height:0.98;
  letter-spacing:0;
  margin:18px 0 22px;
}
h1.display em{
  font-style:italic; color:var(--seal);
}
h1.display .underline{
  display:inline-block; position:relative;
}
h1.display .underline::after{
  content:""; position:absolute; left:0; right:0; bottom:0.06em; height:0.32em;
  background:rgba(184,88,56,.18);
  z-index:-1; border-radius:1px;
}

.lede{
  font-size:19px;
  color:var(--ink-soft);
  max-width:560px;
  text-wrap:pretty;
}

.hero-ctas{display:flex; gap:14px; margin:32px 0 28px; flex-wrap:wrap;}

.hero-trust{
  display:grid; grid-template-columns:repeat(3, minmax(0,1fr)); gap:14px 28px;
  margin-top:36px;
  padding-top:24px;
  border-top:1px solid var(--rule);
  font-size:13.5px;
  color:var(--ink-soft);
}
.hero-trust li{list-style:none; display:flex; gap:8px; align-items:flex-start;}
.hero-trust ul{margin:0; padding:0; display:contents;}
.hero-trust .tick{
  flex:0 0 16px; width:16px; height:16px; margin-top:2px;
  border:1.5px solid var(--seal);
  border-radius:50%;
  display:inline-flex; align-items:center; justify-content:center;
  color:var(--seal);
}
.hero-trust .tick svg{width:9px; height:9px;}

.finder-band{
  background:#ffffff;
  border-bottom:1px solid var(--rule);
  border-top:1px solid var(--rule);
  display:grid;
  gap:28px;
  grid-template-columns:minmax(0, 1.15fr) minmax(320px, .85fr);
  margin:0 auto;
  max-width:none;
  padding:42px max(28px, calc((100vw - 1280px) / 2 + 28px));
}

.finder-copy h2{
  font-family:"Instrument Serif", serif;
  font-size:clamp(34px, 4vw, 52px);
  font-weight:400;
  letter-spacing:0;
  line-height:1.02;
  margin:12px 0 12px;
}

.finder-copy p{
  color:var(--ink-soft);
  font-size:17px;
  margin:0;
  max-width:680px;
}

.finder-form{
  display:grid;
  gap:10px;
  margin-top:24px;
  max-width:760px;
}

.finder-form label{
  color:var(--ink-soft);
  font-size:13px;
  font-weight:700;
}

.finder-form > div{
  display:grid;
  gap:10px;
  grid-template-columns:minmax(0, 1fr) auto;
}

.finder-form input{
  border:1px solid var(--rule-strong);
  border-radius:4px;
  color:var(--ink);
  font:inherit;
  min-height:46px;
  padding:10px 12px;
  width:100%;
}

.finder-safeguards{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:16px;
}

.finder-safeguards span{
  background:var(--paper-warm);
  border:1px solid var(--rule);
  border-radius:999px;
  color:var(--ink-soft);
  font-size:12px;
  font-weight:700;
  padding:7px 10px;
}

.finder-examples{
  display:grid;
  gap:10px;
}

.finder-examples a{
  background:#f8fafc;
  border:1px solid var(--rule);
  border-radius:8px;
  color:var(--ink);
  display:grid;
  gap:4px;
  min-height:72px;
  padding:14px;
  text-decoration:none;
}

.finder-examples a:hover{
  border-color:var(--seal);
}

.finder-examples span{
  font-weight:800;
}

.finder-examples small{
  color:var(--ink-mute);
}

/* Dashboard mockup */
.dash{
  background:#ffffff;
  border:1px solid var(--rule-strong);
  border-radius:6px;
  box-shadow:var(--shadow);
  overflow:hidden;
  position:relative;
}
.dash-chrome{
  display:flex; align-items:center; gap:8px;
  padding:11px 14px;
  background:#eef6f2;
  border-bottom:1px solid var(--rule);
  font-size:12px; color:var(--ink-mute);
}
.dash-chrome .dot{width:9px; height:9px; border-radius:50%; background:var(--rule-strong);}
.dash-chrome .url{
  margin-left:8px; padding:3px 10px;
  background:#f8fafc;
  border:1px solid var(--rule);
  border-radius:3px;
  font-family:"JetBrains Mono", monospace; font-size:11px;
  letter-spacing:0;
}

.dash-body{padding:22px 24px 24px;}
.dash-head{
  display:flex; justify-content:space-between; align-items:flex-start;
  margin-bottom:22px;
}
.dash-head .crest{
  font-family:"JetBrains Mono", monospace;
  font-size:10px; letter-spacing:.18em; color:var(--ink-mute);
  text-transform:uppercase;
}
.dash-head .title{
  font-family:"Instrument Serif", serif;
  font-size:24px; line-height:1.05; margin-top:4px;
}
.dash-head .sub{
  font-size:12px; color:var(--ink-mute); margin-top:2px;
  font-family:"JetBrains Mono", monospace;
}
.live-tag{
  display:inline-flex; align-items:center; gap:6px;
  font-size:11px; font-weight:600; letter-spacing:.08em; text-transform:uppercase;
  color:var(--seal-deep);
  background:var(--seal-soft);
  padding:5px 9px;
  border-radius:2px;
  border:1px solid rgba(31,77,58,.2);
}
.live-tag::before{
  content:""; width:6px; height:6px; border-radius:50%;
  background:#2a9d6b;
  box-shadow:0 0 0 0 rgba(42,157,107,.55);
  animation:pulse 2s infinite;
}

.quorum-block{
  border:1px solid var(--rule);
  border-radius:4px;
  padding:18px 20px;
  background:#f8fafc;
  margin-bottom:18px;
}
.qrow{display:flex; align-items:baseline; justify-content:space-between; gap:14px;}
.q-big{
  font-family:"Instrument Serif", serif;
  font-size:54px; line-height:1; letter-spacing:0;
}
.q-big em{font-style:italic; color:var(--seal);}
.q-counts{
  font-family:"JetBrains Mono", monospace;
  font-size:12px; color:var(--ink-soft);
  text-align:right;
}
.q-counts b{color:var(--ink); font-weight:600}
.q-bar{
  height:8px; background:var(--paper-deep); border-radius:99px; overflow:hidden;
  margin-top:14px; position:relative;
}
.q-bar .fill{
  height:100%; width:0%;
  background:linear-gradient(90deg, var(--seal), #2a9d6b);
  transition:width 1.6s cubic-bezier(.22,1,.36,1);
  border-radius:99px;
}
.q-bar .target{
  position:absolute; top:-3px; bottom:-3px; width:2px;
  background:var(--stamp);
  left:67%;
}
.q-meta{
  display:flex; justify-content:space-between;
  margin-top:8px;
  font-size:11px; color:var(--ink-mute);
  font-family:"JetBrains Mono", monospace;
}

.dash-grid{
  display:grid; grid-template-columns:1fr 1fr; gap:12px; margin-bottom:18px;
}
.dash-tile{
  border:1px solid var(--rule);
  border-radius:4px;
  padding:14px 16px;
  background:#ffffff;
}
.dash-tile .k{
  font-family:"JetBrains Mono", monospace;
  font-size:10px; letter-spacing:.12em; text-transform:uppercase;
  color:var(--ink-mute);
}
.dash-tile .v{
  margin-top:6px;
  font-size:15px; font-weight:600;
}
.dash-tile .v .dot{
  display:inline-block; width:7px; height:7px; border-radius:50%;
  background:var(--seal); margin-right:6px; vertical-align:middle;
}

.ledger{
  border-top:1px dashed var(--rule-strong);
  padding-top:14px;
}
.ledger-h{
  display:flex; justify-content:space-between;
  font-family:"JetBrains Mono", monospace;
  font-size:10px; letter-spacing:.12em; text-transform:uppercase;
  color:var(--ink-mute);
  margin-bottom:8px;
}
.ledger-row{
  display:grid;
  grid-template-columns: 90px 1fr auto;
  gap:14px;
  font-family:"JetBrains Mono", monospace;
  font-size:12px;
  padding:5px 0;
  color:var(--ink-soft);
  align-items:center;
}
.ledger-row .t{color:var(--ink-mute);}
.ledger-row .id{color:var(--ink); font-weight:500;}
.ledger-row .s{
  display:inline-flex; align-items:center; gap:5px;
  color:var(--seal-deep);
}
.ledger-row .s::before{
  content:""; width:5px; height:5px; border-radius:50%; background:var(--seal);
}
.ledger-row.new{
  animation:slideIn .6s ease-out;
}
@keyframes slideIn{
  from{opacity:0; transform:translateY(-6px)}
  to{opacity:1; transform:translateY(0)}
}

/* Decorative stamps on dashboard */
.stamp{
  position:absolute;
  top:30px; right:-30px;
  transform:rotate(-14deg);
  font-family:"Instrument Serif", serif;
  font-style:italic;
  color:var(--stamp);
  border:2px solid var(--stamp);
  padding:8px 18px;
  border-radius:4px;
  font-size:18px;
  opacity:.85;
  letter-spacing:.04em;
  pointer-events:none;
  background:rgba(248,250,252,.5);
}

/* Marquee */
.marquee{
  border-top:1px solid var(--rule);
  border-bottom:1px solid var(--rule);
  background:#eef6f2;
  padding:14px 0;
  overflow:hidden;
  position:relative; z-index:1;
}
.marquee-track{
  display:flex; gap:48px;
  animation: marquee 50s linear infinite;
  white-space:nowrap;
  font-family:"JetBrains Mono", monospace;
  font-size:12px; letter-spacing:.06em; text-transform:uppercase;
  color:var(--ink-soft);
}
.marquee-track span{display:inline-flex; align-items:center; gap:48px;}
.marquee-track span::after{content:"✦"; color:var(--rule-strong);}
@keyframes marquee{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}

/* ───────────────────────── SECTIONS ───────────────────────── */
section.s{
  position:relative; z-index:1;
  max-width:1280px;
  margin:0 auto;
  padding:96px 28px;
}
.s.tinted{
  background:#eef6f2;
  max-width:none;
  padding-left:max(28px, calc((100vw - 1280px)/2 + 28px));
  padding-right:max(28px, calc((100vw - 1280px)/2 + 28px));
  border-top:1px solid var(--rule);
  border-bottom:1px solid var(--rule);
}
.s.dark{
  background:var(--ink);
  color:var(--paper);
  max-width:none;
  padding-left:max(28px, calc((100vw - 1280px)/2 + 28px));
  padding-right:max(28px, calc((100vw - 1280px)/2 + 28px));
}
.s.dark .lede, .s.dark .eyebrow{color:rgba(248,250,252,.7);}
.s.dark .eyebrow::before{background:rgba(248,250,252,.5);}

.section-head{
  max-width:1280px; margin:0 auto;
  display:grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1.2fr);
  gap:64px;
  align-items:end;
  margin-bottom:56px;
}
.section-head h2{
  font-family:"Instrument Serif", serif;
  font-weight:400;
  font-size:60px;
  line-height:1.02;
  letter-spacing:0;
  margin:14px 0 0;
}
.section-head h2 em{font-style:italic; color:var(--seal)}
.s.dark .section-head h2 em{color:#88d3ad}
.section-head .lede{
  font-size:17.5px;
  max-width:520px;
}

/* Problem cards: editorial numbered */
.problem-grid{
  display:grid; grid-template-columns:repeat(5, 1fr); gap:0;
  border-top:1px solid var(--rule);
  border-left:1px solid var(--rule);
}
.problem-card{
  padding:28px 26px 32px;
  border-right:1px solid var(--rule);
  border-bottom:1px solid var(--rule);
  background:#f8fafc;
}
.problem-card .num{
  font-family:"JetBrains Mono", monospace;
  font-size:12px; color:var(--ink-mute); letter-spacing:.08em;
  margin-bottom:14px;
  display:flex; justify-content:space-between;
}
.problem-card h3{
  font-family:"Instrument Serif", serif;
  font-weight:400;
  font-size:24px; line-height:1.1;
  margin:0 0 10px;
  letter-spacing:0;
}
.problem-card p{margin:0; font-size:14.5px; color:var(--ink-soft);}

/* Solution: master grid */
.feat-grid{
  display:grid; grid-template-columns:repeat(3, 1fr); gap:1px;
  background:var(--rule);
  border:1px solid var(--rule);
  border-radius:4px;
  overflow:hidden;
}
.feat{
  background:#f8fafc;
  padding:24px 24px 26px;
  display:flex; flex-direction:column; gap:10px;
  min-height:158px;
  transition:background .2s;
}
.feat:hover{background:#fcf8eb;}
.feat .ic{
  width:34px; height:34px;
  display:flex; align-items:center; justify-content:center;
  color:var(--seal);
  margin-bottom:6px;
}
.feat .ic svg{width:22px; height:22px;}
.feat h4{
  font-family:"Inter Tight", sans-serif;
  font-size:15.5px; font-weight:600;
  margin:0;
  letter-spacing:0;
}
.feat h4 a{
  color:inherit;
  text-decoration-color:var(--rule-strong);
}
.feat h4 a:hover{
  color:var(--seal);
}
.feat p{margin:0; font-size:13.5px; color:var(--ink-soft);}

/* Election types: editorial inline list */
.types{
  display:flex; flex-wrap:wrap; gap:10px;
  margin-top:8px;
}
.type-pill{
  font-family:"Instrument Serif", serif;
  font-style:italic;
  font-size:24px;
  padding:8px 18px 10px;
  border:1px solid var(--rule-strong);
  border-radius:99px;
  background:transparent;
  color:var(--ink);
  cursor:default;
  transition: background .15s, color .15s, border-color .15s, transform .15s;
}
a.type-pill{
  text-decoration:none;
}
.type-pill:hover{
  background:var(--ink); color:var(--paper); border-color:var(--ink);
  transform:translateY(-2px);
}
.type-pill .n{
  font-family:"JetBrains Mono", monospace; font-style:normal;
  font-size:11px; vertical-align:super; color:var(--ink-mute); margin-right:6px;
}
.type-pill:hover .n{color:rgba(248,250,252,.6);}

/* Modes */
.modes{
  display:grid; grid-template-columns:repeat(4, 1fr); gap:18px;
}
.mode{
  background:#f8fafc;
  border:1px solid var(--rule);
  border-radius:4px;
  padding:22px 22px 24px;
  display:flex; flex-direction:column; gap:10px;
  position:relative;
  min-height:200px;
}
.mode .badge{
  position:absolute; top:18px; right:18px;
  font-family:"JetBrains Mono", monospace; font-size:10px;
  color:var(--ink-mute); letter-spacing:.1em;
}
.mode h3{
  font-family:"Instrument Serif", serif; font-weight:400;
  font-size:26px; margin:30px 0 0; line-height:1.05;
}
.mode p{margin:0; color:var(--ink-soft); font-size:14px;}
.mode-icon{
  width:36px; height:36px;
  border:1px solid var(--rule-strong);
  border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  color:var(--seal);
}
.mode-icon svg{width:18px; height:18px;}

.ledger-note{
  margin-top:28px;
  padding:20px 24px;
  background:var(--ink);
  color:var(--paper);
  border-radius:4px;
  display:flex; gap:18px; align-items:center;
  font-size:16px;
}
.ledger-note .seal-mini{
  flex:0 0 auto;
  width:46px; height:46px; border-radius:50%;
  border:1.5px solid rgba(248,250,252,.4);
  display:flex; align-items:center; justify-content:center;
  font-family:"Instrument Serif", serif; font-style:italic;
  color:#88d3ad;
}
.ledger-note em{font-style:italic; color:#88d3ad;}

.packet-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:18px;
}
.packet-card{
  background:#f8fafc;
  border:1px solid var(--rule);
  border-radius:4px;
  color:var(--ink);
  display:grid;
  gap:10px;
  min-height:170px;
  padding:24px;
  text-decoration:none;
}
.packet-card:hover{
  border-color:var(--seal);
  background:#fcf8eb;
}
.packet-card h3{
  font-family:"Instrument Serif", serif;
  font-size:28px;
  font-weight:400;
  line-height:1.06;
  margin:0;
}
.packet-card p{
  color:var(--ink-soft);
  margin:0;
}
.packet-label{
  color:var(--stamp);
  font-family:"JetBrains Mono", monospace;
  font-size:11px;
  font-weight:700;
  letter-spacing:.12em;
  text-transform:uppercase;
}

/* Admin workflow: horizontal rail */
.rail{
  position:relative;
  display:grid; grid-template-columns:repeat(4, 1fr); gap:24px;
  padding-top:48px;
}
.rail::before{
  content:""; position:absolute; top:18px; left:6%; right:6%; height:1px;
  background:repeating-linear-gradient(90deg, var(--rule-strong) 0 6px, transparent 6px 12px);
}
.step{
  position:relative;
  background:transparent;
}
.step .marker{
  position:absolute; top:-48px; left:0;
  width:36px; height:36px; border-radius:50%;
  background:#f8fafc;
  border:1.5px solid var(--ink);
  display:flex; align-items:center; justify-content:center;
  font-family:"JetBrains Mono", monospace; font-size:13px; font-weight:600;
}
.s.tinted .step .marker{background:#eef6f2;}
.step h3{
  font-family:"Instrument Serif", serif; font-weight:400;
  font-size:24px; margin:0 0 8px; line-height:1.1;
  letter-spacing:0;
}
.step p{margin:0; font-size:14.5px; color:var(--ink-soft);}
.step .micro{
  margin-top:14px;
  font-family:"JetBrains Mono", monospace;
  font-size:11px; color:var(--ink-mute);
  letter-spacing:.04em;
}

/* Voter journey: receipt */
.receipt-wrap{
  display:grid; grid-template-columns: 1fr 0.85fr; gap:64px; align-items:start;
}
.receipt{
  background:#ffffff;
  border:1px solid var(--rule-strong);
  border-radius:4px;
  padding:28px 32px 36px;
  box-shadow:var(--shadow);
  font-family:"JetBrains Mono", monospace;
  font-size:13px;
  position:relative;
  max-width:480px;
  margin-left:auto;
}
.receipt::before, .receipt::after{
  content:"";
  position:absolute; left:0; right:0; height:14px;
  background:radial-gradient(circle at 7px 0, transparent 6px, var(--paper) 6.5px);
  background-size:14px 14px;
}
.receipt::before{top:-14px;}
.receipt::after{bottom:-14px; transform:rotate(180deg);}
.s.tinted .receipt::before, .s.tinted .receipt::after{
  background:radial-gradient(circle at 7px 0, transparent 6px, var(--paper-warm) 6.5px);
  background-size:14px 14px;
}
.s.tinted .receipt::after{transform:rotate(180deg);}

.receipt-head{
  text-align:center;
  border-bottom:1px dashed var(--rule-strong);
  padding-bottom:14px; margin-bottom:14px;
}
.receipt-head .seal{
  display:inline-flex; align-items:center; justify-content:center;
  width:54px; height:54px; border-radius:50%;
  border:2px double var(--seal);
  color:var(--seal);
  font-family:"Instrument Serif", serif; font-style:italic;
  font-size:24px;
  margin-bottom:10px;
}
.receipt-head .name{
  font-family:"Instrument Serif", serif;
  font-style:normal; font-size:22px;
  letter-spacing:.04em;
}
.receipt-head .sub{font-size:11px; color:var(--ink-mute); letter-spacing:.1em; text-transform:uppercase;}

.receipt-row{
  display:flex; justify-content:space-between; padding:4px 0;
  border-bottom:1px dotted var(--rule);
  font-size:12.5px;
}
.receipt-row .k{color:var(--ink-mute);}
.receipt-row .v{color:var(--ink); font-weight:500;}

.receipt-foot{
  margin-top:14px; padding-top:12px;
  border-top:1px dashed var(--rule-strong);
  font-size:11px;
  text-align:center;
  color:var(--ink-mute);
  letter-spacing:.08em;
}

/* Voter steps list */
.voter-steps{
  list-style:none; padding:0; margin:0;
  counter-reset:vs;
}
.voter-steps li{
  counter-increment:vs;
  display:grid; grid-template-columns: 44px 1fr auto; gap:18px; align-items:center;
  padding:16px 0;
  border-bottom:1px solid var(--rule);
  font-size:16px;
}
.voter-steps li:first-child{border-top:1px solid var(--rule);}
.voter-steps li::before{
  content: counter(vs, decimal-leading-zero);
  font-family:"JetBrains Mono", monospace;
  font-size:13px;
  color:var(--ink-mute);
  letter-spacing:.04em;
}
.voter-steps li .when{
  font-family:"JetBrains Mono", monospace;
  font-size:11.5px;
  color:var(--ink-mute);
}

/* Security */
.s.dark .feat-grid{background:rgba(248,250,252,.16); border-color:rgba(248,250,252,.16);}
.s.dark .feat{background:var(--ink);}
.s.dark .feat:hover{background:#161e1a;}
.s.dark .feat h4{color:var(--paper);}
.s.dark .feat p{color:rgba(248,250,252,.65);}
.s.dark .feat .ic{color:#88d3ad;}

.disclaim{
  margin-top:36px;
  font-size:13px;
  color:rgba(248,250,252,.55);
  max-width:760px;
  border-left:2px solid #88d3ad;
  padding-left:16px;
}

/* Compliance config */
.compliance{
  display:grid; grid-template-columns: 1fr 1fr; gap:64px; align-items:start;
}
.checklist{
  list-style:none; padding:0; margin:0;
  background:#f8fafc;
  border:1px solid var(--rule-strong);
  border-radius:4px;
  overflow:hidden;
}
.checklist li{
  padding:16px 22px;
  border-bottom:1px solid var(--rule);
  display:flex; align-items:center; gap:14px;
  font-size:15.5px;
}
.checklist li:last-child{border-bottom:0}
.checklist .box{
  flex:0 0 18px; width:18px; height:18px;
  border:1.5px solid var(--seal);
  display:flex; align-items:center; justify-content:center;
  color:var(--seal);
}
.checklist .box svg{width:11px; height:11px;}
.checklist li .tag{
  margin-left:auto;
  font-family:"JetBrains Mono", monospace; font-size:10px;
  color:var(--ink-mute); letter-spacing:.08em; text-transform:uppercase;
}

/* Service plans */
.plans{
  display:grid; grid-template-columns:1fr 1fr; gap:24px;
}
.plan{
  background:#f8fafc;
  border:1px solid var(--rule-strong);
  border-radius:4px;
  padding:32px 32px 36px;
  position:relative;
  display:flex; flex-direction:column; gap:14px;
}
.plan.feature{
  background:var(--ink);
  color:var(--paper);
  border-color:var(--ink);
}
.plan .kicker{
  font-family:"JetBrains Mono", monospace;
  font-size:11px; letter-spacing:.12em; text-transform:uppercase;
  color:var(--ink-mute);
}
.plan.feature .kicker{color:#88d3ad;}
.plan h3{
  font-family:"Instrument Serif", serif; font-weight:400;
  font-size:36px; margin:6px 0 8px; line-height:1.02; letter-spacing:0;
}
.plan .desc{font-size:14.5px; color:var(--ink-soft); margin:0;}
.plan.feature .desc{color:rgba(248,250,252,.7);}
.plan ul{list-style:none; padding:0; margin:14px 0 0;}
.plan ul li{
  padding:11px 0; border-top:1px solid var(--rule);
  display:flex; gap:12px; align-items:flex-start;
  font-size:14.5px;
}
.plan.feature ul li{border-top-color:rgba(248,250,252,.16);}
.plan ul li:last-child{border-bottom:1px solid var(--rule);}
.plan.feature ul li:last-child{border-bottom-color:rgba(248,250,252,.16);}
.plan ul li::before{
  content:""; flex:0 0 6px; width:6px; height:6px; margin-top:8px;
  border-radius:50%; background:var(--seal);
}
.plan.feature ul li::before{background:#88d3ad;}
.plan .ribbon{
  position:absolute; top:24px; right:-1px;
  background:var(--stamp); color:var(--paper);
  font-family:"JetBrains Mono", monospace;
  font-size:10px; letter-spacing:.16em; text-transform:uppercase;
  padding:5px 12px;
}

/* Reporting */
.report{
  background:#f8fafc;
  border:1px solid var(--rule-strong);
  border-radius:4px;
  overflow:hidden;
}
.report-head{
  padding:16px 22px;
  border-bottom:1px solid var(--rule);
  display:flex; justify-content:space-between; align-items:center;
  background:#eef6f2;
  font-family:"JetBrains Mono", monospace;
  font-size:11px; letter-spacing:.1em; text-transform:uppercase;
  color:var(--ink-mute);
}
.report-head .right{display:flex; gap:14px;}
.report-body{
  display:grid; grid-template-columns: 1.1fr 1fr; gap:0;
}
.report-col{
  padding:22px 24px;
}
.report-col + .report-col{border-left:1px solid var(--rule);}
.report-col h4{
  font-family:"JetBrains Mono", monospace;
  font-size:11px; letter-spacing:.1em; text-transform:uppercase;
  color:var(--ink-mute);
  margin:0 0 16px;
}
.metric-row{
  display:grid; grid-template-columns: 1fr auto auto; gap:14px;
  padding:10px 0;
  border-bottom:1px dotted var(--rule);
  align-items:center;
  font-size:14.5px;
}
.metric-row:last-child{border-bottom:0;}
.metric-row .v{
  font-family:"JetBrains Mono", monospace;
  font-weight:600;
}
.metric-row .pct{
  font-family:"JetBrains Mono", monospace;
  font-size:11px;
  color:var(--ink-mute);
  min-width:48px; text-align:right;
}
.metric-row .pct.up{color:var(--seal);}
.exports{
  display:grid; gap:8px;
}
.export-row{
  display:grid; grid-template-columns: auto 1fr auto; gap:14px;
  padding:11px 14px; border:1px solid var(--rule); border-radius:3px;
  font-size:13.5px; align-items:center;
  background:#ffffff;
}
.export-row .ext{
  font-family:"JetBrains Mono", monospace;
  font-size:10.5px;
  padding:3px 7px; background:var(--ink); color:var(--paper);
  border-radius:2px; letter-spacing:.06em;
}
.export-row .size{font-family:"JetBrains Mono", monospace; font-size:11px; color:var(--ink-mute);}

/* Member portal CTA */
.member-card{
  background:#f8fafc;
  border:1px solid var(--rule-strong);
  border-radius:4px;
  padding:28px 32px 32px;
  margin-top:48px;
  max-width:680px;
}
.member-card h3{
  font-family:"Instrument Serif", serif; font-weight:400;
  font-size:30px; margin:6px 0 6px; line-height:1.05;
}
.member-card p{margin:0 0 18px; color:var(--ink-soft); font-size:15px;}
.member-form{
  display:grid; grid-template-columns: 1fr auto; gap:10px;
  align-items:stretch;
}
.member-form .input-wrap{
  display:flex; align-items:center;
  background:#ffffff;
  border:1px solid var(--rule-strong);
  border-radius:3px;
  padding:0 14px;
  font-family:"JetBrains Mono", monospace;
  font-size:14px;
}
.member-form .input-wrap input{
  border:none; background:transparent; outline:none;
  font:inherit; flex:1; padding:14px 0;
  color:var(--ink);
  min-width:100px;
}
.member-form .input-wrap .suffix{
  color:var(--ink-mute);
}
.member-card .example{
  font-family:"JetBrains Mono", monospace;
  font-size:12px; color:var(--ink-mute);
  margin-top:14px;
}

/* FAQ */
.faq-grid{
  display:grid; grid-template-columns: minmax(0, 0.5fr) minmax(0, 1fr);
  gap:64px; align-items:start;
}
.faq-grid .head{
  position:sticky; top:96px;
}
.faq-list{margin:0; padding:0;}
.faq-item{
  border-top:1px solid var(--rule);
  padding:0;
}
.faq-item:last-child{border-bottom:1px solid var(--rule);}
.faq-item summary{
  list-style:none;
  cursor:pointer;
  padding:22px 0 22px 48px;
  position:relative;
  font-family:"Instrument Serif", serif;
  font-size:22px;
  letter-spacing:0;
  color:var(--ink);
}
.faq-item summary::-webkit-details-marker{display:none;}
.faq-item summary::before{
  content:""; position:absolute; left:0; top:30px;
  width:18px; height:1.5px; background:var(--ink);
}
.faq-item summary::after{
  content:""; position:absolute; left:8.25px; top:23px;
  width:1.5px; height:15px; background:var(--ink);
  transition:transform .2s;
}
.faq-item[open] summary::after{transform:scaleY(0);}
.faq-item .ans{
  padding:0 0 22px 48px;
  color:var(--ink-soft);
  max-width:620px;
  font-size:15.5px;
}

/* CTA */
.cta{
  position:relative; z-index:1;
  max-width:1280px; margin:0 auto 96px;
  background:var(--ink);
  color:var(--paper);
  border-radius:6px;
  padding:80px 64px;
  display:grid; grid-template-columns: 1.2fr 0.8fr; gap:48px; align-items:end;
  overflow:hidden;
}
.cta h2{
  font-family:"Instrument Serif", serif; font-weight:400;
  font-size:56px;
  line-height:1.02;
  margin:14px 0 0;
  letter-spacing:0;
}
.cta h2 em{font-style:italic; color:#88d3ad}
.cta .eyebrow{color:rgba(248,250,252,.7)}
.cta .eyebrow::before{background:rgba(248,250,252,.5);}
.cta-actions{
  display:flex; gap:14px; flex-wrap:wrap;
}
.cta .btn-primary{background:#88d3ad; border-color:#88d3ad; color:var(--ink-soft); color:#0a1411;}
.cta .btn-primary:hover{background:#a8e3c2; border-color:#a8e3c2;}
.cta .btn-ghost{border-color:rgba(248,250,252,.4); color:var(--paper);}
.cta .btn-ghost:hover{background:#f8fafc; color:var(--ink);}

/* Footer */
footer.site{
  border-top:1px solid var(--rule);
  background:#eef6f2;
  position:relative; z-index:1;
}
.foot{
  max-width:1280px; margin:0 auto;
  padding:48px 28px 36px;
  display:grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap:48px;
}
.foot h5{
  font-family:"JetBrains Mono", monospace;
  font-size:11px; letter-spacing:.12em; text-transform:uppercase;
  color:var(--ink-mute);
  margin:0 0 14px;
}
.foot ul{list-style:none; padding:0; margin:0; display:grid; gap:8px;}
.foot ul a{text-decoration:none; color:var(--ink-soft); font-size:14px;}
.foot ul a:hover{color:var(--seal); text-decoration:underline;}
.foot .about{font-size:13.5px; color:var(--ink-soft); margin:10px 0 0; max-width:340px;}
.foot-bottom{
  border-top:1px solid var(--rule);
  padding:18px 28px;
  max-width:1280px; margin:0 auto;
  display:flex; justify-content:space-between; align-items:center;
  font-family:"JetBrains Mono", monospace; font-size:11px;
  color:var(--ink-mute); letter-spacing:.04em;
}

/* Responsive */
@media (max-width:1080px){
  .hero{grid-template-columns:1fr; padding-top:36px; padding-bottom:48px; gap:48px;}
  .finder-band{grid-template-columns:1fr;}
  .section-head{grid-template-columns:1fr; gap:24px; margin-bottom:36px;}
  .problem-grid{grid-template-columns:repeat(2, 1fr);}
  .feat-grid{grid-template-columns:repeat(2, 1fr);}
  .packet-grid{grid-template-columns:repeat(2, 1fr);}
  .modes{grid-template-columns:repeat(2, 1fr);}
  .rail{grid-template-columns:repeat(2, 1fr); row-gap:64px;}
  .rail::before{display:none;}
  .receipt-wrap, .compliance, .plans, .report-body, .faq-grid, .cta, .foot{grid-template-columns:1fr; gap:32px;}
  .nav{grid-template-columns: auto auto; }
  .nav-links{display:none;}
  .receipt{margin:0;}
  .faq-grid .head{position:static;}
  .cta{padding:48px 32px;}
}
@media (max-width:640px){
  .hero{padding:28px 18px 36px;}
  .finder-band{padding:34px 18px;}
  .finder-form > div{grid-template-columns:1fr;}
  section.s{padding:64px 18px;}
  .problem-grid, .feat-grid, .packet-grid, .modes{grid-template-columns:1fr;}
  .rail{grid-template-columns:1fr;}
  .nav{padding:14px 18px;}
  .bar-top .wrap{padding:9px 18px;}
  .bar-top .hide-sm{display:none;}
  h1.display{font-size:46px;}
  .section-head h2{font-size:34px;}
  .dash-body{padding:18px;}
  .q-big{font-size:42px;}
  .hero-trust{grid-template-columns:1fr;}
  .foot{grid-template-columns:1fr 1fr;}
}

@media (max-width:640px){
  .faq-grid h2.serif{font-size:34px !important;}
}
