/* ============================================================
   REAL ESTATE DIGITAL MARKETING - LANDING PAGE
   Page-specific layer on top of /css/styles.css (tokens + fonts +
   base components). Prefix: .rdm-*  (real-estate digital marketing)

   Motion model: nothing is hidden by default. JS adds `html.anim`
   ONLY when GSAP is present AND motion is allowed; every reveal/hide
   rule lives under `html.anim`, so without JS the page is fully
   visible and usable. prefers-reduced-motion never gets `.anim`.
   ============================================================ */

/* ---- local tweaks / extra tokens ---- */
:root {
  --rdm-maxw: 1320px;
  --rdm-glow: 0 0 0 1px color-mix(in srgb, var(--c-brand-yellow) 30%, transparent);
}
html { scroll-behavior: smooth; }
body { overflow-x: clip; }
.container { max-width: var(--rdm-maxw); }
.rdm-ta-r { text-align: right; }
/* fixed-nav offset for in-page anchor jumps */
#results, #services, #calculator, #process, #faq, #audit, #hero { scroll-margin-top: 84px; }

/* When Lenis drives scrolling, it sets `html.lenis` - kill native smooth. */
html.lenis { scroll-behavior: auto; }
.rdm-prefix, .rdm-suffix { font-family: inherit; }

/* ============================================================
   MOTION STATES (only active under html.anim)
   ============================================================ */
html.anim .reveal { opacity: 0; transform: translateY(26px); will-change: opacity, transform; }
html.anim .reveal-row { opacity: 0; transform: translateX(-18px); }
html.anim .reveal-line { opacity: 0; }
html.anim .rdm-card.reveal { transform: translateY(40px); }

/* ============================================================
   SCROLL PROGRESS RAIL
   ============================================================ */
.rdm-progress {
  position: fixed; top: 0; left: 0; right: 0; height: 3px;
  background: transparent; z-index: 200; pointer-events: none;
}
.rdm-progress__bar {
  display: block; height: 100%; width: 0%;
  background: var(--c-brand-yellow);
  box-shadow: 0 0 12px color-mix(in srgb, var(--c-brand-yellow) 70%, transparent);
}

/* ============================================================
   SLIM NAV
   ============================================================ */
.rdm-nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 150;
  background: color-mix(in srgb, var(--c-ink) 86%, transparent);
  backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px);
  border-bottom: 1px solid color-mix(in srgb, var(--c-brand-yellow) 18%, transparent);
  transition: transform var(--dur-base) var(--ease-std), background var(--dur-base) var(--ease-std);
}
.rdm-nav--hidden { transform: translateY(-104%); }
.rdm-nav__inner { display: flex; align-items: center; justify-content: space-between; height: 64px; gap: var(--s-5); }
.rdm-nav__logo { display: inline-flex; align-items: center; gap: var(--s-2); color: var(--c-brand-yellow); }
.rdm-nav__logo-mark { font-size: 18px; line-height: 1; }
.rdm-nav__logo-text { font-family: var(--f-display); font-weight: 800; font-size: 20px; letter-spacing: -0.02em; text-transform: uppercase; }
.rdm-nav__links { display: none; gap: var(--s-6); }
.rdm-nav__link {
  font-family: var(--f-mono); font-size: 12px; letter-spacing: 0.12em; text-transform: uppercase;
  color: color-mix(in srgb, var(--c-brand-yellow) 78%, transparent); position: relative; padding: var(--s-2) 0;
}
.rdm-nav__link::after { content: ''; position: absolute; left: 0; right: 100%; bottom: 0; height: 1.5px; background: var(--c-brand-yellow); transition: right var(--dur-base) var(--ease-std); }
.rdm-nav__link:hover { color: var(--c-brand-yellow); }
.rdm-nav__link:hover::after { right: 0; }
.rdm-nav__cta { padding: var(--s-2) var(--s-4); font-family: var(--f-mono); font-size: 12px; letter-spacing: 0.12em; text-transform: uppercase; }
@media (min-width: 900px) { .rdm-nav__links { display: flex; } }

/* ============================================================
   HERO
   ============================================================ */
.rdm-hero {
  position: relative; padding: 0; min-height: 100svh;
  display: flex; flex-direction: column; justify-content: center;
  background: var(--c-ink); color: var(--c-brand-yellow); overflow: hidden;
}
.rdm-hero__canvas { position: absolute; inset: 0; width: 100%; height: 100%; z-index: 0; opacity: 0.9; }
.rdm-hero > .container, .rdm-hero__masthead, .rdm-hero__scroll { position: relative; z-index: 2; }

/* masthead */
.rdm-hero__masthead { position: absolute; top: 0; left: 0; right: 0; padding: calc(64px + var(--s-3)) 0 var(--s-3); border-bottom: 1px solid color-mix(in srgb, var(--c-brand-yellow) 16%, transparent); }
.rdm-hero__masthead-inner { display: flex; align-items: center; justify-content: center; flex-wrap: wrap; gap: var(--s-3); font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.24em; text-transform: uppercase; }
.rdm-mast-bit { color: color-mix(in srgb, var(--c-brand-yellow) 72%, transparent); }
.rdm-mast-bit--brand { color: var(--c-brand-yellow); font-weight: 700; }
.rdm-mast-sep { color: color-mix(in srgb, var(--c-brand-yellow) 40%, transparent); }
.rdm-mast-live { display: inline-flex; align-items: center; gap: var(--s-2); color: var(--c-brand-yellow); }
.rdm-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--c-brand-yellow); box-shadow: 0 0 0 0 color-mix(in srgb, var(--c-brand-yellow) 60%, transparent); animation: rdm-pulse 2s var(--ease-std) infinite; }
@keyframes rdm-pulse { 70% { box-shadow: 0 0 0 7px color-mix(in srgb, var(--c-brand-yellow) 0%, transparent); } 100% { box-shadow: 0 0 0 0 transparent; } }

.rdm-hero__grid { display: grid; grid-template-columns: 1fr; gap: var(--s-7); align-items: center; padding-top: var(--s-10); padding-bottom: var(--s-9); }
@media (min-width: 1024px) { .rdm-hero__grid { grid-template-columns: 1.08fr 0.92fr; gap: var(--s-8); padding-top: var(--s-9); } }
/* Mobile: the absolute masthead wraps to ~2 lines; compact it and give the grid
   enough top clearance so the kicker never collides with it. */
