/* Roadmap homepage — Stripe-calibre redesign. Fully scoped under .rm-home + rm-* classes so it
   never collides with Bootstrap or the existing theme CSS. No global/body overrides. */
.rm-home {
  --rm-ground: #F4F7FA;
  --rm-surface: #FFFFFF;
  --rm-ink: #07263B;
  --rm-muted: #55738A;
  --rm-line: #E2EAF0;
  --rm-sea-deep: #0A5A7A;
  --rm-sea-aqua: #15AEC0;
  --rm-sea-foam: #86E1D3;
  --rm-dawn: #FFB57C;
  --rm-coral: #FF6A45;
  --rm-coral-ink: #E24E2C;
  --rm-shadow: 0 1px 2px rgba(7,38,59,.06), 0 12px 32px -12px rgba(7,38,59,.18);
  --rm-shadow-lg: 0 2px 4px rgba(7,38,59,.06), 0 28px 60px -22px rgba(10,90,122,.35);
  --rm-font: "Helvetica Neue", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, Arial, sans-serif;

  background: var(--rm-ground);
  color: var(--rm-ink);
  font-family: var(--rm-font);
  font-size: 17px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}
.rm-home * { box-sizing: border-box; }
.rm-home h1, .rm-home h2, .rm-home h3, .rm-home p { margin: 0; }
.rm-home a { color: inherit; text-decoration: none; }
.rm-wrap { width: 100%; max-width: 1080px; margin: 0 auto; padding: 0 24px; }
.rm-eyebrow { font-size: .76rem; font-weight: 600; letter-spacing: .15em; text-transform: uppercase; color: var(--rm-sea-deep); }

