@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&family=Zen+Kaku+Gothic+New:wght@400;500;700;900&display=swap');
/* 未病レーダー LP v2: mobile-first, isolated styles */
:root {
  --mr2-bg: #f6f6f1;
  --mr2-panel: #ffffff;
  --mr2-panel-warm: #fbfcf8;
  --mr2-mint: #edf3ee;
  --mr2-mint-2: #e2f1ea;
  --mr2-line: #d3e1d5;
  --mr2-line-soft: #cfe0d3;
  --mr2-green: #5c9f88;
  --mr2-green-deep: #355f52;
  --mr2-green-ink: #255f4f;
  --mr2-amber: #f0b43f;
  --mr2-amber-deep: #9a5f08;
  --mr2-amber-soft: #ffedb8;
  --mr2-amber-pale: #fff5df;
  --mr2-amber-rgb: 240, 180, 63;
  --mr2-orange: #e8943b;
  --mr2-text: #101827;
  --mr2-soft: #536477;
  --mr2-muted: #8b99a8;
  --mr2-shadow: 0 18px 42px -30px rgba(31, 52, 44, .38);
  --mr2-shadow-card: 0 14px 28px -24px rgba(31, 52, 44, .32);
}

.mr2,
.mr2 * {
  box-sizing: border-box;
}

.mr2 {
  color: var(--mr2-text);
  background:
    radial-gradient(circle at 88% 2%, rgba(var(--mr2-amber-rgb), .23), transparent 28rem),
    radial-gradient(circle at 10% 11%, rgba(92, 159, 136, .13), transparent 22rem),
    var(--mr2-bg);
  overflow: hidden;
  font-family: -apple-system, BlinkMacSystemFont, "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Yu Gothic", "YuGothic", "Noto Sans JP", sans-serif;
}

.mr2 img {
  max-width: 100%;
  height: auto;
  display: block;
}

.mr2 a {
  color: inherit;
  text-decoration: none;
}

.mr2-wrap {
  width: min(100% - 32px, 1080px);
  margin: 0 auto;
}

.mr2-section {
  padding: 54px 0;
  position: relative;
}

.mr2-kicker {
  margin: 0 0 10px;
  color: var(--mr2-green-deep);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .18em;
  text-transform: uppercase;
}



/* v24 hero kicker pill
   - ヒーロー上部の「未病レーダー」を、他セクションと揃う日本語ピルに調整。 */
.mr2 .mr2-hero-copy > .mr2-kicker {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  width: fit-content;
  margin: 0 0 18px;
  padding: 10px 18px;
  border-radius: 999px;
  border: 1px solid rgba(53, 95, 82, .12);
  background: linear-gradient(180deg, rgba(255,255,255,.94), rgba(247,249,245,.92));
  box-shadow:
    0 12px 24px -20px rgba(31, 50, 44, .28),
    inset 0 1px 0 rgba(255,255,255,.88);
  color: var(--mr2-green-deep);
  font-size: 15px;
  font-weight: 800;
  letter-spacing: .01em;
  text-transform: none;
}

.mr2 .mr2-hero-copy > .mr2-kicker::before {
  content: "";
  width: 9px;
  height: 9px;
  flex: 0 0 auto;
  border-radius: 999px;
  background: #D8A63A;
  box-shadow:
    0 0 0 6px rgba(216, 166, 58, .14),
    inset 0 1px 0 rgba(255,255,255,.46);
}
.mr2 h1,
.mr2 h2,
.mr2 h3,
.mr2 p {
  margin-top: 0;
}

.mr2 h1 {
  font-size: clamp(32px, 9.4vw, 60px);
  line-height: 1.12;
  letter-spacing: -.055em;
  color: var(--mr2-text);
  margin-bottom: 18px;
}

.mr2 h2 {
  font-size: clamp(25px, 7vw, 44px);
  line-height: 1.18;
  letter-spacing: -.045em;
  color: var(--mr2-text);
  margin-bottom: 14px;
}

.mr2 h3 {
  font-size: 18px;
  line-height: 1.38;
  letter-spacing: -.02em;
  margin-bottom: 8px;
}

.mr2 p {
  line-height: 1.82;
}

.mr2-lead {
  font-size: 16px;
  line-height: 1.9;
  color: var(--mr2-text);
  margin-bottom: 10px;
}

.mr2-lead strong {
  color: var(--mr2-green-ink);
  background: linear-gradient(transparent 62%, rgba(var(--mr2-amber-rgb), .18) 0);
  font-weight: 850;
}

.mr2-body,
.mr2-section-head p {
  color: var(--mr2-soft);
  font-size: 14px;
}

.mr2-section-head {
  margin-bottom: 24px;
}

.mr2-section-head p {
  max-width: 720px;
  margin-bottom: 0;
}

.mr2-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  border-radius: 999px;
  padding: 13px 18px;
  font-size: 14px;
  font-weight: 800;
  line-height: 1.35;
  transition: transform .18s ease, box-shadow .18s ease, background .18s ease;
}

.mr2-btn:active {
  transform: translateY(1px);
}

.mr2-btn-main {
  color: #fff;
  background: linear-gradient(135deg, var(--mr2-green-ink), var(--mr2-green));
  box-shadow: 0 16px 30px -18px rgba(37, 95, 79, .65);
}

.mr2-btn-sub {
  color: var(--mr2-green-ink);
  background: rgba(255,255,255,.74);
  border: 1px solid var(--mr2-line);
}

/* Hero */
.mr2-hero {
  position: relative;
  padding: 34px 0 40px;
  min-height: min(760px, auto);
}

.mr2-orbit {
  position: absolute;
  pointer-events: none;
  opacity: .9;
}

.mr2-orbit img {
  width: 100%;
}

.mr2-orbit-hero {
  width: 270px;
  right: -74px;
  top: 42px;
  opacity: .72;
  transform: rotate(-12deg);
}

.mr2-hero-grid {
  display: grid;
  gap: 30px;
  align-items: center;
  position: relative;
  z-index: 1;
}

.mr2-actions {
  display: grid;
  gap: 10px;
  margin: 22px 0 13px;
}

.mr2-mini-notes {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  color: var(--mr2-green-deep);
  font-size: 11px;
  font-weight: 750;
}

.mr2-mini-notes span {
  padding: 7px 10px;
  border: 1px solid rgba(53, 95, 82, .14);
  border-radius: 999px;
  background: rgba(255,255,255,.68);
}

.mr2-hero-visual {
  position: relative;
  min-height: 390px;
}

.mr2-phone-stack {
  position: relative;
  width: min(82vw, 330px);
  margin: 0 auto;
  min-height: 398px;
}

.mr2-phone {
  position: absolute;
  overflow: hidden;
  border-radius: 30px;
  background: #fff;
  border: 1px solid rgba(53, 95, 82, .18);
  box-shadow: 0 26px 46px -28px rgba(17, 24, 39, .62);
}

.mr2-phone img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.mr2-phone-main {
  width: 230px;
  height: 382px;
  left: 50%;
  top: 6px;
  transform: translateX(-50%);
  z-index: 3;
}

.mr2-phone-back {
  width: 148px;
  height: 266px;
  opacity: .78;
  z-index: 2;
  filter: saturate(.95);
}

.mr2-phone-left {
  left: -2px;
  top: 82px;
  transform: rotate(-7deg);
}

.mr2-phone-right {
  right: -4px;
  top: 118px;
  transform: rotate(6deg);
}

.mr2-animal-float {
  position: absolute;
  z-index: 5;
  width: 74px;
  border-radius: 22px;
  box-shadow: 0 16px 26px -22px rgba(17, 24, 39, .44);
}

.mr2-float-a {
  left: 4px;
  bottom: 32px;
  transform: rotate(-7deg);
}

.mr2-float-b {
  right: 10px;
  top: 28px;
  transform: rotate(7deg);
}

/* Empathy */
.mr2-empathy {
  padding-top: 42px;
}

.mr2-check-list {
  display: grid;
  gap: 10px;
}

.mr2-check-card {
  display: grid;
  grid-template-columns: 28px 1fr;
  align-items: start;
  gap: 10px;
  padding: 14px 14px;
  border-radius: 20px;
  background: rgba(255,255,255,.72);
  border: 1px solid rgba(211, 225, 213, .9);
  box-shadow: var(--mr2-shadow-card);
}

.mr2-check-card span {
  display: grid;
  place-items: center;
  width: 26px;
  height: 26px;
  color: var(--mr2-green-ink);
  background: var(--mr2-mint-2);
  border-radius: 999px;
  font-weight: 900;
}

.mr2-check-card p {
  font-size: 13.5px;
  line-height: 1.65;
  color: var(--mr2-text);
  margin: 1px 0 0;
}

.mr2-soft-message {
  margin: 18px 0 0;
  padding: 16px 18px;
  border-radius: 22px;
  color: var(--mr2-green-deep);
  background: linear-gradient(135deg, rgba(237, 243, 238, .92), rgba(var(--mr2-amber-rgb), .12));
  border: 1px solid rgba(53, 95, 82, .12);
  font-size: 14px;
  font-weight: 750;
  line-height: 1.75;
}

/* Concept */
.mr2-concept-board {
  position: relative;
  border-radius: 32px;
  padding: 16px;
  background:
    radial-gradient(circle at 88% 18%, rgba(var(--mr2-amber-rgb), .26), transparent 10rem),
    radial-gradient(circle at 12% 64%, rgba(92, 159, 136, .14), transparent 12rem),
    rgba(255,255,255,.66);
  border: 1px solid rgba(211, 225, 213, .92);
  box-shadow: var(--mr2-shadow);
  overflow: hidden;
}

.mr2-animal-cloud {
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.mr2-cloud-animal {
  position: absolute;
  width: 44px;
  border-radius: 15px;
  opacity: .34;
  filter: saturate(.94);
}

.mr2-cloud-animal-1 { right: 12px; top: 12px; transform: rotate(9deg); }
.mr2-cloud-animal-2 { left: 22px; top: 42%; transform: rotate(-8deg); }
.mr2-cloud-animal-3 { right: 20px; bottom: 18px; transform: rotate(-6deg); }
.mr2-cloud-animal-4 { left: 48%; top: 10px; transform: rotate(5deg); }
.mr2-cloud-animal-5 { display: none; }
.mr2-cloud-animal-6 { display: none; }

.mr2-pill-panel {
  position: relative;
  z-index: 1;
  border-radius: 24px;
  padding: 14px;
  background: rgba(253, 254, 252, .86);
  border: 1px solid rgba(211, 225, 213, .9);
  backdrop-filter: blur(8px);
}

.mr2-panel-title {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 12px;
}

.mr2-panel-title span {
  color: var(--mr2-green-ink);
  font-size: 15px;
  font-weight: 850;
}

.mr2-panel-title small {
  color: var(--mr2-muted);
  font-size: 11px;
  font-weight: 750;
}

.mr2-icon-row {
  display: flex;
  gap: 10px;
  overflow-x: auto;
  padding: 2px 2px 6px;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
}

.mr2-icon-row::-webkit-scrollbar,
.mr2-step-scroll::-webkit-scrollbar,
.mr2-timeline::-webkit-scrollbar,
.mr2-animal-strip::-webkit-scrollbar {
  display: none;
}

.mr2-icon-chip {
  flex: 0 0 92px;
  min-height: 116px;
  scroll-snap-align: start;
  display: grid;
  justify-items: center;
  align-content: center;
  gap: 6px;
  text-align: center;
  padding: 10px 8px;
  border-radius: 20px;
  background: rgba(246, 246, 241, .72);
  border: 1px solid rgba(211, 225, 213, .76);
}

.mr2-icon-chip img {
  width: 48px;
  height: 48px;
}

.mr2-icon-chip span {
  color: var(--mr2-text);
  font-size: 12px;
  line-height: 1.35;
  font-weight: 820;
}

.mr2-icon-chip small {
  color: var(--mr2-green-deep);
  font-size: 10px;
  font-weight: 750;
}

.mr2-formula {
  position: relative;
  z-index: 1;
  display: grid;
  place-items: center;
  height: 36px;
}

.mr2-formula span {
  display: grid;
  place-items: center;
  width: 34px;
  height: 34px;
  color: var(--mr2-amber-deep);
  background: var(--mr2-amber-soft);
  border-radius: 999px;
  font-size: 20px;
  font-weight: 900;
}

.mr2-result-line {
  position: relative;
  z-index: 1;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 8px;
  margin-top: 14px;
  padding: 13px;
  color: var(--mr2-green-ink);
  background: rgba(237, 243, 238, .84);
  border: 1px solid rgba(53, 95, 82, .12);
  border-radius: 999px;
  font-size: 13px;
  font-weight: 850;
}

.mr2-result-line strong {
  color: var(--mr2-amber-deep);
}

/* Steps */
.mr2-step-scroll {
  display: flex;
  gap: 14px;
  overflow-x: auto;
  padding: 2px 0 8px;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
}

.mr2-step-card {
  flex: 0 0 min(86vw, 330px);
  scroll-snap-align: start;
  display: grid;
  grid-template-rows: auto 1fr;
  gap: 14px;
  padding: 17px;
  border-radius: 28px;
  background: rgba(255,255,255,.8);
  border: 1px solid rgba(211, 225, 213, .88);
  box-shadow: var(--mr2-shadow-card);
}

.mr2-step-num {
  display: inline-flex;
  margin-bottom: 10px;
  padding: 6px 10px;
  border-radius: 999px;
  color: var(--mr2-green-ink);
  background: var(--mr2-mint-2);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .08em;
}

.mr2-step-card p {
  color: var(--mr2-soft);
  font-size: 13px;
  line-height: 1.75;
  margin-bottom: 0;
}

.mr2-step-card figure {
  overflow: hidden;
  border-radius: 22px;
  margin: 0;
  height: 250px;
  background: var(--mr2-bg);
  border: 1px solid rgba(211, 225, 213, .8);
}

.mr2-step-card figure img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top center;
}

.mr2-animal-strip {
  display: flex;
  gap: 10px;
  overflow-x: auto;
  padding: 12px 0 4px;
  -webkit-overflow-scrolling: touch;
}

.mr2-animal-strip div {
  flex: 0 0 78px;
  display: grid;
  justify-items: center;
  gap: 5px;
}

.mr2-animal-strip img {
  width: 58px;
  height: 58px;
  border-radius: 18px;
  object-fit: cover;
  background: #fff;
  border: 1px solid rgba(211, 225, 213, .8);
}

.mr2-animal-strip span {
  color: var(--mr2-soft);
  font-size: 10px;
  font-weight: 750;
  white-space: nowrap;
}

/* Usecase */
.mr2-usecase {
  background: linear-gradient(180deg, rgba(237, 243, 238, .48), rgba(246,246,241,0));
}

.mr2-timeline {
  display: flex;
  gap: 12px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  padding-bottom: 8px;
  -webkit-overflow-scrolling: touch;
}

.mr2-time-card {
  flex: 0 0 min(82vw, 310px);
  scroll-snap-align: start;
  padding: 18px;
  border-radius: 26px;
  background: rgba(255,255,255,.78);
  border: 1px solid rgba(211, 225, 213, .9);
  box-shadow: var(--mr2-shadow-card);
}

.mr2-time-card span {
  color: var(--mr2-amber-deep);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .05em;
}

.mr2-time-card p {
  color: var(--mr2-soft);
  font-size: 13px;
  line-height: 1.78;
  margin-bottom: 0;
}

.mr2-charm {
  margin: 18px 0 0;
  color: var(--mr2-green-deep);
  font-size: 14px;
  line-height: 1.8;
  text-align: center;
  font-weight: 800;
}

/* Trust */
.mr2-trust {
  padding-bottom: 70px;
}

.mr2-trust-card {
  display: grid;
  gap: 14px;
  padding: 18px;
  border-radius: 32px;
  background: rgba(255,255,255,.78);
  border: 1px solid rgba(211,225,213,.9);
  box-shadow: var(--mr2-shadow);
}

.mr2-trust-main p {
  color: var(--mr2-soft);
  font-size: 13.5px;
}

.mr2-trust-notes {
  display: grid;
  gap: 8px;
  margin-top: 14px;
}

.mr2-trust-notes span {
  padding: 10px 12px;
  color: var(--mr2-green-ink);
  background: var(--mr2-mint);
  border-radius: 16px;
  font-size: 12px;
  font-weight: 800;
}

.mr2-free-box {
  padding: 16px;
  border-radius: 26px;
  background:
    radial-gradient(circle at 90% 0%, rgba(var(--mr2-amber-rgb), .29), transparent 9rem),
    var(--mr2-panel-warm);
  border: 1px solid rgba(211,225,213,.8);
}

.mr2-free-box h3 {
  color: var(--mr2-green-ink);
}

.mr2-free-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.mr2-free-grid span {
  display: grid;
  place-items: center;
  min-height: 42px;
  padding: 8px 6px;
  border-radius: 15px;
  color: var(--mr2-text);
  background: rgba(255,255,255,.78);
  border: 1px solid rgba(211,225,213,.84);
  font-size: 12px;
  font-weight: 820;
  text-align: center;
}

.mr2-dev-box {
  margin-top: 14px;
  padding: 13px;
  border-radius: 20px;
  background: rgba(237, 243, 238, .7);
}

.mr2-dev-box p {
  color: var(--mr2-soft);
  font-size: 12px;
  line-height: 1.75;
  margin-bottom: 8px;
}

.mr2-dev-box a {
  color: var(--mr2-green-ink);
  font-size: 12px;
  font-weight: 850;
  text-decoration: underline;
  text-underline-offset: 3px;
}

.mr2-final-cta {
  position: relative;
  margin-top: 18px;
  padding: 30px 18px;
  border-radius: 34px;
  text-align: center;
  background:
    radial-gradient(circle at 20% 10%, rgba(var(--mr2-amber-rgb), .26), transparent 12rem),
    linear-gradient(135deg, rgba(237,243,238,.94), rgba(var(--mr2-amber-rgb), .11));
  border: 1px solid rgba(211,225,213,.9);
  overflow: hidden;
}

.mr2-final-cta img {
  width: 126px;
  margin: 0 auto 2px;
  opacity: .9;
}

.mr2-final-cta h2 {
  font-size: clamp(24px, 7vw, 38px);
}

.mr2-final-cta p {
  color: var(--mr2-soft);
  font-size: 14px;
}

.mr2-final-cta small {
  display: block;
  color: var(--mr2-muted);
  font-size: 11px;
  line-height: 1.6;
  margin-top: 12px;
}