@media (max-width: 767px) {
  .rdm-hero__masthead { padding: calc(64px + var(--s-2)) 0 var(--s-2); }
  .rdm-hero__masthead-inner { font-size: 9px; letter-spacing: 0.14em; gap: var(--s-1) var(--s-2); padding: var(--s-1) 0; }
  .rdm-hero__grid { padding-top: 148px; }
}
.rdm-hero__left { display: flex; flex-direction: column; gap: var(--s-5); }

.rdm-hero__kicker { display: flex; align-items: center; gap: var(--s-3); margin: 0; font-family: var(--f-mono); font-size: 12px; letter-spacing: 0.2em; text-transform: uppercase; color: color-mix(in srgb, var(--c-brand-yellow) 80%, transparent); }
.rdm-hero__kicker-rule { width: 40px; height: 1.5px; background: var(--c-brand-yellow); display: inline-block; }

.rdm-hero__headline { font-family: var(--f-display); font-weight: 400; text-transform: uppercase; color: var(--c-brand-yellow); font-size: clamp(52px, 9vw, 132px); line-height: 0.88; letter-spacing: -0.025em; margin: 0; }
.rdm-hero__line { display: block; }
.rdm-hero__line--swap { display: flex; flex-wrap: wrap; align-items: baseline; gap: 0; }
.rdm-hero__out { color: var(--c-brand-yellow); }

/* word swap - all words share one grid cell (stable height, no layout jump);
   justify-items:start so each word's yellow box hugs its own text width. */
.rdm-swap { position: relative; display: inline-grid; justify-items: start; }
/* Exactly one word is .is-active at a time; opacity is class-driven (not JS-timed)
   so words can never stack even if a rAF-based animation stalls. */
.rdm-swap__word {
  grid-area: 1 / 1; display: inline-block;
  background: var(--c-brand-yellow); color: var(--c-ink);
  padding: 0 0.16em; line-height: 0.9;
  opacity: 0; transform: translateY(0.5em);
  transition: opacity 0.45s var(--ease-enter), transform 0.45s var(--ease-enter);
}
.rdm-swap__word.is-active { opacity: 1; transform: translateY(0); }

.rdm-hero__sub { font-family: var(--f-body); font-size: clamp(16px, 1.5vw, 20px); line-height: 1.6; max-width: 52ch; margin: 0; color: color-mix(in srgb, var(--c-brand-yellow) 82%, var(--c-surface) 0%); }
.rdm-hero__sub strong { color: var(--c-brand-yellow); }

.rdm-hero__ctas { display: flex; flex-wrap: wrap; gap: var(--s-3); margin-top: var(--s-2); }
.rdm-cta-lg { padding: var(--s-4) var(--s-6); font-family: var(--f-mono); font-size: 13px; letter-spacing: 0.14em; text-transform: uppercase; font-weight: 600; }
.rdm-cta-onink { color: var(--c-brand-yellow); border-color: var(--c-brand-yellow); background: transparent; }
.rdm-cta-onink:hover { background: var(--c-brand-yellow); color: var(--c-ink); }

.rdm-hero__ledger { list-style: none; margin: var(--s-5) 0 0; padding: var(--s-5) 0 0; display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--s-5) var(--s-4); border-top: 1.5px solid color-mix(in srgb, var(--c-brand-yellow) 30%, transparent); }
@media (min-width: 560px) { .rdm-hero__ledger { grid-template-columns: repeat(4, 1fr); } }
.rdm-hero__ledger li { display: flex; flex-direction: column; gap: 2px; }
.rdm-hero__ledger b { font-family: var(--f-display); font-weight: 800; font-size: clamp(24px, 2.6vw, 34px); letter-spacing: -0.02em; line-height: 1; color: var(--c-brand-yellow); }
.rdm-hero__ledger span { font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase; color: color-mix(in srgb, var(--c-brand-yellow) 62%, transparent); line-height: 1.3; }