.rm-btn {
  display: inline-flex; align-items: center; gap: 8px; font-family: var(--rm-font);
  font-size: .95rem; font-weight: 600; border: 0; border-radius: 999px; cursor: pointer;
  padding: 13px 22px; transition: transform .12s ease, box-shadow .2s ease, background .2s ease;
}
.rm-btn-primary { background: var(--rm-coral); color: #fff; box-shadow: 0 6px 18px -6px rgba(255,106,69,.7); }
.rm-btn-primary:hover { background: var(--rm-coral-ink); transform: translateY(-1px); color: #fff; }

/* hero */
.rm-hero { position: relative; overflow: hidden; padding: 88px 0 40px; text-align: center; }
.rm-glow {
  position: absolute; left: 50%; bottom: -46%; transform: translateX(-50%);
  width: 140%; height: 96%; z-index: 0; filter: blur(18px); opacity: .9; pointer-events: none;
  background:
    radial-gradient(48% 60% at 30% 40%, rgba(255,181,124,.55), transparent 70%),
    radial-gradient(52% 66% at 68% 46%, rgba(21,174,192,.6), transparent 72%),
    radial-gradient(60% 70% at 50% 78%, rgba(10,90,122,.55), transparent 74%),
    radial-gradient(40% 54% at 82% 30%, rgba(134,225,211,.5), transparent 70%);
  background-size: 200% 200%; animation: rm-drift 22s ease-in-out infinite;
}
@keyframes rm-drift {
  0%,100% { background-position: 0% 50%, 100% 50%, 50% 100%, 100% 0%; }
  50%     { background-position: 30% 40%, 70% 60%, 40% 90%, 80% 20%; }
}
.rm-hero > * { position: relative; z-index: 1; }
.rm-hero .rm-eyebrow { margin-bottom: 18px; }
.rm-hero h1 {
  font-size: clamp(2.5rem, 6vw, 4.4rem); font-weight: 700; letter-spacing: -.035em;
  line-height: 1.02; text-wrap: balance; margin: 0 auto; max-width: 14ch; color: var(--rm-ink);
}
.rm-hero h1 .rm-grad {
  background: linear-gradient(100deg, var(--rm-sea-deep), var(--rm-sea-aqua) 55%, var(--rm-dawn));
  -webkit-background-clip: text; background-clip: text; color: transparent;
}
.rm-lede { margin: 22px auto 0; max-width: 46ch; font-size: 1.2rem; color: var(--rm-muted); text-wrap: balance; }

/* search */
.rm-search { margin: 38px auto 0; max-width: 660px; }
.rm-searchbox {
  display: flex; align-items: center; gap: 10px; background: var(--rm-surface);
  border: 1px solid var(--rm-line); border-radius: 18px; padding: 10px 10px 10px 20px;
  box-shadow: var(--rm-shadow-lg); transition: border-color .18s ease, box-shadow .18s ease;
}
.rm-searchbox:focus-within { border-color: var(--rm-sea-aqua); box-shadow: var(--rm-shadow-lg), 0 0 0 4px rgba(21,174,192,.16); }
.rm-searchbox .rm-mag { flex: none; color: var(--rm-sea-deep); display: flex; }
.rm-searchbox input {
  flex: 1; border: 0; outline: 0; background: transparent; font-family: var(--rm-font);
  font-size: 1.12rem; color: var(--rm-ink); min-width: 0; padding: 8px 0;
}
.rm-searchbox input::placeholder { color: #90A6B5; }
.rm-searchbox .rm-btn-primary { flex: none; }
.rm-mic {
  flex: none; display: grid; place-items: center; width: 42px; height: 42px;
  border: 0; border-radius: 12px; background: transparent; color: var(--rm-sea-deep);
  cursor: pointer; transition: background .15s ease, color .15s ease;
}
.rm-mic:hover { background: rgba(21,174,192,.12); }
.rm-mic.rm-listening { background: var(--rm-coral); color: #fff; animation: rm-pulse 1.4s ease-in-out infinite; }
@keyframes rm-pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(255,106,69,.5); }
  50%      { box-shadow: 0 0 0 9px rgba(255,106,69,0); }
}
@media (prefers-reduced-motion: reduce) { .rm-mic.rm-listening { animation: none; } }
.rm-searchbox .rm-btn-primary[aria-busy="true"] { opacity: .7; pointer-events: none; }
.rm-examples { display: flex; flex-wrap: wrap; justify-content: center; gap: 8px; margin-top: 18px; }
.rm-chip {
  font-family: var(--rm-font); font-size: .88rem; font-weight: 500; color: var(--rm-muted);
  background: var(--rm-surface); border: 1px solid var(--rm-line); border-radius: 999px;
  padding: 7px 14px; cursor: pointer; transition: color .15s, border-color .15s, transform .15s;
}
.rm-chip:hover { color: var(--rm-sea-deep); border-color: var(--rm-sea-aqua); transform: translateY(-1px); }

.rm-understood {
  margin: 30px auto 0; max-width: 660px; background: var(--rm-surface); border: 1px solid var(--rm-line);
  border-radius: 16px; padding: 16px 18px; box-shadow: var(--rm-shadow); text-align: left;
}
.rm-understood .rm-label { font-size: .74rem; font-weight: 600; letter-spacing: .13em; text-transform: uppercase; color: var(--rm-muted); }
.rm-understood .rm-row { display: flex; align-items: center; gap: 10px; margin-top: 10px; flex-wrap: wrap; }
.rm-understood .rm-q { font-weight: 600; color: var(--rm-ink); }
.rm-understood .rm-arrow { color: var(--rm-sea-aqua); font-weight: 700; }
.rm-tag {
  font-size: .82rem; font-weight: 600; border-radius: 8px; padding: 5px 10px;
  background: rgba(21,174,192,.1); color: var(--rm-sea-deep); border: 1px solid rgba(21,174,192,.22);
  font-variant-numeric: tabular-nums;
}
.rm-tag.rm-warm { background: rgba(255,106,69,.1); color: var(--rm-coral-ink); border-color: rgba(255,106,69,.24); }

/* sections */
.rm-band { padding: 76px 0; }
.rm-band-head { text-align: center; max-width: 40ch; margin: 0 auto 44px; }
.rm-band-head h2 { font-size: clamp(1.7rem, 3.4vw, 2.4rem); font-weight: 700; letter-spacing: -.025em; text-wrap: balance; color: var(--rm-ink); }
.rm-band-head p { margin-top: 12px; color: var(--rm-muted); font-size: 1.1rem; }

.rm-cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
.rm-card { background: var(--rm-surface); border: 1px solid var(--rm-line); border-radius: 18px; overflow: hidden; box-shadow: var(--rm-shadow); transition: transform .18s ease, box-shadow .18s ease; }
.rm-card:hover { transform: translateY(-3px); box-shadow: var(--rm-shadow-lg); }
.rm-card .rm-top { height: 132px; position: relative; }
.rm-card .rm-top span { position: absolute; left: 14px; top: 12px; font-size: .72rem; font-weight: 700; letter-spacing: .04em; text-transform: uppercase; color: #fff; background: rgba(7,38,59,.34); padding: 4px 9px; border-radius: 7px; }
.rm-card .rm-cbody { padding: 18px; }
.rm-card h3 { font-size: 1.15rem; font-weight: 700; letter-spacing: -.01em; color: var(--rm-ink); }
.rm-card .rm-meta { color: var(--rm-muted); font-size: .94rem; margin-top: 4px; }
.rm-card .rm-price { margin-top: 14px; display: flex; align-items: baseline; gap: 6px; }
.rm-card .rm-price b { font-size: 1.35rem; font-weight: 700; font-variant-numeric: tabular-nums; letter-spacing: -.02em; }
.rm-card .rm-price span { color: var(--rm-muted); font-size: .85rem; }

.rm-feats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 30px; }
.rm-feat .rm-ic { width: 42px; height: 42px; border-radius: 11px; display: grid; place-items: center; margin-bottom: 16px; background: linear-gradient(135deg, rgba(21,174,192,.16), rgba(10,90,122,.12)); color: var(--rm-sea-deep); }
.rm-feat h3 { font-size: 1.15rem; font-weight: 700; letter-spacing: -.01em; color: var(--rm-ink); }
.rm-feat p { margin-top: 8px; color: var(--rm-muted); font-size: .98rem; }
.rm-divider { height: 1px; background: var(--rm-line); }

.rm-reveal { opacity: 0; transform: translateY(14px); }
.rm-reveal.rm-in { opacity: 1; transform: none; transition: opacity .6s ease, transform .6s ease; }
@media (prefers-reduced-motion: reduce) {
  .rm-glow { animation: none; }
  .rm-reveal { opacity: 1; transform: none; transition: none; }
}
.rm-home :focus-visible { outline: 3px solid rgba(21,174,192,.5); outline-offset: 2px; border-radius: 6px; }

@media (max-width: 760px) {
  .rm-cards, .rm-feats { grid-template-columns: 1fr; }
  .rm-searchbox .rm-btn-primary span { display: none; }
  .rm-hero { padding-top: 56px; }
}
