/* Eligibility Voronoi Map — "Modern Jewel" (OKLCH-harmonised, warm near-black) · .em- prefix · standalone */
:root{
  --em-forest-dk:#17171b; --em-forest:#201f25; --em-forest-mid:#2a2932; --em-sage:#584948;
  --em-sienna:#c4532b; --em-sienna-dk:#a3401f; --em-gold:#b18400; --em-navy:#4390da;
  --em-parchment:#f3f1ea; --em-parch-dim:rgba(243,241,234,.66); --em-rim:#cbb89a;
  --em-line:rgba(203,184,154,.15); --em-panel:#201f25; --em-panel-2:#1a1a1f;
}
*{box-sizing:border-box}
.em-page{margin:0;background:var(--em-forest-dk);color:var(--em-parchment);
  font-family:Inter,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;line-height:1.5;
  /* nav-v7 is position:fixed (56px + safe-area) — without this it overlays the masthead */
  padding-top:calc(56px + env(safe-area-inset-top, 0px))}
.em-wrap{max-width:1280px;margin:0 auto;padding:0 20px}

/* hero */
.em-masthead{padding:54px 0 22px;text-align:center;max-width:760px;margin:0 auto}
.em-masthead h1{font-family:Fraunces,Georgia,serif;font-weight:700;font-size:clamp(28px,4.4vw,46px);line-height:1.08;margin:0 0 14px;letter-spacing:-.5px}
.em-masthead h1 .em-accent{color:#e0795a}
.em-masthead p{font-size:clamp(15px,1.7vw,18px);color:var(--em-parch-dim);margin:0 auto;max-width:620px}
.em-masthead .em-static{font-size:13px;color:var(--em-parch-dim);margin-top:14px}

/* layout */
.em-app{display:grid;grid-template-columns:1.35fr .95fr;gap:26px;align-items:start;padding:8px 0 64px}
.em-stage{position:relative;min-height:560px;display:flex;flex-direction:column;border-radius:18px;padding:16px 0 8px;
  background:radial-gradient(120% 120% at 50% 42%,#211f26 0%,var(--em-forest-dk) 72%);overflow:hidden}
/* counter is now a header band above the circle — no more overlap with cells/labels */
.em-counter{flex:0 0 auto;text-align:center;pointer-events:none;padding:2px 0 6px}
#em-counter{font-family:Fraunces,Georgia,serif;font-weight:700;font-size:48px;line-height:1;color:var(--em-parchment);text-shadow:0 2px 18px rgba(0,0,0,.4)}
#em-counter-label{font-size:12px;letter-spacing:.4px;color:var(--em-rim);margin-top:4px;text-transform:uppercase}
.em-viz-wrap{flex:1 1 auto;min-height:0;display:flex;align-items:center;justify-content:center}
#em-viz{width:100%;height:100%;max-height:640px;display:block}

/* side panel */
.em-panel{background:var(--em-panel);border:1px solid var(--em-line);border-radius:18px;padding:22px;position:sticky;top:18px}
.em-dim-label{font-size:11px;text-transform:uppercase;letter-spacing:.7px;color:var(--em-rim);margin:0 0 7px 2px}
.em-dim{display:flex;background:var(--em-panel-2);border:1px solid var(--em-line);border-radius:11px;padding:4px;margin-bottom:18px}
.em-dim button{flex:1;min-height:40px;background:none;border:0;color:var(--em-parch-dim);padding:10px;border-radius:8px;cursor:pointer;font-weight:600;font-size:13px;font-family:inherit;transition:.15s}
.em-dim button.is-active{background:var(--em-sienna);color:#fff}

.em-q__progress{font-size:11px;text-transform:uppercase;letter-spacing:.7px;color:var(--em-rim);margin-bottom:8px}
.em-q__title{font-family:Fraunces,Georgia,serif;font-weight:600;font-size:21px;margin:0 0 4px;line-height:1.2}
.em-q__sub{font-size:13px;color:var(--em-parch-dim);margin:0 0 14px}
.em-q__opts{display:flex;flex-direction:column;gap:8px;margin:14px 0 16px}
.em-opt{display:flex;align-items:center;min-height:44px;text-align:left;background:var(--em-panel-2);border:1px solid var(--em-line);border-radius:10px;padding:11px 14px;
  color:var(--em-parchment);cursor:pointer;font-size:14px;font-weight:500;font-family:inherit;transition:.13s}
.em-opt:hover{border-color:var(--em-rim);transform:translateX(2px)}
.em-opt.is-on{background:var(--em-forest-mid);border-color:var(--em-gold);box-shadow:0 0 0 1px var(--em-gold) inset}
.em-q__nav{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}
.em-back,.em-skip{background:none;border:0;color:var(--em-parch-dim);cursor:pointer;font-size:12.5px;font-weight:600;font-family:inherit;padding:6px 2px}
.em-back:hover,.em-skip:hover{color:var(--em-parchment)}
.em-next{background:var(--em-forest-mid);border:1px solid var(--em-gold);color:#fff;border-radius:9px;padding:9px 16px;cursor:pointer;font-weight:600;font-family:inherit;font-size:13px}

/* map footer: "coloured by" caption + legend, sitting UNDER the circle */
.em-mapfoot{flex:0 0 auto;padding:6px 18px 4px;text-align:center}
.em-colorby{font-size:10.5px;text-transform:uppercase;letter-spacing:.6px;color:var(--em-rim);margin-bottom:7px}
.em-legend{display:flex;flex-wrap:wrap;justify-content:center;gap:5px 12px}
.em-leg{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--em-parch-dim)}
.em-leg i{width:10px;height:10px;border-radius:2px;display:inline-block;flex:0 0 auto}

/* end state */
.em-end{text-align:center;padding:8px 4px}
.em-end__n{font-family:Fraunces,Georgia,serif;font-weight:700;font-size:64px;line-height:1;color:var(--em-gold)}
.em-end__lead{font-size:17px;font-weight:600;margin:6px 0 12px}
.em-end__sub{font-size:13.5px;color:var(--em-parch-dim);margin:0 0 20px}
.em-end__matches{text-align:left;margin:4px 0 18px}
.em-match{display:flex;align-items:stretch;gap:6px;margin-bottom:7px}
.em-match__link{flex:1 1 auto;display:flex;align-items:center;gap:10px;text-decoration:none;background:var(--em-panel-2);
  border:1px solid var(--em-line);border-radius:10px;padding:10px 12px;transition:.13s;min-width:0}
.em-match__link:hover{border-color:var(--em-gold);background:var(--em-forest-mid);transform:translateX(2px)}
.em-match__body{flex:1 1 auto;min-width:0}
.em-match__t{display:block;font-size:13.5px;font-weight:600;color:var(--em-parchment);line-height:1.25}
.em-match__m{display:block;font-size:11.5px;color:#8fd6ad;margin-top:2px;text-transform:capitalize}
.em-match__go{flex:0 0 auto;color:var(--em-rim);font-size:15px;opacity:0;transition:opacity .13s}
.em-match__link:hover .em-match__go{opacity:1}
.em-match__save{flex:0 0 auto;width:40px;height:40px;align-self:center;display:flex;align-items:center;justify-content:center;
  background:var(--em-panel-2);border:1px solid var(--em-line);border-radius:10px;
  color:var(--em-parch-dim);font-size:17px;cursor:pointer;transition:.13s;line-height:1}
.em-match__save:hover{border-color:var(--em-rim);color:var(--em-parchment)}
.em-match__save.is-on{color:var(--em-sienna);border-color:var(--em-sienna)}
.em-teaser__more{font-size:12px;color:var(--em-rim);font-weight:600;padding:6px 2px 2px;text-align:center}
/* end-state refine filters */
.em-refine{text-align:left;margin:0 0 18px}
.em-refine__h{font-size:11px;text-transform:uppercase;letter-spacing:.7px;color:var(--em-rim);margin:0 0 9px}
.em-refine__b{display:inline-flex;align-items:center;gap:6px;background:var(--em-panel-2);border:1px solid var(--em-line);border-radius:20px;
  padding:7px 13px;margin:0 6px 7px 0;color:var(--em-parch-dim);cursor:pointer;font-size:12.5px;font-weight:500;font-family:inherit;transition:.13s}
.em-refine__b::before{content:"+";font-weight:700;opacity:.7}
.em-refine__b:hover{border-color:var(--em-rim);color:var(--em-parchment)}
.em-refine__b.is-on{background:var(--em-forest-mid);border-color:var(--em-gold);color:#fff}
.em-refine__b.is-on::before{content:"✓";opacity:1}
.em-end__cta{display:flex;flex-direction:column;gap:10px;margin-bottom:14px}
.em-cta{display:block;text-decoration:none;border-radius:11px;padding:13px 18px;font-weight:700;font-size:14.5px;transition:.15s}
.em-cta--primary{background:var(--em-sienna);color:#fff}
.em-cta--primary:hover{background:var(--em-sienna-dk)}
.em-cta--secondary{background:transparent;color:var(--em-parchment);border:1px solid var(--em-rim)}
.em-cta--secondary:hover{background:rgba(216,199,160,.1)}

/* tooltip */
#em-tooltip{position:fixed;pointer-events:none;background:#0b1d14;border:1px solid var(--em-line);border-radius:10px;
  padding:9px 12px;font-size:12px;max-width:250px;opacity:0;transition:opacity .12s;z-index:60;box-shadow:0 10px 34px rgba(0,0,0,.55)}
#em-tooltip{max-width:268px}
#em-tooltip b{display:block;font-size:12.5px;margin-bottom:3px;line-height:1.25}
.em-tip-meta{display:block;color:var(--em-parch-dim);font-size:11px}
.em-tip-amt{display:block;color:#8fd6ad;font-weight:600;font-size:11.5px;margin-top:3px}
.em-tip-ctx{display:block;color:var(--em-rim);font-size:11px;margin-top:5px;padding-top:5px;border-top:1px solid var(--em-line)}
.em-tip-ctx b{display:inline;font-size:11px;color:var(--em-parchment)}
.em-tip-hint{display:block;color:var(--em-parch-dim);font-size:10.5px;margin-top:5px;opacity:.8}

/* end-state share + restart footer */
.em-end__foot{display:flex;align-items:center;justify-content:center;gap:16px;flex-wrap:wrap}
.em-share{background:none;border:0;color:var(--em-rim);cursor:pointer;font-size:12.5px;font-weight:700;font-family:inherit;padding:6px 2px}
.em-share:hover{color:var(--em-parchment)}

/* mobile tap-to-view info card (bottom sheet) — hover isn't available on touch */
.em-mcard{position:fixed;left:12px;right:12px;bottom:12px;z-index:70;background:#0b1d14;border:1px solid var(--em-line);
  border-radius:16px;padding:16px 16px 14px;box-shadow:0 -8px 40px rgba(0,0,0,.55);transform:translateY(130%);transition:transform .26s cubic-bezier(.2,.8,.2,1);max-width:520px;margin:0 auto}
.em-mcard.is-open{transform:translateY(0)}
.em-mcard__x{position:absolute;top:8px;right:10px;background:none;border:0;color:var(--em-parch-dim);font-size:22px;line-height:1;cursor:pointer}
.em-mcard__t{font-family:Fraunces,Georgia,serif;font-weight:600;font-size:17px;line-height:1.2;padding-right:24px}
.em-mcard__m{font-size:12.5px;color:var(--em-parch-dim);margin-top:3px}
.em-mcard__amt{font-size:13px;color:#8fd6ad;font-weight:600;margin-top:6px}
.em-mcard__ctx{display:block;font-size:12px;color:var(--em-rim);margin-top:6px}
.em-mcard__ctx b{color:var(--em-parchment)}
.em-mcard__go{display:inline-block;margin-top:12px;background:var(--em-sienna);color:#fff;text-decoration:none;border-radius:10px;padding:11px 16px;font-weight:700;font-size:14px}

/* toast */
.em-toast{position:fixed;left:50%;bottom:26px;transform:translateX(-50%) translateY(16px);z-index:80;background:#0b1d14;border:1px solid var(--em-line);
  color:var(--em-parchment);border-radius:24px;padding:11px 20px;font-size:13px;font-weight:600;opacity:0;transition:opacity .25s,transform .25s;box-shadow:0 8px 30px rgba(0,0,0,.5)}
.em-toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

.em-rim{paint-order:stroke;stroke:var(--em-forest-dk);stroke-width:3.5px;stroke-linejoin:round}
/* in-cell labels: dark halo so white text reads over any cell colour */
.em-clabel text{paint-order:stroke;stroke:rgba(8,18,12,.85);stroke-width:2.6px;stroke-linejoin:round}
#em-viz path{shape-rendering:geometricPrecision}

/* responsive */
@media (max-width:860px){
  .em-app{grid-template-columns:1fr;gap:16px}
  /* counter band + fixed-height circle + legend, all auto-stacked */
  .em-stage{min-height:0;height:auto;padding:10px 0 8px}
  .em-viz-wrap{height:min(78vw,300px);flex:0 0 auto}
  .em-panel{position:static}
  #em-counter{font-size:32px}
  .em-masthead{padding:34px 0 12px}
}
@media (prefers-reduced-motion:reduce){
  .em-opt,.em-cta,.em-dim button{transition:none}
}

/* ── indexable supporting content below the map (SEO/GEO — the SVG has no crawlable text) ── */
.em-seo{padding:8px 20px 72px}
.em-seo__col{max-width:680px;margin:0 auto}
.em-seo h2{font-family:Fraunces,Georgia,serif;font-weight:600;font-size:clamp(22px,2.6vw,28px);line-height:1.2;color:var(--em-parchment);margin:44px 0 12px}
.em-seo h2:first-child{margin-top:0}
.em-seo h3{font-size:16px;font-weight:700;color:var(--em-parchment);margin:24px 0 6px}
.em-seo p{font-size:15px;line-height:1.65;color:var(--em-parch-dim);margin:0 0 12px}
.em-seo a{color:var(--em-sienna);text-decoration:none}
.em-seo a:hover{text-decoration:underline}
.em-seo strong{color:var(--em-parchment);font-weight:600}
.em-seo__stats{list-style:none;margin:0 0 12px;padding:0}
.em-seo__stats li{font-size:15px;line-height:1.6;color:var(--em-parch-dim);padding:9px 0 9px 18px;border-bottom:1px solid var(--em-line);position:relative}
.em-seo__stats li::before{content:"";position:absolute;left:0;top:18px;width:7px;height:7px;border-radius:2px;background:var(--em-sienna)}
.em-seo__note{font-size:12.5px;color:var(--em-rim)}

.em-match__save svg{display:block}
.em-match__save.is-on svg path{fill:currentColor}

/* loading veil while the worker tessellates (~1s) + fetch-failure retry */
.em-viz-wrap{position:relative}
.em-loading{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;gap:10px;
  font-size:13px;letter-spacing:.4px;color:var(--em-rim);animation:emPulse 1.6s ease-in-out infinite;pointer-events:none}
.em-loading.is-error{animation:none;pointer-events:auto;color:var(--em-parch-dim)}
.em-loading__retry{background:var(--em-sienna);color:#fff;border:0;border-radius:8px;padding:8px 14px;font:inherit;font-weight:700;cursor:pointer}
@keyframes emPulse{0%,100%{opacity:.45}50%{opacity:1}}
a.em-teaser__more{display:block;text-decoration:none;cursor:pointer}
a.em-teaser__more:hover{color:var(--em-sienna)}
/* coarse-pointer (touch) targets up to 44px without changing desktop look */
@media (pointer:coarse){
  .em-refine__b,.em-lens,.em-share,.em-skip,.em-back,.em-next{min-height:44px}
}
@media (prefers-reduced-motion:reduce){.em-loading{animation:none}}