/* live terminal */
.rdm-hero__right { position: relative; }
.rdm-terminal {
  position: relative; background: color-mix(in srgb, var(--c-brand-yellow) 3%, var(--c-ink));
  border: 1.5px solid color-mix(in srgb, var(--c-brand-yellow) 36%, transparent);
  border-radius: var(--r-md); padding: var(--s-4); display: flex; flex-direction: column; gap: var(--s-3);
  box-shadow: 0 30px 80px rgba(0,0,0,0.55), inset 0 0 60px color-mix(in srgb, var(--c-brand-yellow) 3%, transparent);
  min-height: 420px;
}
.rdm-terminal__bar { display: flex; align-items: center; gap: var(--s-2); padding-bottom: var(--s-3); border-bottom: 1px solid color-mix(in srgb, var(--c-brand-yellow) 22%, transparent); }
.rdm-terminal__dot { width: 10px; height: 10px; border-radius: 50%; background: color-mix(in srgb, var(--c-brand-yellow) 35%, transparent); }
.rdm-terminal__dot:first-child { background: var(--c-brand-yellow); }
.rdm-terminal__title { margin-left: auto; font-family: var(--f-mono); font-size: 12px; letter-spacing: 0.1em; color: color-mix(in srgb, var(--c-brand-yellow) 70%, transparent); }
.rdm-terminal__head, .rdm-terminal__row { display: grid; grid-template-columns: 0.7fr 1fr 1.1fr 0.9fr; gap: var(--s-3); align-items: center; }
.rdm-terminal__head { font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.18em; color: color-mix(in srgb, var(--c-brand-yellow) 48%, transparent); padding: 0 var(--s-1) var(--s-2); }
.rdm-terminal__stream { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 2px; flex: 1; overflow: hidden; }
.rdm-terminal__row { font-family: var(--f-mono); font-size: 12.5px; padding: var(--s-2) var(--s-1); border-radius: var(--r-sm); border: 1px solid transparent; }
.rdm-terminal__row.is-new { animation: rdm-row-in 0.5s var(--ease-enter); background: color-mix(in srgb, var(--c-brand-yellow) 10%, transparent); border-color: color-mix(in srgb, var(--c-brand-yellow) 24%, transparent); }
@keyframes rdm-row-in { from { opacity: 0; transform: translateY(-8px); } to { opacity: 1; transform: translateY(0); } }
.rdm-terminal__time { color: color-mix(in srgb, var(--c-brand-yellow) 58%, transparent); }
.rdm-terminal__cfg { color: var(--c-brand-yellow); font-weight: 600; }
.rdm-terminal__loc { color: color-mix(in srgb, var(--c-brand-yellow) 80%, transparent); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.rdm-terminal__status { text-align: right; font-weight: 600; letter-spacing: 0.04em; }
.rdm-terminal__status--q { color: var(--c-live); }
.rdm-terminal__status--c { color: var(--c-brand-yellow); }
.rdm-terminal__foot { display: flex; justify-content: space-between; align-items: center; padding-top: var(--s-3); border-top: 1px solid color-mix(in srgb, var(--c-brand-yellow) 22%, transparent); font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.08em; color: color-mix(in srgb, var(--c-brand-yellow) 70%, transparent); }
.rdm-terminal__foot b { color: var(--c-brand-yellow); font-size: 14px; }
.rdm-terminal__pulse { display: inline-flex; align-items: center; gap: var(--s-2); text-transform: uppercase; }

/* scanline tint over hero */
.rdm-hero::after { content: ''; position: absolute; inset: 0; z-index: 1; pointer-events: none; background: repeating-linear-gradient(0deg, transparent 0 3px, color-mix(in srgb, var(--c-brand-yellow) 4%, transparent) 3px 4px); opacity: 0.5; }

/* scroll cue */
.rdm-hero__scroll { position: absolute; bottom: var(--s-5); left: 50%; transform: translateX(-50%); display: flex; flex-direction: column; align-items: center; gap: var(--s-2); font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.24em; text-transform: uppercase; color: color-mix(in srgb, var(--c-brand-yellow) 60%, transparent); }
.rdm-hero__scroll-line { width: 1.5px; height: 40px; background: linear-gradient(to bottom, var(--c-brand-yellow), transparent); position: relative; overflow: hidden; }
.rdm-hero__scroll-line::after { content: ''; position: absolute; top: -50%; left: 0; width: 100%; height: 50%; background: var(--c-brand-yellow); animation: rdm-scroll-cue 1.8s var(--ease-std) infinite; }
@keyframes rdm-scroll-cue { to { top: 100%; } }

/* ============================================================
   STAT BAND (odometers)
   ============================================================ */
.rdm-stats__heading { font-family: var(--f-display); text-transform: uppercase; font-size: clamp(36px, 5vw, 76px); line-height: 0.95; letter-spacing: -0.02em; margin: 0 0 var(--s-7); max-width: 18ch; }
.rdm-stats__grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--s-6) var(--s-5); }
@media (min-width: 900px) { .rdm-stats__grid { grid-template-columns: repeat(4, 1fr); } }
.rdm-stat { border-top: 2px solid var(--c-ink); padding-top: var(--s-4); }
.rdm-stat__value { display: flex; align-items: baseline; font-family: var(--f-display); font-weight: 800; font-size: clamp(44px, 6vw, 84px); line-height: 0.9; letter-spacing: -0.03em; color: var(--c-ink); }
.rdm-stat__label { display: block; margin-top: var(--s-3); font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: color-mix(in srgb, var(--c-ink) 70%, transparent); }
.rdm-prefix, .rdm-suffix { font-size: 0.5em; font-weight: 800; }
.rdm-stats__note { margin: var(--s-7) 0 0; max-width: 60ch; font-family: var(--f-mono); font-size: 12px; line-height: 1.6; padding-left: var(--s-4); border-left: 2px solid var(--c-ink); color: var(--c-ink-soft); }

/* ============================================================
   PROBLEM / COMPARE
   ============================================================ */
.rdm-problem__grid { display: grid; grid-template-columns: 1fr; gap: var(--s-8); }
@media (min-width: 1024px) { .rdm-problem__grid { grid-template-columns: 0.9fr 1.1fr; gap: var(--s-9); align-items: start; } }
.rdm-problem__heading { font-family: var(--f-display); text-transform: uppercase; font-size: clamp(34px, 4.5vw, 68px); line-height: 0.96; letter-spacing: -0.02em; margin: 0 0 var(--s-5); }
.rdm-problem__copy { font-size: 18px; line-height: 1.65; color: var(--c-ink-soft); max-width: 46ch; margin: 0; }
.rdm-compare { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; border-top: 2px solid var(--c-ink); }
.rdm-compare__row { display: grid; grid-template-columns: 1fr auto 1fr; gap: var(--s-4); align-items: center; padding: var(--s-5) 0; border-bottom: 1.5px solid color-mix(in srgb, var(--c-ink) 18%, transparent); }
.rdm-compare__bad { font-family: var(--f-mono); font-size: 14px; color: var(--c-ink-muted); }
.rdm-compare__bad s { text-decoration-thickness: 1.5px; }
.rdm-compare__arrow { color: var(--c-ink); font-size: 20px; }
.rdm-compare__good { font-family: var(--f-display); font-weight: 400; text-transform: uppercase; font-size: clamp(18px, 1.8vw, 26px); line-height: 1.05; letter-spacing: -0.01em; }

/* ============================================================
   SERVICES (tilt cards)
   ============================================================ */
