/* ═══════════════════════════════════════════════════════════════════════
   OXFORD-METRO ANALYTICS — oma-homepage-v5.css  v5.2
   Compact hero · crystal-clear voting UX · single footer · mobile-first
   Brand palette: Navy #002147 · Gold #B8962E · Cream #F5F5F0
   ═══════════════════════════════════════════════════════════════════════ */

/* ── SUPPRESS LEGACY ELEMENTS ─────────────────────────── */
.oma-ticker-wrap,
.oma-global-banner,
.oma-footer-api-strip,
.oma-footer-research,
.oma-footer            { display:none !important; }

/* ── CSS RESET (scoped) ────────────────────────────────── */
.oma5-hero,.oma5-sec,.oma5-cred,.oma5-alayout,.oma-footer-v5 { box-sizing:border-box; }

/* ── KEYFRAMES ─────────────────────────────────────────── */
@keyframes oma5Up   { from{opacity:0;transform:translateY(12px)} to{opacity:1;transform:translateY(0)} }
@keyframes oma5In   { from{opacity:0} to{opacity:1} }
@keyframes oma5Pop  { 0%{opacity:0;transform:scale(.95)} 100%{opacity:1;transform:scale(1)} }
@keyframes omaRed   { 0%,100%{box-shadow:0 0 0 0 rgba(229,62,62,.5)} 50%{box-shadow:0 0 0 6px rgba(229,62,62,0)} }
@keyframes omaGold  { 0%,100%{box-shadow:0 0 0 0 rgba(184,150,46,.5)} 50%{box-shadow:0 0 0 6px rgba(184,150,46,0)} }