/* Wider screens: still phone-first, just cleaner alignment */
@media (min-width: 760px) {
  .mr2-wrap {
    width: min(100% - 56px, 1080px);
  }

  .mr2-section {
    padding: 76px 0;
  }

  .mr2-hero {
    padding: 64px 0 70px;
  }

  .mr2-hero-grid {
    grid-template-columns: minmax(0, 1fr) 430px;
    gap: 52px;
  }

  .mr2-actions {
    grid-template-columns: max-content max-content;
    align-items: center;
  }

  .mr2-hero-visual {
    min-height: 460px;
  }

  .mr2-phone-stack {
    min-height: 450px;
  }

  .mr2-phone-main {
    width: 270px;
    height: 440px;
  }

  .mr2-phone-back {
    width: 178px;
    height: 316px;
  }

  .mr2-check-list {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .mr2-concept-board {
    padding: 24px;
  }

  .mr2-icon-chip {
    flex-basis: 112px;
  }

  .mr2-step-card {
    flex-basis: 340px;
  }

  .mr2-trust-card {
    grid-template-columns: 1.15fr .85fr;
    gap: 22px;
    padding: 24px;
  }
}

@media (min-width: 1020px) {
  .mr2-step-scroll,
  .mr2-timeline {
    overflow: visible;
  }

  .mr2-step-card {
    flex: 1 1 0;
  }

  .mr2-time-card {
    flex: 1 1 0;
  }
}


/* ===== LP v2 polish pass: app-like typography, cleaner background, better mockup layout ===== */
/* Amber tuning: app itawari-mode inspired richer warm gold; light effects use --mr2-amber-rgb. */
body.mibyo-shell-body,
body.mibyo-shell-body .mibyo-shell,
body.mibyo-shell-body .mibyo-shell * {
  font-family: "Zen Kaku Gothic New", -apple-system, BlinkMacSystemFont, "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Yu Gothic", "YuGothic", "Segoe UI", sans-serif;
}

.mr2 {
  --mr2-bg: #f7f8f4;
  --mr2-panel-warm: #fbfcf7;
  --mr2-mint: #eef5ef;
  --mr2-mint-2: #e4f1ea;
  --mr2-line: rgba(53, 95, 82, .15);
  --mr2-line-soft: rgba(53, 95, 82, .11);
  --mr2-green: #5c9f88;
  --mr2-green-deep: #355f52;
  --mr2-green-ink: #255f4f;
  --mr2-amber: #f0b43f;
  --mr2-amber-deep: #9a5f08;
  --mr2-amber-soft: #ffedb8;
  --mr2-amber-pale: #fff5df;
  --mr2-amber-rgb: 240, 180, 63;
  --mr2-text: #111827;
  --mr2-muted: #647184;
  background:
    radial-gradient(circle at 84% 4%, rgba(var(--mr2-amber-rgb), .18), transparent 26rem),
    radial-gradient(circle at 8% 16%, rgba(92, 159, 136, .11), transparent 24rem),
    linear-gradient(180deg, #f8f9f4 0%, #f5f8f3 46%, #fbfaf4 100%);
  letter-spacing: .01em;
}

.mr2 h1,
.mr2 h2,
.mr2 h3,
.mr2 .mr2-btn,
.mr2 .mr2-mini-notes,
.mr2 .mr2-icon-chip span,
.mr2 .mr2-animal-strip span {
  font-family: "Zen Kaku Gothic New", -apple-system, BlinkMacSystemFont, "Hiragino Sans", "Yu Gothic", sans-serif;
}

.mr2 h1,
.mr2 h2,
.mr2 h3 {
  font-weight: 900;
  letter-spacing: .018em;
}

.mr2-body,
.mr2-lead,
.mr2-section-head p,
.mr2-signal-list li,
.mr2-time-card p,
.mr2-step-card p,
.mr2-trust-card p {
  line-height: 2;
}

.mr2-btn-main,
.mr2 a.mr2-btn-main {
  color: #ffffff !important;
  background: linear-gradient(135deg, #286f5f 0%, #5ca78d 100%);
  box-shadow: 0 18px 38px -22px rgba(37, 95, 79, .62);
}

.mr2-btn-sub,
.mr2 a.mr2-btn-sub {
  color: var(--mr2-text) !important;
}

/* Hero: phone mockup first on mobile, with screenshots no longer cut off */
.mr2-hero {
  padding-top: 26px;
}

.mr2-hero-grid {
  gap: 22px;
}

.mr2-hero-visual {
  order: 1;
  min-height: min(152vw, 625px);
  margin: 0 auto -4px;
  width: min(100%, 420px);
}

.mr2-hero-copy {
  order: 2;
}

.mr2-phone-stack {
  position: relative;
  width: min(94vw, 410px);
  min-height: min(148vw, 610px);
  margin: 0 auto;
}

.mr2-phone {
  background:
    linear-gradient(180deg, rgba(255,255,255,.98), rgba(251,252,247,.96));
  box-shadow:
    0 22px 48px -30px rgba(30, 45, 39, .46),
    0 1px 0 rgba(255,255,255,.98) inset;
  border-color: rgba(53, 95, 82, .14);
}

.mr2-phone-main {
  width: min(64vw, 254px);
  height: min(142vw, 565px);
  left: 50%;
  top: 18px;
  transform: translateX(-50%);
  z-index: 4;
  padding: 7px;
  border-radius: 34px;
}

.mr2-phone-back {
  width: min(44vw, 174px);
  height: min(98vw, 388px);
  opacity: .86;
  z-index: 2;
  padding: 6px;
  border-radius: 28px;
  filter: saturate(.98) contrast(.98);
}

.mr2-phone-left {
  left: 0;
  top: min(25vw, 108px);
  transform: rotate(-7deg) translateX(-4%);
}

.mr2-phone-right {
  right: 0;
  top: min(29vw, 132px);
  transform: rotate(6deg) translateX(4%);
}

.mr2-phone img,
.mr2-step-card figure img {
  object-fit: contain;
  object-position: top center;
  background: linear-gradient(180deg, #ffffff, #fbfcf7);
}

.mr2-animal-float {
  width: 66px;
  border-radius: 22px;
  background: rgba(255,255,255,.86);
  border: 1px solid rgba(53, 95, 82, .11);
  box-shadow: 0 18px 34px -26px rgba(30,45,39,.35);
  padding: 4px;
}

.mr2-float-a {
  left: 4px;
  bottom: min(15vw, 76px);
  transform: rotate(-6deg);
}

.mr2-float-b {
  right: 8px;
  top: min(12vw, 54px);
  transform: rotate(8deg);
}

/* Scroll affordance */
.mr2-scroll-hint {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  margin-top: 12px;
  margin-bottom: 0;
  color: var(--mr2-green-deep);
  font-size: 13px;
  font-weight: 800;
  line-height: 1.4;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(237, 243, 238, .82);
  border: 1px solid rgba(53, 95, 82, .12);
}

.mr2-scroll-hint::after {
  content: "→";
  color: var(--mr2-amber-deep);
  font-weight: 900;
}

/* Concept board: keep animals visible but not messy */
.mr2-concept-board {
  padding: 18px 14px 18px;
  background:
    radial-gradient(circle at 86% 13%, rgba(var(--mr2-amber-rgb), .19), transparent 12rem),
    radial-gradient(circle at 10% 58%, rgba(92, 159, 136, .10), transparent 13rem),
    rgba(255,255,255,.74);
  border-color: rgba(53,95,82,.13);
  overflow: visible;
}

.mr2-animal-cloud {
  pointer-events: none;
}

.mr2-cloud-animal {
  width: 52px;
  opacity: .72;
  border-radius: 18px;
  padding: 3px;
  background: rgba(255,255,255,.72);
  border: 1px solid rgba(53,95,82,.08);
  box-shadow: 0 15px 30px -25px rgba(30,45,39,.28);
  filter: saturate(.98);
}

.mr2-cloud-animal-1 {
  right: 12px;
  top: -22px;
  transform: rotate(8deg);
}

.mr2-cloud-animal-2 {
  left: -8px;
  top: 47%;
  transform: rotate(-7deg);
}

.mr2-cloud-animal-3 {
  right: 6px;
  bottom: -24px;
  transform: rotate(-5deg);
}

.mr2-cloud-animal-4 {
  left: 10px;
  top: -20px;
  transform: rotate(-4deg);
}

.mr2-cloud-animal-5,
.mr2-cloud-animal-6 {
  display: none;
}

.mr2-pill-panel {
  position: relative;
  z-index: 2;
  background: rgba(255,255,255,.82);
  backdrop-filter: blur(10px);
  border-color: rgba(53,95,82,.13);
}

.mr2-formula {
  position: relative;
  z-index: 2;
}

/* horizontal screenshots: make frames taller and show the whole image */
.mr2-step-card {
  flex-basis: min(88vw, 350px);
  background: rgba(255,255,255,.82);
  border-color: rgba(53, 95, 82, .13);
}

.mr2-step-card figure {
  height: min(112vw, 470px);
  background:
    linear-gradient(180deg, rgba(255,255,255,.94), rgba(247,248,244,.92));
  border-color: rgba(53, 95, 82, .12);
}

.mr2-step-scroll,
.mr2-timeline,
.mr2-icon-row {
  scroll-padding-inline: 18px;
}

.mr2-step-scroll::after,
.mr2-timeline::after,
.mr2-icon-row::after {
  content: "";
  flex: 0 0 10px;
}

/* softer panels and bottom CTA */
.mr2-time-card,
.mr2-trust-card,
.mr2-final-card,
.mr2-signal-list li,
.mr2-soft-message {
  background: rgba(255,255,255,.78);
  border-color: rgba(53, 95, 82, .13);
  box-shadow: 0 20px 44px -34px rgba(30,45,39,.32);
}

.mr2-trust-card {
  background:
    radial-gradient(circle at 92% 92%, rgba(92,159,136,.10), transparent 14rem),
    rgba(255,255,255,.78);
}

.mr2-final-card {
  background:
    radial-gradient(circle at 70% 12%, rgba(var(--mr2-amber-rgb), .22), transparent 13rem),
    radial-gradient(circle at 16% 70%, rgba(92, 159, 136, .11), transparent 13rem),
    rgba(255,255,255,.82);
}

@media (min-width: 760px) {
  .mr2-hero-grid {
    grid-template-columns: minmax(320px, .9fr) minmax(360px, 1.1fr);
    gap: 36px;
  }

  .mr2-hero-visual {
    order: 1;
    min-height: 620px;
  }

  .mr2-hero-copy {
    order: 2;
  }

  .mr2-phone-stack {
    min-height: 610px;
  }

  .mr2-phone-main {
    width: 270px;
    height: 600px;
  }

  .mr2-phone-back {
    width: 188px;
    height: 418px;
  }

  .mr2-step-card figure {
    height: 430px;
  }

  .mr2-cloud-animal-5 {
    display: block;
    left: 50%;
    top: -22px;
    transform: translateX(-50%) rotate(5deg);
  }
}

@media (max-width: 420px) {
  .mr2 h1 {
    font-size: clamp(38px, 10.8vw, 48px);
    line-height: 1.17;
  }

  .mr2-hero-visual {
    min-height: 592px;
  }

  .mr2-phone-stack {
    min-height: 578px;
  }

  .mr2-phone-main {
    width: 246px;
    height: 548px;
  }

  .mr2-phone-back {
    width: 160px;
    height: 356px;
  }

  .mr2-phone-left {
    top: 102px;
  }

  .mr2-phone-right {
    top: 128px;
  }

  .mr2-step-card figure {
    height: 425px;
  }
}

/* v2.2 refinement: app URL copy, concept scrollers, notification/free icons */
.mr2 {
  font-family: "Zen Kaku Gothic New", -apple-system, BlinkMacSystemFont, "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Yu Gothic", "YuGothic", "Noto Sans JP", sans-serif;
  background:
    radial-gradient(circle at 91% 0%, rgba(var(--mr2-amber-rgb), .17), transparent 25rem),
    radial-gradient(circle at 73% 13%, rgba(var(--mr2-amber-rgb), .07), transparent 20rem),
    radial-gradient(circle at 8% 8%, rgba(123, 196, 179, .12), transparent 21rem),
    linear-gradient(180deg, #f7f8f3 0%, #f4f7f1 48%, #f8f7f1 100%);
}

.mr2 h1,
.mr2 h2,
.mr2 h3,
.mr2 .mr2-logo-text strong {
  letter-spacing: .01em;
}

.mr2-orbit-hero,
.mr2-animal-cloud,
.mr2-animal-strip {
  display: none !important;
}

.mr2-hero-copy {
  position: relative;
  isolation: isolate;
}

.mr2-copy-orbit {
  position: absolute;
  width: 238px;
  right: -92px;
  top: 28px;
  opacity: .38;
  transform: rotate(-12deg);
  z-index: -1;
  pointer-events: none;
}

.mr2-copy-orbit img { width: 100%; }

.mr2-hero-visual {
  z-index: 2;
}

.mr2-phone-main img {
  object-fit: cover;
  object-position: top center;
}

.mr2-phone-back img {
  object-fit: cover;
  object-position: top center;
}

.mr2-scroll-hint { display: none !important; }

.mr2-swipe-bar {
  width: 72px;
  height: 5px;
  border-radius: 999px;
  margin: 12px auto 0;
  background: rgba(53, 95, 82, .10);
  overflow: hidden;
}

.mr2-swipe-bar span {
  display: block;
  width: 32px;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, rgba(92,159,136,.78), rgba(var(--mr2-amber-rgb), .70));
}

.mr2-swipe-bar-wide {
  margin-top: 16px;
}

.mr2-concept-board {
  overflow: hidden;
  padding: 18px 14px 20px;
}

.mr2-body-panel {
  background:
    radial-gradient(circle at 96% 8%, rgba(var(--mr2-amber-rgb), .10), transparent 11rem),
    rgba(255,255,255,.84);
}

.mr2-concept-subhead {
  margin: 12px 0 12px;
}

.mr2-concept-subhead strong {
  display: block;
  color: var(--mr2-green-ink);
  font-size: 15px;
  font-weight: 900;
  line-height: 1.55;
}

.mr2-concept-subhead small {
  display: block;
  margin-top: 4px;
  color: var(--mr2-soft);
  font-size: 12px;
  font-weight: 700;
  line-height: 1.7;
}

.mr2-concept-subhead-small {
  margin-top: 16px;
  margin-bottom: 9px;
}

.mr2-concept-subhead-small strong {
  font-size: 13px;
  color: var(--mr2-soft);
}

.mr2-animal-row {
  display: flex;
  gap: 10px;
  overflow-x: auto;
  overscroll-behavior-x: contain;
  scroll-snap-type: x proximity;
  padding: 3px 4px 5px;
  margin: 0 -4px;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}

.mr2-animal-row::-webkit-scrollbar,
.mr2-icon-row::-webkit-scrollbar,
.mr2-step-scroll::-webkit-scrollbar,
.mr2-timeline::-webkit-scrollbar { display: none; }

.mr2-animal-row::after {
  content: "";
  flex: 0 0 8px;
}

.mr2-animal-chip {
  flex: 0 0 104px;
  min-height: 142px;
  scroll-snap-align: start;
  border-radius: 22px;
  border: 1px solid rgba(53,95,82,.12);
  background:
    linear-gradient(180deg, rgba(255,255,255,.98), rgba(249,250,246,.92));
  box-shadow: 0 14px 28px -26px rgba(31,52,44,.32);
  padding: 10px 9px 11px;
  text-align: center;
}

.mr2-animal-chip img {
  width: 70px;
  height: 58px;
  object-fit: contain;
  margin: 0 auto 8px;
  filter: saturate(.96) contrast(.99);
}

.mr2-animal-chip span {
  display: block;
  color: var(--mr2-text);
  font-size: 12px;
  font-weight: 900;
  line-height: 1.35;
}

.mr2-animal-chip small {
  display: block;
  margin-top: 5px;
  color: var(--mr2-soft);
  font-size: 9.5px;
  font-weight: 800;
  line-height: 1.45;
}

.mr2-icon-row-compact .mr2-icon-chip {
  flex-basis: 112px;
  min-height: 138px;
  padding: 12px 10px;
}

.mr2-icon-row-compact .mr2-icon-chip img {
  width: 42px;
  height: 42px;
}

.mr2-icon-row-compact .mr2-icon-chip span {
  font-size: 11.5px;
  line-height: 1.45;
}

.mr2-icon-row-compact .mr2-icon-chip small {
  font-size: 10px;
}

.mr2-result-line {
  gap: 7px;
  flex-wrap: wrap;
  justify-content: center;
  padding: 12px 12px;
  line-height: 1.6;
}

.mr2-result-line span {
  white-space: normal;
}

.mr2-result-line strong {
  color: var(--mr2-amber-deep);
}

.mr2-time-card span::before {
  content: "";
  display: inline-block;
  width: 8px;
  height: 8px;
  margin-right: 7px;
  border-radius: 999px;
  background: currentColor;
  opacity: .45;
  vertical-align: 1px;
}

.mr2-free-grid {
  grid-template-columns: 1fr;
  gap: 10px;
}

.mr2-free-grid span {
  min-height: 54px;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 10px;
  padding: 9px 12px;
  text-align: left;
  color: var(--mr2-text);
  background: rgba(255,255,255,.84);
}

.mr2-free-grid span img {
  width: 34px;
  height: 34px;
  flex: 0 0 auto;
}

.mr2-free-grid span b {
  font-size: 13px;
  font-weight: 900;
  line-height: 1.45;
}

@media (min-width: 460px) {
  .mr2-free-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 420px) {
  .mr2-copy-orbit {
    width: 212px;
    right: -106px;
    top: 34px;
    opacity: .32;
  }

  .mr2-animal-chip {
    flex-basis: 100px;
  }
}


/* v2.4 refinement: replace swipe bars with right-edge fade + clipped next card */
.mr2-swipe-bar {
  display: none !important;
}

.mr2-animal-row,
.mr2-icon-row,
.mr2-step-scroll,
.mr2-timeline {
  -webkit-mask-image: linear-gradient(90deg, #000 0%, #000 calc(100% - 44px), rgba(0, 0, 0, 0) 100%);
  mask-image: linear-gradient(90deg, #000 0%, #000 calc(100% - 44px), rgba(0, 0, 0, 0) 100%);
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-size: 100% 100%;
  mask-size: 100% 100%;
}

.mr2-animal-row,
.mr2-icon-row {
  padding-right: 52px !important;
  margin-right: -14px !important;
}

.mr2-step-scroll,
.mr2-timeline {
  padding-right: 56px !important;
  margin-right: -18px !important;
}

.mr2-animal-row::after,
.mr2-icon-row::after,
.mr2-step-scroll::after,
.mr2-timeline::after {
  flex: 0 0 22px !important;
}

@media (min-width: 720px) {
  .mr2-animal-row,
  .mr2-icon-row,
  .mr2-step-scroll,
  .mr2-timeline {
    -webkit-mask-image: none;
    mask-image: none;
    margin-right: 0 !important;
  }
}

/* v2.5 concept result refinement: body x weather => forecast, friendly explanations, notification callout */
.mr2-concept-board {
  padding-bottom: 22px;
}

.mr2-concept-subhead small {
  max-width: 34em;
}

.mr2-weather-note {
  margin-top: 2px;
}

.mr2-forecast-result-card {
  position: relative;
  z-index: 2;
  margin: 18px 0 0;
  border-radius: 26px;
  padding: 17px 16px 16px;
  text-align: center;
  border: 1px solid rgba(53, 95, 82, .13);
  background:
    radial-gradient(circle at 92% 14%, rgba(var(--mr2-amber-rgb), .22), transparent 9rem),
    radial-gradient(circle at 8% 92%, rgba(92, 159, 136, .13), transparent 10rem),
    rgba(255, 255, 255, .84);
  box-shadow:
    0 20px 44px -34px rgba(30, 45, 39, .30),
    0 1px 0 rgba(255,255,255,.92) inset;
}

.mr2-result-formula {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  max-width: 100%;
  margin: 0 auto 10px;
  padding: 7px 11px;
  border-radius: 999px;
  background: rgba(237, 243, 238, .76);
  border: 1px solid rgba(53, 95, 82, .11);
  color: var(--mr2-green-deep);
  font-size: 12px;
  font-weight: 900;
  line-height: 1.35;
  white-space: nowrap;
}

.mr2-result-formula b {
  color: var(--mr2-amber-deep);
  font-size: 14px;
  line-height: 1;
}

.mr2-forecast-result-card > strong {
  display: block;
  color: var(--mr2-text);
  font-size: clamp(22px, 6.4vw, 28px);
  font-weight: 900;
  line-height: 1.35;
  letter-spacing: .02em;
}

.mr2-forecast-result-card p {
  margin: 8px auto 0;
  color: var(--mr2-soft);
  font-size: 13px;
  font-weight: 800;
  line-height: 1.8;
}

.mr2-mode-tags {
  display: flex;
  justify-content: center;
  gap: 7px;
  flex-wrap: wrap;
  margin-top: 12px;
}

.mr2-mode-tags small {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  border-radius: 999px;
  padding: 4px 10px;
  color: var(--mr2-green-deep);
  background: rgba(237, 243, 238, .78);
  border: 1px solid rgba(53, 95, 82, .11);
  font-size: 11px;
  font-weight: 900;
}

.mr2-notify-callout {
  display: grid;
  grid-template-columns: 46px minmax(0, 1fr);
  gap: 12px;
  align-items: center;
  margin: 0 0 16px;
  padding: 14px;
  border-radius: 26px;
  border: 1px solid rgba(53, 95, 82, .13);
  background:
    radial-gradient(circle at 96% 10%, rgba(var(--mr2-amber-rgb), .20), transparent 9rem),
    rgba(255, 255, 255, .78);
  box-shadow: 0 18px 38px -32px rgba(30,45,39,.28);
}

.mr2-notify-callout img {
  width: 46px;
  height: 46px;
  object-fit: contain;
}

.mr2-notify-callout p {
  margin: 0;
}

.mr2-notify-callout strong,
.mr2-notify-callout span {
  display: block;
}

.mr2-notify-callout strong {
  color: var(--mr2-text);
  font-size: 14px;
  font-weight: 900;
  line-height: 1.55;
}

.mr2-notify-callout span {
  margin-top: 3px;
  color: var(--mr2-soft);
  font-size: 12px;
  font-weight: 750;
  line-height: 1.75;
}

@media (max-width: 360px) {
  .mr2-result-formula {
    font-size: 11px;
    gap: 6px;
    padding-inline: 9px;
  }

  .mr2-notify-callout {
    grid-template-columns: 40px minmax(0, 1fr);
  }

  .mr2-notify-callout img {
    width: 40px;
    height: 40px;
  }
}

/* v2.6 concept output card: body x weather = forecast */
.mr2-formula-equal {
  margin-top: 2px;
  margin-bottom: 2px;
}

.mr2-formula-equal span {
  color: #2F6F5F;
  background: linear-gradient(180deg, rgba(237, 248, 243, .98), rgba(226, 240, 233, .94));
  border: 1px solid rgba(47, 111, 95, .16);
  box-shadow: 0 12px 24px -18px rgba(35, 70, 60, .32);
}

.mr2-result-eyebrow {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 28px;
  margin: 0 auto 8px;
  padding: 4px 11px;
  border-radius: 999px;
  color: #2F6F5F;
  background: rgba(237, 248, 243, .86);
  border: 1px solid rgba(47, 111, 95, .12);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .08em;
}

.mr2-mode-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
  margin-top: 14px;
}

.mr2-mode-chip {
  display: grid;
  align-content: center;
  min-height: 72px;
  padding: 10px 7px;
  border-radius: 18px;
  border: 1px solid rgba(53, 95, 82, .12);
  background: rgba(255, 255, 255, .76);
  box-shadow: 0 12px 28px -24px rgba(28, 45, 40, .34), 0 1px 0 rgba(255,255,255,.9) inset;
}

.mr2-mode-chip b {
  display: block;
  font-size: 14px;
  line-height: 1.25;
  font-weight: 950;
  letter-spacing: .02em;
}

.mr2-mode-chip span {
  display: block;
  margin-top: 4px;
  color: rgba(73, 91, 105, .88);
  font-size: 10px;
  line-height: 1.42;
  font-weight: 850;
}

.mr2-mode-stable {
  background: linear-gradient(180deg, rgba(239, 250, 246, .96), rgba(225, 244, 238, .86));
  border-color: rgba(98, 195, 177, .32);
}

.mr2-mode-stable b { color: #2E8270; }

.mr2-mode-care {
  background: linear-gradient(180deg, rgba(var(--mr2-amber-rgb), .08), rgba(var(--mr2-amber-rgb), .18));
  border-color: rgba(var(--mr2-amber-rgb), .36);
}

.mr2-mode-care b { color: #B38318; }

.mr2-mode-guard {
  background: linear-gradient(180deg, rgba(255, 247, 240, .98), rgba(253, 232, 216, .88));
  border-color: rgba(228, 146, 87, .34);
}

.mr2-mode-guard b { color: #B9672B; }

.mr2-care-route {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px solid rgba(53, 95, 82, .10);
}

.mr2-care-route span {
  display: grid;
  justify-items: center;
  gap: 5px;
  min-height: 58px;
  padding: 8px 5px;
  border-radius: 18px;
  background: rgba(255,255,255,.66);
  border: 1px solid rgba(53, 95, 82, .10);
}

.mr2-care-route img {
  width: 30px;
  height: 30px;
}

.mr2-care-route b {
  color: #2F6F5F;
  font-size: 12px;
  line-height: 1.25;
  font-weight: 950;
}

@media (max-width: 360px) {
  .mr2-mode-grid,
  .mr2-care-route {
    gap: 6px;
  }

  .mr2-mode-chip {
    min-height: 68px;
    padding-inline: 5px;
  }

  .mr2-mode-chip b { font-size: 13px; }
  .mr2-mode-chip span { font-size: 9.5px; }

  .mr2-care-route img {
    width: 27px;
    height: 27px;
  }
}
/* v2 JS polish: motion, formula sequence, policy route */
.mr2.mr2-js .mr2-reveal {
  opacity: 0;
  transform: translateY(18px);
  transition:
    opacity .7s cubic-bezier(.22, 1, .36, 1) var(--mr2-reveal-delay, 0ms),
    transform .7s cubic-bezier(.22, 1, .36, 1) var(--mr2-reveal-delay, 0ms);
}

.mr2.mr2-js .mr2-reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.mr2-phone-stack {
  --phone-main-scale: 1;
}

.mr2-phone {
  transition:
    transform .75s cubic-bezier(.22, 1, .36, 1),
    opacity .75s cubic-bezier(.22, 1, .36, 1),
    z-index .75s step-end,
    filter .75s ease;
}

.mr2-phone-stack[data-active="0"] .mr2-phone-main,
.mr2-phone-stack[data-active="1"] .mr2-phone-left,
.mr2-phone-stack[data-active="2"] .mr2-phone-right {
  opacity: 1;
  z-index: 4;
  filter: saturate(1) contrast(1);
}

.mr2-phone-stack[data-active="1"] .mr2-phone-main,
.mr2-phone-stack[data-active="2"] .mr2-phone-main {
  opacity: .74;
  z-index: 2;
  transform: translateX(-50%) scale(.86) rotate(0deg);
}

.mr2-phone-stack[data-active="1"] .mr2-phone-left {
  transform: translateX(82px) translateY(-56px) scale(1.18) rotate(-2deg);
}

.mr2-phone-stack[data-active="2"] .mr2-phone-right {
  transform: translateX(-82px) translateY(-88px) scale(1.22) rotate(2deg);
}

.mr2-phone-stack[data-active="1"] .mr2-phone-right {
  opacity: .58;
  transform: rotate(8deg) translateY(10px) scale(.94);
}

.mr2-phone-stack[data-active="2"] .mr2-phone-left {
  opacity: .58;
  transform: rotate(-9deg) translateY(18px) scale(.94);
}

.mr2.mr2-js .mr2-concept-board > * {
  transition:
    opacity .62s cubic-bezier(.22, 1, .36, 1),
    transform .62s cubic-bezier(.22, 1, .36, 1);
}

.mr2.mr2-js .mr2-concept-board:not(.is-sequenced) > * {
  opacity: 0;
  transform: translateY(16px) scale(.985);
}

.mr2.mr2-js .mr2-concept-board.is-sequenced > *:nth-child(1) { transition-delay: 0ms; }
.mr2.mr2-js .mr2-concept-board.is-sequenced > *:nth-child(2) { transition-delay: 180ms; }
.mr2.mr2-js .mr2-concept-board.is-sequenced > *:nth-child(3) { transition-delay: 340ms; }
.mr2.mr2-js .mr2-concept-board.is-sequenced > *:nth-child(4) { transition-delay: 500ms; }
.mr2.mr2-js .mr2-concept-board.is-sequenced > *:nth-child(5) { transition-delay: 680ms; }

.mr2-forecast-result-card {
  background:
    radial-gradient(circle at 86% 10%, rgba(var(--mr2-amber-rgb), .23), transparent 9rem),
    linear-gradient(135deg, rgba(255,255,255,.88), rgba(248, 251, 247, .88));
}

.mr2-forecast-result-card > strong {
  display: block;
  color: var(--mr2-green-ink);
  font-size: 20px;
  line-height: 1.35;
  letter-spacing: -.02em;
  margin-bottom: 7px;
}

.mr2-forecast-result-card > p {
  color: var(--mr2-soft);
  font-size: 13px;
  line-height: 1.72;
  margin-bottom: 14px;
}

.mr2-mode-grid {
  margin-bottom: 14px;
}

.mr2-mode-stable {
  background: linear-gradient(135deg, rgba(216, 239, 229, .94), rgba(255,255,255,.82));
  border-color: rgba(75, 167, 139, .28);
}

.mr2-mode-care {
  background: linear-gradient(135deg, rgba(var(--mr2-amber-rgb), .20), rgba(255,255,255,.82));
  border-color: rgba(var(--mr2-amber-rgb), .42);
}

.mr2-mode-guard {
  background: linear-gradient(135deg, rgba(250, 224, 205, .96), rgba(255,255,255,.82));
  border-color: rgba(227, 137, 73, .34);
}

.mr2-policy-mini {
  margin: 12px 0 14px;
  padding: 12px;
  border-radius: 22px;
  background: rgba(246, 246, 241, .64);
  border: 1px solid rgba(211, 225, 213, .72);
}

.mr2-mini-title {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 9px;
}

.mr2-mini-title span {
  color: var(--mr2-green-ink);
  font-size: 13px;
  font-weight: 900;
}

.mr2-mini-title small {
  color: var(--mr2-muted);
  font-size: 10px;
  font-weight: 780;
}

.mr2-policy-row {
  position: relative;
  display: flex;
  gap: 9px;
  overflow-x: auto;
  padding: 1px 28px 4px 1px;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
}

.mr2-policy-row::-webkit-scrollbar {
  display: none;
}

.mr2-policy-row::after {
  content: "";
  position: sticky;
  right: -29px;
  flex: 0 0 34px;
  width: 34px;
  margin-left: -34px;
  pointer-events: none;
  background: linear-gradient(90deg, rgba(246,246,241,0), rgba(246,246,241,.98));
  transition: opacity .2s ease;
}

.mr2-policy-row.is-at-end::after {
  opacity: 0;
}

.mr2-policy-row span {
  flex: 0 0 104px;
  scroll-snap-align: start;
  display: grid;
  justify-items: center;
  align-content: start;
  gap: 4px;
  min-height: 106px;
  padding: 10px 7px;
  border-radius: 18px;
  background: rgba(255,255,255,.82);
  border: 1px solid rgba(211,225,213,.82);
  text-align: center;
}

.mr2-policy-row img {
  width: 38px;
  height: 38px;
  object-fit: contain;
}

.mr2-policy-row b {
  color: var(--mr2-text);
  font-size: 12px;
  line-height: 1.2;
}

.mr2-policy-row small {
  color: var(--mr2-soft);
  font-size: 9.5px;
  line-height: 1.35;
  font-weight: 720;
}

.mr2-care-route span {
  min-height: 82px;
}

.mr2-care-route small {
  display: block;
  color: var(--mr2-muted);
  font-size: 9.5px;
  line-height: 1.2;
  font-weight: 760;
}

.mr2-formula-equal span {
  background: linear-gradient(135deg, rgba(237,243,238,.96), rgba(var(--mr2-amber-rgb), .15));
  color: var(--mr2-green-ink);
}

@media (prefers-reduced-motion: reduce) {
  .mr2 *,
  .mr2 *::before,
  .mr2 *::after {
    animation-duration: .001ms !important;
    animation-iteration-count: 1 !important;
    scroll-behavior: auto !important;
    transition-duration: .001ms !important;
  }
}

@media (min-width: 760px) {
  .mr2-policy-row {
    overflow: visible;
    flex-wrap: wrap;
    padding-right: 1px;
  }

  .mr2-policy-row::after {
    content: none;
  }

  .mr2-policy-row span {
    flex: 1 1 96px;
  }
}


/* v2.7 concept motion polish: scroll staged explanation */
.mr2-concept-motion {
  --mr2-concept-progress: 0;
}

.mr2-concept-stage-nav {
  position: relative;
  z-index: 5;
  display: flex;
  gap: 7px;
  overflow-x: auto;
  padding: 0 1px 13px;
  margin-bottom: 1px;
  scroll-snap-type: x proximity;
  -webkit-overflow-scrolling: touch;
}

.mr2-concept-stage-nav::-webkit-scrollbar {
  display: none;
}

.mr2-concept-stage-nav span {
  flex: 0 0 auto;
  scroll-snap-align: start;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 7px 9px 7px 7px;
  border-radius: 999px;
  color: rgba(53, 95, 82, .62);
  background: rgba(255, 255, 255, .62);
  border: 1px solid rgba(211, 225, 213, .72);
  box-shadow: 0 10px 22px -20px rgba(32, 52, 45, .3);
  transition:
    color .35s ease,
    background .35s ease,
    border-color .35s ease,
    transform .35s cubic-bezier(.22, 1, .36, 1);
}

.mr2-concept-stage-nav i {
  display: grid;
  place-items: center;
  width: 19px;
  height: 19px;
  border-radius: 999px;
  color: #fff;
  background: rgba(92, 159, 136, .54);
  font-size: 10px;
  font-style: normal;
  font-weight: 950;
  line-height: 1;
}

.mr2-concept-stage-nav b {
  font-size: 10px;
  font-weight: 850;
  line-height: 1;
  white-space: nowrap;
}

.mr2-concept-stage-nav span.is-active {
  color: var(--mr2-green-ink);
  background: rgba(237, 243, 238, .96);
  border-color: rgba(92, 159, 136, .28);
  transform: translateY(-1px);
}

.mr2-concept-stage-nav span.is-active i {
  background: var(--mr2-green);
}

.mr2-concept-stage-nav span.is-complete {
  color: rgba(53, 95, 82, .75);
}

.mr2-concept-stage-nav span.is-complete i {
  background: rgba(var(--mr2-amber-rgb), .78);
}

.mr2-concept-motion::before {
  content: "";
  position: absolute;
  left: 18px;
  top: 58px;
  bottom: 20px;
  width: 2px;
  border-radius: 999px;
  background:
    linear-gradient(
      180deg,
      rgba(92, 159, 136, .78),
      rgba(var(--mr2-amber-rgb), .66),
      rgba(227, 137, 73, .58)
    );
  transform: scaleY(var(--mr2-concept-progress));
  transform-origin: top;
  opacity: .38;
  transition: transform .15s linear;
  z-index: 0;
}

.mr2-concept-motion::after {
  content: "";
  position: absolute;
  inset: -35% -35% auto auto;
  width: 220px;
  height: 220px;
  pointer-events: none;
  border-radius: 999px;
  background: radial-gradient(circle, rgba(var(--mr2-amber-rgb), .29), rgba(var(--mr2-amber-rgb), 0) 62%);
  transform:
    translate3d(
      calc((var(--mr2-concept-progress) - .5) * -24px),
      calc(var(--mr2-concept-progress) * 52px),
      0
    )
    scale(calc(.92 + var(--mr2-concept-progress) * .14));
  opacity: .75;
  z-index: 0;
}

.mr2-concept-motion > .mr2-pill-panel,
.mr2-concept-motion > .mr2-formula,
.mr2-concept-motion > .mr2-forecast-result-card {
  position: relative;
  z-index: 2;
}

.mr2.mr2-js .mr2-concept-motion.is-sequenced > .mr2-pill-panel,
.mr2.mr2-js .mr2-concept-motion.is-sequenced > .mr2-formula,
.mr2.mr2-js .mr2-concept-motion.is-sequenced > .mr2-forecast-result-card {
  filter: saturate(.88);
  transform: translateY(0) scale(.985);
  transition:
    opacity .5s ease,
    transform .5s cubic-bezier(.22, 1, .36, 1),
    filter .5s ease,
    box-shadow .5s ease,
    border-color .5s ease;
}

.mr2.mr2-js .mr2-concept-motion.is-sequenced > .mr2-pill-panel.is-step-active,
.mr2.mr2-js .mr2-concept-motion.is-sequenced > .mr2-forecast-result-card.is-step-active {
  filter: saturate(1.04);
  transform: translateY(-2px) scale(1);
  border-color: rgba(92, 159, 136, .32);
  box-shadow:
    0 26px 54px -38px rgba(37, 95, 79, .34),
    0 1px 0 rgba(255,255,255,.95) inset;
}

.mr2.mr2-js .mr2-concept-motion.is-sequenced > .mr2-pill-panel.is-step-complete,
.mr2.mr2-js .mr2-concept-motion.is-sequenced > .mr2-forecast-result-card.is-step-complete {
  filter: saturate(.94);
}

.mr2-concept-motion .mr2-formula span {
  transition:
    transform .42s cubic-bezier(.22, 1, .36, 1),
    box-shadow .42s ease,
    background .42s ease;
}

.mr2-concept-motion .mr2-formula.is-step-active span {
  transform: scale(1.13);
  box-shadow:
    0 12px 28px -20px rgba(173, 122, 24, .66),
    0 0 0 8px rgba(var(--mr2-amber-rgb), .22);
}

.mr2-concept-motion .mr2-formula-equal.is-step-active span {
  box-shadow:
    0 12px 28px -20px rgba(53, 95, 82, .62),
    0 0 0 8px rgba(92, 159, 136, .12);
}

.mr2-concept-motion .mr2-animal-chip,
.mr2-concept-motion .mr2-icon-chip,
.mr2-concept-motion .mr2-policy-row span,
.mr2-concept-motion .mr2-care-route span,
.mr2-concept-motion .mr2-mode-chip {
  transition:
    opacity .46s cubic-bezier(.22, 1, .36, 1),
    transform .46s cubic-bezier(.22, 1, .36, 1),
    box-shadow .46s ease,
    border-color .46s ease,
    background .46s ease,
    filter .46s ease;
}

.mr2.mr2-js .mr2-concept-motion .mr2-animal-row:not(.is-row-revealed) .mr2-animal-chip,
.mr2.mr2-js .mr2-concept-motion .mr2-icon-row:not(.is-row-revealed) .mr2-icon-chip,
.mr2.mr2-js .mr2-concept-motion .mr2-policy-row:not(.is-row-revealed) span {
  opacity: 0;
  transform: translateX(18px) scale(.985);
}

.mr2-concept-motion .is-row-revealed .mr2-animal-chip,
.mr2-concept-motion .is-row-revealed .mr2-icon-chip,
.mr2-concept-motion .is-row-revealed span {
  transition-delay: calc(var(--mr2-chip-index, 0) * 42ms);
}

.mr2-concept-motion .mr2-mode-grid.is-step-active .mr2-mode-chip {
  transform: translateY(-1px);
}

.mr2-concept-motion .mr2-policy-mini.is-step-active,
.mr2-concept-motion .mr2-care-route.is-step-active {
  animation: mr2-soft-rise .72s cubic-bezier(.22, 1, .36, 1) both;
}

.mr2-concept-motion .mr2-mode-chip.is-highlighted,
.mr2-concept-motion .mr2-policy-row span.is-highlighted {
  transform: translateY(-3px) scale(1.015);
  border-color: rgba(var(--mr2-amber-rgb), .50);
  box-shadow:
    0 18px 34px -28px rgba(173, 122, 24, .48),
    0 0 0 4px rgba(var(--mr2-amber-rgb), .13);
  filter: saturate(1.08);
}

.mr2-concept-motion .mr2-care-route span {
  position: relative;
  overflow: hidden;
}

.mr2-concept-motion .mr2-care-route span::after {
  content: "";
  position: absolute;
  inset: 0 auto 0 -65%;
  width: 54%;
  pointer-events: none;
  transform: skewX(-18deg);
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.56), transparent);
  opacity: 0;
}

.mr2-concept-motion .mr2-care-route.is-step-active span::after {
  animation: mr2-care-sheen 2.8s ease-in-out infinite;
  animation-delay: calc(var(--mr2-chip-index, 0) * 140ms);
  opacity: 1;
}

@keyframes mr2-soft-rise {
  from {
    opacity: .62;
    transform: translateY(12px) scale(.985);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

@keyframes mr2-care-sheen {
  0%, 46% {
    transform: translateX(0) skewX(-18deg);
  }
  78%, 100% {
    transform: translateX(310%) skewX(-18deg);
  }
}

@media (min-width: 760px) {
  .mr2-concept-stage-nav {
    justify-content: center;
    overflow: visible;
  }

  .mr2-concept-motion::before {
    left: 26px;
    top: 64px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .mr2-concept-motion::before {
    transform: none;
  }

  .mr2-concept-motion .mr2-care-route.is-step-active span::after {
    animation: none;
  }
}


/* v2.8 bot + gauge refresh */

.mr2-guidebot-float {
  position: absolute;
  right: min(3vw, 14px);
  top: min(13vw, 54px);
  z-index: 6;
  width: min(23vw, 88px);
  padding: 8px;
  border-radius: 26px;
  background: rgba(255,255,255,.82);
  border: 1px solid rgba(53,95,82,.10);
  box-shadow: 0 18px 36px -24px rgba(25,35,33,.28);
  backdrop-filter: blur(6px);
  transform: rotate(4deg);
}
.mr2-guidebot-float img { width: 100%; height: auto; }

.mr2-formula-flow {
  height: auto;
  margin: 8px 0;
}
.mr2-formula-flow span {
  width: auto;
  min-height: 32px;
  padding: 8px 14px;
  border-radius: 999px;
  font-size: 12px;
  letter-spacing: .04em;
  color: var(--mr2-green-ink);
  background: rgba(255,255,255,.82);
  border: 1px solid rgba(53,95,82,.11);
  box-shadow: 0 14px 26px -22px rgba(31,52,44,.24);
}
.mr2-formula-equal.mr2-formula-flow span {
  background: linear-gradient(135deg, rgba(237,243,238,.96), rgba(var(--mr2-amber-rgb), .14));
}

.mr2-forecast-result-card {
  text-align: left;
  padding: 18px 16px 18px;
}
.mr2-result-eyebrow {
  margin-bottom: 10px;
}
.mr2-forecast-result-card > strong,
.mr2-forecast-result-card > p {
  text-align: center;
}
.mr2-result-gauge-figure {
  margin: 14px auto 12px;
  max-width: min(100%, 430px);
}
.mr2-result-gauge-figure img {
  width: 100%;
  height: auto;
  display: block;
}
.mr2-result-signs {
  display: grid;
  gap: 9px;
  margin-top: 4px;
}
.mr2-result-signs div {
  display: grid;
  grid-template-columns: 28px 1fr;
  gap: 10px;
  align-items: center;
  padding: 10px 12px;
  border-radius: 18px;
  background: rgba(255,255,255,.82);
  border: 1px solid rgba(211,225,213,.8);
  box-shadow: 0 12px 22px -22px rgba(31,52,44,.22);
}
.mr2-result-signs span {
  display: grid;
  place-items: center;
  width: 24px;
  height: 24px;
  border-radius: 999px;
  background: linear-gradient(180deg, #efc85f, #dfae33);
  color: #fff;
  font-size: 12px;
  font-weight: 900;
}
.mr2-result-signs p {
  margin: 0;
  color: var(--mr2-text);
  font-size: 12.5px;
  font-weight: 820;
  line-height: 1.55;
}
.mr2-result-badges {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 12px;
  padding-inline: 2px;
}
.mr2-result-badges small {
  color: var(--mr2-muted);
  font-size: 11px;
  font-weight: 800;
}
.mr2-result-badges span {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-height: 28px;
  padding: 5px 10px;
  border-radius: 999px;
  background: rgba(247,248,244,.94);
  border: 1px solid rgba(211,225,213,.8);
  color: var(--mr2-green-deep);
  font-size: 11px;
  font-weight: 850;
}
.mr2-result-badges span img {
  width: 18px;
  height: 18px;
}
.mr2-policy-mini {
  margin-top: 14px;
}
.mr2-care-route {
  margin-top: 14px;
}

.mr2-final-cta {
  padding-top: 24px;
}
.mr2-final-visual {
  position: relative;
  width: min(100%, 240px);
  margin: 0 auto 10px;
  height: 126px;
}
.mr2-final-gauge {
  position: absolute;
  inset: -34px 0 auto 0;
  width: 100%;
  opacity: .24;
  filter: saturate(.9);
}
.mr2-final-bot {
  position: relative;
  z-index: 2;
  width: 84px;
  margin: 18px auto 0;
  padding: 8px;
  border-radius: 28px;
  background: rgba(255,255,255,.82);
  border: 1px solid rgba(53,95,82,.08);
  box-shadow: 0 18px 36px -26px rgba(30,45,39,.28);
}

/* calm the concept animation down */
.mr2-concept-motion .mr2-care-route span::after {
  display: none;
}
.mr2-concept-motion .mr2-mode-chip.is-highlighted,
.mr2-concept-motion .mr2-policy-row span.is-highlighted {
  transform: none;
  border-color: rgba(211,225,213,.82);
  box-shadow: 0 12px 24px -22px rgba(31,52,44,.16);
  filter: none;
}
@media (min-width: 760px) {
  .mr2-result-signs {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
  .mr2-result-signs div {
    grid-template-columns: 28px 1fr;
    min-height: 72px;
  }
  .mr2-final-visual {
    width: 280px;
    height: 142px;
  }
  .mr2-final-bot {
    width: 92px;
    margin-top: 22px;
  }
  .mr2-guidebot-float {
    width: 96px;
  }
}


/* v2.9 stable bot + cleaner concept refresh */

.mr2-guidebot-float { display:none !important; }
.mr2-guidebot-stand {
  position: absolute;
  right: max(10px, 1.6vw);
  bottom: clamp(56px, 9vw, 92px);
  z-index: 6;
  width: clamp(72px, 13vw, 96px);
  pointer-events: none;
  filter: drop-shadow(0 14px 20px rgba(37,95,79,.18));
}
.mr2-guidebot-stand img { display:block; width:100%; height:auto; }

.mr2-concept .mr2-section-head {
  max-width: 760px;
  margin-inline: auto;
  text-align: center;
}
.mr2-concept .mr2-section-head p { margin-inline: auto; }
.mr2-concept-board {
  max-width: 980px;
  margin-inline: auto;
  padding: 20px 16px 24px;
  background: linear-gradient(180deg, rgba(255,255,255,.78), rgba(252,252,248,.9));
  border: 1px solid rgba(53,95,82,.10);
  box-shadow: 0 28px 60px -40px rgba(31,52,44,.22);
}
.mr2-concept-stage-nav {
  justify-content: flex-start;
  gap: 8px;
  padding-bottom: 14px;
}
.mr2-concept-stage-nav span {
  background: rgba(248,249,245,.92);
  border-color: rgba(211,225,213,.82);
}
.mr2-concept-stage-nav span.is-active {
  background: #fff;
  box-shadow: 0 14px 28px -24px rgba(37,95,79,.24);
}
.mr2-pill-panel,
.mr2-forecast-result-card {
  border-radius: 28px;
  background: rgba(255,255,255,.88);
  border: 1px solid rgba(53,95,82,.10);
  box-shadow: 0 18px 34px -28px rgba(31,52,44,.16);
}
.mr2-concept-subhead strong { font-size: 16px; }
.mr2-concept-subhead small { font-size: 12.5px; }
.mr2-animal-row { gap: 12px; }
.mr2-animal-chip {
  flex: 0 0 116px;
  min-height: 154px;
  padding: 12px 10px;
  border-radius: 24px;
}
.mr2-animal-chip img {
  width: 82px;
  height: 70px;
  margin-bottom: 10px;
}
.mr2-animal-chip span { font-size: 13px; }
.mr2-animal-chip small { font-size: 10px; line-height: 1.5; }

.mr2-icon-row-compact .mr2-icon-chip,
.mr2-weather-panel .mr2-icon-chip {
  min-height: 132px;
  border-radius: 22px;
  background: linear-gradient(180deg, rgba(255,255,255,.98), rgba(248,249,245,.92));
  box-shadow: 0 14px 28px -26px rgba(31,52,44,.18);
}
.mr2-icon-row-compact .mr2-icon-chip img,
.mr2-weather-panel .mr2-icon-chip img { width: 34px; height: 34px; }
.mr2-icon-row-compact .mr2-icon-chip span,
.mr2-weather-panel .mr2-icon-chip span { font-size: 11.5px; }
.mr2-formula-flow { margin: 10px auto; }
.mr2-formula-flow span {
  min-height: 34px;
  padding: 8px 16px;
  font-size: 11.5px;
  font-weight: 900;
  letter-spacing: .06em;
  color: var(--mr2-green-ink);
  background: linear-gradient(180deg, rgba(247,248,244,.98), rgba(255,255,255,.96));
}
.mr2-forecast-result-card {
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(circle at 88% 10%, rgba(var(--mr2-amber-rgb), .18), transparent 9rem),
    radial-gradient(circle at 10% 96%, rgba(92,159,136,.08), transparent 10rem),
    rgba(255,255,255,.9);
}
.mr2-forecast-result-card::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: linear-gradient(180deg, rgba(255,255,255,.18), rgba(255,255,255,0));
}
.mr2-result-eyebrow { background: rgba(242,246,241,.94); letter-spacing: .12em; }
.mr2-result-gauge-figure {
  border-radius: 24px;
  padding: 12px 10px 6px;
  background: linear-gradient(180deg, rgba(251,250,244,.88), rgba(255,255,255,.72));
  border: 1px solid rgba(211,225,213,.74);
}
.mr2-result-signs { gap: 10px; }
.mr2-result-signs div { border-radius: 20px; }
.mr2-policy-mini { background: linear-gradient(180deg, rgba(246,246,241,.74), rgba(255,255,255,.6)); }
.mr2-policy-row span { border-radius: 18px; min-height: 112px; }
.mr2-care-route { border-top-color: rgba(53,95,82,.08); padding-top: 14px; }
.mr2-care-route span { min-height: 86px; border-radius: 20px; background: rgba(255,255,255,.74); }

.mr2-final-cta { padding-top: 28px; overflow: hidden; }
.mr2-final-visual {
  position: relative;
  width: min(100%, 260px);
  height: 120px;
  margin: 0 auto 14px;
}
.mr2-final-motif {
  position: absolute;
  inset: -26px -26px auto auto;
  width: 240px;
  opacity: .55;
}
.mr2-final-bot {
  position: absolute;
  right: 24px;
  bottom: -2px;
  z-index: 2;
  width: 82px;
  filter: drop-shadow(0 14px 18px rgba(37,95,79,.18));
}
.mr2-final-gauge { display:none !important; }

@media (max-width: 420px) {
  .mr2-guidebot-stand { right: 6px; bottom: 86px; width: 80px; }
  .mr2-animal-chip { flex-basis: 112px; }
  .mr2-final-visual { width: 220px; height: 112px; }
  .mr2-final-motif { width: 214px; right: -18px; }
  .mr2-final-bot { right: 18px; width: 76px; }
}
@media (min-width: 760px) {
  .mr2-guidebot-stand { right: 18px; bottom: 96px; width: 102px; }
  .mr2-concept-stage-nav { justify-content: center; }
  .mr2-animal-chip { flex-basis: 124px; min-height: 160px; }
  .mr2-animal-chip img { width: 88px; height: 74px; }
  .mr2-result-signs { grid-template-columns: repeat(3, minmax(0,1fr)); }
  .mr2-final-visual { width: 320px; height: 136px; }
  .mr2-final-motif { width: 290px; right: -12px; top: -20px; }
  .mr2-final-bot { width: 92px; right: 40px; bottom: -2px; }
}


/* v3 CTA bot cleanup */

.mr2-final-cta {
  padding-top: 22px;
}
.mr2-final-cta .mr2-final-visual {
  position: relative;
  width: min(100%, 236px);
  height: 92px;
  margin: 0 auto 16px;
}
.mr2-final-cta .mr2-final-motif {
  position: absolute;
  top: -10px;
  right: 8px;
  width: 172px;
  opacity: .58;
}
.mr2-final-cta .mr2-final-bot {
  position: absolute;
  top: 8px;
  right: 42px;
  width: 68px;
  margin: 0;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  filter: drop-shadow(0 12px 18px rgba(37,95,79,.18));
}
.mr2-final-cta .mr2-final-bot img,
.mr2-final-cta .mr2-final-bot svg,
.mr2-final-cta .mr2-final-bot {
  display: block;
  height: auto;
}

@media (max-width: 420px) {
  .mr2-final-cta .mr2-final-visual {
    width: 220px;
    height: 88px;
    margin-bottom: 14px;
  }
  .mr2-final-cta .mr2-final-motif {
    width: 160px;
    right: 6px;
    top: -8px;
  }
  .mr2-final-cta .mr2-final-bot {
    width: 62px;
    right: 40px;
    top: 10px;
  }
}
@media (min-width: 760px) {
  .mr2-final-cta .mr2-final-visual {
    width: 260px;
    height: 100px;
  }
  .mr2-final-cta .mr2-final-motif {
    width: 190px;
    right: 12px;
    top: -10px;
  }
  .mr2-final-cta .mr2-final-bot {
    width: 72px;
    right: 48px;
    top: 8px;
  }
}


/* v4 CTA centering refinement */

.mr2-final-cta .mr2-final-visual {
  width: min(100%, 260px);
  height: 110px;
  margin: 0 auto 18px;
}
.mr2-final-cta .mr2-final-motif {
  left: 50%;
  right: auto;
  top: -14px;
  width: 196px;
  transform: translateX(-50%);
  opacity: .62;
}
.mr2-final-cta .mr2-final-bot {
  left: 50%;
  right: auto;
  top: 6px;
  width: 78px;
  transform: translateX(-50%);
}

@media (max-width: 420px) {
  .mr2-final-cta .mr2-final-visual {
    width: 236px;
    height: 104px;
    margin-bottom: 16px;
  }
  .mr2-final-cta .mr2-final-motif {
    width: 182px;
    top: -12px;
  }
  .mr2-final-cta .mr2-final-bot {
    width: 72px;
    top: 8px;
  }
}
@media (min-width: 760px) {
  .mr2-final-cta .mr2-final-visual {
    width: 288px;
    height: 118px;
  }
  .mr2-final-cta .mr2-final-motif {
    width: 214px;
    top: -16px;
  }
  .mr2-final-cta .mr2-final-bot {
    width: 84px;
    top: 4px;
  }
}


/* v5 CTA visual tuning: larger motif slightly-left, centered larger bot */
.mr2-final-cta {
  padding-top: 20px;
}

.mr2-final-cta .mr2-final-visual {
  position: relative;
  width: min(100%, 290px);
  height: 132px;
  margin: 0 auto 12px;
}

.mr2-final-cta .mr2-final-motif {
  position: absolute;
  top: -18px;
  left: 46%;
  right: auto;
  width: 228px;
  transform: translateX(-50%);
  opacity: 0.62;
  pointer-events: none;
}

.mr2-final-cta .mr2-final-bot {
  position: absolute;
  top: 20px;
  left: 50%;
  right: auto;
  width: 86px;
  margin: 0;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  transform: translateX(-50%);
  filter: drop-shadow(0 14px 18px rgba(37, 95, 79, 0.16));
  pointer-events: none;
}

.mr2-final-cta h2 {
  margin-top: 2px;
}

@media (max-width: 420px) {
  .mr2-final-cta .mr2-final-visual {
    width: 252px;
    height: 118px;
    margin-bottom: 10px;
  }

  .mr2-final-cta .mr2-final-motif {
    top: -14px;
    left: 46%;
    width: 204px;
  }

  .mr2-final-cta .mr2-final-bot {
    top: 18px;
    width: 78px;
  }
}

@media (min-width: 760px) {
  .mr2-final-cta .mr2-final-visual {
    width: 320px;
    height: 142px;
    margin-bottom: 14px;
  }

  .mr2-final-cta .mr2-final-motif {
    top: -20px;
    left: 47%;
    width: 244px;
  }

  .mr2-final-cta .mr2-final-bot {
    top: 22px;
    width: 90px;
  }
}


/* v6 CTA bot lower adjustment */
.mr2-final-cta .mr2-final-bot {
  top: 30px;
}

@media (max-width: 420px) {
  .mr2-final-cta .mr2-final-bot {
    top: 28px;
  }
}

@media (min-width: 760px) {
  .mr2-final-cta .mr2-final-bot {
    top: 32px;
  }
}


/* v7 hero mockup tuning: bot slightly lower, hedgehog relatively higher */
.mr2-guidebot-stand {
  bottom: clamp(40px, 6vw, 74px);
}

.mr2-float-a {
  bottom: min(18vw, 88px);
}

@media (max-width: 420px) {
  .mr2-guidebot-stand {
    bottom: 54px;
  }

  .mr2-float-a {
    bottom: min(18vw, 84px);
  }
}

@media (min-width: 760px) {
  .mr2-guidebot-stand {
    bottom: 76px;
  }

  .mr2-float-a {
    bottom: 92px;
  }
}


/* v8 hero mockup smartphone-frame refinement */
.mr2-phone-frame {
  position: relative;
  overflow: hidden;
  border-radius: 38px;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.96), rgba(244,247,244,0.92));
  border: 1px solid rgba(163, 184, 174, 0.28);
  box-shadow:
    0 30px 70px -44px rgba(31, 52, 44, 0.46),
    0 12px 28px -24px rgba(31, 52, 44, 0.24),
    inset 0 0 0 7px rgba(255, 255, 255, 0.72),
    inset 0 0 0 8px rgba(210, 221, 215, 0.32);
}

/* upper speaker / dynamic-island-like detail */
.mr2-phone-frame::before {
  content: "";
  position: absolute;
  top: 13px;
  left: 50%;
  z-index: 4;
  width: 92px;
  height: 8px;
  border-radius: 999px;
  background: linear-gradient(180deg, rgba(201, 209, 207, 0.62), rgba(246, 248, 247, 0.94));
  box-shadow:
    inset 0 1px 2px rgba(72, 91, 87, 0.12),
    0 1px 0 rgba(255, 255, 255, 0.9);
  transform: translateX(-50%);
}

/* bottom home indicator */
.mr2-phone-frame::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: 12px;
  z-index: 4;
  width: 92px;
  height: 4px;
  border-radius: 999px;
  background: rgba(82, 104, 98, 0.14);
  transform: translateX(-50%);
}

/* inner screen: a little inset so it reads as glass inside a device */
.mr2-phone-frame img {
  position: relative;
  z-index: 2;
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 30px;
  padding: 16px 10px 18px;
  background: rgba(255, 255, 255, 0.62);
  box-shadow:
    inset 0 0 0 1px rgba(210, 221, 215, 0.44);
}

/* side highlight for a more device-like edge */
.mr2-phone-frame .mr2-phone-edge {
  display: none;
}

.mr2-phone-frame {
  transform-style: preserve-3d;
}

.mr2-phone-main {
  border-radius: 40px;
}

.mr2-phone-side {
  border-radius: 34px;
  box-shadow:
    0 28px 60px -48px rgba(31, 52, 44, 0.42),
    inset 0 0 0 6px rgba(255,255,255,.58),
    inset 0 0 0 7px rgba(210,221,215,.24);
}

@media (max-width: 420px) {
  .mr2-phone-frame {
    border-radius: 34px;
    box-shadow:
      0 24px 54px -40px rgba(31, 52, 44, 0.44),
      0 10px 24px -22px rgba(31, 52, 44, 0.22),
      inset 0 0 0 6px rgba(255, 255, 255, 0.72),
      inset 0 0 0 7px rgba(210, 221, 215, 0.30);
  }

  .mr2-phone-frame::before {
    top: 11px;
    width: 78px;
    height: 7px;
  }

  .mr2-phone-frame::after {
    bottom: 10px;
    width: 78px;
  }

  .mr2-phone-frame img {
    border-radius: 27px;
    padding: 14px 8px 16px;
  }
}

@media (min-width: 760px) {
  .mr2-phone-frame {
    border-radius: 42px;
  }

  .mr2-phone-frame img {
    border-radius: 32px;
    padding: 18px 12px 20px;
  }
}


/* v9 stronger iPhone-like mockup frame (targets the real .mr2-phone elements) */
.mr2-phone {
  position: absolute;
  overflow: hidden;
  border-radius: 34px;
  background: linear-gradient(180deg, #f8fbfa 0%, #eef3f1 100%);
  border: 1px solid rgba(160, 174, 170, 0.42);
  box-shadow:
    0 28px 58px -34px rgba(17, 24, 39, 0.36),
    0 10px 22px -18px rgba(17, 24, 39, 0.18),
    inset 0 1px 0 rgba(255,255,255,0.92),
    inset 0 0 0 1px rgba(255,255,255,0.55);
}

.mr2-phone img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Main phone: make the device shell clearly visible */
.mr2-phone-main {
  border-radius: 40px;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.92), rgba(238,243,241,0.96));
  border: 1px solid rgba(154, 168, 164, 0.48);
  box-shadow:
    0 36px 76px -42px rgba(17, 24, 39, 0.42),
    0 14px 32px -24px rgba(17, 24, 39, 0.22),
    inset 0 0 0 7px rgba(255,255,255,0.74),
    inset 0 0 0 8px rgba(207,218,213,0.42);
}

/* Dynamic-island / speaker detail */
.mr2-phone-main::before {
  content: "";
  position: absolute;
  top: 12px;
  left: 50%;
  z-index: 4;
  width: 90px;
  height: 24px;
  border-radius: 999px;
  background: linear-gradient(180deg, rgba(48,58,63,0.96), rgba(28,34,37,0.98));
  box-shadow:
    inset 0 1px 1px rgba(255,255,255,0.08),
    0 1px 0 rgba(255,255,255,0.34);
  transform: translateX(-50%);
}

/* Home indicator */
.mr2-phone-main::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: 10px;
  z-index: 4;
  width: 96px;
  height: 4px;
  border-radius: 999px;
  background: rgba(44, 57, 54, 0.22);
  transform: translateX(-50%);
}

/* The actual screen sits inside the device shell */
.mr2-phone-main img {
  position: relative;
  z-index: 2;
  width: calc(100% - 18px);
  height: calc(100% - 22px);
  margin: 11px 9px 11px;
  border-radius: 30px;
  object-fit: cover;
  box-shadow:
    inset 0 0 0 1px rgba(216, 226, 221, 0.72);
}

/* Secondary devices: a little cleaner, but not as strong as the main one */
.mr2-phone-back {
  border-radius: 30px;
  background: linear-gradient(180deg, rgba(255,255,255,0.92), rgba(241,245,243,0.92));
  box-shadow:
    0 24px 48px -36px rgba(17, 24, 39, 0.28),
    inset 0 0 0 5px rgba(255,255,255,0.56),
    inset 0 0 0 6px rgba(213,223,218,0.28);
}

.mr2-phone-back::before {
  content: "";
  position: absolute;
  top: 10px;
  left: 50%;
  width: 54px;
  height: 7px;
  border-radius: 999px;
  background: rgba(75, 88, 84, 0.18);
  transform: translateX(-50%);
}

.mr2-phone-back::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: 8px;
  width: 54px;
  height: 3px;
  border-radius: 999px;
  background: rgba(75, 88, 84, 0.12);
  transform: translateX(-50%);
}

.mr2-phone-back img {
  width: calc(100% - 12px);
  height: calc(100% - 16px);
  margin: 8px 6px;
  border-radius: 24px;
}

@media (max-width: 420px) {
  .mr2-phone {
    border-radius: 32px;
  }

  .mr2-phone-main {
    border-radius: 36px;
    box-shadow:
      0 30px 66px -40px rgba(17, 24, 39, 0.40),
      0 12px 28px -22px rgba(17, 24, 39, 0.20),
      inset 0 0 0 6px rgba(255,255,255,0.74),
      inset 0 0 0 7px rgba(207,218,213,0.40);
  }

  .mr2-phone-main::before {
    top: 11px;
    width: 78px;
    height: 21px;
  }

  .mr2-phone-main::after {
    bottom: 9px;
    width: 80px;
  }

  .mr2-phone-main img {
    width: calc(100% - 16px);
    height: calc(100% - 20px);
    margin: 10px 8px 10px;
    border-radius: 27px;
  }
}

@media (min-width: 760px) {
  .mr2-phone-main {
    border-radius: 42px;
  }

  .mr2-phone-main::before {
    width: 96px;
    height: 25px;
  }

  .mr2-phone-main img {
    border-radius: 31px;
  }
}


/* v10 soften main phone top bar to match side devices */

.mr2-phone-main::before {
  top: 10px;
  width: 56px;
  height: 8px;
  border-radius: 999px;
  background: rgba(75, 88, 84, 0.18);
  box-shadow: none;
}

@media (max-width: 420px) {
  .mr2-phone-main::before {
    top: 9px;
    width: 52px;
    height: 7px;
  }
}

@media (min-width: 760px) {
  .mr2-phone-main::before {
    top: 10px;
    width: 58px;
    height: 8px;
  }
}


/* v11 main phone dynamic island refinement */

.mr2-phone-main::before {
  top: 10px;
  width: 76px;
  height: 18px;
  border-radius: 999px;
  background: linear-gradient(180deg, rgba(33, 37, 41, 0.98), rgba(17, 20, 24, 0.99));
  box-shadow:
    inset 0 1px 1px rgba(255,255,255,0.08),
    0 1px 1px rgba(255,255,255,0.20),
    0 3px 8px rgba(0,0,0,0.10);
}

@media (max-width: 420px) {
  .mr2-phone-main::before {
    top: 9px;
    width: 70px;
    height: 17px;
  }
}

@media (min-width: 760px) {
  .mr2-phone-main::before {
    top: 10px;
    width: 80px;
    height: 18px;
  }
}


/* v12 main phone dark iPhone-like frame, subtle thickness */

.mr2-phone-main {
  background: linear-gradient(180deg, #454b50 0%, #2f353a 100%);
  border: 1px solid rgba(16, 20, 24, 0.30);
  box-shadow:
    0 36px 76px -42px rgba(17, 24, 39, 0.42),
    0 14px 32px -24px rgba(17, 24, 39, 0.22),
    inset 0 1px 0 rgba(255,255,255,0.08),
    inset 0 0 0 3px rgba(255,255,255,0.10),
    inset 0 0 0 4px rgba(0,0,0,0.12);
}

.mr2-phone-main img {
  width: calc(100% - 12px);
  height: calc(100% - 16px);
  margin: 8px 6px 8px;
  border-radius: 30px;
  box-shadow: inset 0 0 0 1px rgba(216, 226, 221, 0.60);
}

.mr2-phone-main::after {
  bottom: 9px;
  width: 90px;
  height: 4px;
  background: rgba(255,255,255,0.22);
}

@media (max-width: 420px) {
  .mr2-phone-main {
    box-shadow:
      0 30px 66px -40px rgba(17, 24, 39, 0.40),
      0 12px 28px -22px rgba(17, 24, 39, 0.20),
      inset 0 1px 0 rgba(255,255,255,0.08),
      inset 0 0 0 3px rgba(255,255,255,0.10),
      inset 0 0 0 4px rgba(0,0,0,0.12);
  }
  .mr2-phone-main img {
    width: calc(100% - 10px);
    height: calc(100% - 14px);
    margin: 7px 5px 7px;
    border-radius: 27px;
  }
}

@media (min-width: 760px) {
  .mr2-phone-main img {
    width: calc(100% - 14px);
    height: calc(100% - 18px);
    margin: 9px 7px 9px;
    border-radius: 31px;
  }
}


/* v13 thinner dark main-phone frame */

.mr2-phone-main {
  box-shadow:
    0 36px 76px -42px rgba(17, 24, 39, 0.42),
    0 14px 32px -24px rgba(17, 24, 39, 0.22),
    inset 0 1px 0 rgba(255,255,255,0.08),
    inset 0 0 0 1px rgba(255,255,255,0.08),
    inset 0 0 0 2px rgba(0,0,0,0.10);
}

.mr2-phone-main img {
  width: calc(100% - 6px);
  height: calc(100% - 10px);
  margin: 5px 3px 5px;
  border-radius: 32px;
  box-shadow: inset 0 0 0 1px rgba(216, 226, 221, 0.48);
}

.mr2-phone-main::before {
  top: 8px;
}

.mr2-phone-main::after {
  bottom: 7px;
  width: 84px;
}

@media (max-width: 420px) {
  .mr2-phone-main {
    box-shadow:
      0 30px 66px -40px rgba(17, 24, 39, 0.40),
      0 12px 28px -22px rgba(17, 24, 39, 0.20),
      inset 0 1px 0 rgba(255,255,255,0.08),
      inset 0 0 0 1px rgba(255,255,255,0.08),
      inset 0 0 0 2px rgba(0,0,0,0.10);
  }
  .mr2-phone-main img {
    width: calc(100% - 6px);
    height: calc(100% - 10px);
    margin: 5px 3px 5px;
    border-radius: 29px;
  }
  .mr2-phone-main::before {
    top: 8px;
  }
  .mr2-phone-main::after {
    bottom: 7px;
    width: 76px;
  }
}

@media (min-width: 760px) {
  .mr2-phone-main img {
    width: calc(100% - 8px);
    height: calc(100% - 12px);
    margin: 6px 4px 6px;
    border-radius: 34px;
  }
}


/* v14 ultra-thin dark main-phone frame */

.mr2-phone-main {
  background: linear-gradient(180deg, #34393f 0%, #2c3136 100%);
  border: 1px solid rgba(16, 20, 24, 0.22);
  box-shadow:
    0 36px 76px -42px rgba(17, 24, 39, 0.42),
    0 14px 32px -24px rgba(17, 24, 39, 0.22),
    inset 0 1px 0 rgba(255,255,255,0.06),
    inset 0 0 0 1px rgba(255,255,255,0.05),
    inset 0 0 0 2px rgba(0,0,0,0.08);
}

.mr2-phone-main img {
  width: calc(100% - 4px);
  height: calc(100% - 8px);
  margin: 2px 2px 6px;
  border-radius: 35px;
  box-shadow: inset 0 0 0 1px rgba(216, 226, 221, 0.38);
}

.mr2-phone-main::before {
  top: 12px;
  width: 74px;
  height: 17px;
  border-radius: 999px;
  background: linear-gradient(180deg, rgba(26, 29, 33, 0.98), rgba(13, 15, 19, 0.99));
  box-shadow:
    inset 0 1px 1px rgba(255,255,255,0.05),
    0 1px 0 rgba(255,255,255,0.12);
}

.mr2-phone-main::after {
  bottom: 5px;
  width: 78px;
  height: 3px;
  background: rgba(255,255,255,0.18);
}

@media (max-width: 420px) {
  .mr2-phone-main img {
    width: calc(100% - 4px);
    height: calc(100% - 8px);
    margin: 2px 2px 6px;
    border-radius: 32px;
  }
  .mr2-phone-main::before {
    top: 11px;
    width: 68px;
    height: 16px;
  }
  .mr2-phone-main::after {
    bottom: 5px;
    width: 72px;
  }
}

@media (min-width: 760px) {
  .mr2-phone-main img {
    width: calc(100% - 4px);
    height: calc(100% - 8px);
    margin: 2px 2px 6px;
    border-radius: 36px;
  }
  .mr2-phone-main::before {
    width: 76px;
    height: 17px;
  }
}


/* v15 center phone matches side-frame look */

.mr2-phone-main {
  border-radius: 30px;
  background: linear-gradient(180deg, rgba(255,255,255,0.92), rgba(241,245,243,0.92));
  border: none;
  box-shadow:
    0 24px 48px -36px rgba(17, 24, 39, 0.28),
    inset 0 0 0 5px rgba(255,255,255,0.56),
    inset 0 0 0 6px rgba(213,223,218,0.28);
}

.mr2-phone-main::before {
  top: 10px;
  left: 50%;
  width: 54px;
  height: 7px;
  border-radius: 999px;
  background: rgba(75, 88, 84, 0.18);
  box-shadow: none;
  transform: translateX(-50%);
}

.mr2-phone-main::after {
  left: 50%;
  bottom: 8px;
  width: 54px;
  height: 3px;
  border-radius: 999px;
  background: rgba(75, 88, 84, 0.12);
  transform: translateX(-50%);
}

.mr2-phone-main img {
  width: calc(100% - 12px);
  height: calc(100% - 16px);
  margin: 8px 6px;
  border-radius: 24px;
  box-shadow: none;
}

@media (max-width: 420px) {
  .mr2-phone-main {
    border-radius: 30px;
  }
  .mr2-phone-main::before {
    top: 10px;
    width: 54px;
    height: 7px;
  }
  .mr2-phone-main::after {
    bottom: 8px;
    width: 54px;
    height: 3px;
  }
  .mr2-phone-main img {
    width: calc(100% - 12px);
    height: calc(100% - 16px);
    margin: 8px 6px;
    border-radius: 24px;
  }
}

@media (min-width: 760px) {
  .mr2-phone-main {
    border-radius: 30px;
  }
  .mr2-phone-main::before {
    width: 54px;
    height: 7px;
  }
  .mr2-phone-main::after {
    width: 54px;
    height: 3px;
  }
  .mr2-phone-main img {
    width: calc(100% - 12px);
    height: calc(100% - 16px);
    margin: 8px 6px;
    border-radius: 24px;
  }
}


/* v16 center phone uses the same frame design as side phones, scaled proportionally */
.mr2-phone-main {
  border-radius: 44px;
  background: linear-gradient(180deg, rgba(255,255,255,0.92), rgba(241,245,243,0.92));
  border: none;
  box-shadow:
    0 30px 56px -40px rgba(17, 24, 39, 0.30),
    inset 0 0 0 7px rgba(255,255,255,0.56),
    inset 0 0 0 8px rgba(213,223,218,0.28);
}

.mr2-phone-main::before {
  top: 15px;
  left: 50%;
  width: 79px;
  height: 10px;
  border-radius: 999px;
  background: rgba(75, 88, 84, 0.18);
  box-shadow: none;
  transform: translateX(-50%);
}

.mr2-phone-main::after {
  left: 50%;
  bottom: 11px;
  width: 79px;
  height: 4px;
  border-radius: 999px;
  background: rgba(75, 88, 84, 0.12);
  transform: translateX(-50%);
}

.mr2-phone-main img {
  width: calc(100% - 18px);
  height: calc(100% - 24px);
  margin: 12px 9px;
  border-radius: 35px;
  box-shadow: none;
}

@media (max-width: 420px) {
  .mr2-phone-main {
    border-radius: 41px;
    box-shadow:
      0 28px 52px -40px rgba(17, 24, 39, 0.30),
      inset 0 0 0 6px rgba(255,255,255,0.56),
      inset 0 0 0 7px rgba(213,223,218,0.28);
  }

  .mr2-phone-main::before {
    top: 14px;
    width: 74px;
    height: 9px;
  }

  .mr2-phone-main::after {
    bottom: 10px;
    width: 74px;
    height: 4px;
  }

  .mr2-phone-main img {
    width: calc(100% - 16px);
    height: calc(100% - 22px);
    margin: 11px 8px;
    border-radius: 33px;
  }
}

@media (min-width: 760px) {
  .mr2-phone-main {
    border-radius: 46px;
  }

  .mr2-phone-main::before {
    top: 15px;
    width: 82px;
    height: 10px;
  }

  .mr2-phone-main::after {
    bottom: 11px;
    width: 82px;
    height: 4px;
  }

  .mr2-phone-main img {
    width: calc(100% - 20px);
    height: calc(100% - 26px);
    margin: 13px 10px;
    border-radius: 36px;
  }
}


/* v17 typography balance tuning: slightly smaller titles, larger darker body text */

:root {
  --mr2-soft-readable: #4b5d6c;
}

.mr2 h1 {
  font-size: clamp(30px, 8.9vw, 54px);
  line-height: 1.15;
  letter-spacing: .004em;
}

.mr2 h2 {
  font-size: clamp(24px, 6.5vw, 40px);
  line-height: 1.22;
  letter-spacing: .006em;
}

.mr2-lead {
  font-size: 16.5px;
  line-height: 1.88;
}

.mr2-body,
.mr2-section-head p,
.mr2-time-card p,
.mr2-step-card p,
.mr2-trust-card p,
.mr2-soft-message,
.mr2-check-card p {
  color: var(--mr2-soft-readable);
}

.mr2-body,
.mr2-section-head p {
  font-size: 15.5px;
  line-height: 1.92;
}

.mr2-check-card {
  gap: 12px;
  padding: 16px 16px;
}

.mr2-check-card p {
  font-size: 15px;
  line-height: 1.78;
  font-weight: 500;
}

.mr2-soft-message {
  font-size: 15.5px;
  line-height: 1.82;
}

@media (max-width: 420px) {
  .mr2 h1 {
    font-size: clamp(34px, 9.4vw, 42px);
    line-height: 1.16;
  }

  .mr2 h2 {
    font-size: clamp(22px, 7.1vw, 32px);
    line-height: 1.24;
  }

  .mr2-lead {
    font-size: 16px;
    line-height: 1.84;
  }

  .mr2-body,
  .mr2-section-head p {
    font-size: 15.5px;
    line-height: 1.9;
  }

  .mr2-check-card p {
    font-size: 15px;
    line-height: 1.74;
  }
}

@media (min-width: 760px) {
  .mr2 h1 {
    font-size: clamp(40px, 5vw, 56px);
  }

  .mr2 h2 {
    font-size: clamp(28px, 3.6vw, 42px);
  }

  .mr2-body,
  .mr2-section-head p {
    font-size: 16px;
  }

  .mr2-check-card p {
    font-size: 15.5px;
  }
}

/* v3.1 concept mobile story redesign */
.mr2-concept .mr2-section-head {
  max-width: 780px;
}

.mr2-concept .mr2-section-head h2 {
  letter-spacing: -.048em;
}

.mr2-concept-board-v3 {
  position: relative;
  max-width: 1040px;
  margin-inline: auto;
  padding: 14px;
  overflow: hidden;
  border-radius: 34px;
  background:
    radial-gradient(circle at 88% 3%, rgba(var(--mr2-amber-rgb), .26), transparent 12rem),
    radial-gradient(circle at 4% 42%, rgba(92, 159, 136, .14), transparent 14rem),
    linear-gradient(180deg, rgba(255,255,255,.88), rgba(251,252,247,.94));
  border: 1px solid rgba(53,95,82,.12);
  box-shadow: 0 26px 64px -44px rgba(31,52,44,.28);
}

.mr2-concept-board-v3::before {
  content: "";
  position: absolute;
  inset: 12px;
  pointer-events: none;
  border-radius: 28px;
  background:
    linear-gradient(90deg, rgba(53,95,82,.055) 1px, transparent 1px),
    linear-gradient(180deg, rgba(53,95,82,.045) 1px, transparent 1px);
  background-size: 28px 28px;
  mask-image: linear-gradient(180deg, rgba(0,0,0,.5), transparent 78%);
  opacity: .5;
}

.mr2-concept-board-v3 > * {
  position: relative;
  z-index: 1;
}

.mr2-concept-lead-card {
  padding: 18px;
  border-radius: 28px;
  color: var(--mr2-text);
  background:
    radial-gradient(circle at 95% 0%, rgba(var(--mr2-amber-rgb), .29), transparent 8rem),
    linear-gradient(135deg, rgba(255,255,255,.98), rgba(242,248,243,.92));
  border: 1px solid rgba(53,95,82,.12);
  box-shadow: 0 18px 40px -34px rgba(31,52,44,.28), 0 1px 0 rgba(255,255,255,.9) inset;
}

.mr2-concept-label {
  display: inline-flex;
  align-items: center;
  margin: 0 0 10px;
  padding: 5px 10px;
  border-radius: 999px;
  color: var(--mr2-green-ink);
  background: rgba(237,243,238,.92);
  border: 1px solid rgba(53,95,82,.10);
  font-size: 11px;
  line-height: 1;
  font-weight: 900;
  letter-spacing: .12em;
}

.mr2-concept-lead-card h3 {
  margin: 0 0 8px;
  color: var(--mr2-green-ink);
  font-size: 20px;
  line-height: 1.42;
  letter-spacing: -.035em;
}

.mr2-concept-lead-card p:not(.mr2-concept-label) {
  margin: 0;
  color: var(--mr2-soft);
  font-size: 13.5px;
  line-height: 1.82;
}

.mr2-concept-equation {
  display: grid;
  grid-template-columns: 1fr auto 1fr auto 1.18fr;
  align-items: center;
  gap: 6px;
  margin-top: 16px;
  padding: 8px;
  border-radius: 22px;
  background: rgba(255,255,255,.76);
  border: 1px solid rgba(211,225,213,.82);
}

.mr2-concept-equation span,
.mr2-concept-equation strong {
  display: grid;
  place-items: center;
  min-height: 38px;
  padding: 8px 6px;
  border-radius: 16px;
  text-align: center;
  font-size: 12px;
  line-height: 1.25;
  font-weight: 900;
  white-space: nowrap;
}

.mr2-concept-equation span {
  color: var(--mr2-green-ink);
  background: rgba(237,243,238,.9);
}

.mr2-concept-equation strong {
  color: var(--mr2-amber-deep);
  background: linear-gradient(180deg, rgba(var(--mr2-amber-rgb), .10), rgba(var(--mr2-amber-rgb), .20));
}

.mr2-concept-equation i {
  color: rgba(37,95,79,.58);
  font-style: normal;
  font-size: 15px;
  font-weight: 950;
}

.mr2-concept-flow {
  position: relative;
  display: grid;
  gap: 14px;
  margin-top: 14px;
}

.mr2-concept-flow::before {
  content: "";
  position: absolute;
  left: 31px;
  top: 26px;
  bottom: 26px;
  width: 2px;
  border-radius: 999px;
  background: linear-gradient(180deg, rgba(92,159,136,.16), rgba(var(--mr2-amber-rgb), .36), rgba(92,159,136,.18));
}

.mr2-concept-step {
  position: relative;
  padding: 18px 14px 16px;
  border-radius: 28px;
  background: rgba(255,255,255,.88);
  border: 1px solid rgba(53,95,82,.10);
  box-shadow: 0 18px 36px -32px rgba(31,52,44,.22);
}

.mr2-step-marker {
  position: absolute;
  top: 18px;
  left: 16px;
  z-index: 2;
  display: grid;
  place-items: center;
  width: 32px;
  height: 32px;
  border-radius: 999px;
  color: #fff;
  background: linear-gradient(135deg, var(--mr2-green-ink), var(--mr2-green));
  box-shadow: 0 12px 24px -18px rgba(37,95,79,.58);
  font-size: 13px;
  font-weight: 950;
}

.mr2-step-copy {
  padding-left: 46px;
}

.mr2-concept-step-kicker {
  margin: 0 0 4px;
  color: var(--mr2-green-deep);
  font-size: 10.5px;
  line-height: 1;
  font-weight: 900;
  letter-spacing: .15em;
}

.mr2-concept-step h3 {
  margin: 0 0 6px;
  color: var(--mr2-text);
  font-size: 17px;
  line-height: 1.42;
  letter-spacing: -.025em;
}

.mr2-concept-step p:not(.mr2-concept-step-kicker) {
  margin: 0;
  color: var(--mr2-soft);
  font-size: 13px;
  line-height: 1.78;
}

.mr2-animal-mini-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  margin-top: 14px;
}

.mr2-animal-mini {
  display: grid;
  grid-template-columns: 48px minmax(0, 1fr);
  grid-template-rows: auto auto;
  column-gap: 8px;
  align-items: center;
  min-height: 72px;
  padding: 9px;
  border-radius: 20px;
  background: linear-gradient(180deg, rgba(255,255,255,.96), rgba(248,249,245,.86));
  border: 1px solid rgba(211,225,213,.78);
}

.mr2-animal-mini img {
  grid-row: 1 / span 2;
  width: 48px;
  height: 48px;
  object-fit: contain;
}

.mr2-animal-mini span {
  min-width: 0;
  color: var(--mr2-green-ink);
  font-size: 12px;
  line-height: 1.25;
  font-weight: 900;
}

.mr2-animal-mini small {
  min-width: 0;
  margin-top: 2px;
  color: var(--mr2-muted);
  font-size: 9.5px;
  line-height: 1.36;
  font-weight: 760;
}

.mr2-concept-pill-cloud {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  margin-top: 10px;
}

.mr2-concept-pill {
  display: grid;
  grid-template-columns: 28px minmax(0, 1fr);
  grid-template-rows: auto auto;
  column-gap: 8px;
  align-items: center;
  min-height: 56px;
  padding: 8px;
  border-radius: 18px;
  background: rgba(246,246,241,.72);
  border: 1px solid rgba(211,225,213,.70);
}

.mr2-concept-pill img {
  grid-row: 1 / span 2;
  width: 28px;
  height: 28px;
}

.mr2-concept-pill b {
  color: var(--mr2-text);
  font-size: 11px;
  line-height: 1.25;
  font-weight: 900;
}

.mr2-concept-pill small {
  color: var(--mr2-green-deep);
  font-size: 9.5px;
  line-height: 1.2;
  font-weight: 800;
}

.mr2-weather-mini-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  margin-top: 14px;
}

.mr2-weather-mini {
  display: flex;
  align-items: center;
  gap: 8px;
  min-height: 48px;
  padding: 9px 10px;
  border-radius: 18px;
  background: linear-gradient(180deg, rgba(255,255,255,.96), rgba(248,249,245,.88));
  border: 1px solid rgba(211,225,213,.78);
}

.mr2-weather-mini img {
  width: 28px;
  height: 28px;
  flex: 0 0 auto;
}

.mr2-weather-mini b {
  color: var(--mr2-text);
  font-size: 12px;
  line-height: 1.25;
  font-weight: 900;
}

.mr2-output-preview-card {
  margin-top: 14px;
  padding: 14px;
  border-radius: 24px;
  background:
    radial-gradient(circle at 90% 8%, rgba(var(--mr2-amber-rgb), .22), transparent 9rem),
    linear-gradient(180deg, rgba(255,255,255,.96), rgba(250,251,246,.9));
  border: 1px solid rgba(53,95,82,.11);
  box-shadow: 0 16px 32px -30px rgba(31,52,44,.22);
}

.mr2-output-preview-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.mr2-output-preview-head span {
  color: var(--mr2-green-deep);
  font-size: 11px;
  line-height: 1;
  font-weight: 900;
  letter-spacing: .08em;
}

.mr2-output-preview-head strong {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 6px 11px;
  border-radius: 999px;
  color: var(--mr2-amber-deep);
  background: rgba(var(--mr2-amber-rgb), .18);
  border: 1px solid rgba(var(--mr2-amber-rgb), .32);
  font-size: 12px;
  line-height: 1;
  font-weight: 950;
  white-space: nowrap;
}

.mr2-output-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 12px;
}

.mr2-output-badges span {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-height: 34px;
  padding: 6px 10px;
  border-radius: 999px;
  color: var(--mr2-green-ink);
  background: rgba(237,243,238,.82);
  border: 1px solid rgba(53,95,82,.10);
  font-size: 11.5px;
  font-weight: 900;
}

.mr2-output-badges img {
  width: 20px;
  height: 20px;
}

.mr2-output-signs {
  display: grid;
  gap: 8px;
  margin: 12px 0 0;
  padding: 0;
  list-style: none;
}

.mr2-output-signs li {
  display: grid;
  grid-template-columns: 26px 1fr;
  align-items: center;
  gap: 8px;
  min-height: 44px;
  padding: 8px 10px;
  border-radius: 17px;
  color: var(--mr2-text);
  background: rgba(255,255,255,.72);
  border: 1px solid rgba(211,225,213,.68);
  font-size: 12px;
  line-height: 1.5;
  font-weight: 760;
}

.mr2-output-signs li span {
  display: grid;
  place-items: center;
  width: 24px;
  height: 24px;
  border-radius: 999px;
  color: var(--mr2-green-ink);
  background: var(--mr2-mint-2);
  font-size: 11px;
  font-weight: 950;
}

.mr2-policy-tag-row {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 12px;
}

.mr2-policy-tag {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 5px 9px;
  border-radius: 999px;
  color: var(--mr2-green-ink);
  background: rgba(248,249,245,.86);
  border: 1px solid rgba(211,225,213,.76);
  font-size: 11px;
  line-height: 1;
  font-weight: 900;
}

.mr2-output-preview-card .mr2-care-route {
  margin-top: 12px;
  padding-top: 12px;
  gap: 8px;
  border-top: 1px solid rgba(53,95,82,.08);
}

.mr2-output-preview-card .mr2-care-route span {
  min-height: 68px;
  padding: 8px 5px;
  border-radius: 18px;
  background: rgba(255,255,255,.78);
  border-color: rgba(53,95,82,.10);
}

.mr2-output-preview-card .mr2-care-route img {
  width: 28px;
  height: 28px;
}

.mr2-output-preview-card .mr2-care-route small {
  color: var(--mr2-muted);
  font-size: 9.5px;
  line-height: 1.2;
  font-weight: 800;
}

.mr2.mr2-js .mr2-concept-board-v3.is-sequenced .mr2-concept-step,
.mr2.mr2-js .mr2-concept-board-v3.is-sequenced .mr2-animal-mini,
.mr2.mr2-js .mr2-concept-board-v3.is-sequenced .mr2-concept-pill,
.mr2.mr2-js .mr2-concept-board-v3.is-sequenced .mr2-weather-mini,
.mr2.mr2-js .mr2-concept-board-v3.is-sequenced .mr2-output-signs li,
.mr2.mr2-js .mr2-concept-board-v3.is-sequenced .mr2-policy-tag,
.mr2.mr2-js .mr2-concept-board-v3.is-sequenced .mr2-care-route span {
  animation: mr2-concept-pop .58s cubic-bezier(.22, 1, .36, 1) both;
  animation-delay: calc(var(--mr2-chip-index, 0) * 34ms);
}

@keyframes mr2-concept-pop {
  from {
    opacity: 0;
    transform: translateY(10px) scale(.985);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

@media (max-width: 370px) {
  .mr2-concept-board-v3 {
    padding: 12px;
  }

  .mr2-concept-lead-card,
  .mr2-concept-step,
  .mr2-output-preview-card {
    border-radius: 24px;
  }

  .mr2-concept-equation {
    gap: 4px;
    padding: 6px;
  }

  .mr2-concept-equation span,
  .mr2-concept-equation strong {
    min-height: 34px;
    padding-inline: 4px;
    font-size: 11px;
  }

  .mr2-animal-mini {
    grid-template-columns: 42px minmax(0, 1fr);
    padding: 8px 7px;
  }

  .mr2-animal-mini img {
    width: 42px;
    height: 42px;
  }

  .mr2-animal-mini small {
    font-size: 9px;
  }
}

@media (min-width: 760px) {
  .mr2-concept-board-v3 {
    padding: 22px;
    border-radius: 38px;
  }

  .mr2-concept-lead-card {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(340px, .78fr);
    column-gap: 24px;
    align-items: center;
    padding: 24px;
  }

  .mr2-concept-lead-card .mr2-concept-label,
  .mr2-concept-lead-card h3,
  .mr2-concept-lead-card p:not(.mr2-concept-label) {
    grid-column: 1;
  }

  .mr2-concept-equation {
    grid-column: 2;
    grid-row: 1 / span 3;
    margin-top: 0;
  }

  .mr2-concept-flow {
    grid-template-columns: 1.05fr .95fr;
    gap: 16px;
    margin-top: 16px;
  }

  .mr2-concept-flow::before {
    display: none;
  }

  .mr2-concept-step-output {
    grid-column: 1 / -1;
  }

  .mr2-concept-step {
    padding: 22px;
  }

  .mr2-step-marker {
    top: 22px;
    left: 22px;
  }

  .mr2-step-copy {
    padding-left: 48px;
  }

  .mr2-animal-mini-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .mr2-concept-pill-cloud,
  .mr2-weather-mini-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .mr2-output-preview-card {
    display: grid;
    grid-template-columns: minmax(0, .95fr) minmax(0, 1.05fr);
    gap: 14px;
    align-items: start;
  }

  .mr2-output-preview-head,
  .mr2-output-badges,
  .mr2-output-signs {
    grid-column: 1;
  }

  .mr2-policy-tag-row,
  .mr2-output-preview-card .mr2-care-route {
    grid-column: 2;
  }

  .mr2-policy-tag-row {
    margin-top: 0;
  }

  .mr2-output-preview-card .mr2-care-route {
    margin-top: 12px;
  }
}

@media (min-width: 1020px) {
  .mr2-concept-flow {
    grid-template-columns: 1.08fr .92fr 1.04fr;
  }

  .mr2-concept-step-output {
    grid-column: auto;
  }

  .mr2-concept-pill-cloud {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .mr2-weather-mini-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .mr2-output-preview-card {
    display: block;
  }

  .mr2-policy-tag-row {
    margin-top: 12px;
  }
}

/* v3.3 concept redesign: logic stays deep, UI stays simple */
.mr2-concept .mr2-section-head {
  max-width: 760px;
}

.mr2-concept-board-v4 {
  position: relative;
  max-width: 1040px;
  margin-inline: auto;
  padding: 14px;
  overflow: hidden;
  border-radius: 34px;
  background:
    radial-gradient(circle at 88% 4%, rgba(var(--mr2-amber-rgb), .23), transparent 12rem),
    radial-gradient(circle at 6% 28%, rgba(92, 159, 136, .15), transparent 15rem),
    linear-gradient(180deg, rgba(255,255,255,.92), rgba(249,251,246,.96));
  border: 1px solid rgba(53,95,82,.12);
  box-shadow: 0 26px 64px -44px rgba(31,52,44,.30);
}

.mr2-concept-board-v4::before {
  content: "";
  position: absolute;
  inset: 12px;
  pointer-events: none;
  border-radius: 28px;
  background:
    linear-gradient(90deg, rgba(53,95,82,.052) 1px, transparent 1px),
    linear-gradient(180deg, rgba(53,95,82,.042) 1px, transparent 1px);
  background-size: 28px 28px;
  mask-image: linear-gradient(180deg, rgba(0,0,0,.48), transparent 74%);
  opacity: .46;
}

.mr2-concept-board-v4 > * {
  position: relative;
  z-index: 1;
}

.mr2-concept-map-head {
  padding: 18px;
  border-radius: 28px;
  background:
    radial-gradient(circle at 94% 0%, rgba(var(--mr2-amber-rgb), .27), transparent 9rem),
    linear-gradient(135deg, rgba(255,255,255,.98), rgba(242,248,243,.92));
  border: 1px solid rgba(53,95,82,.12);
  box-shadow: 0 18px 40px -34px rgba(31,52,44,.28), 0 1px 0 rgba(255,255,255,.9) inset;
}

.mr2-concept-map-head h3 {
  margin: 0 0 8px;
  color: var(--mr2-green-ink);
  font-size: 20px;
  line-height: 1.42;
  letter-spacing: -.04em;
}

.mr2-concept-map-head p:not(.mr2-concept-label) {
  margin: 0;
  color: var(--mr2-soft);
  font-size: 13.5px;
  line-height: 1.82;
}

.mr2-concept-map {
  display: grid;
  gap: 12px;
  margin-top: 14px;
}

.mr2-concept-board-v4 > .mr2-concept-map:first-child {
  margin-top: 0;
}

.mr2-concept-node {
  position: relative;
  padding: 16px 14px 14px;
  border-radius: 26px;
  background: rgba(255,255,255,.90);
  border: 1px solid rgba(53,95,82,.10);
  box-shadow: 0 16px 34px -30px rgba(31,52,44,.22);
}

.mr2-node-head {
  display: grid;
  grid-template-columns: 38px minmax(0, 1fr);
  gap: 10px;
  align-items: start;
}

.mr2-node-icon {
  display: inline-grid;
  place-items: center;
  width: 34px;
  height: 34px;
  border-radius: 999px;
  color: #fff;
  background: linear-gradient(135deg, var(--mr2-green-ink), var(--mr2-green));
  box-shadow: 0 12px 24px -18px rgba(37,95,79,.58);
  font-size: 12px;
  line-height: 1;
  font-weight: 950;
}

.mr2-node-copy h3 {
  margin: 0 0 5px;
  color: var(--mr2-text);
  font-size: 17px;
  line-height: 1.36;
  letter-spacing: -.035em;
}

.mr2-node-copy p:not(.mr2-concept-step-kicker) {
  margin: 0;
  color: var(--mr2-soft);
  font-size: 12.8px;
  line-height: 1.72;
}

.mr2-animal-matrix {
  display: grid;
  gap: 6px;
  margin-top: 14px;
  padding: 9px;
  border-radius: 22px;
  background: linear-gradient(180deg, rgba(248,249,245,.84), rgba(255,255,255,.78));
  border: 1px solid rgba(211,225,213,.72);
}

.mr2-matrix-label-top {
  display: grid;
  grid-template-columns: 54px repeat(3, minmax(0, 1fr));
  gap: 5px;
  align-items: center;
}

.mr2-matrix-label-top::before {
  content: "";
}

.mr2-matrix-label-top span {
  color: rgba(92,110,130,.78);
  font-size: 9px;
  line-height: 1;
  text-align: center;
  font-weight: 900;
}

.mr2-matrix-row {
  display: grid;
  grid-template-columns: 54px repeat(3, minmax(0, 1fr));
  gap: 5px;
  align-items: stretch;
}

.mr2-matrix-row > b {
  display: grid;
  place-items: center;
  min-height: 56px;
  border-radius: 15px;
  color: var(--mr2-green-ink);
  background: rgba(237,243,238,.86);
  border: 1px solid rgba(53,95,82,.10);
  font-size: 9.5px;
  line-height: 1.2;
  font-weight: 950;
  writing-mode: vertical-rl;
  letter-spacing: .05em;
}

.mr2-matrix-row span {
  display: grid;
  place-items: center;
  gap: 2px;
  min-width: 0;
  min-height: 56px;
  padding: 5px 2px;
  border-radius: 15px;
  background: rgba(255,255,255,.88);
  border: 1px solid rgba(211,225,213,.74);
  box-shadow: 0 10px 20px -18px rgba(31,52,44,.22);
}

.mr2-matrix-row img {
  width: 32px;
  height: 32px;
  object-fit: contain;
}

.mr2-matrix-row small {
  display: block;
  max-width: 100%;
  color: var(--mr2-text);
  font-size: 8.8px;
  line-height: 1.1;
  font-weight: 900;
  letter-spacing: -.04em;
  white-space: nowrap;
}

.mr2-body-factor-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 7px;
  margin-top: 9px;
}

.mr2-body-factor-grid > span {
  display: flex;
  align-items: center;
  gap: 7px;
  min-width: 0;
  min-height: 44px;
  padding: 7px 8px;
  border-radius: 16px;
  background: rgba(237,243,238,.78);
  border: 1px solid rgba(53,95,82,.10);
}

.mr2-body-factor-grid img {
  width: 22px;
  height: 22px;
  flex: 0 0 auto;
}

.mr2-body-factor-text {
  display: grid;
  gap: 2px;
  min-width: 0;
}

.mr2-body-factor-grid b {
  min-width: 0;
  color: var(--mr2-green-ink);
  font-size: 10.8px;
  line-height: 1.05;
  font-weight: 950;
  white-space: nowrap;
}

.mr2-body-factor-grid small {
  display: block;
  min-width: 0;
  color: rgba(92,110,130,.88);
  font-size: 8.6px;
  line-height: 1.12;
  font-weight: 850;
  letter-spacing: -.05em;
  white-space: nowrap;
}

.mr2-node-weather-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 7px;
  margin-top: 13px;
}

.mr2-node-weather-grid span {
  display: grid;
  place-items: center;
  gap: 4px;
  min-height: 68px;
  padding: 8px 4px;
  border-radius: 18px;
  text-align: center;
  background: linear-gradient(180deg, rgba(255,255,255,.96), rgba(248,249,245,.88));
  border: 1px solid rgba(211,225,213,.78);
}

.mr2-node-weather-grid img {
  width: 26px;
  height: 26px;
}

.mr2-node-weather-grid b {
  color: var(--mr2-text);
  font-size: 10.2px;
  line-height: 1.2;
  font-weight: 900;
}

.mr2-symptom-chip-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 7px;
  margin-top: 13px;
  padding: 10px;
  border-radius: 22px;
  background:
    radial-gradient(circle at 90% 8%, rgba(var(--mr2-amber-rgb), .20), transparent 7rem),
    rgba(248,249,245,.78);
  border: 1px solid rgba(211,225,213,.68);
}

.mr2-symptom-chip-grid span {
  display: flex;
  align-items: center;
  min-height: 36px;
  padding: 8px 10px;
  border-radius: 14px;
  color: var(--mr2-text);
  background: rgba(255,255,255,.84);
  border: 1px solid rgba(211,225,213,.66);
  font-size: 11.2px;
  line-height: 1.25;
  font-weight: 850;
  letter-spacing: -.04em;
}

.mr2-symptom-chip-grid span::before {
  content: "";
  flex: 0 0 auto;
  width: 6px;
  height: 6px;
  margin-right: 6px;
  border-radius: 999px;
  background: var(--mr2-amber);
}

.mr2-concept-merge {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 6px;
  margin: 14px auto 12px;
  color: rgba(37,95,79,.64);
  font-size: 12px;
  line-height: 1;
  font-weight: 950;
}

.mr2-concept-merge span {
  display: inline-flex;
  align-items: center;
  min-height: 32px;
  padding: 7px 10px;
  border-radius: 999px;
  color: var(--mr2-green-ink);
  background: rgba(255,255,255,.78);
  border: 1px solid rgba(211,225,213,.74);
}

.mr2-concept-merge i {
  font-style: normal;
}

.mr2-concept-merge b {
  flex-basis: 100%;
  color: var(--mr2-amber-deep);
  font-size: 20px;
  line-height: .8;
  text-align: center;
}

.mr2-concept-output-v4 {
  display: grid;
  gap: 11px;
  padding: 16px;
  border-radius: 28px;
  background:
    radial-gradient(circle at 92% 0%, rgba(var(--mr2-amber-rgb), .23), transparent 10rem),
    linear-gradient(180deg, rgba(255,255,255,.97), rgba(250,251,246,.92));
  border: 1px solid rgba(53,95,82,.12);
  box-shadow: 0 18px 38px -32px rgba(31,52,44,.25);
}

.mr2-output-copy-v4 h3 {
  margin: 0 0 6px;
  color: var(--mr2-green-ink);
  font-size: 18px;
  line-height: 1.44;
  letter-spacing: -.04em;
}

.mr2-output-copy-v4 p:not(.mr2-concept-step-kicker) {
  margin: 0;
  color: var(--mr2-soft);
  font-size: 13px;
  line-height: 1.78;
}

.mr2-output-mode-grid {
  display: grid;
  gap: 8px;
}

.mr2-output-mode-grid span {
  position: relative;
  display: grid;
  gap: 3px;
  min-height: 58px;
  padding: 12px 12px 12px 36px;
  border-radius: 18px;
  background: rgba(255,255,255,.84);
  border: 1px solid rgba(211,225,213,.74);
  box-shadow: 0 12px 22px -20px rgba(31,52,44,.22);
}

.mr2-output-mode-grid span::before {
  content: "";
  position: absolute;
  left: 14px;
  top: 17px;
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: var(--mr2-green);
  box-shadow: 0 0 0 5px rgba(92,159,136,.12);
}

.mr2-output-mode-grid span:nth-child(2)::before {
  background: var(--mr2-amber);
  box-shadow: 0 0 0 5px rgba(var(--mr2-amber-rgb), .23);
}

.mr2-output-mode-grid span:nth-child(3)::before {
  background: #d48756;
  box-shadow: 0 0 0 5px rgba(212,135,86,.13);
}

.mr2-output-mode-grid b {
  color: var(--mr2-text);
  font-size: 13.2px;
  line-height: 1.2;
  font-weight: 950;
}

.mr2-output-mode-grid small {
  color: var(--mr2-soft);
  font-size: 11.5px;
  line-height: 1.35;
  font-weight: 800;
}

.mr2-output-tabs-v4 {
  display: grid;
  gap: 8px;
}

.mr2-output-tabs-v4 span {
  display: grid;
  gap: 3px;
  padding: 10px 12px;
  border-radius: 18px;
  background: rgba(248,249,245,.85);
  border: 1px solid rgba(211,225,213,.76);
}

.mr2-output-tabs-v4 b {
  color: var(--mr2-green-ink);
  font-size: 12.5px;
  line-height: 1;
  font-weight: 950;
}

.mr2-output-tabs-v4 small {
  color: var(--mr2-soft);
  font-size: 11.5px;
  line-height: 1.35;
  font-weight: 800;
}

.mr2-output-care-v4 {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}

.mr2-output-care-v4 span {
  display: grid;
  place-items: center;
  gap: 5px;
  min-height: 66px;
  padding: 8px 4px;
  border-radius: 18px;
  color: var(--mr2-text);
  background: rgba(255,255,255,.82);
  border: 1px solid rgba(53,95,82,.10);
  font-size: 12px;
  line-height: 1;
  font-weight: 900;
}

.mr2-output-care-v4 img {
  width: 28px;
  height: 28px;
}

.mr2.mr2-js .mr2-concept-board-v4.is-sequenced .mr2-concept-map-head,
.mr2.mr2-js .mr2-concept-board-v4.is-sequenced .mr2-concept-node,
.mr2.mr2-js .mr2-concept-board-v4.is-sequenced .mr2-matrix-row span,
.mr2.mr2-js .mr2-concept-board-v4.is-sequenced .mr2-body-factor-grid > span,
.mr2.mr2-js .mr2-concept-board-v4.is-sequenced .mr2-node-weather-grid span,
.mr2.mr2-js .mr2-concept-board-v4.is-sequenced .mr2-symptom-chip-grid span,
.mr2.mr2-js .mr2-concept-board-v4.is-sequenced .mr2-concept-output-v4,
.mr2.mr2-js .mr2-concept-board-v4.is-sequenced .mr2-output-mode-grid span,
.mr2.mr2-js .mr2-concept-board-v4.is-sequenced .mr2-output-care-v4 span {
  animation: mr2-concept-pop .58s cubic-bezier(.22, 1, .36, 1) both;
  animation-delay: calc(var(--mr2-chip-index, 0) * 34ms);
}

@media (max-width: 370px) {
  .mr2-concept-board-v4 {
    padding: 12px;
    border-radius: 30px;
  }

  .mr2-concept-map-head,
  .mr2-concept-node,
  .mr2-concept-output-v4 {
    border-radius: 24px;
  }

  .mr2-node-head {
    grid-template-columns: 34px minmax(0, 1fr);
    gap: 8px;
  }

  .mr2-matrix-row,
  .mr2-matrix-label-top {
    grid-template-columns: 48px repeat(3, minmax(0, 1fr));
  }

  .mr2-matrix-row > b {
    font-size: 8.5px;
  }

  .mr2-matrix-row img {
    width: 29px;
    height: 29px;
  }

  .mr2-matrix-row small {
    font-size: 8px;
  }

  .mr2-node-weather-grid {
    gap: 6px;
  }

  .mr2-node-weather-grid span {
    min-height: 64px;
  }

  .mr2-node-weather-grid b,
  .mr2-body-factor-grid b,
  .mr2-symptom-chip-grid span {
    font-size: 9.6px;
  }

  .mr2-body-factor-grid small {
    font-size: 7.8px;
  }
}

@media (min-width: 760px) {
  .mr2-concept-board-v4 {
    padding: 22px;
    border-radius: 38px;
  }

  .mr2-concept-map-head {
    padding: 24px;
  }

  .mr2-concept-map {
    grid-template-columns: minmax(0, 1.18fr) minmax(0, .91fr) minmax(0, .91fr);
    gap: 14px;
    margin-top: 16px;
  }

  .mr2-concept-node {
    padding: 18px;
  }

  .mr2-body-factor-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .mr2-node-weather-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .mr2-concept-merge {
    margin-block: 18px 14px;
  }

  .mr2-concept-merge b {
    flex-basis: auto;
    padding-inline: 5px;
    transform: rotate(-90deg);
  }

  .mr2-concept-output-v4 {
    grid-template-columns: minmax(0, .92fr) minmax(0, 1fr);
    align-items: start;
    gap: 14px 18px;
    padding: 18px;
  }

  .mr2-output-copy-v4 {
    grid-column: 1;
    grid-row: 1 / span 3;
  }

  .mr2-output-mode-grid {
    grid-column: 2;
  }

  .mr2-output-tabs-v4 {
    grid-column: 2;
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .mr2-output-care-v4 {
    grid-column: 2;
  }
}

@media (min-width: 1020px) {
  .mr2-concept-map-head {
    display: grid;
    grid-template-columns: minmax(0, .72fr) minmax(0, 1fr);
    column-gap: 28px;
    align-items: center;
  }

  .mr2-concept-map-head .mr2-concept-label,
  .mr2-concept-map-head h3 {
    grid-column: 1;
  }

  .mr2-concept-map-head p:not(.mr2-concept-label) {
    grid-column: 2;
    grid-row: 1 / span 2;
  }
}

/* v3.4 readability tuning: larger mobile visuals and stronger text contrast */
:root {
  --mr2-soft: #435265;
  --mr2-muted: #728094;
}

.mr2-body,
.mr2-section-head p {
  color: var(--mr2-soft);
  font-size: 15px;
  line-height: 1.92;
  font-weight: 500;
}

.mr2-concept .mr2-section-head p {
  color: #465569;
  font-size: 15.5px;
  line-height: 1.95;
  font-weight: 500;
}

.mr2-concept-map-head {
  padding: 20px;
}

.mr2-concept-map-head h3 {
  font-size: 21.5px;
  line-height: 1.42;
}

.mr2-concept-map-head p:not(.mr2-concept-label) {
  color: #465569;
  font-size: 14.7px;
  line-height: 1.9;
  font-weight: 500;
}

.mr2-concept-node {
  padding: 18px 16px 16px;
}

.mr2-node-head {
  grid-template-columns: 42px minmax(0, 1fr);
  gap: 12px;
}

.mr2-node-icon {
  width: 38px;
  height: 38px;
  font-size: 13px;
}

.mr2-node-copy h3 {
  font-size: 19.5px;
  line-height: 1.34;
}

.mr2-node-copy p:not(.mr2-concept-step-kicker) {
  color: #4a596c;
  font-size: 14.4px;
  line-height: 1.78;
  font-weight: 500;
}

.mr2-concept-step-kicker {
  color: var(--mr2-green-deep);
  font-size: 12px;
}

.mr2-animal-matrix {
  gap: 8px;
  margin-top: 16px;
  padding: 10px;
  border-radius: 24px;
}

.mr2-matrix-label-top,
.mr2-matrix-row {
  grid-template-columns: 48px repeat(3, minmax(0, 1fr));
  gap: 6px;
}

.mr2-matrix-label-top span {
  color: #647286;
  font-size: 10.5px;
}

.mr2-matrix-row > b {
  min-height: 66px;
  font-size: 10.5px;
}

.mr2-matrix-row span {
  min-height: 66px;
  padding: 6px 2px;
}

.mr2-matrix-row img {
  width: 38px;
  height: 38px;
}

.mr2-matrix-row small {
  color: #121b2b;
  font-size: 9.8px;
  font-weight: 950;
}

.mr2-body-factor-grid {
  gap: 9px;
  margin-top: 11px;
}

.mr2-body-factor-grid > span {
  gap: 8px;
  min-height: 54px;
  padding: 9px 10px;
  border-radius: 18px;
}

.mr2-body-factor-grid img {
  width: 28px;
  height: 28px;
}

.mr2-body-factor-grid b {
  font-size: 13.2px;
  line-height: 1.08;
}

.mr2-body-factor-grid small {
  color: #59687a;
  font-size: 11.2px;
  line-height: 1.15;
  font-weight: 850;
}

.mr2-node-weather-grid {
  gap: 9px;
  margin-top: 15px;
}

.mr2-node-weather-grid span {
  min-height: 84px;
  gap: 6px;
  padding: 10px 4px;
  border-radius: 20px;
}

.mr2-node-weather-grid img {
  width: 34px;
  height: 34px;
}

.mr2-node-weather-grid b {
  color: #121b2b;
  font-size: 12.4px;
  line-height: 1.2;
  font-weight: 950;
}

.mr2-symptom-chip-grid {
  gap: 9px;
  margin-top: 15px;
  padding: 12px;
}

.mr2-symptom-chip-grid span {
  min-height: 44px;
  padding: 9px 11px;
  border-radius: 16px;
  color: #121b2b;
  font-size: 13.2px;
  line-height: 1.25;
  font-weight: 900;
}

.mr2-symptom-chip-grid span::before {
  width: 7px;
  height: 7px;
  margin-right: 7px;
}

.mr2-concept-merge {
  margin: 16px auto 14px;
  font-size: 13.4px;
}

.mr2-concept-merge span {
  min-height: 36px;
  padding: 8px 12px;
}

.mr2-concept-output-v4 {
  gap: 13px;
  padding: 19px 17px;
  border-radius: 30px;
}

.mr2-output-copy-v4 h3 {
  font-size: 21px;
  line-height: 1.42;
}

.mr2-output-copy-v4 p:not(.mr2-concept-step-kicker) {
  color: #465569;
  font-size: 14.6px;
  line-height: 1.9;
  font-weight: 500;
}

.mr2-output-mode-grid {
  gap: 9px;
}

.mr2-output-mode-grid span {
  min-height: 64px;
  padding: 13px 13px 13px 40px;
  border-radius: 20px;
}

.mr2-output-mode-grid span::before {
  left: 15px;
  top: 19px;
  width: 12px;
  height: 12px;
}

.mr2-output-mode-grid b {
  color: #121b2b;
  font-size: 15.2px;
  line-height: 1.2;
}

.mr2-output-mode-grid small {
  color: #4f5f72;
  font-size: 13.2px;
  line-height: 1.35;
  font-weight: 850;
}

.mr2-output-care-v4 {
  gap: 9px;
}

.mr2-output-care-v4 span {
  min-height: 76px;
  gap: 6px;
  border-radius: 20px;
  font-size: 13.2px;
  font-weight: 950;
}

.mr2-output-care-v4 img {
  width: 34px;
  height: 34px;
}

@media (max-width: 370px) {
  .mr2-concept-map-head h3 {
    font-size: 20px;
  }

  .mr2-concept-map-head p:not(.mr2-concept-label),
  .mr2-node-copy p:not(.mr2-concept-step-kicker),
  .mr2-output-copy-v4 p:not(.mr2-concept-step-kicker) {
    font-size: 14px;
  }

  .mr2-node-head {
    grid-template-columns: 38px minmax(0, 1fr);
    gap: 10px;
  }

  .mr2-node-icon {
    width: 36px;
    height: 36px;
  }

  .mr2-matrix-label-top,
  .mr2-matrix-row {
    grid-template-columns: 44px repeat(3, minmax(0, 1fr));
    gap: 5px;
  }

  .mr2-matrix-row img {
    width: 34px;
    height: 34px;
  }

  .mr2-matrix-row small {
    font-size: 9px;
  }

  .mr2-body-factor-grid > span {
    gap: 6px;
    padding-inline: 8px;
  }

  .mr2-body-factor-grid img {
    width: 25px;
    height: 25px;
  }

  .mr2-body-factor-grid b {
    font-size: 12.2px;
  }

  .mr2-body-factor-grid small {
    font-size: 10.2px;
  }

  .mr2-node-weather-grid span {
    min-height: 78px;
  }

  .mr2-node-weather-grid img {
    width: 31px;
    height: 31px;
  }

  .mr2-symptom-chip-grid span {
    font-size: 12.2px;
    padding-inline: 9px;
  }
}


/* Body layer labels: clarify core type vs qi-blood-fluid details. */
.mr2-body-layer-head {
  display: grid;
  gap: 3px;
  margin: 15px 1px 8px;
}

.mr2-body-layer-head b {
  color: #183d34;
  font-size: 13.6px;
  line-height: 1.25;
  font-weight: 950;
  letter-spacing: -.02em;
}

.mr2-body-layer-head small {
  color: #4f5f72;
  font-size: 12.2px;
  line-height: 1.58;
  font-weight: 750;
}

.mr2-body-layer-head + .mr2-animal-matrix,
.mr2-body-layer-head + .mr2-body-factor-grid {
  margin-top: 8px;
}

.mr2-body-layer-head-factors {
  margin-top: 15px;
}

@media (max-width: 370px) {
  .mr2-body-layer-head b {
    font-size: 13px;
  }

  .mr2-body-layer-head small {
    font-size: 11.6px;
    line-height: 1.5;
  }
}

/* Concept icon balance tuning: animal label is the primary layer, body-factor icons stay secondary. */
.mr2-matrix-row > b,
.mr2-matrix-row span {
  min-height: 74px;
}

.mr2-matrix-row img {
  width: 50px;
  height: 44px;
}

.mr2-body-factor-grid > span {
  min-height: 58px;
}

.mr2-body-factor-grid img {
  width: 31px;
  height: 31px;
}

@media (max-width: 370px) {
  .mr2-matrix-row > b,
  .mr2-matrix-row span {
    min-height: 68px;
  }

  .mr2-matrix-row img {
    width: 44px;
    height: 40px;
  }

  .mr2-body-factor-grid > span {
    min-height: 54px;
  }

  .mr2-body-factor-grid img {
    width: 28px;
    height: 28px;
  }
}

/* Output card refinement: show what appears in the app, with less explanatory copy. */
.mr2-concept-output-v4 {
  position: relative;
  gap: 12px;
  overflow: hidden;
}

.mr2-concept-output-v4::after {
  content: '';
  position: absolute;
  top: -28px;
  right: -24px;
  width: 168px;
  height: 168px;
  border-radius: 999px;
  background-image: url('../images/mibyo-lp/icons/ui/orbit-mark.svg');
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  opacity: .28;
  pointer-events: none;
  z-index: 0;
  transform: rotate(-8deg);
}

.mr2-output-copy-v4,
.mr2-output-block {
  position: relative;
  z-index: 1;
}

.mr2-output-copy-v4 h3 {
  margin-bottom: 5px;
}

.mr2-output-copy-v4 p:not(.mr2-concept-step-kicker) {
  max-width: 28em;
  color: #3f5062;
  font-size: 14.2px;
  line-height: 1.65;
  font-weight: 700;
}

.mr2-output-block {
  display: grid;
  gap: 9px;
  padding: 12px;
  border-radius: 22px;
  background: rgba(255,255,255,.78);
  border: 1px solid rgba(53,95,82,.10);
  box-shadow: 0 12px 24px -24px rgba(31,52,44,.26);
}

.mr2-output-block-head {
  display: flex;
  align-items: center;
  gap: 8px;
  color: #1f3f35;
  font-size: 13.5px;
  line-height: 1.1;
  font-weight: 950;
  letter-spacing: -.02em;
}

.mr2-output-block-head img {
  width: 24px;
  height: 24px;
  flex: 0 0 auto;
}

.mr2-output-block-modes .mr2-output-mode-grid {
  gap: 7px;
}

.mr2-output-block-modes .mr2-output-mode-grid span {
  min-height: 56px;
  padding: 11px 11px 11px 38px;
  border-radius: 18px;
  background: rgba(250,252,249,.92);
}

.mr2-output-block-modes .mr2-output-mode-grid span::before {
  left: 14px;
  top: 17px;
}

.mr2-output-sign-chip-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 7px;
}

.mr2-output-sign-chip-grid span {
  display: grid;
  place-items: center;
  min-height: 36px;
  padding: 7px 5px;
  border-radius: 999px;
  color: #253145;
  background: rgba(248,249,245,.94);
  border: 1px solid rgba(211,225,213,.78);
  font-size: 12.4px;
  line-height: 1.15;
  font-weight: 900;
  text-align: center;
}

.mr2-output-block-care .mr2-output-care-v4 span {
  min-height: 72px;
  padding-inline: 3px;
}

.mr2-output-block-care .mr2-output-care-v4 img {
  width: 32px;
  height: 32px;
}

@media (min-width: 760px) {
  .mr2-concept-output-v4 {
    grid-template-columns: minmax(0, .84fr) minmax(0, 1fr);
    gap: 13px 16px;
  }

  .mr2-output-copy-v4 {
    grid-column: 1;
    grid-row: 1 / span 3;
  }

  .mr2-output-block {
    grid-column: 2;
  }
}

@media (max-width: 370px) {
  .mr2-concept-output-v4::after {
    top: -18px;
    right: -16px;
    width: 134px;
    height: 134px;
  }

  .mr2-output-copy-v4 p:not(.mr2-concept-step-kicker) {
    font-size: 13.4px;
    line-height: 1.6;
  }

  .mr2-output-block {
    padding: 10px;
    border-radius: 20px;
  }

  .mr2-output-block-head {
    font-size: 13px;
  }

  .mr2-output-block-head img {
    width: 22px;
    height: 22px;
  }

  .mr2-output-sign-chip-grid span {
    min-height: 34px;
    font-size: 11.7px;
  }

  .mr2-output-block-care .mr2-output-care-v4 span {
    min-height: 68px;
    font-size: 12.1px;
  }
}


/* HOW IT WORKS: show more of the next card on smartphone horizontal scroll */
@media (max-width: 719px) {
  .mr2-step-scroll {
    gap: 12px;
    padding-right: 72px !important;
  }

  .mr2-step-card {
    flex-basis: min(78vw, 312px);
  }

  .mr2-step-scroll::after {
    flex-basis: 34px !important;
  }
}

/* Core type legend: short definitions below animal matrix. */
.mr2-core-legend {
  display: grid;
  grid-template-columns: 1fr;
  gap: 6px;
  margin: 10px 1px 16px;
}

.mr2-core-legend span {
  display: grid;
  grid-template-columns: 58px 1fr;
  align-items: center;
  gap: 8px;
  padding: 8px 10px;
  border-radius: 14px;
  background: rgba(255,255,255,.64);
  border: 1px solid rgba(61,99,86,.08);
}

.mr2-core-legend b {
  color: #1e4f43;
  font-size: 11.8px;
  line-height: 1.2;
  font-weight: 950;
}

.mr2-core-legend small {
  color: #45576a;
  font-size: 11.5px;
  line-height: 1.45;
  font-weight: 760;
}

.mr2-body-layer-head-core {
  margin-bottom: 7px;
}

@media (max-width: 370px) {
  .mr2-core-legend span {
    grid-template-columns: 52px 1fr;
    padding: 7px 9px;
  }

  .mr2-core-legend b {
    font-size: 11.3px;
  }

  .mr2-core-legend small {
    font-size: 10.9px;
  }
}

/* v13 FREE section: lighter structure, one role per surface. */
.mr2-free-start .mr2-section-head {
  margin-bottom: 24px;
}

.mr2-free-layout {
  display: grid;
  gap: 14px;
}

.mr2-free-main-card {
  position: relative;
  overflow: visible;
  margin-top: 32px;
  padding: 25px 16px 16px;
  border-radius: 30px;
  background:
    linear-gradient(145deg, rgba(255, 252, 242, .92), rgba(246, 251, 247, .82));
  border: 1px solid rgba(var(--mr2-amber-rgb), .32);
  box-shadow: 0 24px 56px -42px rgba(31, 52, 44, .42);
}

.mr2-free-main-card::before {
  content: "";
  position: absolute;
  top: -48px;
  right: -42px;
  width: 210px;
  height: 210px;
  background-image: url('../images/mibyo-lp/icons/ui/orbit-mark.svg');
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  opacity: .26;
  transform: rotate(-7deg);
  pointer-events: none;
  z-index: 0;
}

.mr2-free-main-card > * {
  position: relative;
  z-index: 1;
}

.mr2-free-main-card h3 {
  margin: 0 78px 14px 0;
  color: var(--mr2-green-ink);
  font-size: 19px;
  line-height: 1.35;
  font-weight: 900;
  letter-spacing: .02em;
}

.mr2-free-bot {
  position: absolute;
  top: -46px;
  right: 24px;
  width: 74px;
  z-index: 3;
  pointer-events: none;
  filter: drop-shadow(0 13px 13px rgba(43, 71, 58, .12));
}

.mr2-free-list {
  display: grid;
  gap: 6px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.mr2-free-list li {
  display: grid;
  grid-template-columns: 38px 1fr 20px;
  align-items: center;
  gap: 10px;
  min-height: 58px;
  padding: 10px 12px;
  border-radius: 20px;
  color: var(--mr2-text);
  background: rgba(255, 255, 255, .68);
  border: 1px solid rgba(211, 225, 213, .72);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.70);
}

.mr2-free-list li:nth-child(even) {
  background: rgba(255, 255, 255, .52);
}

.mr2-free-icon {
  display: grid;
  width: 38px;
  height: 38px;
  place-items: center;
  border-radius: 15px;
  background: rgba(237, 247, 242, .88);
  border: 1px solid rgba(90, 165, 139, .18);
}

.mr2-free-icon img {
  width: 23px;
  height: 23px;
}

.mr2-free-list b {
  min-width: 0;
  font-size: 15px;
  line-height: 1.38;
  font-weight: 900;
  letter-spacing: .005em;
}

.mr2-free-check {
  position: relative;
  display: block;
  width: 18px;
  height: 18px;
  border-radius: 999px;
  background: rgba(90, 165, 139, .12);
  border: 1px solid rgba(90, 165, 139, .16);
}

.mr2-free-check::after {
  content: "";
  position: absolute;
  left: 5px;
  top: 3px;
  width: 5px;
  height: 8px;
  border-right: 2px solid var(--mr2-green-ink);
  border-bottom: 2px solid var(--mr2-green-ink);
  transform: rotate(42deg);
  opacity: .9;
}

.mr2-dev-mini-card {
  margin-top: 0;
  padding: 16px;
  border-radius: 26px;
  background: rgba(237, 243, 238, .74);
  border: 1px solid rgba(53, 95, 82, .10);
  box-shadow: 0 18px 44px -38px rgba(31, 52, 44, .30);
}

.mr2-dev-title {
  margin: 0 0 6px !important;
  color: var(--mr2-green-ink) !important;
  font-size: 14px !important;
  line-height: 1.4;
  font-weight: 900;
  letter-spacing: .02em;
}

.mr2-dev-mini-card p:not(.mr2-dev-title) {
  margin: 0 0 10px;
  color: var(--mr2-soft-readable);
  font-size: 13.4px;
  line-height: 1.78;
}

.mr2-dev-mini-card a {
  color: var(--mr2-green-ink);
  font-size: 13px;
  font-weight: 850;
  text-decoration: underline;
  text-underline-offset: 4px;
}

.mr2-final {
  padding-top: 0;
}

@media (min-width: 760px) {
  .mr2-free-start .mr2-section-head {
    margin-bottom: 30px;
  }

  .mr2-free-layout {
    grid-template-columns: minmax(0, 1.08fr) minmax(260px, .82fr);
    align-items: stretch;
    gap: 18px;
  }

  .mr2-free-main-card {
    margin-top: 38px;
    padding: 30px 22px 22px;
    border-radius: 34px;
  }

  .mr2-free-main-card::before {
    width: 250px;
    height: 250px;
    top: -58px;
    right: -52px;
    opacity: .25;
  }

  .mr2-free-main-card h3 {
    margin-right: 104px;
    margin-bottom: 16px;
    font-size: 22px;
  }

  .mr2-free-bot {
    width: 92px;
    top: -58px;
    right: 32px;
  }

  .mr2-free-list {
    gap: 8px;
  }

  .mr2-free-list li {
    min-height: 64px;
    grid-template-columns: 42px 1fr 22px;
    padding: 12px 14px;
    border-radius: 22px;
  }

  .mr2-free-icon {
    width: 42px;
    height: 42px;
    border-radius: 16px;
  }

  .mr2-free-icon img {
    width: 25px;
    height: 25px;
  }

  .mr2-free-list b {
    font-size: 15.8px;
  }

  .mr2-dev-mini-card {
    align-self: end;
    display: grid;
    align-content: center;
    min-height: calc(100% - 38px);
    padding: 20px;
    border-radius: 30px;
  }
}

@media (max-width: 370px) {
  .mr2-free-main-card {
    margin-top: 28px;
    padding: 23px 13px 13px;
    border-radius: 27px;
  }

  .mr2-free-main-card h3 {
    margin-right: 64px;
    font-size: 17.4px;
  }

  .mr2-free-bot {
    top: -40px;
    right: 18px;
    width: 64px;
  }

  .mr2-free-list li {
    grid-template-columns: 34px 1fr 18px;
    min-height: 54px;
    gap: 9px;
    padding: 9px 10px;
    border-radius: 18px;
  }

  .mr2-free-icon {
    width: 34px;
    height: 34px;
    border-radius: 13px;
  }

  .mr2-free-icon img {
    width: 21px;
    height: 21px;
  }

  .mr2-free-list b {
    font-size: 13.8px;
  }
}

/* v12 FAQ cards */
.mr2-faq-list {
  display: grid;
  gap: 10px;
}

.mr2-faq-item {
  border-radius: 22px;
  background: rgba(255,255,255,.82);
  border: 1px solid rgba(211,225,213,.88);
  box-shadow: 0 16px 36px -34px rgba(31,52,44,.36);
  overflow: hidden;
}

.mr2-faq-item[open] {
  background: linear-gradient(180deg, rgba(255,255,255,.92), rgba(247,251,247,.78));
  border-color: rgba(90,165,139,.24);
}

.mr2-faq-item summary {
  display: grid;
  grid-template-columns: 1fr 34px;
  align-items: center;
  gap: 12px;
  padding: 15px 15px 15px 16px;
  color: var(--mr2-text);
  font-size: 14.2px;
  line-height: 1.55;
  font-weight: 850;
  letter-spacing: .01em;
  cursor: pointer;
  list-style: none;
}

.mr2-faq-item summary::-webkit-details-marker {
  display: none;
}

.mr2-faq-item summary::after {
  content: "+";
  display: grid;
  width: 34px;
  height: 34px;
  place-items: center;
  border-radius: 999px;
  color: var(--mr2-green-ink);
  background: rgba(237,247,242,.88);
  border: 1px solid rgba(90,165,139,.20);
  font-size: 20px;
  line-height: 1;
  font-weight: 600;
}

.mr2-faq-item[open] summary::after {
  content: "−";
  color: #9d6c14;
  background: rgba(255,247,225,.9);
  border-color: rgba(var(--mr2-amber-rgb), .34);
}

.mr2-faq-item p {
  margin: 0;
  padding: 0 16px 16px;
  color: var(--mr2-soft-readable);
  font-size: 13.4px;
  line-height: 1.78;
}

@media (min-width: 760px) {
  .mr2-faq-list {
    max-width: 820px;
    margin: 0 auto;
    gap: 12px;
  }

  .mr2-faq-item summary {
    padding: 18px 20px;
    font-size: 15.2px;
  }

  .mr2-faq-item p {
    padding: 0 20px 18px;
    font-size: 14.4px;
  }
}

@media (max-width: 370px) {
  .mr2-faq-item summary {
    grid-template-columns: 1fr 30px;
    padding: 14px 13px 14px 14px;
    font-size: 13.5px;
  }

  .mr2-faq-item summary::after {
    width: 30px;
    height: 30px;
  }
}

/* Concept motion v5: functional scroll guidance for mobile-first reading. */
.mr2-concept-board-v4.mr2-concept-motion-v5 {
  --mr2-concept-progress: 0;
}

.mr2.mr2-js .mr2-concept-motion-v5 .mr2-concept-node,
.mr2.mr2-js .mr2-concept-motion-v5 .mr2-concept-merge,
.mr2.mr2-js .mr2-concept-motion-v5 .mr2-concept-output-v4 {
  transition:
    opacity .62s cubic-bezier(.22, 1, .36, 1),
    transform .62s cubic-bezier(.22, 1, .36, 1),
    border-color .62s cubic-bezier(.22, 1, .36, 1),
    box-shadow .62s cubic-bezier(.22, 1, .36, 1),
    background-color .62s cubic-bezier(.22, 1, .36, 1);
  will-change: transform, opacity;
}

.mr2.mr2-js .mr2-concept-motion-v5 .mr2-concept-node::after,
.mr2.mr2-js .mr2-concept-motion-v5 .mr2-concept-output-v4::before {
  content: "";
  position: absolute;
  left: 0;
  top: 18px;
  bottom: 18px;
  width: 4px;
  border-radius: 999px;
  background: linear-gradient(180deg, var(--mr2-green), var(--mr2-amber));
  opacity: 0;
  transform: scaleY(.55);
  transform-origin: center;
  transition: opacity .48s cubic-bezier(.22, 1, .36, 1), transform .62s cubic-bezier(.22, 1, .36, 1);
}

.mr2.mr2-js .mr2-concept-motion-v5 .mr2-concept-node.is-concept-current,
.mr2.mr2-js .mr2-concept-motion-v5 .mr2-concept-output-v4.is-concept-current {
  opacity: 1;
  transform: translateY(-3px) scale(1.006);
  border-color: rgba(53,95,82,.24);
  box-shadow: 0 24px 52px -38px rgba(31,52,44,.38), 0 1px 0 rgba(255,255,255,.86) inset;
}

.mr2.mr2-js .mr2-concept-motion-v5 .mr2-concept-node.is-concept-current::after,
.mr2.mr2-js .mr2-concept-motion-v5 .mr2-concept-output-v4.is-concept-current::before {
  opacity: .92;
  transform: scaleY(1);
}

.mr2.mr2-js .mr2-concept-motion-v5 .mr2-concept-node.is-concept-after,
.mr2.mr2-js .mr2-concept-motion-v5 .mr2-concept-output-v4.is-concept-after {
  opacity: .78;
  transform: translateY(5px) scale(.992);
}

.mr2.mr2-js .mr2-concept-motion-v5 .mr2-concept-node.is-concept-before,
.mr2.mr2-js .mr2-concept-motion-v5 .mr2-concept-output-v4.is-concept-before {
  opacity: .92;
  transform: translateY(0) scale(.996);
}

.mr2.mr2-js .mr2-concept-motion-v5 .mr2-concept-node.is-concept-current .mr2-node-icon {
  transform: scale(1.06);
  box-shadow: 0 18px 34px -20px rgba(37,95,79,.62);
}

.mr2.mr2-js .mr2-concept-motion-v5 .mr2-node-icon {
  transition: transform .62s cubic-bezier(.22, 1, .36, 1), box-shadow .62s cubic-bezier(.22, 1, .36, 1);
}

.mr2.mr2-js .mr2-concept-motion-v5 .mr2-concept-node.is-concept-current .mr2-matrix-row span,
.mr2.mr2-js .mr2-concept-motion-v5 .mr2-concept-node.is-concept-current .mr2-body-factor-grid > span,
.mr2.mr2-js .mr2-concept-motion-v5 .mr2-concept-node.is-concept-current .mr2-node-weather-grid span,
.mr2.mr2-js .mr2-concept-motion-v5 .mr2-concept-node.is-concept-current .mr2-symptom-chip-grid span,
.mr2.mr2-js .mr2-concept-motion-v5 .mr2-concept-output-v4.is-concept-current .mr2-output-block {
  transform: translateY(-1px);
  filter: saturate(1.04);
}

.mr2.mr2-js .mr2-concept-motion-v5 .mr2-matrix-row span,
.mr2.mr2-js .mr2-concept-motion-v5 .mr2-body-factor-grid > span,
.mr2.mr2-js .mr2-concept-motion-v5 .mr2-node-weather-grid span,
.mr2.mr2-js .mr2-concept-motion-v5 .mr2-symptom-chip-grid span,
.mr2.mr2-js .mr2-concept-motion-v5 .mr2-output-block {
  transition: transform .48s cubic-bezier(.22, 1, .36, 1), filter .48s cubic-bezier(.22, 1, .36, 1), box-shadow .48s cubic-bezier(.22, 1, .36, 1);
}

.mr2.mr2-js .mr2-concept-motion-v5 .mr2-concept-merge.is-concept-current {
  opacity: 1;
  transform: translateY(-2px);
}

.mr2.mr2-js .mr2-concept-motion-v5 .mr2-concept-merge.is-concept-after {
  opacity: .74;
}

.mr2.mr2-js .mr2-concept-motion-v5 .mr2-concept-merge.is-concept-current span {
  background: rgba(255,255,255,.96);
  border-color: rgba(53,95,82,.20);
  box-shadow: 0 12px 24px -22px rgba(31,52,44,.30);
}

.mr2.mr2-js .mr2-concept-motion-v5 .mr2-concept-merge.is-concept-current b {
  transform: translateY(2px);
}

@media (max-width: 759px) {
  .mr2-concept-motion-v5 .mr2-concept-map {
    position: relative;
  }

  .mr2-concept-motion-v5 .mr2-concept-map::before,
  .mr2-concept-motion-v5 .mr2-concept-map::after {
    content: "";
    position: absolute;
    left: 28px;
    top: 46px;
    bottom: 46px;
    width: 3px;
    border-radius: 999px;
    pointer-events: none;
    z-index: 0;
  }

  .mr2-concept-motion-v5 .mr2-concept-map::before {
    background: rgba(53,95,82,.10);
  }

  .mr2-concept-motion-v5 .mr2-concept-map::after {
    bottom: auto;
    height: calc((100% - 92px) * var(--mr2-concept-progress));
    background: linear-gradient(180deg, var(--mr2-green), var(--mr2-amber));
    opacity: .72;
  }

  .mr2-concept-motion-v5 .mr2-concept-node {
    z-index: 1;
  }
}

@media (prefers-reduced-motion: reduce) {
  .mr2-concept-motion-v5 .mr2-concept-map::after {
    height: auto;
    bottom: 46px;
  }

  .mr2.mr2-js .mr2-concept-motion-v5 .mr2-concept-node,
  .mr2.mr2-js .mr2-concept-motion-v5 .mr2-concept-merge,
  .mr2.mr2-js .mr2-concept-motion-v5 .mr2-concept-output-v4 {
    opacity: 1 !important;
    transform: none !important;
  }
}


/* v12 FAQ cards + free character anchor fix */
.mr2-free-trust-card .mr2-free-box {
  margin-top: 20px;
  padding-top: 28px;
}

.mr2-free-bot {
  top: -42px;
  right: 26px;
  width: 70px;
  transform: translateY(2px);
}

.mr2-faq-list {
  display: grid;
  gap: 10px;
}

.mr2-faq-item {
  border-radius: 22px;
  background: rgba(255,255,255,.82);
  border: 1px solid rgba(211,225,213,.88);
  box-shadow: 0 16px 36px -34px rgba(31,52,44,.36);
  overflow: hidden;
}

.mr2-faq-item[open] {
  background: linear-gradient(180deg, rgba(255,255,255,.92), rgba(247,251,247,.78));
  border-color: rgba(90,165,139,.24);
}

.mr2-faq-item summary {
  display: grid;
  grid-template-columns: 1fr 34px;
  align-items: center;
  gap: 12px;
  padding: 15px 15px 15px 16px;
  color: var(--mr2-text);
  font-size: 14.2px;
  line-height: 1.55;
  font-weight: 850;
  letter-spacing: .01em;
  cursor: pointer;
  list-style: none;
}

.mr2-faq-item summary::-webkit-details-marker {
  display: none;
}

.mr2-faq-item summary::after {
  content: "+";
  display: grid;
  width: 34px;
  height: 34px;
  place-items: center;
  border-radius: 999px;
  color: var(--mr2-green-ink);
  background: rgba(237,247,242,.88);
  border: 1px solid rgba(90,165,139,.20);
  font-size: 20px;
  line-height: 1;
  font-weight: 600;
}

.mr2-faq-item[open] summary::after {
  content: "−";
  color: #9d6c14;
  background: rgba(255,247,225,.9);
  border-color: rgba(var(--mr2-amber-rgb), .34);
}

.mr2-faq-item p {
  margin: 0;
  padding: 0 16px 16px;
  color: var(--mr2-soft-readable);
  font-size: 13.4px;
  line-height: 1.78;
}

@media (min-width: 760px) {
  .mr2-free-trust-card .mr2-free-box {
    margin-top: 26px;
    padding-top: 32px;
  }

  .mr2-free-bot {
    top: -52px;
    right: 28px;
    width: 86px;
  }

  .mr2-faq-list {
    gap: 12px;
  }

  .mr2-faq-item summary {
    padding: 18px 20px;
    font-size: 15.2px;
  }

  .mr2-faq-item p {
    padding: 0 20px 18px;
    font-size: 14.4px;
  }
}

@media (max-width: 370px) {
  .mr2-free-trust-card .mr2-free-box {
    margin-top: 18px;
    padding-top: 26px;
  }

  .mr2-free-bot {
    top: -38px;
    right: 18px;
    width: 64px;
  }

  .mr2-faq-item summary {
    grid-template-columns: 1fr 30px;
    padding: 14px 13px 14px 14px;
    font-size: 13.5px;
  }

  .mr2-faq-item summary::after {
    width: 30px;
    height: 30px;
  }
}


/* v14 FREE section visual correction: rich list, single focal motif, anchored bot. */
.mr2-free-main-card {
  overflow: visible;
  margin-top: 72px;
  padding: 34px 15px 16px;
  border-radius: 30px;
  background:
    url('../images/mibyo-lp/icons/ui/orbit-mark.svg') calc(100% + 68px) -72px / 228px 228px no-repeat,
    linear-gradient(145deg, rgba(255, 252, 242, .94), rgba(247, 252, 248, .86));
  border: 1px solid rgba(var(--mr2-amber-rgb), .36);
  box-shadow: 0 24px 58px -42px rgba(31, 52, 44, .42);
}

.mr2-free-main-card::before {
  content: none !important;
}

.mr2-free-main-card h3 {
  margin: 0 84px 14px 0;
  font-size: 19.4px;
  line-height: 1.35;
}

.mr2-free-bot,
.mr2-free-trust-card .mr2-free-bot {
  top: -73px;
  right: 36px;
  width: 76px;
  transform: none;
  z-index: 5;
  filter: drop-shadow(0 12px 13px rgba(43, 71, 58, .16));
}

.mr2-free-list {
  gap: 8px;
}

.mr2-free-list li {
  grid-template-columns: 52px 1fr;
  gap: 12px;
  min-height: 68px;
  padding: 10px 13px;
  border-radius: 23px;
  background: rgba(255, 255, 255, .70);
  border-color: rgba(211, 225, 213, .80);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, .78),
    0 12px 30px -28px rgba(31, 52, 44, .38);
}

.mr2-free-list li:nth-child(even) {
  background: rgba(255, 255, 255, .58);
}

.mr2-free-icon {
  width: 50px;
  height: 50px;
  border-radius: 18px;
  background: rgba(237, 247, 242, .94);
  border-color: rgba(90, 165, 139, .22);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.72);
}

.mr2-free-icon img {
  width: 30px;
  height: 30px;
}

.mr2-free-list b {
  font-size: 15.8px;
  line-height: 1.35;
}

.mr2-free-check {
  display: none !important;
}

@media (min-width: 760px) {
  .mr2-free-main-card {
    margin-top: 88px;
    padding: 40px 22px 22px;
    border-radius: 34px;
    background:
      url('../images/mibyo-lp/icons/ui/orbit-mark.svg') calc(100% + 82px) -88px / 280px 280px no-repeat,
      linear-gradient(145deg, rgba(255, 252, 242, .94), rgba(247, 252, 248, .86));
  }

  .mr2-free-main-card h3 {
    margin-right: 116px;
    font-size: 22px;
  }

  .mr2-free-bot,
  .mr2-free-trust-card .mr2-free-bot {
    top: -92px;
    right: 42px;
    width: 96px;
  }

  .mr2-free-list li {
    grid-template-columns: 58px 1fr;
    min-height: 76px;
    gap: 14px;
    padding: 12px 16px;
    border-radius: 25px;
  }

  .mr2-free-icon {
    width: 56px;
    height: 56px;
    border-radius: 20px;
  }

  .mr2-free-icon img {
    width: 34px;
    height: 34px;
  }

  .mr2-free-list b {
    font-size: 16.8px;
  }
}

@media (max-width: 370px) {
  .mr2-free-main-card {
    margin-top: 62px;
    padding: 31px 12px 13px;
    border-radius: 27px;
    background:
      url('../images/mibyo-lp/icons/ui/orbit-mark.svg') calc(100% + 58px) -62px / 196px 196px no-repeat,
      linear-gradient(145deg, rgba(255, 252, 242, .94), rgba(247, 252, 248, .86));
  }

  .mr2-free-main-card h3 {
    margin-right: 70px;
    font-size: 17.8px;
  }

  .mr2-free-bot,
  .mr2-free-trust-card .mr2-free-bot {
    top: -63px;
    right: 24px;
    width: 66px;
  }

  .mr2-free-list li {
    grid-template-columns: 46px 1fr;
    min-height: 62px;
    gap: 10px;
    padding: 9px 10px;
    border-radius: 20px;
  }

  .mr2-free-icon {
    width: 44px;
    height: 44px;
    border-radius: 16px;
  }

  .mr2-free-icon img {
    width: 27px;
    height: 27px;
  }

  .mr2-free-list b {
    font-size: 14.4px;
  }
}

/* v15 FREE section: bot sits on the first feature row, not on the outer frame. */
.mr2-free-main-card {
  margin-top: 16px;
  padding: 30px 15px 16px;
  background:
    url('../images/mibyo-lp/icons/ui/orbit-mark.svg') calc(100% + 52px) -54px / 216px 216px no-repeat,
    linear-gradient(145deg, rgba(255, 252, 242, .94), rgba(247, 252, 248, .86));
}

.mr2-free-main-card h3 {
  margin: 0 0 17px 0;
}

.mr2-free-list li {
  position: relative;
  overflow: visible;
}

.mr2-free-list li.is-first {
  padding-right: 82px;
}

.mr2-free-list .mr2-free-bot,
.mr2-free-bot,
.mr2-free-trust-card .mr2-free-bot {
  position: absolute;
  /* 下端を1行目カードの上枠線に接地させる */
  top: -68px;
  right: 20px;
  width: 68px;
  height: auto;
  transform: none;
  z-index: 4;
  pointer-events: none;
  filter: drop-shadow(0 12px 13px rgba(43, 71, 58, .15));
}

@media (min-width: 760px) {
  .mr2-free-main-card {
    margin-top: 20px;
    padding: 36px 22px 22px;
    background:
      url('../images/mibyo-lp/icons/ui/orbit-mark.svg') calc(100% + 72px) -72px / 270px 270px no-repeat,
      linear-gradient(145deg, rgba(255, 252, 242, .94), rgba(247, 252, 248, .86));
  }

  .mr2-free-main-card h3 {
    margin-bottom: 20px;
  }

  .mr2-free-list li.is-first {
    padding-right: 104px;
  }

  .mr2-free-list .mr2-free-bot,
  .mr2-free-bot,
  .mr2-free-trust-card .mr2-free-bot {
    top: -88px;
    right: 26px;
    width: 88px;
  }
}

@media (max-width: 370px) {
  .mr2-free-main-card {
    margin-top: 14px;
    padding: 28px 12px 13px;
    background:
      url('../images/mibyo-lp/icons/ui/orbit-mark.svg') calc(100% + 48px) -48px / 190px 190px no-repeat,
      linear-gradient(145deg, rgba(255, 252, 242, .94), rgba(247, 252, 248, .86));
  }

  .mr2-free-main-card h3 {
    margin-bottom: 15px;
  }

  .mr2-free-list li.is-first {
    padding-right: 72px;
  }

  .mr2-free-list .mr2-free-bot,
  .mr2-free-bot,
  .mr2-free-trust-card .mr2-free-bot {
    top: -60px;
    right: 16px;
    width: 60px;
  }
}

/* v16 FREE section: pin guide bot to the first feature row itself.
   The bot image is a child of the first <li>; bottom:100% makes its lower edge touch the row's upper border. */
.mr2-free-list li.is-first {
  position: relative !important;
  padding-right: 88px;
}

.mr2-free-list li.is-first > .mr2-free-bot {
  position: absolute !important;
  top: auto !important;
  bottom: 100% !important;
  right: 18px !important;
  width: 68px !important;
  height: auto !important;
  transform: none !important;
  z-index: 6 !important;
  pointer-events: none;
  filter: drop-shadow(0 12px 13px rgba(43, 71, 58, .15));
}

@media (min-width: 760px) {
  .mr2-free-list li.is-first {
    padding-right: 112px;
  }

  .mr2-free-list li.is-first > .mr2-free-bot {
    right: 24px !important;
    width: 88px !important;
  }
}

@media (max-width: 370px) {
  .mr2-free-list li.is-first {
    padding-right: 76px;
  }

  .mr2-free-list li.is-first > .mr2-free-bot {
    right: 14px !important;
    width: 60px !important;
  }
}

/* v17 FREE section: pin bot to the first row using a dedicated class.
   This avoids older broad .mr2-free-bot positioning rules and anchors the visible bot to the first list card. */
.mr2-free-main-card > .mr2-free-bot {
  display: none !important;
}

.mr2-free-list li.is-first {
  position: relative !important;
  overflow: visible !important;
  padding-right: 92px !important;
}

.mr2-free-bot-pin {
  position: absolute !important;
  top: auto !important;
  bottom: calc(100% - 5px) !important; /* SVG has a little transparent/shadow space; this makes the body visually touch the row border. */
  right: 18px !important;
  width: 70px !important;
  height: auto !important;
  z-index: 8 !important;
  transform: none !important;
  pointer-events: none;
  filter: drop-shadow(0 12px 13px rgba(43, 71, 58, .15));
}

@media (min-width: 760px) {
  .mr2-free-list li.is-first {
    padding-right: 116px !important;
  }

  .mr2-free-bot-pin {
    right: 24px !important;
    width: 90px !important;
    bottom: calc(100% - 6px) !important;
  }
}

@media (max-width: 370px) {
  .mr2-free-list li.is-first {
    padding-right: 80px !important;
  }

  .mr2-free-bot-pin {
    right: 14px !important;
    width: 62px !important;
    bottom: calc(100% - 4px) !important;
  }
}

/* v18 hero amber middle tone + concept heading alignment
   - The previous hero amber was a touch strong; keep warmth but reduce the filter-like yellow feel.
   - Align CONCEPT section heading with other section headings instead of center alignment. */
.mr2 {
  background:
    radial-gradient(circle at 91% 0%, rgba(var(--mr2-amber-rgb), .15), transparent 25rem),
    radial-gradient(circle at 73% 13%, rgba(var(--mr2-amber-rgb), .05), transparent 20rem),
    radial-gradient(circle at 8% 8%, rgba(123, 196, 179, .12), transparent 21rem),
    linear-gradient(180deg, #f7f8f3 0%, #f4f7f1 48%, #f8f7f1 100%);
}

.mr2-concept .mr2-section-head {
  margin-inline: 0 auto;
  text-align: left;
}

.mr2-concept .mr2-section-head p {
  margin-inline: 0;
}

/* v19 amber light consistency
   Heroで合わせたウォームアンバーを、カード内の淡いライトにも反映。 */
.mr2-concept-board-v3 {
  background:
    radial-gradient(circle at 88% 3%, rgba(var(--mr2-amber-rgb), .19), transparent 12rem),
    radial-gradient(circle at 4% 42%, rgba(92, 159, 136, .14), transparent 14rem),
    linear-gradient(180deg, rgba(255,255,255,.88), rgba(251,252,247,.94));
}

.mr2-concept-lead-card {
  background:
    radial-gradient(circle at 95% 0%, rgba(var(--mr2-amber-rgb), .20), transparent 8rem),
    linear-gradient(135deg, rgba(255,255,255,.98), rgba(242,248,243,.92));
}

.mr2-concept-output-v4 {
  background:
    radial-gradient(circle at 92% 0%, rgba(var(--mr2-amber-rgb), .19), transparent 10rem),
    linear-gradient(180deg, rgba(255,255,255,.97), rgba(250,251,246,.92));
}

.mr2-forecast-result-card,
.mr2-notify-callout {
  background:
    radial-gradient(circle at 92% 14%, rgba(var(--mr2-amber-rgb), .18), transparent 9rem),
    radial-gradient(circle at 8% 92%, rgba(92, 159, 136, .13), transparent 10rem),
    rgba(255, 255, 255, .84);
}

.mr2-free-main-card {
  background:
    url('../images/mibyo-lp/icons/ui/orbit-mark.svg') calc(100% + 68px) -72px / 228px 228px no-repeat,
    radial-gradient(circle at 94% 3%, rgba(var(--mr2-amber-rgb), .14), transparent 12rem),
    linear-gradient(145deg, rgba(255, 252, 242, .94), rgba(247, 252, 248, .86));
}

.mr2-final-card {
  background:
    radial-gradient(circle at 70% 12%, rgba(var(--mr2-amber-rgb), .18), transparent 13rem),
    radial-gradient(circle at 16% 70%, rgba(92, 159, 136, .11), transparent 13rem),
    rgba(255,255,255,.78);
}

.mr2-output-preview-head strong,
.mr2-concept-equation strong {
  background: linear-gradient(180deg, rgba(var(--mr2-amber-rgb), .10), rgba(var(--mr2-amber-rgb), .20));
}

/* Body concept card: add breathing room between the core-type matrix/legend and the qi-blood-fluid layer. */
.mr2-core-legend {
  margin-bottom: 24px;
}

.mr2-body-layer-head-factors {
  margin-top: 22px;
  padding-top: 2px;
}

@media (max-width: 370px) {
  .mr2-core-legend {
    margin-bottom: 21px;
  }

  .mr2-body-layer-head-factors {
    margin-top: 20px;
  }
}

/* v20 output/free icon visibility + refined mode dots
   - 過ごし方モードの色丸を少し上品なトーンへ
   - OUTPUT内の小見出しアイコンを読み取りやすく
   - FREEリストは枠サイズを変えず、SVG絵だけ少し大きく */
.mr2-output-mode-grid span::before,
.mr2-output-block-modes .mr2-output-mode-grid span::before {
  width: 13px;
  height: 13px;
  left: 14px;
  top: 18px;
  background: #5FAF9B;
  box-shadow:
    0 0 0 7px rgba(95, 175, 155, .16),
    inset 0 1px 0 rgba(255,255,255,.48);
}

.mr2-output-mode-grid span:nth-child(2)::before,
.mr2-output-block-modes .mr2-output-mode-grid span:nth-child(2)::before {
  background: #D8A63A;
  box-shadow:
    0 0 0 7px rgba(216, 166, 58, .18),
    inset 0 1px 0 rgba(255,255,255,.50);
}

.mr2-output-mode-grid span:nth-child(3)::before,
.mr2-output-block-modes .mr2-output-mode-grid span:nth-child(3)::before {
  background: #D78355;
  box-shadow:
    0 0 0 7px rgba(215, 131, 85, .15),
    inset 0 1px 0 rgba(255,255,255,.48);
}

.mr2-output-block-head {
  gap: 10px;
  font-size: 14.4px;
}

.mr2-output-block-head img {
  width: 31px;
  height: 31px;
}

.mr2-output-block-care .mr2-output-care-v4 img {
  width: 37px;
  height: 37px;
}

.mr2-free-icon img {
  width: 35px;
  height: 35px;
}

@media (min-width: 760px) {
  .mr2-output-mode-grid span::before,
  .mr2-output-block-modes .mr2-output-mode-grid span::before {
    width: 14px;
    height: 14px;
    left: 16px;
    top: 20px;
  }

  .mr2-output-block-head img {
    width: 34px;
    height: 34px;
  }

  .mr2-output-block-care .mr2-output-care-v4 img {
    width: 40px;
    height: 40px;
  }

  .mr2-free-icon img {
    width: 39px;
    height: 39px;
  }
}

@media (max-width: 370px) {
  .mr2-output-mode-grid span::before,
  .mr2-output-block-modes .mr2-output-mode-grid span::before {
    width: 12px;
    height: 12px;
    left: 13px;
    top: 17px;
    box-shadow:
      0 0 0 6px rgba(95, 175, 155, .15),
      inset 0 1px 0 rgba(255,255,255,.48);
  }

  .mr2-output-mode-grid span:nth-child(2)::before,
  .mr2-output-block-modes .mr2-output-mode-grid span:nth-child(2)::before {
    box-shadow:
      0 0 0 6px rgba(216, 166, 58, .17),
      inset 0 1px 0 rgba(255,255,255,.50);
  }

  .mr2-output-mode-grid span:nth-child(3)::before,
  .mr2-output-block-modes .mr2-output-mode-grid span:nth-child(3)::before {
    box-shadow:
      0 0 0 6px rgba(215, 131, 85, .14),
      inset 0 1px 0 rgba(255,255,255,.48);
  }

  .mr2-output-block-head {
    gap: 9px;
    font-size: 13.6px;
  }

  .mr2-output-block-head img {
    width: 28px;
    height: 28px;
  }

  .mr2-output-block-care .mr2-output-care-v4 img {
    width: 34px;
    height: 34px;
  }

  .mr2-free-icon img {
    width: 31px;
    height: 31px;
  }
}


/* v22 section kicker pills
   英字キッカーを、スマホで意味が入りやすい日本語ピルに変更。 */
.mr2 .mr2-section-head > .mr2-kicker {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  width: fit-content;
  margin: 0 0 13px;
  padding: 7px 13px 7px 12px;
  border: 1px solid rgba(211, 225, 213, .92);
  border-radius: 999px;
  background: rgba(255, 255, 255, .74);
  box-shadow: 0 12px 26px -22px rgba(31, 52, 44, .36);
  color: var(--mr2-green-ink);
  font-size: 13px;
  font-weight: 850;
  line-height: 1.2;
  letter-spacing: .03em;
  text-transform: none;
}

.mr2 .mr2-section-head > .mr2-kicker::before {
  content: "";
  width: 9px;
  height: 9px;
  flex: 0 0 auto;
  border-radius: 999px;
  background: #D8A63A;
  box-shadow:
    0 0 0 6px rgba(216, 166, 58, .14),
    inset 0 1px 0 rgba(255,255,255,.46);
}

.mr2 .mr2-concept .mr2-section-head > .mr2-kicker {
  margin-inline: 0;
}

/* v23 section pill amber dot refinement
   - 小見出しピルのアンバー丸を、いたわりモード寄りの上品な琥珀色に調整。 */

/* =========================================================
   MIBYOU RADAR LP visual polish v1
   - WordPressトップと同じく、背景はくすませ、ティールを鮮やかに残す
   ========================================================= */
:root {
  --mr2-bg: #F7F5EE;
  --mr2-panel: #FFFFFF;
  --mr2-panel-warm: #FBFAF5;
  --mr2-mint: #EEF4EF;
  --mr2-mint-2: #E3F2EB;
  --mr2-line: #D8E3DB;
  --mr2-line-soft: #CFDDD5;
  --mr2-green: #3BA58B;
  --mr2-green-deep: #24564C;
  --mr2-green-ink: #214C43;
  --mr2-amber: #F9B02D;
  --mr2-amber-deep: #B77913;
  --mr2-amber-soft: #F7E6B7;
  --mr2-amber-pale: #FFF5DF;
  --mr2-amber-rgb: 249, 176, 45;
  --mr2-orange: #D78355;
  --mr2-text: #111827;
  --mr2-soft: #5F6B65;
  --mr2-muted: #8B99A8;
  --mr2-shadow: 0 20px 46px -30px rgba(31, 56, 49, .34);
  --mr2-shadow-card: 0 15px 30px -24px rgba(31, 56, 49, .30);
}

.mr2 {
  background:
    radial-gradient(circle at 88% 2%, rgba(var(--mr2-amber-rgb), .16), transparent 28rem),
    radial-gradient(circle at 10% 11%, rgba(59, 165, 139, .11), transparent 22rem),
    var(--mr2-bg);
}

.mr2 .mr2-hero-copy > .mr2-kicker::before {
  background: var(--mr2-amber);
  box-shadow:
    0 0 0 6px rgba(249, 176, 45, .13),
    inset 0 1px 0 rgba(255,255,255,.46);
}

.mr2-lead,
.mr2-body,
.mr2-section-head p,
.mr2 p {
  color: var(--mr2-soft);
  font-weight: 520;
}

.mr2 h1,
.mr2 h2,
.mr2 h3 {
  color: var(--mr2-text);
}

.mr2-lead strong {
  color: var(--mr2-green-ink);
  background: linear-gradient(transparent 62%, rgba(var(--mr2-amber-rgb), .15) 0);
}

/* =========================================================
   MIBYOU RADAR LP design polish v2
   - トップページと同じ方向：くすませた背景 + 鮮やかなティール
   - しくみページ全体のタイポ/余白/ボタン/カードを整理
   ========================================================= */
:root {
  --mr2-bg: #FAFAF6;
  --mr2-panel: #FFFFFF;
  --mr2-panel-warm: #FBFAF5;
  --mr2-mint: #EEF4EF;
  --mr2-mint-2: #E5F3ED;
  --mr2-line: #DCE6DF;
  --mr2-line-soft: #D1DED6;
  --mr2-green: #3BA58B;
  --mr2-green-deep: #24564C;
  --mr2-green-ink: #214C43;
  --mr2-amber: #F9B02D;
  --mr2-amber-deep: #B77913;
  --mr2-amber-soft: #F7E6B7;
  --mr2-amber-pale: #FFF5DF;
  --mr2-amber-rgb: 249, 176, 45;
  --mr2-orange: #D78355;
  --mr2-text: #111827;
  --mr2-soft: #596861;
  --mr2-muted: #8B99A8;
  --mr2-shadow: 0 20px 48px -32px rgba(31, 56, 49, .32);
  --mr2-shadow-card: 0 16px 34px -26px rgba(31, 56, 49, .26);
}

.mr2 {
  font-family: 'Zen Kaku Gothic New', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  background:
    radial-gradient(circle at 88% 2%, rgba(var(--mr2-amber-rgb), .105), transparent 28rem),
    radial-gradient(circle at 10% 11%, rgba(59, 165, 139, .10), transparent 22rem),
    linear-gradient(180deg, #FAFAF6 0%, #F2F5EE 52%, #F5F1E8 100%);
  color: var(--mr2-text);
}

.mr2 h1,
.mr2 h2,
.mr2 h3,
.mr2 h4,
.mr2 strong,
.mr2 b {
  color: var(--mr2-text);
}

.mr2 h1,
.mr2 h2 {
  font-weight: 800;
  letter-spacing: -0.055em;
}

.mr2 h3,
.mr2 h4 {
  font-weight: 800;
}

.mr2 p,
.mr2 li,
.mr2-lead,
.mr2-body,
.mr2-section-head p,
.mr2-node-copy p:not(.mr2-concept-step-kicker),
.mr2-output-copy-v4 p:not(.mr2-concept-step-kicker),
.mr2-check-card p,
.mr2-time-card p,
.mr2-step-card p,
.mr2-trust-card p {
  color: var(--mr2-soft);
  font-weight: 500;
  line-height: 1.84;
}

.mr2-wrap {
  width: min(100% - 30px, 1080px);
}

.mr2-section {
  padding: clamp(48px, 10vw, 92px) 0;
}

.mr2-section-head {
  margin-bottom: clamp(24px, 5vw, 38px);
}

.mr2 .mr2-hero-copy > .mr2-kicker,
.mr2 .mr2-section-head > .mr2-kicker {
  border-color: rgba(36, 86, 76, .12);
  background: rgba(255,255,255,.82);
  color: var(--mr2-green-ink);
  box-shadow: 0 12px 28px -22px rgba(31, 56, 49, .34);
}

.mr2 .mr2-hero-copy > .mr2-kicker::before,
.mr2 .mr2-section-head > .mr2-kicker::before {
  background: var(--mr2-amber);
  box-shadow:
    0 0 0 6px rgba(249,176,45,.13),
    inset 0 1px 0 rgba(255,255,255,.48);
}

.mr2-hero {
  padding: clamp(32px, 8vw, 76px) 0 clamp(48px, 10vw, 96px);
}

.mr2-hero-grid {
  gap: clamp(26px, 6vw, 76px);
}

.mr2 h1 {
  font-size: clamp(34px, 8.8vw, 66px);
  line-height: 1.08;
}

.mr2 h2 {
  font-size: clamp(28px, 6.4vw, 48px);
  line-height: 1.15;
}

.mr2-lead {
  font-size: clamp(16px, 2.5vw, 18px);
}

.mr2-btn {
  min-height: 54px;
  padding: 14px 22px;
  font-weight: 800;
  letter-spacing: .005em;
}

.mr2-btn-main,
.mr2 a.mr2-btn-main {
  background: var(--mr2-green);
  color: #fff;
  box-shadow:
    0 16px 30px -18px rgba(59, 165, 139, .58),
    inset 0 0 0 1px rgba(255,255,255,.16);
}

.mr2-btn-main:hover,
.mr2 a.mr2-btn-main:hover {
  background: #2F8F79;
}

.mr2-btn-sub,
.mr2 a.mr2-btn-sub {
  border-color: rgba(36,86,76,.13);
  background: rgba(255,255,255,.82);
  color: var(--mr2-green-ink);
}

.mr2-check-card,
.mr2-step-card,
.mr2-time-card,
.mr2-trust-card,
.mr2-final-card,
.mr2-concept-lead-card,
.mr2-concept-step,
.mr2-output-preview-card,
.mr2-pill-panel,
.mr2-output-preview-card,
.mr2-free-item,
.mr2-mode-chip,
.mr2-policy-mini,
.mr2-care-route {
  border-color: rgba(36,86,76,.105);
  background-color: rgba(255,255,255,.88);
  box-shadow: var(--mr2-shadow-card);
}

.mr2-check-card,
.mr2-step-card,
.mr2-time-card,
.mr2-trust-card,
.mr2-concept-step,
.mr2-output-preview-card {
  border-radius: clamp(24px, 5vw, 34px);
}

.mr2-core-table,
.mr2-body-layer,
.mr2-weather-grid,
.mr2-output-preview-card,
.mr2-final-card {
  border-color: rgba(36,86,76,.105);
  background:
    radial-gradient(circle at 100% 0%, rgba(249,176,45,.07), transparent 13rem),
    rgba(255,255,255,.88);
}

.mr2-step-num,
.mr2-step-marker,
.mr2-output-mode-grid span::before,
.mr2-output-block-modes .mr2-output-mode-grid span::before {
  background: var(--mr2-green);
}

.mr2-phone,
.mr2-hero-phone,
.mr2-final-bot,
.mr2-device,
.mr2-screen-stack figure,
.mr2-step-card figure,
.mr2-output-preview-card img {
  box-shadow: 0 24px 64px -34px rgba(31,56,49,.28);
}

.mr2-hero-visual,
.mr2-final-visual {
  filter: saturate(1.02);
}

.mr2-hero-bg,
.mr2-bg-art {
  opacity: .72;
}

.mr2-final-cta {
  background:
    radial-gradient(circle at 70% 8%, rgba(249,176,45,.10), transparent 15rem),
    radial-gradient(circle at 12% 100%, rgba(59,165,139,.11), transparent 16rem),
    rgba(255,255,255,.88);
  border-color: rgba(36,86,76,.11);
}

.mr2-final-cta h2 {
  font-weight: 800;
}

@media (max-width: 759px) {
  .mr2-wrap {
    width: min(100% - 28px, 1080px);
  }

  .mr2-section {
    padding: 52px 0;
  }

  .mr2 h1 {
    font-size: clamp(34px, 10vw, 46px);
  }

  .mr2 h2 {
    font-size: clamp(28px, 8vw, 36px);
  }

  .mr2-btn {
    width: 100%;
  }

  .mr2-check-card,
  .mr2-step-card,
  .mr2-time-card,
  .mr2-trust-card,
  .mr2-concept-step,
  .mr2-output-preview-card {
    border-radius: 28px;
  }
}


/* =========================================================
   Scheme page emergency repair v3
   - 壊れたヒーロー軌道円は一旦すべて無効化
   - トップページと同じボタン色・フォント感だけ残す
   ========================================================= */

.mr2 {
  --mr2-green: #3BA58B;
  --mr2-green-deep: #2F8F79;
  --mr2-green-ink: #24564C;
  font-family: 'Inter', 'Zen Kaku Gothic New', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
}

.mr2 h1,
.mr2 h2,
.mr2 h3,
.mr2 p,
.mr2 li,
.mr2 a,
.mr2 span,
.mr2 small,
.mr2 button {
  font-family: inherit;
}

.mr2 h1,
.mr2 h2,
.mr2 h3,
.mr2 .mr2-btn,
.mr2 .mr2-kicker,
.mr2 .mr2-mini-notes,
.mr2 .mr2-icon-chip span,
.mr2 .mr2-animal-strip span {
  font-family: 'Inter', 'Zen Kaku Gothic New', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
}

.mr2 h1,
.mr2 h2,
.mr2 h3 {
  font-weight: 800;
  letter-spacing: -0.045em;
}

.mr2-body,
.mr2-lead,
.mr2-section-head p,
.mr2-signal-list li,
.mr2-time-card p,
.mr2-step-card p,
.mr2-trust-card p {
  font-weight: 500;
}

.mr2-btn-main,
.mr2 a.mr2-btn-main {
  background: #3BA58B !important;
  color: #fff !important;
  box-shadow:
    0 16px 30px -18px rgba(59, 165, 139, .58),
    inset 0 0 0 1px rgba(255,255,255,.16) !important;
}

.mr2-btn-main:hover,
.mr2 a.mr2-btn-main:hover {
  background: #2F8F79 !important;
}

.mr2-btn-sub,
.mr2 a.mr2-btn-sub {
  color: #24564C !important;
  border-color: rgba(36,86,76,.13) !important;
  background: rgba(255,255,255,.84) !important;
}

/* The orbit motif broke on the scheme page because the hero visual is very tall.
   Keep the hero stable; no pseudo-element rings here. */
.mr2-hero-visual::before,
.mr2-hero-visual::after,
.mr2-phone-stack::before,
.mr2-phone-stack::after {
  content: none !important;
  display: none !important;
  box-shadow: none !important;
  border: 0 !important;
  background: none !important;
}

.mr2-hero-visual {
  overflow: visible;
  background: none !important;
}

.mr2-phone-stack {
  position: relative;
  z-index: 2;
}

@media (max-width: 759px) {
  .mr2 h1 {
    letter-spacing: -0.055em;
  }
}