.rdm-services__heading { font-family: var(--f-display); text-transform: uppercase; font-size: clamp(36px, 5vw, 76px); line-height: 0.95; letter-spacing: -0.02em; margin: 0 0 var(--s-4); max-width: 16ch; }
.rdm-services__sub { font-family: var(--f-mono); font-size: 13px; line-height: 1.6; max-width: 60ch; margin: 0 0 var(--s-8); padding-left: var(--s-4); border-left: 2px solid var(--c-ink); color: var(--c-ink-soft); }
.rdm-cards { display: grid; grid-template-columns: 1fr; gap: var(--s-4); }
@media (min-width: 680px) { .rdm-cards { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .rdm-cards { grid-template-columns: repeat(3, 1fr); gap: var(--s-5); } }
.rdm-card {
  position: relative; background: var(--c-surface); border: 1.5px solid var(--c-ink);
  padding: var(--s-6); display: flex; flex-direction: column; gap: var(--s-3);
  transform-style: preserve-3d; transition: box-shadow var(--dur-base) var(--ease-std), transform var(--dur-base) var(--ease-std);
  overflow: hidden;
}
.rdm-card::before { content: ''; position: absolute; inset: 0; background: var(--c-brand-yellow); transform: translateY(101%); transition: transform var(--dur-base) var(--ease-enter); z-index: 0; }
.rdm-card:hover { box-shadow: 10px 10px 0 0 var(--c-ink); }
.rdm-card:hover::before { transform: translateY(0); }
.rdm-card > * { position: relative; z-index: 1; }
.rdm-card__idx { font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.2em; color: var(--c-ink-muted); }
.rdm-card__icon { width: 48px; height: 48px; display: flex; align-items: center; justify-content: center; font-size: 22px; background: var(--c-ink); color: var(--c-brand-yellow); border: 1.5px solid var(--c-ink); transition: background var(--dur-base) var(--ease-std), color var(--dur-base) var(--ease-std); }
.rdm-card:hover .rdm-card__icon { background: var(--c-surface); color: var(--c-ink); }
.rdm-card__title { font-family: var(--f-display); font-weight: 400; text-transform: uppercase; font-size: clamp(22px, 2vw, 28px); line-height: 1.04; letter-spacing: -0.01em; margin: 0; color: var(--c-ink); }
.rdm-card__body { font-size: 15px; line-height: 1.6; color: var(--c-ink-soft); margin: 0; }
.rdm-card:hover .rdm-card__body, .rdm-card:hover .rdm-card__idx { color: var(--c-ink); }

/* ============================================================
   LEDGER (results) - ink section
   ============================================================ */
.rdm-ledger-sec { color: var(--c-brand-yellow); }
.rdm-ledger__heading { font-family: var(--f-display); text-transform: uppercase; font-size: clamp(36px, 5vw, 76px); line-height: 0.95; letter-spacing: -0.02em; margin: 0 0 var(--s-4); color: var(--c-brand-yellow); }
.rdm-ledger__sub { font-family: var(--f-mono); font-size: 13px; line-height: 1.6; max-width: 64ch; margin: 0 0 var(--s-7); padding-left: var(--s-4); border-left: 2px solid var(--c-brand-yellow); color: color-mix(in srgb, var(--c-brand-yellow) 80%, transparent); }
.rdm-ledger { display: flex; flex-direction: column; }
.rdm-ledger__head, .rdm-ledger__row { display: grid; grid-template-columns: 36px 1.4fr 1fr 0.8fr 0.8fr 0.7fr; gap: var(--s-4); align-items: baseline; }
.rdm-ledger__head { font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase; color: color-mix(in srgb, var(--c-brand-yellow) 55%, transparent); padding: var(--s-2) 0; border-top: 2px solid var(--c-brand-yellow); border-bottom: 1.5px solid color-mix(in srgb, var(--c-brand-yellow) 40%, transparent); }
.rdm-ledger__row { padding: var(--s-5) 0; border-bottom: 1.5px solid color-mix(in srgb, var(--c-brand-yellow) 18%, transparent); transition: background var(--dur-fast) var(--ease-std); }
.rdm-ledger__row:hover { background: color-mix(in srgb, var(--c-brand-yellow) 6%, transparent); }
.rdm-ledger__idx { font-family: var(--f-mono); font-size: 12px; letter-spacing: 0.16em; color: color-mix(in srgb, var(--c-brand-yellow) 55%, transparent); }
.rdm-ledger__label { font-family: var(--f-display); font-weight: 400; text-transform: uppercase; font-size: clamp(17px, 1.7vw, 24px); line-height: 1; letter-spacing: -0.01em; color: var(--c-brand-yellow); }
.rdm-ledger__loc { font-family: var(--f-body); font-size: 14px; color: color-mix(in srgb, var(--c-brand-yellow) 72%, transparent); }
.rdm-ledger__num { font-family: var(--f-display); font-weight: 800; font-size: clamp(18px, 2vw, 30px); letter-spacing: -0.02em; color: var(--c-brand-yellow); font-variant-numeric: tabular-nums; }
.rdm-ledger__q { font-family: var(--f-mono); font-weight: 700; font-size: clamp(15px, 1.6vw, 20px); color: var(--c-live); font-variant-numeric: tabular-nums; }
.rdm-ledger__foot { margin: var(--s-6) 0 0; max-width: 60ch; font-family: var(--f-mono); font-size: 12px; line-height: 1.6; color: color-mix(in srgb, var(--c-brand-yellow) 70%, transparent); }
@media (max-width: 720px) {
  .rdm-ledger__head { display: none; }
  .rdm-ledger__row { grid-template-columns: 28px 1fr 1fr; grid-template-areas: "idx label label" "idx loc loc" "idx spend leads" "idx qual qual"; row-gap: var(--s-2); }
  .rdm-ledger__idx { grid-area: idx; } .rdm-ledger__label { grid-area: label; } .rdm-ledger__loc { grid-area: loc; }
  .rdm-ledger__num:nth-of-type(1) { grid-area: spend; } .rdm-ledger__num:nth-of-type(2) { grid-area: leads; }
  .rdm-ledger__q { grid-area: qual; text-align: left !important; }
  .rdm-ledger__row .rdm-ta-r { text-align: left; }
}

/* ============================================================
   CALCULATOR
   ============================================================ */
.rdm-calc__heading { font-family: var(--f-display); text-transform: uppercase; font-size: clamp(36px, 5vw, 76px); line-height: 0.95; letter-spacing: -0.02em; margin: 0 0 var(--s-4); max-width: 16ch; }
.rdm-calc__sub { font-family: var(--f-mono); font-size: 13px; line-height: 1.6; max-width: 60ch; margin: 0 0 var(--s-7); padding-left: var(--s-4); border-left: 2px solid var(--c-ink); color: var(--c-ink-soft); }
.rdm-calc__panel { display: grid; grid-template-columns: 1fr; gap: var(--s-6); border: 1.5px solid var(--c-ink); background: var(--c-surface); }
@media (min-width: 940px) { .rdm-calc__panel { grid-template-columns: 1fr 1fr; gap: 0; } }
.rdm-calc__controls { padding: var(--s-7) var(--s-6); display: flex; flex-direction: column; gap: var(--s-7); border-bottom: 1.5px solid var(--c-ink); }
@media (min-width: 940px) { .rdm-calc__controls { border-bottom: 0; border-right: 1.5px solid var(--c-ink); } }
.rdm-calc__field { display: flex; flex-direction: column; gap: var(--s-2); }
.rdm-calc__label { font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--c-ink-muted); }
.rdm-calc__readout { font-family: var(--f-display); font-weight: 800; font-size: clamp(32px, 4vw, 48px); letter-spacing: -0.02em; color: var(--c-ink); line-height: 1; font-variant-numeric: tabular-nums; }
.rdm-calc__scale { display: flex; justify-content: space-between; font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--c-ink-muted); margin-top: 2px; }
.rdm-calc__assume { font-family: var(--f-mono); font-size: 11px; line-height: 1.6; color: var(--c-ink-muted); margin: 0; }
.rdm-calc__reset { background: none; border: 0; border-bottom: 1.5px solid var(--c-ink); color: var(--c-ink); font: inherit; cursor: pointer; padding: 0 0 1px; }