/* ── LIVE DOTS ─────────────────────────────────────────── */
.oma5-live-dot {
  display:inline-block; width:6px; height:6px; border-radius:50%;
  background:#E53E3E; flex-shrink:0; animation:omaRed 1.8s ease infinite;
}
.oma5-live-dot--gold { background:#D4AE48; animation:omaGold 1.8s ease infinite; }

/* ── SHARED INNER CONTAINER ────────────────────────────── */
.oma5-inner {
  max-width:1200px; margin:0 auto; padding:0 40px;
  font-family:'DM Sans',system-ui,sans-serif;
}
.oma5-rel { position:relative; z-index:1; }


/* ═══════════════════════════════════════════════════════════
   § 1  HERO — compact, not full-screen
   ═══════════════════════════════════════════════════════════ */
.oma5-hero {
  position:relative; background:#002147;
  padding:32px 0 0;   /* tight top — hero must NOT fill viewport */
  overflow:hidden; isolation:isolate;
  font-family:'DM Sans',system-ui,sans-serif;
}
.oma5-hero__grid {
  position:absolute; inset:0; pointer-events:none;
  background-image:
    linear-gradient(rgba(184,150,46,.05) 1px,transparent 1px),
    linear-gradient(90deg,rgba(184,150,46,.05) 1px,transparent 1px);
  background-size:44px 44px;
}
.oma5-hero__diagonal {
  position:absolute; inset:0; pointer-events:none;
  background:linear-gradient(125deg,transparent 55%,rgba(184,150,46,.035) 100%);
}
.oma5-hero__inner {
  position:relative; z-index:2; max-width:1200px; margin:0 auto; padding:0 40px;
}
.oma5-hero__copy { animation:oma5Up .5s ease both; }

.oma5-hero__eyebrow {
  display:flex; align-items:center; gap:8px; margin:0 0 10px;
  font-size:.6rem; font-weight:700; letter-spacing:.14em; text-transform:uppercase;
  color:rgba(255,255,255,.4);
}
.oma5-hero__hl { color:#D4AE48; }

.oma5-hero__headline {
  font-family:'EB Garamond',Georgia,serif;
  font-size:clamp(2rem,4.5vw,3.6rem); /* compact — not oversized */
  font-weight:700; line-height:1.08; color:#fff;
  margin:0 0 10px; letter-spacing:-.01em;
}
.oma5-hero__headline em { color:#D4AE48; font-style:italic; }

.oma5-hero__sub {
  font-size:.9rem; line-height:1.68; color:rgba(255,255,255,.6);
  margin:0 0 14px; max-width:540px;
}

.oma5-hero__badges {
  display:flex; flex-wrap:wrap; gap:6px; margin-bottom:18px;
  animation:oma5Up .5s .07s ease both;
}
.oma5-badge {
  font-size:.62rem; font-weight:600; letter-spacing:.06em; text-transform:uppercase;
  color:rgba(255,255,255,.44); padding:3px 10px; border:1px solid rgba(255,255,255,.12);
}

.oma5-hero__actions {
  display:flex; gap:10px; flex-wrap:wrap; margin-bottom:22px;
  animation:oma5Up .5s .14s ease both;
}

/* Stat bar */
.oma5-hero__statbar {
  display:flex; align-items:center; flex-wrap:wrap;
  border-top:1px solid rgba(255,255,255,.08); padding:12px 0;
  animation:oma5Up .5s .2s ease both;
}
.oma5-stat { flex:1; min-width:72px; padding:0 12px; }
.oma5-stat:first-child { padding-left:0; }
.oma5-stat__num {
  font-family:'EB Garamond',Georgia,serif;
  font-size:1.35rem; font-weight:700; color:#fff; line-height:1;
  font-variant-numeric:tabular-nums;
}
.oma5-stat__lbl {
  font-size:.54rem; font-weight:600; letter-spacing:.08em; text-transform:uppercase;
  color:rgba(255,255,255,.36); margin-top:3px;
}
.oma5-stat__div { width:1px; height:30px; background:rgba(255,255,255,.08); flex-shrink:0; }

/* Brand tagline below hero */
.oma5-hero__brand {
  position:relative; z-index:2; max-width:1200px; margin:0 auto; padding:9px 40px;
  font-size:.62rem; color:rgba(255,255,255,.28);
  font-family:'EB Garamond',Georgia,serif;
  border-top:1px solid rgba(255,255,255,.05);
}
.oma5-hero__brand em { font-style:italic; }


/* ═══════════════════════════════════════════════════════════
   § 2  CREDIBILITY STRIP
   ═══════════════════════════════════════════════════════════ */
.oma5-cred {
  background:#001530; border-top:2px solid #B8962E;
  padding:14px 0; font-family:'DM Sans',system-ui,sans-serif;
}
.oma5-cred__inner {
  max-width:1200px; margin:0 auto; padding:0 40px;
  display:flex; flex-direction:column; align-items:center; gap:7px; text-align:center;
}
.oma5-cred__main { font-size:.88rem; color:rgba(255,255,255,.72); margin:0; }
.oma5-cred__sub  { font-size:.76rem; color:rgba(255,255,255,.38); margin:0; }
.oma5-cred__items {
  display:flex; align-items:center; gap:14px; flex-wrap:wrap; justify-content:center;
}
.oma5-cred__items span {
  font-size:.6rem; font-weight:600; letter-spacing:.07em; text-transform:uppercase;
  color:rgba(255,255,255,.42);
}
.oma5-cred__div { width:1px; height:12px; background:rgba(255,255,255,.1); }


/* ═══════════════════════════════════════════════════════════
   SHARED SECTION CHROME
   ═══════════════════════════════════════════════════════════ */
.oma5-sec {
  padding:52px 0; font-family:'DM Sans',system-ui,sans-serif;
}
.oma5-sec--light  { background:#F5F5F0; }
.oma5-sec--dark   { background:#002147; }
.oma5-sec--navy   { background:#001530; }
.oma5-sec--navydp { background:#001530; position:relative; overflow:hidden; }
.oma5-sec--btop   { border-top:1px solid #D5D5CC; }

.oma5-sec__head  { margin-bottom:22px; }
.oma5-eyebrow {
  display:inline-flex; align-items:center; gap:7px; margin:0 0 7px;
  font-size:.6rem; font-weight:700; letter-spacing:.14em; text-transform:uppercase;
  color:#B8962E;
}
.oma5-eyebrow--gold { color:#D4AE48; }
.oma5-sec__title {
  font-family:'EB Garamond',Georgia,serif;
  font-size:clamp(1.55rem,2.8vw,2.25rem);
  font-weight:700; color:#002147; line-height:1.1; margin:0 0 7px;
}
.oma5-sec__title--light { color:#fff; }
.oma5-sec__sub {
  font-size:.84rem; line-height:1.72; color:#5A6474; margin:0; max-width:600px;
}
.oma5-sec__sub--light { color:rgba(255,255,255,.52); }
.oma5-sec__sub strong { color:#002147; }
.oma5-sec__sub--light strong { color:#fff; }
.oma5-gold-em { color:#D4AE48; font-style:italic; }

.oma5-cta-row { margin-top:22px; }


/* ── BUTTONS ──────────────────────────────────── */
.oma5-btn-pri {
  display:inline-flex; align-items:center; gap:6px;
  padding:11px 24px; background:#B8962E; color:#002147 !important;
  font-family:'DM Sans',sans-serif; font-size:.75rem; font-weight:800;
  letter-spacing:.07em; text-transform:uppercase; text-decoration:none;
  border:none; cursor:pointer; transition:background .16s,transform .14s;
}
.oma5-btn-pri:hover { background:#D4AE48; transform:translateY(-2px); }

.oma5-btn-sec {
  display:inline-flex; align-items:center; gap:6px;
  padding:10px 20px; background:transparent; color:rgba(255,255,255,.7) !important;
  border:1.5px solid rgba(255,255,255,.2); font-family:'DM Sans',sans-serif;
  font-size:.75rem; font-weight:600; letter-spacing:.06em; text-transform:uppercase;
  text-decoration:none; transition:border-color .16s,color .16s,transform .14s;
}
.oma5-btn-sec:hover { border-color:#D4AE48; color:#D4AE48 !important; transform:translateY(-2px); }

.oma5-btn-gold {
  display:inline-flex; align-items:center; gap:6px;
  padding:11px 22px; background:#B8962E; color:#002147 !important;
  font-family:'DM Sans',sans-serif; font-size:.75rem; font-weight:800;
  letter-spacing:.07em; text-transform:uppercase; text-decoration:none;
  border:none; cursor:pointer; transition:background .16s,transform .14s;
}
.oma5-btn-gold:hover { background:#D4AE48; transform:translateY(-2px); }

.oma5-btn-outline {
  display:inline-flex; align-items:center; gap:6px;
  padding:10px 18px; background:transparent; color:#002147;
  border:1.5px solid #002147; font-family:'DM Sans',sans-serif;
  font-size:.75rem; font-weight:600; letter-spacing:.05em; text-transform:uppercase;
  text-decoration:none; transition:background .16s,color .16s;
}
.oma5-btn-outline:hover { background:#002147; color:#fff !important; }

.oma5-btn-sm {
  display:inline-flex; align-items:center; gap:5px;
  padding:7px 14px; background:transparent; color:#002147;
  border:1.5px solid #002147; font-family:'DM Sans',sans-serif;
  font-size:.7rem; font-weight:600; text-transform:uppercase; text-decoration:none;
  transition:background .16s,color .16s; margin-top:10px;
}
.oma5-btn-sm:hover { background:#002147; color:#fff !important; }

.oma5-btn-signup {
  width:100%; display:flex; align-items:center; justify-content:center; gap:6px;
  padding:13px 14px; background:#B8962E; color:#002147;
  font-family:'DM Sans',sans-serif; font-size:.78rem; font-weight:800;
  letter-spacing:.07em; text-transform:uppercase; border:none; cursor:pointer;
  transition:background .16s; margin-top:2px;
}
.oma5-btn-signup:hover { background:#D4AE48; }


/* ── NOTICES ──────────────────────────────────── */
.oma5-notice {
  padding:10px 14px; margin-bottom:16px; font-size:.76rem; line-height:1.55;
  font-family:'DM Sans',sans-serif;
}
.oma5-notice--info {
  background:rgba(0,33,71,.06); border-left:3px solid #002147; color:#5A6474;
}
.oma5-notice--info strong { color:#002147; }
.oma5-notice--warning {
  background:rgba(184,150,46,.1); border-left:3px solid #B8962E;
  color:rgba(255,255,255,.55); margin-top:16px;
}
.oma5-notice--warning strong { color:rgba(255,255,255,.88); }


/* ═══════════════════════════════════════════════════════════
   VOTE INSTRUCTION BANNER
   ═══════════════════════════════════════════════════════════ */
.oma5-vote-instr {
  display:flex; align-items:center; gap:8px; flex-wrap:wrap;
  background:#002147; color:rgba(255,255,255,.8);
  padding:11px 16px; margin-bottom:14px;
  border-left:4px solid #B8962E;
  font-size:.82rem; font-family:'DM Sans',sans-serif; line-height:1.5;
}
.oma5-vote-instr strong { color:#fff; }
.oma5-vote-instr__step {
  display:inline-block; background:#B8962E; color:#002147;
  font-size:.58rem; font-weight:800; letter-spacing:.08em; text-transform:uppercase;
  padding:2px 8px; border-radius:2px; white-space:nowrap;
}


/* ═══════════════════════════════════════════════════════════
   § 3  CANDIDATE GRID + CARDS
   ═══════════════════════════════════════════════════════════ */
.oma5-cgrid {
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(145px,1fr));
  gap:10px; margin-bottom:16px;
}

.oma5-ccard {
  display:flex; flex-direction:column;
  background:#fff; border:2px solid #D5D5CC;
  cursor:pointer; outline:none; position:relative;
  transition:border-color .16s,transform .18s,box-shadow .16s;
  animation:oma5Pop .3s ease both;
}
.oma5-ccard:hover  { border-color:#8892A0; transform:translateY(-3px); box-shadow:0 6px 16px rgba(0,0,0,.08); }
.oma5-ccard:focus  { border-color:#002147; box-shadow:0 0 0 3px rgba(0,33,71,.14); }

/* SELECTED STATE — highly visible */
.oma5-ccard--sel {
  border-color:#002147 !important; background:#002147 !important;
  transform:translateY(-3px) !important; box-shadow:0 8px 22px rgba(0,33,71,.26) !important;
}
.oma5-ccard--disabled { cursor:default; pointer-events:none; opacity:.68; }

/* Photo block — full face */
.oma5-ccard__photo {
  position:relative; height:96px;
  display:flex; align-items:center; justify-content:center;
  overflow:hidden; flex-shrink:0;
}
.oma5-ccard__photo img {
  width:100%; height:100%; object-fit:cover; object-position:center top;
}
.oma5-ccard__init {
  font-family:'EB Garamond',Georgia,serif;
  font-size:1.5rem; font-weight:700; color:rgba(255,255,255,.8);
}
.oma5-ccard__imgpending {
  position:absolute; bottom:4px; left:0; right:0; text-align:center;
  font-size:.52rem; color:rgba(255,255,255,.5); letter-spacing:.06em; text-transform:uppercase;
}

/* Checkmark overlay */
.oma5-ccard__check {
  position:absolute; top:6px; right:6px;
  width:22px; height:22px; border-radius:50%; background:#B8962E;
  display:flex; align-items:center; justify-content:center;
  color:#002147; font-size:.8rem; font-weight:900;
  opacity:0; transform:scale(.4); transition:opacity .18s,transform .18s;
  pointer-events:none;
}
.oma5-ccard--sel .oma5-ccard__check { opacity:1; transform:scale(1); }

/* Card body */
.oma5-ccard__body { padding:8px 10px 6px; flex:1; }
.oma5-ccard__name {
  font-size:.76rem; font-weight:700; color:#002147;
  line-height:1.2; margin-bottom:2px; transition:color .16s;
}
.oma5-ccard--sel .oma5-ccard__name { color:rgba(255,255,255,.92); }
.oma5-ccard__party {
  font-size:.58rem; font-weight:700; color:#B8962E;
  text-transform:uppercase; letter-spacing:.07em; margin-bottom:2px;
  transition:color .16s;
}
.oma5-ccard--sel .oma5-ccard__party { color:#D4AE48; }
.oma5-ccard__role {
  font-size:.58rem; color:#8892A0; margin-bottom:5px; line-height:1.35;
  transition:color .16s;
}
.oma5-ccard--sel .oma5-ccard__role { color:rgba(255,255,255,.42); }
.oma5-ccard__votes {
  font-size:.56rem; font-weight:600; letter-spacing:.04em; text-transform:uppercase;
  color:#BDC5CF; transition:color .16s;
}
.oma5-ccard--sel .oma5-ccard__votes { color:rgba(255,255,255,.34); }

/* Select tab — bottom strip */
.oma5-ccard__tab {
  display:block; padding:6px 10px; text-align:center;
  font-size:.6rem; font-weight:700; letter-spacing:.07em; text-transform:uppercase;
  color:#5A6474; background:#F5F5F0; border-top:1px solid #D5D5CC;
  transition:background .16s,color .16s; flex-shrink:0;
}
.oma5-ccard:hover .oma5-ccard__tab { background:#EAEAE2; color:#002147; }
.oma5-ccard--sel  .oma5-ccard__tab {
  background:#B8962E; color:#002147; border-color:#B8962E; font-weight:800;
}


/* ═══════════════════════════════════════════════════════════
   VOTE BAR — zone selector + vote button
   ═══════════════════════════════════════════════════════════ */
.oma5-vbar {
  display:flex; align-items:center; gap:10px; flex-wrap:wrap;
  padding:14px 16px; background:#002147; border:2px solid #B8962E;
  margin-bottom:10px;
}
.oma5-vbar__who {
  display:flex; align-items:center; gap:7px; flex:1; min-width:160px;
  font-size:.8rem; font-weight:600; color:#D4AE48;
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}
.oma5-vbar__arrow { color:#B8962E; flex-shrink:0; }
.oma5-vbar__zone {
  padding:9px 12px; background:#fff; border:1px solid #D5D5CC;
  color:#002147; font-family:'DM Sans',sans-serif; font-size:.8rem;
  flex:1; min-width:160px; appearance:none; cursor:pointer;
}
.oma5-vbar__zone:focus { outline:2px solid #002147; }
.oma5-vbar__btn {
  display:inline-flex; align-items:center; justify-content:center; gap:6px;
  padding:12px 24px; background:#B8962E; color:#002147;
  font-family:'DM Sans',sans-serif; font-size:.8rem; font-weight:800;
  letter-spacing:.07em; text-transform:uppercase; border:none; cursor:pointer;
  transition:background .16s,transform .14s; white-space:nowrap;
}
.oma5-vbar__btn:hover:not(:disabled) { background:#D4AE48; transform:translateY(-1px); }
.oma5-vbar__btn:disabled {
  background:rgba(184,150,46,.3); color:rgba(0,33,71,.5);
  cursor:not-allowed; transform:none;
}
.oma5-vbar__helper {
  font-size:.72rem; color:#8892A0; margin:0 0 10px; padding:0 4px;
  font-family:'DM Sans',sans-serif; font-style:italic;
}

/* ── VOTE FEEDBACK ────────────────────────────── */
.oma5-feedback {
  display:none; align-items:flex-start; gap:10px;
  padding:12px 15px; font-size:.82rem; line-height:1.55;
  margin-bottom:12px; animation:oma5Pop .28s ease both;
  font-family:'DM Sans',sans-serif;
}
.oma5-feedback--success { background:#EAF3DE; border-left:4px solid #1D6A3A; color:#1D6A3A; }
.oma5-feedback--already { background:#EAF3DE; border-left:4px solid #1D6A3A; color:#1D6A3A; }
.oma5-feedback--error   { background:#FDEDEE; border-left:4px solid #CC1B1B; color:#CC1B1B; }
.oma5-feedback__ico     { font-size:1.05rem; flex-shrink:0; line-height:1.4; }

/* ── POLL DISCLAIMER ──────────────────────────── */
.oma5-disc {
  font-size:.66rem; color:#8892A0; line-height:1.62; margin:6px 0 0;
  padding:9px 13px; border-left:2px solid #D5D5CC;
  font-family:'DM Sans',sans-serif;
}


/* ═══════════════════════════════════════════════════════════
   § 4  PARTY PRIMARY PULSE
   ═══════════════════════════════════════════════════════════ */
.oma5-lock-bar {
  display:flex; align-items:center; gap:12px; flex-wrap:wrap;
  padding:12px 15px; background:rgba(184,150,46,.1);
  border:1px solid rgba(184,150,46,.24); margin-top:12px;
  font-size:.78rem; font-family:'DM Sans',sans-serif;
}
.oma5-lock-bar strong { color:#D4AE48; display:block; margin-bottom:2px; font-size:.8rem; }
.oma5-lock-bar span   { color:rgba(255,255,255,.45); font-size:.73rem; }
.oma5-lock-timer {
  margin-left:auto; font-family:'EB Garamond',Georgia,serif;
  font-size:1.3rem; color:#D4AE48; font-weight:700; white-space:nowrap;
  font-variant-numeric:tabular-nums; letter-spacing:.04em;
}

/* Party tabs */
.oma5-tabs { display:flex; gap:4px; flex-wrap:wrap; margin-bottom:16px; }
.oma5-tab {
  display:flex; align-items:center; gap:6px; padding:7px 14px;
  background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.1);
  color:rgba(255,255,255,.5); font-family:'DM Sans',sans-serif;
  font-size:.66rem; font-weight:700; letter-spacing:.07em; text-transform:uppercase;
  cursor:pointer; transition:background .16s,color .16s,border-color .16s;
}
.oma5-tab:hover,.oma5-tab--on {
  background:rgba(255,255,255,.1); color:#fff; border-color:rgba(255,255,255,.22);
}
.oma5-tab--on { border-bottom-color:#D4AE48 !important; }
.oma5-tab__dot { width:6px; height:6px; border-radius:50%; flex-shrink:0; }

.oma5-panel     { display:none; }
.oma5-panel--on { display:block; animation:oma5In .2s ease both; }

.oma5-pgrid {
  display:grid; grid-template-columns:repeat(auto-fill,minmax(200px,1fr));
  gap:10px; margin-bottom:6px;
}

/* Primary candidate cards */
.oma5-pcard {
  display:flex; flex-direction:column;
  background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.09);
  overflow:hidden; transition:background .16s,border-color .16s;
}
.oma5-pcard:hover { background:rgba(255,255,255,.08); border-color:rgba(255,255,255,.18); }

.oma5-pcard__photo {
  width:100%; height:120px;  /* tall enough for full face */
  display:flex; align-items:center; justify-content:center;
  overflow:hidden; flex-shrink:0; position:relative;
}
.oma5-pcard__photo img { width:100%; height:100%; object-fit:cover; object-position:center top; }
.oma5-pcard__init { font-family:'EB Garamond',serif; font-size:1.4rem; font-weight:700; color:rgba(255,255,255,.75); }
.oma5-pcard__imgpend {
  position:absolute; bottom:4px; left:0; right:0; text-align:center;
  font-size:.5rem; color:rgba(255,255,255,.4); letter-spacing:.06em; text-transform:uppercase;
}
.oma5-pcard__body  { padding:9px 11px; flex:1; }
.oma5-pcard__name  { font-size:.8rem; font-weight:700; color:#fff; margin-bottom:2px; line-height:1.25; }
.oma5-pcard__party { font-size:.56rem; color:#D4AE48; font-weight:700; text-transform:uppercase; letter-spacing:.07em; margin-bottom:2px; }
.oma5-pcard__role  { font-size:.64rem; color:rgba(255,255,255,.4); margin-bottom:5px; line-height:1.4; }
.oma5-pcard__votes { font-size:.58rem; color:rgba(255,255,255,.3); font-weight:600; }
.oma5-pcard__lock {
  display:flex; align-items:center; gap:6px; padding:6px 11px;
  font-size:.64rem; font-weight:700; letter-spacing:.06em; text-transform:uppercase;
  color:rgba(255,255,255,.4); background:rgba(0,0,0,.2);
}
.oma5-pcard__btn {
  width:100%; display:flex; align-items:center; justify-content:center; gap:6px;
  padding:9px 12px; background:rgba(184,150,46,.2); color:rgba(255,255,255,.4);
  font-family:'DM Sans',sans-serif; font-size:.67rem; font-weight:700;
  letter-spacing:.06em; text-transform:uppercase; border:none; cursor:not-allowed;
  transition:background .16s;
}
.oma5-pcard__btn:not(:disabled) { background:#B8962E; color:#002147; cursor:pointer; }
.oma5-pcard__btn:not(:disabled):hover { background:#D4AE48; }


/* ═══════════════════════════════════════════════════════════
   § 5  LEADERBOARD
   ═══════════════════════════════════════════════════════════ */
.oma5-lb { border:1px solid #D5D5CC; overflow:hidden; margin-bottom:10px; }
.oma5-lb__hdr {
  display:flex; align-items:center; gap:10px;
  background:#002147; padding:9px 14px;
  font-size:.58rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase;
}
.oma5-lb__hdr span { color:rgba(255,255,255,.44); }
.oma5-lb__hdr span:nth-child(1) { width:26px; flex-shrink:0; }
.oma5-lb__hdr span:nth-child(2) { flex:2; }
.oma5-lb__hdr span:nth-child(3) { flex:1.5; }
.oma5-lb__hdr span:nth-child(4) { flex:1; text-align:right; }

.oma5-lb__empty {
  padding:36px 20px; text-align:center; background:#fff;
  display:flex; flex-direction:column; align-items:center; gap:8px;
  font-family:'DM Sans',sans-serif;
}
.oma5-lb__empty p { font-size:.82rem; color:#5A6474; margin:0; line-height:1.6; max-width:360px; }

.oma5-lb__row {
  display:flex; align-items:center; gap:10px;
  padding:9px 14px; background:#fff; border-bottom:1px solid #D5D5CC;
  transition:background .14s,transform .14s;
  font-family:'DM Sans',sans-serif; animation:oma5Up .35s ease both;
}
.oma5-lb__row:hover { background:#F5F5F0; transform:translateX(3px); }
.oma5-lb__row:last-child { border-bottom:none; }
.oma5-lb__rank {
  font-family:'EB Garamond',Georgia,serif; font-size:1.1rem; color:#BDC5CF;
  width:26px; flex-shrink:0; text-align:center;
}
.oma5-lb__rank--gold { color:#B8962E; }
.oma5-lb__cand { display:flex; align-items:center; gap:8px; flex:2; }
.oma5-lb__av {
  width:26px; height:26px; border-radius:50%; flex-shrink:0;
  display:flex; align-items:center; justify-content:center;
  font-family:'EB Garamond',serif; font-size:.68rem; font-weight:700; color:#fff;
}
.oma5-lb__name  { font-size:.8rem; font-weight:600; color:#002147; }
.oma5-lb__party { flex:1.5; font-size:.7rem; color:#5A6474; }
.oma5-lb__votes { flex:1; text-align:right; font-family:'EB Garamond',serif; font-size:.95rem; font-weight:700; color:#002147; }
.oma5-lb__disc {
  font-size:.68rem; color:#8892A0; line-height:1.62;
  padding:9px 13px; border-left:2px solid #B8962E;
  background:rgba(184,150,46,.04); font-family:'DM Sans',sans-serif;
}


/* ═══════════════════════════════════════════════════════════
   § 6  REGIONAL PULSE
   ═══════════════════════════════════════════════════════════ */
.oma5-zgrid {
  display:grid; grid-template-columns:repeat(auto-fill,minmax(240px,1fr));
  gap:10px; margin-bottom:6px;
}
.oma5-zcard {
  display:flex; align-items:flex-start; gap:11px;
  background:#fff; border:1px solid #D5D5CC; padding:13px; text-decoration:none;
  transition:border-color .16s,transform .18s,box-shadow .16s;
}
.oma5-zcard:hover { border-color:#8892A0; transform:translateY(-2px); box-shadow:0 4px 12px rgba(0,0,0,.06); }
.oma5-zcard__badge {
  width:34px; height:34px; flex-shrink:0;
  display:flex; align-items:center; justify-content:center;
  font-family:'EB Garamond',serif; font-size:.68rem; font-weight:700; color:rgba(255,255,255,.9);
}
.oma5-zcard__info  { flex:1; min-width:0; }
.oma5-zcard__name  { font-size:.78rem; font-weight:700; color:#002147; margin-bottom:3px; }
.oma5-zcard__states{ font-size:.64rem; color:#8892A0; margin-bottom:5px; line-height:1.5; }
.oma5-zcard__status{ font-size:.58rem; color:#BDC5CF; font-weight:600; text-transform:uppercase; letter-spacing:.05em; }
.oma5-zcard__arr   { flex-shrink:0; margin-top:2px; opacity:.6; font-size:.9rem; }


/* ═══════════════════════════════════════════════════════════
   § 7  PRESSURE SNAPSHOT
   ═══════════════════════════════════════════════════════════ */
.oma5-snap { display:grid; grid-template-columns:1fr 1fr; gap:40px; align-items:center; }
.oma5-snap__chips { display:grid; grid-template-columns:1fr 1fr; gap:9px; }
.oma5-chip {
  display:flex; align-items:flex-start; gap:9px;
  background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.09);
  padding:10px 12px; transition:background .16s;
}
.oma5-chip:hover { background:rgba(255,255,255,.08); }
.oma5-chip__ico  { font-size:1.1rem; flex-shrink:0; line-height:1.1; }
.oma5-chip__lbl  { display:block; font-size:.76rem; font-weight:700; color:rgba(255,255,255,.82); }
.oma5-chip__desc { display:block; font-size:.61rem; color:rgba(255,255,255,.38); margin-top:1px; }


/* ═══════════════════════════════════════════════════════════
   § 8  TRUST CARDS
   ═══════════════════════════════════════════════════════════ */
.oma5-tgrid {
  display:grid; grid-template-columns:repeat(auto-fill,minmax(220px,1fr));
  gap:11px; margin-bottom:6px;
}
.oma5-tcard {
  background:#fff; border:1px solid #D5D5CC; padding:16px;
  transition:border-color .16s,transform .18s;
}
.oma5-tcard:hover { border-color:#8892A0; transform:translateY(-2px); }
.oma5-tcard__ico {
  width:32px; height:32px; background:#002147;
  display:flex; align-items:center; justify-content:center;
  margin-bottom:9px; font-size:.95rem; color:#B8962E;
}
.oma5-tcard__title { font-size:.8rem; font-weight:700; color:#002147; margin-bottom:5px; }
.oma5-tcard__desc  { font-size:.72rem; color:#5A6474; line-height:1.62; margin:0; }


/* ═══════════════════════════════════════════════════════════
   § 9  ALERTS SIGNUP
   ═══════════════════════════════════════════════════════════ */
.oma5-alerts-bg {
  position:absolute; inset:0; pointer-events:none;
  background:
    radial-gradient(circle 460px at 8% 50%,rgba(184,150,46,.04) 0%,transparent 70%),
    radial-gradient(circle 380px at 92% 50%,rgba(0,48,112,.5) 0%,transparent 70%);
}
.oma5-alayout {
  display:grid; grid-template-columns:1fr 420px; gap:52px; align-items:center;
}
.oma5-channels { display:flex; flex-direction:column; gap:8px; margin-top:16px; }
.oma5-channel  { font-size:.76rem; font-weight:600; color:rgba(255,255,255,.44); }

.oma5-signup {
  background:rgba(255,255,255,.04); border:1px solid rgba(184,150,46,.18); padding:22px;
}
.oma5-signup__hd {
  font-size:.6rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase;
  color:#D4AE48; margin-bottom:14px; padding-bottom:11px;
  border-bottom:1px solid rgba(184,150,46,.1);
}
.oma5-input {
  width:100%; padding:10px 11px; margin-bottom:7px;
  background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.1);
  color:#fff; font-family:'DM Sans',sans-serif; font-size:.8rem;
  outline:none; transition:border-color .16s; display:block;
}
.oma5-input::placeholder { color:rgba(255,255,255,.28); }
.oma5-input:focus { border-color:#D4AE48; }
.oma5-input--sel { appearance:none; cursor:pointer; color:rgba(255,255,255,.52); }
.oma5-input--sel option { background:#001530; color:#fff; }
.oma5-signup__priv {
  font-size:.6rem; color:rgba(255,255,255,.28); line-height:1.55;
  margin-top:10px; padding-top:9px; border-top:1px solid rgba(255,255,255,.05);
}
.oma5-amsg {
  font-size:.76rem; padding:9px 12px; line-height:1.5; margin-top:5px;
  font-family:'DM Sans',sans-serif;
}
.oma5-amsg--ok  { color:#68D391; background:rgba(104,211,145,.08); }
.oma5-amsg--err { color:#FC8181; background:rgba(252,129,129,.08); }


/* ═══════════════════════════════════════════════════════════
   § 10  FOOTER V5 (single, clean)
   ═══════════════════════════════════════════════════════════ */
.oma-footer-v5 {
  background:#0A0A0A; border-top:3px solid #B8962E;
  padding:20px 0 14px; font-family:'DM Sans',system-ui,sans-serif;
}
.oma-footer-v5__inner { max-width:1200px; margin:0 auto; padding:0 40px; }
.oma-footer-v5__logo  { font-family:'EB Garamond',Georgia,serif; font-size:1.05rem; font-weight:700; color:#fff; }
.oma-footer-v5__logo span { color:#D4AE48; }
.oma-footer-v5__tag   { font-size:.62rem; color:rgba(255,255,255,.28); font-style:italic; margin:3px 0 14px; }
.oma-footer-v5__nav   { display:flex; flex-wrap:wrap; gap:4px 12px; margin-bottom:14px; }
.oma-footer-v5__nav a {
  font-size:.66rem; font-weight:600; letter-spacing:.07em; text-transform:uppercase;
  color:rgba(255,255,255,.4); text-decoration:none; transition:color .14s;
}
.oma-footer-v5__nav a:hover { color:#D4AE48; }
.oma-footer-v5__legal {
  font-size:.6rem; color:rgba(255,255,255,.2); line-height:1.6;
  border-top:1px solid rgba(255,255,255,.06); padding-top:12px;
}


/* ═══════════════════════════════════════════════════════════
   INPUTS & SELECT
   ═══════════════════════════════════════════════════════════ */
.oma5-vbar__zone:focus { outline:2px solid #B8962E; outline-offset:1px; }


/* ═══════════════════════════════════════════════════════════
   RESPONSIVE — 960px TABLET
   ═══════════════════════════════════════════════════════════ */
@media (max-width:960px) {
  .oma5-inner,.oma5-hero__inner,.oma5-hero__brand,
  .oma5-cred__inner,.oma-footer-v5__inner { padding:0 24px; }
  .oma5-alayout { grid-template-columns:1fr; gap:28px; }
  .oma5-snap    { grid-template-columns:1fr; gap:24px; }
}

/* ═══════════════════════════════════════════════════════════
   RESPONSIVE — 640px MOBILE
   ═══════════════════════════════════════════════════════════ */
@media (max-width:640px) {
  .oma5-inner,.oma5-hero__inner,.oma5-hero__brand,
  .oma5-cred__inner,.oma-footer-v5__inner { padding:0 16px; }

  /* Hero compact */
  .oma5-hero     { padding-top:24px; }
  .oma5-sec      { padding:36px 0; }
  .oma5-hero__headline { font-size:clamp(1.75rem,7vw,2.2rem); }
  .oma5-hero__sub      { font-size:.84rem; }
  .oma5-hero__actions  { flex-direction:column; }
  .oma5-btn-pri,.oma5-btn-gold { width:100%; justify-content:center; }
  .oma5-btn-sec  { width:100%; justify-content:center; }

  /* Stat bar 2×2 */
  .oma5-stat     { min-width:50%; padding:9px 0; }
  .oma5-stat__div{ display:none; }

  /* Candidate grid 2-col on mobile */
  .oma5-cgrid    { grid-template-columns:repeat(2,1fr); gap:8px; }
  .oma5-ccard__photo { height:78px; }

  /* Vote bar stacks */
  .oma5-vbar     { flex-direction:column; align-items:stretch; }
  .oma5-vbar__who{ min-width:0; }
  .oma5-vbar__btn{ width:100%; justify-content:center; }

  /* Primary */
  .oma5-pgrid    { grid-template-columns:1fr; }

  /* Zone grid */
  .oma5-zgrid    { grid-template-columns:1fr; }

  /* Snapshot chips */
  .oma5-snap__chips { grid-template-columns:1fr; }

  /* Trust */
  .oma5-tgrid    { grid-template-columns:1fr; }

  /* Leaderboard: hide party col */
  .oma5-lb__party,.oma5-lb__hdr span:nth-child(3) { display:none; }

  /* Cred strip */
  .oma5-cred__items { flex-direction:column; gap:6px; }
  .oma5-cred__div   { display:none; }

  /* Footer */
  .oma-footer-v5__nav { gap:4px 10px; }

  /* Party tabs wrap */
  .oma5-tabs { gap:3px; }
  .oma5-tab  { padding:6px 10px; font-size:.62rem; }

  /* Vote instruction */
  .oma5-vote-instr { flex-direction:column; align-items:flex-start; gap:5px; }
}


/* ═══════════════════════════════════════════════════════════════════
   v5.3 ADDITIONS — Portrait rules, Primary Pulse, Regional Pulse
   ═══════════════════════════════════════════════════════════════════ */

/* ── PORTRAIT RULES — consistent, professional, no awkward crops ── */
.oma5-ccard__photo img,
.oma5-pcard__photo img,
.oma5-ppcard__photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 15%; /* favour face/upper body over feet */
  display: block;
}

/* Candidate card photo — Today's Biggest Poll */
.oma5-ccard__photo {
  position: relative;
  height: 108px;          /* tall enough to show face + shoulders */
  overflow: hidden;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* Party Primary card photo */
.oma5-pcard__photo {
  height: 140px;
  overflow: hidden;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
}

/* Primary Pulse voting card photo */
.oma5-ppcard__photo {
  height: 130px;
  overflow: hidden;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
}

/* Initials fallback — centred + big enough to read */
.oma5-ccard__init,
.oma5-pcard__init,
.oma5-ppcard__init {
  font-family: 'EB Garamond', Georgia, serif;
  font-size: 2rem;
  font-weight: 700;
  color: rgba(255,255,255,.75);
  line-height: 1;
}

.oma5-ccard__imgpending,
.oma5-pcard__imgpend,
.oma5-ppcard__imgpend {
  position: absolute;
  bottom: 5px;
  left: 0; right: 0;
  text-align: center;
  font-size: .52rem;
  color: rgba(255,255,255,.45);
  letter-spacing: .06em;
  text-transform: uppercase;
}


/* ═══════════════════════════════════════════════════════════
   § 4b  PARTY PRIMARY PULSE — voting cards (oma5-ppcard)
   ═══════════════════════════════════════════════════════════ */

/* Grid of primary voting cards */
.oma5-ppgrid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 10px;
  margin-bottom: 14px;
}

/* Individual primary voting card */
.oma5-ppcard {
  display: flex;
  flex-direction: column;
  background: rgba(255,255,255,.05);
  border: 1.5px solid rgba(255,255,255,.1);
  transition: border-color .16s, background .16s, transform .16s;
  position: relative;
  overflow: hidden;
}
.oma5-ppcard:hover { background: rgba(255,255,255,.09); border-color: rgba(255,255,255,.22); }
.oma5-ppcard--voted { border-color: #B8962E !important; background: rgba(184,150,46,.08) !important; }

/* Card body */
.oma5-ppcard__body { padding: 9px 11px 5px; flex: 1; }
.oma5-ppcard__name {
  font-size: .82rem; font-weight: 700; color: #fff; margin-bottom: 2px; line-height: 1.25;
}
.oma5-ppcard__party {
  font-size: .58rem; color: #D4AE48; font-weight: 700; text-transform: uppercase;
  letter-spacing: .07em; margin-bottom: 2px;
}
.oma5-ppcard__role {
  font-size: .63rem; color: rgba(255,255,255,.42); line-height: 1.45; margin-bottom: 6px;
}
.oma5-ppcard__tally {
  font-size: .62rem; font-weight: 600; color: rgba(255,255,255,.32);
  letter-spacing: .04em; text-transform: uppercase; margin-bottom: 7px;
}
.oma5-ppcard__tally--live { color: #D4AE48; }

/* Vote button */
.oma5-ppcard__btn {
  width: 100%;
  display: flex; align-items: center; justify-content: center; gap: 5px;
  padding: 9px 10px;
  background: rgba(184,150,46,.18); color: rgba(255,255,255,.45);
  font-family: 'DM Sans', sans-serif; font-size: .66rem; font-weight: 700;
  letter-spacing: .07em; text-transform: uppercase; border: none; cursor: not-allowed;
  transition: background .16s, color .16s;
  flex-shrink: 0;
}
.oma5-ppcard__btn--active {
  background: #B8962E; color: #002147; cursor: pointer;
}
.oma5-ppcard__btn--active:hover { background: #D4AE48; }
.oma5-ppcard__btn--voted {
  background: rgba(184,150,46,.12); color: #D4AE48; cursor: default;
}
.oma5-ppcard__check {
  position: absolute; top: 7px; right: 7px;
  width: 20px; height: 20px; border-radius: 50%; background: #B8962E;
  display: flex; align-items: center; justify-content: center;
  color: #002147; font-size: .72rem; font-weight: 900;
  opacity: 0; transform: scale(.3); transition: opacity .2s, transform .2s;
  pointer-events: none; z-index: 2;
}
.oma5-ppcard--voted .oma5-ppcard__check { opacity: 1; transform: scale(1); }

/* Result bars — shown only after real votes exist */
.oma5-ppcard__bar-wrap {
  padding: 0 11px 9px;
}
.oma5-ppcard__bar-track {
  height: 3px; background: rgba(255,255,255,.1); border-radius: 1px; overflow: hidden;
}
.oma5-ppcard__bar-fill {
  height: 3px; background: #B8962E; border-radius: 1px;
  width: 0; transition: width .6s ease;
}
.oma5-ppcard__bar-pct {
  font-size: .55rem; color: rgba(255,255,255,.3); font-weight: 600;
  margin-top: 3px; display: block; text-align: right;
}

/* State select inside vote bar */
.oma5-pp-state {
  width: 100%; padding: 10px 11px; margin-bottom: 8px;
  background: rgba(255,255,255,.07); border: 1px solid rgba(255,255,255,.15);
  color: rgba(255,255,255,.8); font-family: 'DM Sans', sans-serif; font-size: .8rem;
  appearance: none; cursor: pointer; display: block;
}
.oma5-pp-state:focus { outline: 2px solid #D4AE48; }
.oma5-pp-state option { background: #001a3a; color: #fff; }

/* Success / error feedback inside primary section */
.oma5-pp-feedback {
  display: none; align-items: flex-start; gap: 9px;
  padding: 11px 14px; margin: 8px 0 12px;
  font-size: .8rem; line-height: 1.55; border-left: 3px solid;
  animation: oma5Pop .25s ease both; font-family: 'DM Sans', sans-serif;
}
.oma5-pp-feedback--success { background: rgba(29,106,58,.15); border-color: #1D6A3A; color: #68D391; }
.oma5-pp-feedback--error   { background: rgba(204,27,27,.1);  border-color: #CC1B1B; color: #FC8181; }
.oma5-pp-feedback--already { background: rgba(184,150,46,.1); border-color: #B8962E; color: #D4AE48; }

/* Post-vote results table */
.oma5-pp-results {
  display: none; margin: 12px 0;
  border: 1px solid rgba(255,255,255,.1); overflow: hidden;
}
.oma5-pp-results--show { display: block; animation: oma5Up .3s ease both; }

.oma5-pp-results__hdr {
  display: flex; gap: 8px; align-items: center;
  padding: 8px 12px; background: rgba(0,0,0,.3);
  font-size: .56rem; font-weight: 700; letter-spacing: .1em;
  text-transform: uppercase; color: rgba(255,255,255,.35);
}
.oma5-pp-results__hdr span:nth-child(1) { width: 22px; flex-shrink: 0; }
.oma5-pp-results__hdr span:nth-child(2) { flex: 2; }
.oma5-pp-results__hdr span:nth-child(3) { flex: 1; text-align: right; }
.oma5-pp-results__hdr span:nth-child(4) { width: 42px; flex-shrink: 0; text-align: right; }

.oma5-pp-result-row {
  display: flex; gap: 8px; align-items: center;
  padding: 8px 12px; border-bottom: 1px solid rgba(255,255,255,.06);
  font-family: 'DM Sans', sans-serif; transition: background .14s;
}
.oma5-pp-result-row:last-child { border-bottom: none; }
.oma5-pp-result-row:hover { background: rgba(255,255,255,.04); }
.oma5-pp-result-row--leader { background: rgba(184,150,46,.07); }

.oma5-pp-result-row__rank {
  font-family: 'EB Garamond', serif; font-size: 1rem; color: rgba(255,255,255,.3);
  width: 22px; flex-shrink: 0; text-align: center;
}
.oma5-pp-result-row--leader .oma5-pp-result-row__rank { color: #D4AE48; }

.oma5-pp-result-row__cand { flex: 2; min-width: 0; }
.oma5-pp-result-row__name { font-size: .78rem; font-weight: 600; color: rgba(255,255,255,.88); }
.oma5-pp-result-row__bar  {
  height: 3px; background: rgba(255,255,255,.08); border-radius: 1px; margin-top: 4px;
}
.oma5-pp-result-row__bar-fill {
  height: 3px; background: #B8962E; border-radius: 1px; transition: width .5s ease;
}
.oma5-pp-result-row--leader .oma5-pp-result-row__bar-fill { background: #D4AE48; }

.oma5-pp-result-row__votes {
  flex: 1; text-align: right;
  font-family: 'EB Garamond', serif; font-size: .9rem; color: rgba(255,255,255,.7); font-weight: 700;
}
.oma5-pp-result-row__pct {
  width: 42px; text-align: right; flex-shrink: 0;
  font-size: .68rem; color: rgba(255,255,255,.35); font-weight: 600;
}

/* Primary leaderboard (§5b below primary section) */
.oma5-plb { border: 1px solid #D5D5CC; overflow: hidden; margin-bottom: 10px; }
.oma5-plb__hdr {
  display: flex; align-items: center; gap: 10px;
  background: #002147; padding: 9px 14px;
  font-size: .56rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase;
}
.oma5-plb__hdr span { color: rgba(255,255,255,.4); }
.oma5-plb__hdr span:nth-child(1) { width: 24px; flex-shrink: 0; }
.oma5-plb__hdr span:nth-child(2) { flex: 2; }
.oma5-plb__hdr span:nth-child(3) { flex: 1.2; }
.oma5-plb__hdr span:nth-child(4) { flex: 1; text-align: right; }
.oma5-plb__hdr span:nth-child(5) { width: 44px; flex-shrink: 0; text-align: right; }

.oma5-plb__empty {
  padding: 32px 20px; text-align: center; background: #F5F5F0;
  font-size: .82rem; color: #5A6474; line-height: 1.6;
}
.oma5-plb__row {
  display: flex; align-items: center; gap: 10px;
  padding: 9px 14px; background: #fff; border-bottom: 1px solid #D5D5CC;
  font-family: 'DM Sans', sans-serif; transition: background .14s;
}
.oma5-plb__row:last-child { border-bottom: none; }
.oma5-plb__row:hover { background: #F5F5F0; }
.oma5-plb__rank  { font-family: 'EB Garamond',serif; font-size:1.05rem; color:#BDC5CF; width:24px; flex-shrink:0; text-align:center; }
.oma5-plb__rank--gold { color: #B8962E; }
.oma5-plb__cand  { display:flex; align-items:center; gap:8px; flex:2; }
.oma5-plb__av    { width:26px; height:26px; border-radius:50%; flex-shrink:0; display:flex; align-items:center; justify-content:center; font-family:'EB Garamond',serif; font-size:.68rem; font-weight:700; color:#fff; }
.oma5-plb__name  { font-size:.78rem; font-weight:600; color:#002147; }
.oma5-plb__party { flex:1.2; font-size:.68rem; color:#5A6474; }
.oma5-plb__votes { flex:1; text-align:right; font-family:'EB Garamond',serif; font-size:.92rem; font-weight:700; color:#002147; }
.oma5-plb__pct   { width:44px; flex-shrink:0; text-align:right; font-size:.68rem; color:#8892A0; font-weight:600; }

/* Primary lb tabs */
.oma5-plb-tabs { display:flex; gap:3px; flex-wrap:wrap; margin-bottom:8px; }
.oma5-plb-tab  {
  padding:5px 12px; background:#E5E5DC; border:1px solid #D5D5CC;
  color:#5A6474; font-family:'DM Sans',sans-serif; font-size:.62rem;
  font-weight:700; letter-spacing:.07em; text-transform:uppercase;
  cursor:pointer; transition:background .14s,color .14s;
}
.oma5-plb-tab:hover,.oma5-plb-tab--on { background:#002147; color:#fff; border-color:#002147; }


/* ═══════════════════════════════════════════════════════════
   § 6b  REGIONAL PULSE — connected to real vote data
   ═══════════════════════════════════════════════════════════ */
.oma5-zcard--rich {
  display: grid;
  grid-template-columns: 40px 1fr;
  gap: 12px;
  background: #fff;
  border: 1px solid #D5D5CC;
  padding: 13px 14px;
  text-decoration: none;
  transition: border-color .16s, box-shadow .14s;
  cursor: default; /* not clickable — it's a results display */
}
.oma5-zcard--rich:hover { border-color: #8892A0; box-shadow: 0 3px 10px rgba(0,0,0,.06); }

.oma5-zcard__badge--rich {
  width: 40px; height: 40px; border-radius: 4px; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  font-family: 'EB Garamond', serif; font-size: .72rem; font-weight: 700;
  color: rgba(255,255,255,.9); align-self: flex-start;
}
.oma5-zcard__info--rich { min-width: 0; }
.oma5-zcard__name--rich {
  font-size: .8rem; font-weight: 700; color: #002147; margin-bottom: 6px;
}
.oma5-zcard__stat {
  display: flex; flex-direction: column; gap: 3px; margin-bottom: 6px;
}
.oma5-zcard__stat-row {
  display: flex; align-items: center; gap: 5px; font-size: .66rem;
}
.oma5-zcard__stat-lbl {
  font-size: .55rem; font-weight: 700; letter-spacing: .07em; text-transform: uppercase;
  color: #B8962E; flex-shrink: 0; width: 46px;
}
.oma5-zcard__stat-val { color: #002147; font-weight: 600; }
.oma5-zcard__stat-party { color: #8892A0; font-size: .6rem; }
.oma5-zcard__pending {
  font-size: .64rem; color: #BDC5CF; font-weight: 600;
  text-transform: uppercase; letter-spacing: .05em;
  padding: 4px 0;
}
.oma5-zcard__total {
  font-size: .58rem; color: #BDC5CF; margin-top: 4px;
  font-weight: 600; letter-spacing: .04em; text-transform: uppercase;
}

.oma5-zgrid--rich {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 10px;
  margin-bottom: 8px;
}

/* ── RESPONSIVE additions ─────────────────────── */
@media (max-width: 640px) {
  .oma5-ppgrid { grid-template-columns: repeat(2, 1fr); }
  .oma5-ppcard__photo { height: 100px; }
  .oma5-ccard__photo  { height: 90px; }
  .oma5-pcard__photo  { height: 110px; }
  .oma5-zgrid--rich   { grid-template-columns: 1fr; }
  .oma5-plb__party, .oma5-plb__hdr span:nth-child(3) { display: none; }
  .oma5-pp-results__hdr span:nth-child(3) { display: none; }
}


/* ═══════════════════════════════════════════════════════════════════
   REGIONAL PULSE — Four-tier threshold display system
   ═══════════════════════════════════════════════════════════════════ */

/* Zone card base — updated layout with room for tier content */
.oma5-zcard--rich {
  display: grid;
  grid-template-columns: 44px 1fr;
  gap: 13px;
  background: #fff;
  border: 1px solid #D5D5CC;
  padding: 14px 15px;
  transition: border-color .16s, box-shadow .14s;
  position: relative;
}
.oma5-zcard--rich:hover { border-color: #8892A0; box-shadow: 0 3px 10px rgba(0,0,0,.07); }

/* Badge */
.oma5-zcard__badge--rich {
  width: 44px; height: 44px; border-radius: 5px; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  font-family: 'EB Garamond', serif; font-size: .75rem; font-weight: 700;
  color: rgba(255,255,255,.92); align-self: flex-start;
}

/* Zone name + states */
.oma5-zcard__name--rich {
  font-size: .82rem; font-weight: 700; color: #002147; margin-bottom: 2px; line-height: 1.2;
}
.oma5-zcard__states-list {
  font-size: .58rem; color: #8892A0; line-height: 1.55; margin-bottom: 7px;
}

/* ── Tier status badge ─────────────────────────────────── */
.oma5-ztier {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: .55rem; font-weight: 700; letter-spacing: .08em;
  text-transform: uppercase; padding: 2px 8px;
  border-radius: 2px; margin-bottom: 8px;
}
/* Tier 0 — grey, waiting */
.oma5-ztier--0 {
  background: #EAEAE2; color: #8892A0; border: 1px solid #D5D5CC;
}
/* Tier 1 — amber, early signal */
.oma5-ztier--1 {
  background: rgba(184,150,46,.1); color: #8B6914;
  border: 1px solid rgba(184,150,46,.25);
}
/* Tier 2 — navy/blue, active */
.oma5-ztier--2 {
  background: rgba(0,33,71,.08); color: #002147;
  border: 1px solid rgba(0,33,71,.16);
}
/* Tier 3 — green, strong */
.oma5-ztier--3 {
  background: rgba(29,106,58,.1); color: #1D6A3A;
  border: 1px solid rgba(29,106,58,.22);
}

/* ── Tier 0 content ────────────────────────────────────── */
.oma5-zcard__await-msg {
  font-size: .7rem; font-weight: 600; color: #5A6474;
  margin: 0 0 3px; line-height: 1.4;
}
.oma5-zcard__tracked {
  font-size: .62rem; color: #8892A0; margin: 0 0 3px; line-height: 1.5;
}
.oma5-zcard__tracked strong { color: #002147; }

/* ── Shared across tiers 1–3 ───────────────────────────── */
.oma5-zcard__signal-label {
  font-size: .6rem; font-weight: 700; letter-spacing: .06em; text-transform: uppercase;
  color: #B8962E; margin: 0 0 6px;
}
.oma5-zcard__data-row {
  display: flex; align-items: baseline; flex-wrap: wrap; gap: 3px;
  margin-bottom: 4px;
}
.oma5-zcard__data-lbl {
  font-size: .55rem; font-weight: 700; letter-spacing: .07em; text-transform: uppercase;
  color: #BDC5CF; flex-shrink: 0; min-width: 46px;
}
.oma5-zcard__data-val {
  font-size: .76rem; font-weight: 700; color: #002147; line-height: 1.2;
}
.oma5-zcard__data-party {
  font-size: .6rem; color: #8892A0;
}
.oma5-zcard__caveat {
  font-size: .6rem; color: #8892A0; line-height: 1.5; margin: 5px 0 0;
  font-style: italic;
}

/* ── Tier 3 — percentage bars ──────────────────────────── */
.oma5-zcard__pct-block { margin-bottom: 4px; }
.oma5-zcard__pct-row {
  display: flex; justify-content: space-between; align-items: baseline;
  margin-bottom: 2px;
}
.oma5-zcard__pct-row--leader .oma5-zcard__pct-name { font-weight: 700; color: #002147; }
.oma5-zcard__pct-name { font-size: .72rem; color: #5A6474; }
.oma5-zcard__pct-num  {
  font-family: 'EB Garamond', serif; font-size: .88rem;
  font-weight: 700; color: #002147; white-space: nowrap;
}
.oma5-zcard__pct-bar-track {
  height: 4px; background: #EAEAE2; border-radius: 2px; margin-bottom: 5px; overflow: hidden;
}
.oma5-zcard__pct-bar-fill {
  height: 4px; border-radius: 2px; transition: width .5s ease;
}
.oma5-zcard__pct-inline {
  font-size: .66rem; font-weight: 700; color: #B8962E; margin-left: auto;
}

/* ── Responsive ────────────────────────────────────────── */
@media (max-width: 640px) {
  .oma5-zcard--rich { grid-template-columns: 38px 1fr; gap: 10px; padding: 12px; }
  .oma5-zcard__badge--rich { width: 38px; height: 38px; font-size: .68rem; }
  .oma5-zcard__name--rich  { font-size: .78rem; }
}


/* ════════════════════════════════════════════
   v8 — LOCKED PRIMARY PULSE + 72-HR COUNTDOWN
   (Party Primary locked state on homepage)
════════════════════════════════════════════ */

/* Countdown banner */
.oma5-pp-countdown-banner {
  display: flex; align-items: flex-start; gap: 16px;
  background: rgba(201,168,76,.08);
  border: 1px solid rgba(201,168,76,.3);
  border-left: 4px solid #D4AE48;
  border-radius: 8px; padding: 18px 20px; margin-bottom: 22px;
}
.oma5-pp-countdown-banner__icon { font-size:1.8rem; line-height:1; flex-shrink:0; margin-top:2px; }
.oma5-pp-countdown-banner__body { display:flex; flex-direction:column; gap:4px; flex:1; }
.oma5-pp-countdown-banner__label {
  font-size:.68rem; font-weight:700; text-transform:uppercase; letter-spacing:.1em;
  color:rgba(255,255,255,.45); font-family:'DM Sans',system-ui,sans-serif;
}
.oma5-pp-countdown-banner__timer {
  font-family:'EB Garamond',Georgia,serif; font-size:2.4rem; font-weight:700;
  color:#D4AE48; letter-spacing:.04em; line-height:1.1; font-variant-numeric:tabular-nums;
}
.oma5-pp-countdown-banner__note { font-size:.72rem; color:rgba(255,255,255,.45); line-height:1.55; margin-top:4px; }

/* Lock badge in section eyebrow */
.oma5-pp-lock-badge {
  display:inline-flex; align-items:center; gap:3px;
  font-size:.58rem; font-weight:700; text-transform:uppercase; letter-spacing:.1em;
  background:rgba(255,255,255,.1); color:rgba(255,255,255,.55);
  border:1px solid rgba(255,255,255,.15); border-radius:3px; padding:2px 7px;
  margin-left:8px; vertical-align:middle;
}

/* Locked grid opacity */
.oma5-ppgrid--locked { opacity:.85; }

/* Locked card */
.oma5-ppcard--locked { pointer-events:none; cursor:default; position:relative; }
.oma5-ppcard__lock-overlay {
  position:absolute; inset:0; display:flex; align-items:center; justify-content:center;
  background:rgba(0,0,0,.42); font-size:1.5rem; z-index:2;
}
.oma5-ppcard__locked-status {
  display:flex; align-items:center; gap:4px; font-size:.63rem; font-weight:700;
  color:#D4AE48; text-transform:uppercase; letter-spacing:.05em; margin-top:4px;
}
.oma5-ppcard__btn--locked {
  background:rgba(255,255,255,.07) !important; color:rgba(255,255,255,.35) !important;
  border:1px solid rgba(255,255,255,.12) !important; cursor:not-allowed !important;
  font-size:.72rem;
}
.oma5-ppcard__btn--locked:hover { background:rgba(255,255,255,.07) !important; transform:none !important; }

/* Mobile */
@media (max-width:480px) {
  .oma5-pp-countdown-banner { flex-direction:column; gap:10px; padding:14px 16px; }
  .oma5-pp-countdown-banner__timer { font-size:1.9rem; }
}

/* ── Portrait image fix: object-fit prevents cropped faces ── */
.oma5-ccard__photo img,
.oma5-ppcard__photo img {
  object-fit: cover;
  object-position: top center;
  display: block;
  width: 100%;
  height: 100%;
}

/* ── Mobile candidate grid: 2 columns on narrow screens ── */
@media (max-width: 540px) {
  .oma5-cgrid {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 10px !important;
  }
  .oma5-ccard__photo {
    height: 80px !important;
  }
  .oma5-ccard__name {
    font-size: 11px !important;
  }
  .oma5-ccard__role {
    font-size: 10px !important;
  }
  .oma5-ccard__party {
    font-size: 10px !important;
  }
}

/* ── Mobile leaderboard: prevent horizontal overflow ── */
@media (max-width: 600px) {
  .oma5-lb {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
  .oma5-lb__hdr span:nth-child(3),
  .oma5-lb__row > span:nth-child(3) {
    display: none;
  }
}

/* ── Empty leaderboard placeholder ── */
.oma5-lb__empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: 32px 20px;
  color: var(--sl2, #6B7280);
  font-size: 13px;
  line-height: 1.7;
}