/* range input */
.rdm-range { -webkit-appearance: none; appearance: none; width: 100%; height: 4px; background: color-mix(in srgb, var(--c-ink) 18%, transparent); outline-offset: 6px; border-radius: 0; cursor: pointer; }
.rdm-range::-webkit-slider-thumb { -webkit-appearance: none; appearance: none; width: 26px; height: 26px; border-radius: 50%; background: var(--c-brand-yellow); border: 2.5px solid var(--c-ink); box-shadow: 0 4px 12px rgba(0,0,0,0.2); transition: transform var(--dur-fast) var(--ease-std); }
.rdm-range::-webkit-slider-thumb:active { transform: scale(1.18); }
.rdm-range::-moz-range-thumb { width: 22px; height: 22px; border-radius: 50%; background: var(--c-brand-yellow); border: 2.5px solid var(--c-ink); cursor: pointer; }
.rdm-range::-moz-range-track { height: 4px; background: color-mix(in srgb, var(--c-ink) 18%, transparent); }

.rdm-calc__outputs { padding: var(--s-7) var(--s-6); background: var(--c-ink); color: var(--c-brand-yellow); display: flex; flex-direction: column; gap: var(--s-5); position: relative; isolation: isolate; }
.rdm-calc__outputs::after { content: ''; position: absolute; inset: 0; z-index: -1; pointer-events: none; background: repeating-linear-gradient(0deg, transparent 0 3px, color-mix(in srgb, var(--c-brand-yellow) 4%, transparent) 3px 4px); opacity: 0.5; }
.rdm-calc__out { display: grid; grid-template-columns: 1fr auto; grid-template-areas: "label value" "bar bar"; gap: var(--s-2) var(--s-4); align-items: baseline; }
.rdm-calc__out-label { grid-area: label; font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: color-mix(in srgb, var(--c-brand-yellow) 68%, transparent); }
.rdm-calc__out-value { grid-area: value; font-family: var(--f-display); font-weight: 800; font-size: clamp(26px, 3vw, 40px); letter-spacing: -0.02em; color: var(--c-brand-yellow); line-height: 1; font-variant-numeric: tabular-nums; }
.rdm-calc__out--hero .rdm-calc__out-value { font-size: clamp(34px, 4.4vw, 60px); }
.rdm-calc__out--hero { padding: var(--s-4) 0; border-top: 1.5px solid color-mix(in srgb, var(--c-brand-yellow) 30%, transparent); border-bottom: 1.5px solid color-mix(in srgb, var(--c-brand-yellow) 30%, transparent); }
.rdm-calc__bar { grid-area: bar; display: block; height: 6px; background: color-mix(in srgb, var(--c-brand-yellow) 16%, transparent); overflow: hidden; }
.rdm-calc__bar i { display: block; height: 100%; width: 0%; background: var(--c-brand-yellow); transition: width var(--dur-base) var(--ease-enter); }
.rdm-calc__bar--muted i { background: color-mix(in srgb, var(--c-brand-yellow) 55%, transparent); }
.rdm-calc__cta { margin-top: var(--s-6); }

/* ============================================================
   PROCESS (timeline) - ink
   ============================================================ */
.rdm-process__heading { font-family: var(--f-display); text-transform: uppercase; font-size: clamp(36px, 5vw, 76px); line-height: 0.95; letter-spacing: -0.02em; margin: 0 0 var(--s-4); color: var(--c-brand-yellow); max-width: 16ch; }
.rdm-process__sub { font-family: var(--f-mono); font-size: 13px; line-height: 1.6; max-width: 60ch; margin: 0 0 var(--s-8); padding-left: var(--s-4); border-left: 2px solid var(--c-brand-yellow); color: color-mix(in srgb, var(--c-brand-yellow) 80%, transparent); }
.rdm-timeline { list-style: none; counter-reset: step; margin: 0; padding: 0; display: grid; grid-template-columns: 1fr; gap: 0; border-top: 2px solid var(--c-brand-yellow); }
@media (min-width: 1024px) { .rdm-timeline { grid-template-columns: repeat(5, 1fr); border-top: 0; } }
.rdm-step { position: relative; padding: var(--s-6) 0; border-bottom: 1.5px solid color-mix(in srgb, var(--c-brand-yellow) 18%, transparent); }
@media (min-width: 1024px) { .rdm-step { padding: var(--s-7) var(--s-4) var(--s-7) 0; border-bottom: 0; border-top: 2px solid var(--c-brand-yellow); } .rdm-step + .rdm-step { padding-left: var(--s-4); } }
.rdm-step::before { content: ''; position: absolute; top: -1px; left: 0; width: 0; height: 2px; background: var(--c-brand-yellow); }
.rdm-step__day { display: inline-block; font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--c-ink); background: var(--c-brand-yellow); padding: var(--s-1) var(--s-3); margin-bottom: var(--s-4); }
.rdm-step__name { font-family: var(--f-display); font-weight: 400; text-transform: uppercase; font-size: clamp(20px, 1.7vw, 26px); line-height: 1.0; letter-spacing: -0.01em; margin: 0 0 var(--s-3); color: var(--c-brand-yellow); }
.rdm-step__detail { font-size: 14px; line-height: 1.55; color: color-mix(in srgb, var(--c-brand-yellow) 72%, transparent); margin: 0; }

/* ============================================================
   STACK chips
   ============================================================ */
.rdm-stack__heading { font-family: var(--f-display); text-transform: uppercase; font-size: clamp(32px, 4.5vw, 64px); line-height: 0.96; letter-spacing: -0.02em; margin: 0 0 var(--s-7); max-width: 18ch; }
.rdm-stack__grid { display: flex; flex-wrap: wrap; gap: var(--s-3); }
.rdm-chip { font-family: var(--f-mono); font-size: 13px; letter-spacing: 0.08em; text-transform: uppercase; padding: var(--s-3) var(--s-4); background: var(--c-ink); color: var(--c-brand-yellow); border: 1.5px solid var(--c-ink); transition: transform var(--dur-fast) var(--ease-std); }
.rdm-chip:hover { transform: translateY(-3px) rotate(-1.5deg); }

/* ============================================================
   WHY US
   ============================================================ */
.rdm-why__heading { font-family: var(--f-display); text-transform: uppercase; font-size: clamp(36px, 5vw, 76px); line-height: 0.95; letter-spacing: -0.02em; margin: 0 0 var(--s-8); max-width: 16ch; }
.rdm-why__grid { display: grid; grid-template-columns: 1fr; gap: var(--s-4); }
@media (min-width: 680px) { .rdm-why__grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .rdm-why__grid { grid-template-columns: repeat(3, 1fr); gap: var(--s-5); } }
.rdm-why__card { position: relative; background: var(--c-surface); border: 1.5px solid var(--c-ink); padding: var(--s-6); display: flex; flex-direction: column; gap: var(--s-3); transition: transform var(--dur-base) var(--ease-std), box-shadow var(--dur-base) var(--ease-std); }
.rdm-why__card:hover { transform: translateY(-4px); box-shadow: 8px 8px 0 0 var(--c-brand-yellow), 8px 8px 0 1.5px var(--c-ink); }
.rdm-why__num { font-family: var(--f-mono); font-size: 12px; letter-spacing: 0.2em; color: var(--c-ink-muted); }
.rdm-why__title { font-family: var(--f-display); font-weight: 400; text-transform: uppercase; font-size: clamp(20px, 1.8vw, 26px); line-height: 1.04; letter-spacing: -0.01em; margin: 0; color: var(--c-ink); }
.rdm-why__body { font-size: 15px; line-height: 1.6; color: var(--c-ink-soft); margin: 0; }

/* ============================================================
   QUOTES - ink
   ============================================================ */
.rdm-quotes__heading { font-family: var(--f-display); text-transform: uppercase; font-size: clamp(36px, 5vw, 76px); line-height: 0.95; letter-spacing: -0.02em; margin: 0 0 var(--s-8); color: var(--c-brand-yellow); }
.rdm-quotes__track { display: grid; grid-template-columns: 1fr; gap: var(--s-5); }
@media (min-width: 900px) { .rdm-quotes__track { grid-template-columns: repeat(3, 1fr); } }
.rdm-quote { margin: 0; border: 1.5px solid color-mix(in srgb, var(--c-brand-yellow) 30%, transparent); padding: var(--s-6); display: flex; flex-direction: column; gap: var(--s-5); justify-content: space-between; background: color-mix(in srgb, var(--c-brand-yellow) 3%, transparent); }
.rdm-quote blockquote { margin: 0; font-family: var(--f-display); font-weight: 400; font-size: clamp(19px, 1.8vw, 24px); line-height: 1.25; letter-spacing: -0.01em; color: var(--c-brand-yellow); }
.rdm-quote figcaption { display: flex; flex-direction: column; gap: 2px; border-top: 1px solid color-mix(in srgb, var(--c-brand-yellow) 24%, transparent); padding-top: var(--s-4); }
.rdm-quote figcaption b { font-family: var(--f-mono); font-size: 12px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--c-brand-yellow); }
.rdm-quote figcaption span { font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.08em; color: color-mix(in srgb, var(--c-brand-yellow) 62%, transparent); }

/* ============================================================
   FAQ - mostly inherits .faq-row from styles.css
   ============================================================ */
.rdm-faq__heading { font-family: var(--f-display); text-transform: uppercase; font-size: clamp(36px, 5vw, 76px); line-height: 0.95; letter-spacing: -0.02em; margin: 0 0 var(--s-7); max-width: 16ch; }
.rdm-faq__list { border-top: 2px solid var(--c-ink); }
.rdm-faq__list .faq-row__icon { transition: transform var(--dur-base) var(--ease-std), background var(--dur-fast) var(--ease-std); }
.rdm-faq__list .faq-row[open] .faq-row__icon { transform: rotate(45deg); background: var(--c-ink); color: var(--c-brand-yellow); }

/* ============================================================
   AUDIT / LEAD FORM
   ============================================================ */
.rdm-audit__grid { display: grid; grid-template-columns: 1fr; gap: var(--s-8); }
@media (min-width: 1024px) { .rdm-audit__grid { grid-template-columns: 1fr 1fr; gap: var(--s-9); align-items: start; } }
.rdm-audit__kicker { display: inline-flex; align-items: center; gap: var(--s-3); font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.24em; text-transform: uppercase; margin-bottom: var(--s-4); }
.rdm-audit__kicker-rule { width: 40px; height: 1.5px; background: var(--c-ink); display: inline-block; }
.rdm-audit__heading { font-family: var(--f-display); text-transform: uppercase; font-size: clamp(38px, 5.4vw, 80px); line-height: 0.92; letter-spacing: -0.025em; margin: 0 0 var(--s-5); }
.rdm-audit__sub { font-size: 17px; line-height: 1.6; max-width: 48ch; margin: 0 0 var(--s-6); color: var(--c-ink-soft); }
.rdm-audit__assure { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: var(--s-3); }
.rdm-audit__assure li { font-family: var(--f-mono); font-size: 13px; letter-spacing: 0.04em; color: var(--c-ink); }

.rdm-form { background: var(--c-ink); color: var(--c-brand-yellow); border: 1.5px solid var(--c-ink); padding: var(--s-6); display: flex; flex-direction: column; gap: var(--s-5); box-shadow: 12px 12px 0 0 var(--c-ink); }
.rdm-form__row { display: grid; grid-template-columns: 1fr; gap: var(--s-5); }
@media (min-width: 520px) { .rdm-form__row { grid-template-columns: 1fr 1fr; } }
.rdm-form__field { display: flex; flex-direction: column; gap: var(--s-2); border: 0; padding: 0; margin: 0; min-width: 0; }
.rdm-form__label { font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: color-mix(in srgb, var(--c-brand-yellow) 70%, transparent); padding: 0; }
.rdm-form__opt { color: color-mix(in srgb, var(--c-brand-yellow) 45%, transparent); }
.rdm-form input[type="text"], .rdm-form input[type="tel"], .rdm-form textarea {
  width: 100%; background: color-mix(in srgb, var(--c-brand-yellow) 5%, var(--c-ink)); color: var(--c-brand-yellow);
  border: 1.5px solid color-mix(in srgb, var(--c-brand-yellow) 30%, transparent); border-radius: var(--r-sm);
  padding: var(--s-3) var(--s-4); font-family: var(--f-body); font-size: 15px; transition: border-color var(--dur-fast) var(--ease-std), box-shadow var(--dur-fast) var(--ease-std);
}
.rdm-form input::placeholder, .rdm-form textarea::placeholder { color: color-mix(in srgb, var(--c-brand-yellow) 38%, transparent); }
.rdm-form input:focus, .rdm-form textarea:focus { outline: none; border-color: var(--c-brand-yellow); box-shadow: 0 0 0 3px color-mix(in srgb, var(--c-brand-yellow) 18%, transparent); }
.rdm-form input.is-invalid, .rdm-form .rdm-form__chips.is-invalid { border-color: var(--c-danger-soft); }
.rdm-form__chips { display: flex; flex-wrap: wrap; gap: var(--s-2); }
.rdm-form__chip { font-family: var(--f-mono); font-size: 12px; letter-spacing: 0.04em; padding: var(--s-2) var(--s-4); background: transparent; color: color-mix(in srgb, var(--c-brand-yellow) 80%, transparent); border: 1.5px solid color-mix(in srgb, var(--c-brand-yellow) 30%, transparent); border-radius: var(--r-full); cursor: pointer; transition: all var(--dur-fast) var(--ease-std); }
.rdm-form__chip:hover { border-color: var(--c-brand-yellow); }
.rdm-form__chip.is-active { background: var(--c-brand-yellow); color: var(--c-ink); border-color: var(--c-brand-yellow); font-weight: 600; }
.rdm-form__hp { position: absolute; left: -9999px; width: 1px; height: 1px; opacity: 0; }
.rdm-form__submit { justify-content: center; background: var(--c-brand-yellow); color: var(--c-ink); border-color: var(--c-brand-yellow); margin-top: var(--s-2); font-family: var(--f-mono); font-size: 13px; letter-spacing: 0.12em; text-transform: uppercase; }
.rdm-form__submit[disabled] { opacity: 0.6; cursor: progress; }
.rdm-form__status { margin: 0; font-family: var(--f-mono); font-size: 13px; min-height: 1.2em; }
.rdm-form__status.is-ok { color: var(--c-live); }
.rdm-form__status.is-err { color: var(--c-danger-soft); }
.rdm-form__fineprint { margin: 0; font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.06em; color: color-mix(in srgb, var(--c-brand-yellow) 45%, transparent); }
.rdm-form.is-sent { align-items: center; text-align: center; justify-content: center; min-height: 320px; }
.rdm-thanks__title { font-family: var(--f-display); text-transform: uppercase; font-size: 32px; letter-spacing: -0.02em; margin: 0 0 12px; color: var(--c-brand-yellow); }
.rdm-thanks__text { font-family: var(--f-mono); font-size: 13px; line-height: 1.6; color: color-mix(in srgb, var(--c-brand-yellow) 78%, transparent); max-width: 38ch; margin: 0 auto; }

/* ============================================================
   FOOTER
   ============================================================ */
.rdm-footer { background: var(--c-ledger); color: var(--c-brand-yellow); padding: var(--s-9) 0 var(--s-6); }
.rdm-footer__top { display: grid; grid-template-columns: 1fr; gap: var(--s-6); }
@media (min-width: 768px) { .rdm-footer__top { grid-template-columns: 1fr auto; align-items: end; } }
.rdm-footer__logo { font-family: var(--f-display); font-weight: 400; text-transform: uppercase; font-size: clamp(34px, 4vw, 52px); line-height: 0.95; letter-spacing: -0.02em; color: var(--c-brand-yellow); }
.rdm-footer__tag { font-family: var(--f-mono); font-size: 12px; letter-spacing: 0.06em; color: color-mix(in srgb, var(--c-brand-yellow) 65%, transparent); margin: var(--s-3) 0 0; }
.rdm-footer__meta { display: flex; flex-direction: column; gap: var(--s-2); align-items: flex-start; }
@media (min-width: 768px) { .rdm-footer__meta { align-items: flex-end; } }
.rdm-footer__email { font-family: var(--f-mono); font-size: 14px; color: var(--c-brand-yellow); }
.rdm-footer__email:hover { text-decoration: underline; text-underline-offset: 3px; }
.rdm-footer__loc { font-family: var(--f-mono); font-size: 12px; color: color-mix(in srgb, var(--c-brand-yellow) 60%, transparent); }
.rdm-footer__links { display: flex; flex-wrap: wrap; gap: var(--s-4); margin-top: var(--s-2); }
.rdm-footer__links a { font-family: var(--f-mono); font-size: 12px; letter-spacing: 0.04em; color: color-mix(in srgb, var(--c-brand-yellow) 78%, transparent); }
.rdm-footer__links a:hover { color: var(--c-brand-yellow); }
.rdm-footer__rule { border: 0; border-top: 1px solid color-mix(in srgb, var(--c-brand-yellow) 20%, transparent); margin: var(--s-7) 0; }
.rdm-footer__legal { display: flex; flex-wrap: wrap; justify-content: space-between; gap: var(--s-3); font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; color: color-mix(in srgb, var(--c-brand-yellow) 50%, transparent); }

/* ============================================================
   FULL SERVICE STACK
   ============================================================ */
.rdm-stack-sec__heading { font-family: var(--f-display); text-transform: uppercase; font-size: clamp(36px, 5vw, 76px); line-height: 0.95; letter-spacing: -0.02em; margin: 0 0 var(--s-4); max-width: 16ch; }
.rdm-stack-sec__sub { font-family: var(--f-mono); font-size: 13px; line-height: 1.6; max-width: 62ch; margin: 0 0 var(--s-8); padding-left: var(--s-4); border-left: 2px solid var(--c-ink); color: var(--c-ink-soft); }
.rdm-svc-grid { display: grid; grid-template-columns: 1fr; gap: 0; border-top: 1.5px solid var(--c-hairline); }
@media (min-width: 600px) { .rdm-svc-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .rdm-svc-grid { grid-template-columns: repeat(3, 1fr); } }
.rdm-svc {
  position: relative; padding: var(--s-5) var(--s-5) var(--s-5) 0;
  border-bottom: 1.5px solid var(--c-hairline);
  display: flex; flex-direction: column; gap: var(--s-2);
  transition: background var(--dur-fast) var(--ease-std), padding var(--dur-base) var(--ease-std);
}
@media (min-width: 600px) {
  .rdm-svc { padding: var(--s-5); border-right: 1.5px solid var(--c-hairline); }
  .rdm-svc:nth-child(2n) { border-right: 0; }
}
@media (min-width: 1024px) {
  .rdm-svc:nth-child(2n) { border-right: 1.5px solid var(--c-hairline); }
  .rdm-svc:nth-child(3n) { border-right: 0; }
}
.rdm-svc:hover { background: var(--c-brand-yellow); padding-left: var(--s-4); }
@media (min-width: 600px) { .rdm-svc:hover { padding-left: calc(var(--s-5) + var(--s-2)); } }
.rdm-svc__glyph { font-size: 22px; color: var(--c-ink); line-height: 1; }
.rdm-svc__name { font-family: var(--f-display); font-weight: 400; text-transform: uppercase; font-size: clamp(20px, 1.8vw, 26px); line-height: 1.05; letter-spacing: -0.01em; margin: 0; color: var(--c-ink); }
.rdm-svc__desc { font-size: 14px; line-height: 1.55; color: var(--c-ink-soft); margin: 0; }
.rdm-svc:hover .rdm-svc__desc { color: var(--c-ink); }

/* ============================================================
   INDIA LIVE-LEADS MAP
   ============================================================ */
.rdm-india { color: var(--c-brand-yellow); overflow: hidden; }
.rdm-india__heading { font-family: var(--f-display); text-transform: uppercase; font-size: clamp(36px, 5vw, 76px); line-height: 0.95; letter-spacing: -0.02em; margin: 0 0 var(--s-4); color: var(--c-brand-yellow); }
.rdm-india__sub { font-family: var(--f-mono); font-size: 13px; line-height: 1.6; max-width: 60ch; margin: 0 0 var(--s-7); padding-left: var(--s-4); border-left: 2px solid var(--c-brand-yellow); color: color-mix(in srgb, var(--c-brand-yellow) 80%, transparent); }
.rdm-india__layout { display: grid; grid-template-columns: 1fr; gap: var(--s-7); align-items: start; }
@media (min-width: 940px) { .rdm-india__layout { grid-template-columns: 1fr 1fr; gap: var(--s-8); } }

.rdm-india__mapwrap { position: relative; }
.rdm-india__side { display: flex; flex-direction: column; gap: var(--s-5); }
.rdm-india__total { display: flex; flex-direction: column; gap: var(--s-2); border-left: 2px solid color-mix(in srgb, var(--c-brand-yellow) 40%, transparent); padding-left: var(--s-4); }
.rdm-india__total-meta { display: inline-flex; align-items: center; gap: var(--s-2); }
.rdm-india__total-dot { width: 9px; height: 9px; border-radius: 50%; background: var(--c-live); box-shadow: 0 0 0 0 rgba(124,255,178,0.6); animation: rdm-livedot 2s var(--ease-std) infinite; }
@keyframes rdm-livedot { 70% { box-shadow: 0 0 0 9px rgba(124,255,178,0); } 100% { box-shadow: 0 0 0 0 rgba(124,255,178,0); } }
.rdm-india__total-label { font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: color-mix(in srgb, var(--c-brand-yellow) 65%, transparent); }
.rdm-india__total-value { font-family: var(--f-display); font-weight: 800; font-size: clamp(40px, 5.5vw, 68px); letter-spacing: -0.02em; line-height: 1; color: var(--c-brand-yellow); font-variant-numeric: tabular-nums; }

.rdm-india__stage { position: relative; width: 100%; max-width: 430px; margin: 0 auto; }
@media (min-width: 940px) { .rdm-india__stage { margin: 0; } }
.rdm-india__svg { width: 100%; height: auto; display: block; overflow: visible; }
.rdm-india__land { fill: color-mix(in srgb, var(--c-brand-yellow) 7%, transparent); stroke: color-mix(in srgb, var(--c-brand-yellow) 26%, transparent); stroke-width: 0.6; stroke-linejoin: round; }
.rdm-india__city { cursor: default; }
.rdm-india__dot { fill: var(--c-brand-yellow); filter: drop-shadow(0 0 4px var(--c-brand-yellow)); }
.rdm-india__ping { fill: none; stroke: var(--c-brand-yellow); stroke-width: 1; transform-box: fill-box; transform-origin: center; opacity: 0; animation: rdm-ping 3.2s var(--ease-std) infinite; }
@keyframes rdm-ping { 0% { transform: scale(0.6); opacity: 0.7; } 80% { opacity: 0; } 100% { transform: scale(4.2); opacity: 0; } }
.rdm-india__city.is-hot .rdm-india__dot { animation: rdm-hot 0.6s var(--ease-std); }
@keyframes rdm-hot { 0% { transform: scale(1); } 40% { transform: scale(1.9); } 100% { transform: scale(1); } }
.rdm-india__city.is-hot .rdm-india__dot { transform-box: fill-box; transform-origin: center; }
.rdm-india__city.is-active .rdm-india__dot { fill: var(--c-surface); }
.rdm-india__label { font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.04em; fill: color-mix(in srgb, var(--c-brand-yellow) 78%, transparent); text-transform: uppercase; pointer-events: none; }

/* legend */
.rdm-india__legend { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; border-top: 1.5px solid color-mix(in srgb, var(--c-brand-yellow) 28%, transparent); }
.rdm-india__legrow { display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: var(--s-3); padding: var(--s-2) var(--s-1); border-bottom: 1px solid color-mix(in srgb, var(--c-brand-yellow) 14%, transparent); transition: background var(--dur-fast) var(--ease-std); cursor: default; }
.rdm-india__legrow:hover, .rdm-india__legrow.is-active { background: color-mix(in srgb, var(--c-brand-yellow) 8%, transparent); }
.rdm-india__legdot { width: 8px; height: 8px; border-radius: 50%; background: var(--c-brand-yellow); box-shadow: 0 0 6px var(--c-brand-yellow); }
.rdm-india__legname { font-family: var(--f-mono); font-size: 12px; letter-spacing: 0.06em; text-transform: uppercase; color: color-mix(in srgb, var(--c-brand-yellow) 85%, transparent); }
.rdm-india__legcount { font-family: var(--f-display); font-weight: 800; font-size: clamp(16px, 1.6vw, 22px); letter-spacing: -0.01em; color: var(--c-brand-yellow); font-variant-numeric: tabular-nums; transition: color var(--dur-fast) var(--ease-std); }
.rdm-india__legrow.is-hot .rdm-india__legcount { animation: rdm-legflash 0.6s var(--ease-std); }
@keyframes rdm-legflash { 0% { color: var(--c-live); } 40% { color: var(--c-live); } 100% { color: var(--c-brand-yellow); } }

/* ============================================================
   REDUCED MOTION - kill the optional flourishes
   ============================================================ */
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  .rdm-dot, .rdm-hero__scroll-line::after, .rdm-terminal__row.is-new,
  .rdm-india__total-dot, .rdm-india__ping, .rdm-india__city.is-hot .rdm-india__dot { animation: none !important; }
  .rdm-india__ping { display: none; }
  .rdm-hero::after, .rdm-calc__outputs::after { display: none; }
}
