html {
  scroll-behavior: smooth;
  scroll-padding-top: 5rem;
}

@media (prefers-reduced-motion: reduce) {
  html {
    scroll-behavior: auto;
  }
}

body {
  font-family: Inter, Arial, Helvetica, sans-serif;
}

/* Seção Segurança: o bundle Tailwind em styles.css não inclui size-14 / size-7 */
.cfm-benefit-icon {
  box-sizing: border-box;
  width: 56px;
  height: 56px;
  flex-shrink: 0;
  box-shadow:
    0 10px 15px -3px rgba(0, 0, 0, 0.1),
    0 4px 6px -4px rgba(0, 0, 0, 0.1);
}

.cfm-benefit-icon img {
  width: 28px;
  height: 28px;
  flex-shrink: 0;
}

/* Hero — cards em duas colunas com mesma largura (xl+) */
@media (min-width: 1280px) {
  .cfm-hero-features-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .cfm-hero-features-grid > .cfm-hero-feature {
    justify-self: stretch;
    width: 100%;
    min-width: 0;
  }
}

/* Hero: desktop “estreito” (xl até <2xl) — evita sobreposição texto × ilustração */
@media (min-width: 1280px) and (max-width: 1535.98px) {
  .cfm-hero-layout {
    align-items: flex-start;
  }

  .cfm-hero-copy {
    flex: 1 1 0%;
    max-width: 36rem;
    min-width: 0;
  }

  .cfm-hero-visual {
    flex: 1 1 0%;
    min-width: 0;
    margin-inline-start: auto;
  }
}

@media (min-width: 1536px) {
  .cfm-hero-layout {
    align-items: center;
  }

  .cfm-hero-copy {
    max-width: none;
  }

  .cfm-hero-visual {
    max-width: 678px;
    margin-inline-start: 0;
  }
}

/* RDC 1.000 page: Figma-aligned static layout refinements */
.rdc-page {
  --rdc-green: #266a4a;
  --rdc-ink: #002112;
  --rdc-text: #4a5565;
  --rdc-muted: #64748b;
  --rdc-line: #e2e8f0;
  --rdc-soft: #f9fafb;
}

.rdc-page header > div > div {
  max-width: 1585px;
  padding-inline: clamp(20px, 8.72vw, 167.5px);
}

.rdc-page main > section#faq > div {
  max-width: 1440px;
}

/* ============================================================
   Hero (Figma 9298:32936) — pixel-perfect block
   ============================================================ */
.rdc-page main > section.rdc-hero {
  position: relative;
  width: 100%;
  overflow: hidden;
  background: linear-gradient(148.51deg, #ffffff 0%, #f0fdf4 100%);
  font-family: 'Inter', Arial, Helvetica, sans-serif;
}

.rdc-page main > section.rdc-hero > .rdc-hero__inner {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 32px;
  padding: 128px 240px;
  width: 100%;
  max-width: none;
  margin: 0;
  box-sizing: border-box;
}

/* LEFT COPY */
.rdc-hero__copy {
  flex: 1 1 0;
  min-width: 0;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 32px;
}

.rdc-hero__chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  height: 36px;
  padding: 8px 16px;
  background: #dcfce7;
  border-radius: 9999px;
}

.rdc-hero__chip-icon {
  display: block;
  width: 16px;
  height: 16px;
  flex-shrink: 0;
}

.rdc-hero__chip-text {
  color: #266a4a;
  font-size: 14px;
  font-weight: 500;
  line-height: 20px;
  letter-spacing: -0.1504px;
  white-space: nowrap;
}

.rdc-hero__title {
  margin: 0;
  width: 100%;
  display: block;
}

.rdc-hero__title-lg {
  display: block;
  color: #002112;
  font-size: 64px;
  font-weight: 700;
  line-height: 72px;
  letter-spacing: -1.677px;
}

.rdc-hero__title-md {
  display: block;
  color: #101828;
  font-size: 36px;
  font-weight: 500;
  line-height: 48px;
  letter-spacing: 0.3516px;
}

.rdc-hero__desc {
  margin: 0;
  width: 100%;
  color: #4a5565;
  font-size: 18px;
  font-weight: 400;
  line-height: 29.25px;
  letter-spacing: -0.4395px;
}

.rdc-hero__ctas {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 24px;
}

.rdc-hero__btn {
  box-sizing: border-box;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  height: 60px;
  padding: 18px 34px;
  font-family: inherit;
  font-size: 16px;
  font-weight: 500;
  line-height: 24px;
  letter-spacing: -0.3125px;
  text-decoration: none;
  border-radius: 10px;
  cursor: pointer;
  transition: background-color 0.15s ease, border-color 0.15s ease;
}

.rdc-hero__btn:focus-visible {
  outline: 2px solid #266a4a;
  outline-offset: 2px;
}

.rdc-hero__btn--primary {
  gap: 12px;
  padding: 18px 32px;
  border: 0;
  background: #266a4a;
  color: #ffffff;
  filter: drop-shadow(0 10px 7.5px rgba(13, 84, 43, 0.2)) drop-shadow(0 4px 3px rgba(13, 84, 43, 0.2));
}

.rdc-hero__btn--primary:hover {
  background: #215837;
}

.rdc-hero__btn--primary .rdc-hero__btn-text {
  color: #ffffff;
}

.rdc-hero__btn-icon {
  display: block;
  width: 20px;
  height: 20px;
  flex-shrink: 0;
}

.rdc-hero__btn--secondary {
  border: 2px solid #e5e7eb;
  background: #ffffff;
  color: #364153;
}

.rdc-hero__btn--secondary:hover {
  background: #f9fafb;
}

.rdc-hero__btn-text {
  white-space: nowrap;
}

.rdc-hero__stats {
  list-style: none;
  margin: 0;
  padding: 16px 0 0;
  display: flex;
  align-items: center;
  gap: 32px;
  flex-wrap: wrap;
}

.rdc-hero__stat {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0;
}

.rdc-hero__stat-value {
  color: #266a4a;
  font-size: 24px;
  font-weight: 700;
  line-height: 32px;
  letter-spacing: 0.0703px;
  white-space: nowrap;
}

.rdc-hero__stat-label {
  color: #4a5565;
  font-size: 14px;
  font-weight: 400;
  line-height: 20px;
  letter-spacing: -0.1504px;
  white-space: nowrap;
}

.rdc-hero__stat-sep {
  width: 1px;
  height: 48px;
  background: #d1d5dc;
  flex-shrink: 0;
}

/* RIGHT STAGE (illustration) */
.rdc-hero__stage {
  position: relative;
  flex-shrink: 0;
  width: 704px;
  max-width: 100%;
  height: 920px;
  isolation: isolate;
}

.rdc-hero__panel {
  position: absolute;
  inset: 11.25% 0 11.2% 0;
  border-radius: 28.541px;
  background: linear-gradient(134.62deg, rgba(38, 106, 74, 0.1) 0%, rgba(219, 234, 254, 0.5) 100%);
  z-index: 0;
}

.rdc-hero__blob {
  position: absolute;
  border-radius: 9999px;
  filter: blur(76.108px);
  z-index: 0;
}

.rdc-hero__blob--yellow {
  width: 152.216px;
  height: 152.216px;
  top: 56px;
  right: 60px;
  background: #fdc700;
  opacity: 0.2;
}

.rdc-hero__blob--blue {
  width: 152.216px;
  height: 152.216px;
  bottom: 75px;
  left: 24px;
  background: #2b7fff;
  opacity: 0.5;
}

.rdc-hero__blob--green {
  width: 114.162px;
  height: 114.162px;
  top: 510px;
  right: 78px;
  background: #00c950;
  opacity: 0.2;
}

/* RX Cards */
.rdc-hero-card {
  position: absolute;
  width: 594.595px;
  display: flex;
  flex-direction: column;
  gap: 19.027px;
  padding: 28.541px;
  background: #ffffff;
  border-radius: 19.027px;
  filter: drop-shadow(0 29.73px 29.73px rgba(0, 0, 0, 0.25));
  z-index: 2;
  box-sizing: border-box;
}

.rdc-hero-card--a {
  top: 200px;
  left: -5px;
  transform: rotate(2deg);
}

.rdc-hero-card--b {
  top: 480px;
  left: 35px;
  width: 556.541px;
  transform: rotate(-2deg);
}

.rdc-hero-card__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
}

.rdc-hero-card__title {
  color: #4a5565;
  font-size: 16.649px;
  font-weight: 500;
  line-height: 23.784px;
  letter-spacing: -0.1788px;
  white-space: nowrap;
}

.rdc-hero-card__badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 33.297px;
  height: 33.297px;
  padding: 0 7.135px;
  border-radius: 9999px;
  filter: drop-shadow(0 4.757px 3.568px rgba(0, 0, 0, 0.1)) drop-shadow(0 2.378px 2.378px rgba(0, 0, 0, 0.1));
  flex-shrink: 0;
  box-sizing: border-box;
}

.rdc-hero-card__badge--yellow {
  background: #fdc700;
}

.rdc-hero-card__badge--blue {
  background: #2b7fff;
}

.rdc-hero-card__badge img {
  display: block;
  width: 19.027px;
  height: 19.027px;
}

.rdc-hero-card__body {
  position: relative;
  height: 146.27px;
  width: 100%;
  border-width: 2.378px;
  border-style: solid;
  border-radius: 16.649px;
  padding: 23.78px;
  box-sizing: border-box;
}

.rdc-hero-card__body--yellow {
  border-color: #fff085;
  background: linear-gradient(164.78deg, #fefce8 0%, #fef9c2 100%);
}

.rdc-hero-card__body--blue {
  border-color: #bedbff;
  background: linear-gradient(163.68deg, #eff6ff 0%, #dbeafe 100%);
}

.rdc-hero-card__bar {
  position: absolute;
  display: block;
  left: 23.78px;
  height: 9.514px;
  border-radius: 4.757px;
}

.rdc-hero-card__body--yellow .rdc-hero-card__bar {
  background: #ffdf20;
}

.rdc-hero-card__body--blue .rdc-hero-card__bar {
  background: #8ec5ff;
}

.rdc-hero-card__bar--w1 {
  top: 23.78px;
  width: 63%;
  opacity: 0.6;
}

.rdc-hero-card__bar--w2 {
  top: 47.57px;
  width: 84%;
  opacity: 0.4;
}

.rdc-hero-card__bar--w3 {
  top: 71.35px;
  width: 70%;
  opacity: 0.4;
}

.rdc-hero-card__bar--last {
  top: 110px;
  width: 42%;
  height: 7.135px;
  opacity: 0.5;
}

/* Floating pills */
.rdc-hero-pill {
  position: absolute;
  display: flex;
  align-items: center;
  gap: 14.131px;
  height: 88px;
  padding: 20.216px;
  background: #ffffff;
  border-width: 1.189px;
  border-style: solid;
  border-radius: 16.649px;
  filter: drop-shadow(0 23.784px 14.865px rgba(0, 0, 0, 0.1)) drop-shadow(0 9.514px 5.946px rgba(0, 0, 0, 0.1));
  z-index: 3;
  box-sizing: border-box;
}

.rdc-hero-pill--validacao {
  top: 100px;
  left: -36px;
  width: 215.243px;
  border-color: #dcfce7;
}

.rdc-hero-pill--sncr {
  top: 736px;
  right: 18px;
  width: 228.324px;
  border-color: #dbeafe;
}

.rdc-hero-pill__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 47.568px;
  height: 47.568px;
  border-radius: 11.892px;
  flex-shrink: 0;
}

.rdc-hero-pill__icon--green {
  background: #dcfce7;
}

.rdc-hero-pill__icon--blue {
  background: #dbeafe;
}

.rdc-hero-pill__icon img {
  display: block;
  width: 23.784px;
  height: 23.784px;
}

.rdc-hero-pill__body {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0;
}

.rdc-hero-pill__label {
  color: #6a7282;
  font-size: 14.27px;
  font-weight: 400;
  line-height: 19.027px;
}

.rdc-hero-pill__text {
  color: #101828;
  font-size: 16.649px;
  font-weight: 500;
  line-height: 23.784px;
  letter-spacing: -0.1788px;
  white-space: nowrap;
}

/* Floating RDC 1.000 green chip */
.rdc-hero-chip-rdc {
  position: absolute;
  top: 478px;
  right: 24px;
  display: inline-flex;
  align-items: center;
  gap: 9.411px;
  height: 52.324px;
  padding: 14.27px;
  background: linear-gradient(158.73deg, #00c950 0%, #00a63e 100%);
  border-radius: 16.649px;
  filter: drop-shadow(0 23.784px 14.865px rgba(0, 0, 0, 0.1)) drop-shadow(0 9.514px 5.946px rgba(0, 0, 0, 0.1));
  z-index: 3;
  box-sizing: border-box;
}

.rdc-hero-chip-rdc__icon {
  display: block;
  width: 23.784px;
  height: 23.784px;
  flex-shrink: 0;
}

.rdc-hero-chip-rdc__text {
  color: #ffffff;
  font-size: 14.27px;
  font-weight: 500;
  line-height: 19.027px;
  white-space: nowrap;
}

/* Responsive — wide desktop pull-in (≤1439.98px) */
@media (max-width: 1439.98px) {
  .rdc-page main > section.rdc-hero > .rdc-hero__inner {
    padding: 96px 80px;
    gap: 24px;
  }

  .rdc-hero__title-lg {
    font-size: 52px;
    line-height: 60px;
    letter-spacing: -1.2px;
  }

  .rdc-hero__title-md {
    font-size: 28px;
    line-height: 38px;
  }

  .rdc-hero__stage {
    width: 540px;
    height: 760px;
    transform: scale(0.78);
    transform-origin: top right;
    margin-right: -80px;
    margin-bottom: -180px;
  }
}

/* Responsive — tablet/medium (≤1023.98px) */
@media (max-width: 1023.98px) {
  .rdc-page main > section.rdc-hero > .rdc-hero__inner {
    flex-direction: column;
    align-items: flex-start;
    padding: 72px 40px;
    gap: 48px;
  }

  .rdc-hero__copy {
    width: 100%;
    gap: 24px;
  }

  .rdc-hero__title-lg {
    font-size: 44px;
    line-height: 52px;
    letter-spacing: -1px;
  }

  .rdc-hero__title-md {
    font-size: 24px;
    line-height: 32px;
    letter-spacing: 0;
  }

  .rdc-hero__desc {
    font-size: 16px;
    line-height: 26px;
  }

  .rdc-hero__stage {
    display: none;
  }
}

/* Responsive — mobile (≤639.98px) */
@media (max-width: 639.98px) {
  .rdc-page main > section.rdc-hero > .rdc-hero__inner {
    padding: 56px 20px;
    gap: 32px;
  }

  .rdc-hero__title-lg {
    font-size: 36px;
    line-height: 44px;
  }

  .rdc-hero__title-md {
    font-size: 20px;
    line-height: 28px;
  }

  /* CTAs: stack and stretch to full width */
  .rdc-hero__ctas {
    flex-direction: column;
    align-items: stretch;
    gap: 12px;
    width: 100%;
  }

  .rdc-hero__btn {
    width: 100%;
    height: auto;
    padding: 14px 24px;
  }

  .rdc-hero__btn--primary {
    padding: 14px 22px;
  }

  /* Stats: stacked rows, value + label side-by-side, separators hidden */
  .rdc-hero__stats {
    flex-direction: column;
    align-items: center;
    gap: 8px;
    width: 100%;
  }

  .rdc-hero__stat {
    flex-direction: row;
    align-items: baseline;
    justify-content: flex-start;
    gap: 12px;
    width: 220px;
    max-width: 100%;
  }

  .rdc-hero__stat-value {
    flex-shrink: 0;
    width: 80px;
    text-align: left;
    font-size: 28px;
    line-height: 36px;
  }

  .rdc-hero__stat-label {
    flex: 1 1 auto;
    text-align: left;
  }

  .rdc-hero__stat-sep {
    display: none;
  }
}

/* ============================================================
   Sobre a RDC (Figma 9298:32988) — pixel-perfect block
   ============================================================ */
.rdc-page main > section.rdc-about {
  width: 100%;
  background: #fff;
  font-family: 'Inter', Arial, Helvetica, sans-serif;
}

.rdc-page main > section.rdc-about > .rdc-about__inner {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: center;
  gap: 32px;
  width: 100%;
  max-width: 1194px;
  margin-inline: auto;
  padding: 144px 0;
}

.rdc-about__copy {
  display: flex;
  flex: 1 0 0;
  flex-direction: column;
  align-items: flex-start;
  gap: 16px;
  min-width: 0;
}

.rdc-about__title {
  margin: 0;
  color: #002112;
  font-size: 64px;
  font-weight: 700;
  line-height: 80px;
  letter-spacing: 0;
}

.rdc-about__text {
  margin: 0;
  color: #4a5565;
  font-size: 16px;
  font-weight: 400;
  line-height: 26px;
  letter-spacing: -0.3125px;
}

.rdc-about__cards {
  display: flex;
  flex: 1 0 0;
  flex-wrap: wrap;
  align-items: flex-start;
  align-content: flex-start;
  gap: 24px;
  min-width: 0;
}

.rdc-about-card {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 16px;
  flex-shrink: 0;
  box-sizing: border-box;
  width: 278px;
  padding: 24px;
  background: #fff;
  border: 1.013px solid #e2e8f0;
  border-radius: 16.203px;
  box-shadow: 0 25.316px 25.316px rgba(0, 0, 0, 0.25);
}

.rdc-about-card__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  box-sizing: border-box;
  width: 48px;
  height: 48px;
  padding: 0 12px;
  background: #f0fdf4;
  border-radius: 10px;
}

.rdc-about-card__icon img {
  display: block;
  width: 24px;
  height: 24px;
  flex-shrink: 0;
}

.rdc-about-card__body {
  display: flex;
  flex-direction: column;
  gap: 2px;
  width: 100%;
}

.rdc-about-card__title {
  margin: 0;
  color: #101828;
  font-size: 18px;
  font-weight: 500;
  line-height: 27px;
  letter-spacing: -0.4395px;
  white-space: nowrap;
}

.rdc-about-card__text {
  margin: 0;
  color: #4a5565;
  font-size: 14px;
  font-weight: 400;
  line-height: 20px;
  letter-spacing: -0.1504px;
}

/* Tablet / narrow desktop (<1280px) — stack columns, keep card cluster centered */
@media (max-width: 1279.98px) {
  .rdc-page main > section.rdc-about > .rdc-about__inner {
    flex-direction: column;
    align-items: stretch;
    gap: 40px;
    max-width: 100%;
    padding: 72px 24px;
  }

  .rdc-about__title {
    font-size: 40px;
    line-height: 48px;
  }

  .rdc-about__cards {
    justify-content: center;
  }
}

/* Mobile — single column of cards */
@media (max-width: 639.98px) {
  .rdc-about__title {
    font-size: 32px;
    line-height: 38px;
  }

  .rdc-about-card {
    width: 100%;
    max-width: 360px;
  }

  .rdc-about-card__title {
    white-space: normal;
  }
}

/* ============================================================
   Tipos de receituário (Figma 9309:37274) — pixel-perfect block
   ============================================================ */
.rdc-page main > section.rdc-types {
  width: 100%;
  background: #fff;
  font-family: 'Inter', Arial, Helvetica, sans-serif;
}

.rdc-page main > section.rdc-types > .rdc-types__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 64px;
  width: 100%;
  max-width: 1440px;
  margin-inline: auto;
  padding: 128px 0;
  box-sizing: border-box;
}

.rdc-types__header {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
  width: 100%;
}

.rdc-types__chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 8px 16px;
  background: rgba(38, 106, 74, 0.1);
  border-radius: 9999px;
  color: #266a4a;
  font-size: 14px;
  font-weight: 500;
  line-height: 20px;
  letter-spacing: -0.1504px;
  white-space: nowrap;
}

.rdc-types__heading-group {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  width: 100%;
}

.rdc-types__title {
  margin: 0;
  color: #002112;
  font-size: 64px;
  font-weight: 700;
  line-height: 80px;
  letter-spacing: 0;
  text-align: center;
}

.rdc-types__subtitle {
  margin: 0;
  color: #4a5565;
  font-size: 18px;
  font-weight: 400;
  line-height: 28px;
  letter-spacing: -0.4395px;
  text-align: center;
}

.rdc-types__body {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 48px;
  width: 100%;
}

.rdc-types__cards {
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;
  gap: 32px;
  width: 100%;
}

/* Receituário card */
.rdc-type-card {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 21px;
  flex: 1 0 0;
  min-width: 0;
  overflow: clip;
  box-sizing: border-box;
  padding: 32px;
  background: #fff;
  border-radius: 16px;
  box-shadow:
    0 20px 25px -5px rgba(0, 0, 0, 0.1),
    0 8px 10px -6px rgba(0, 0, 0, 0.1);
}

.rdc-type-card__head {
  display: flex;
  align-items: center;
  gap: 16px;
  width: 100%;
  height: 80px;
}

.rdc-type-card__badge {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: 80px;
  height: 80px;
  border-radius: 16px;
  color: #fff;
  font-family: inherit;
  font-size: 36px;
  font-weight: 700;
  line-height: 40px;
  letter-spacing: 0.3691px;
  box-shadow:
    0 20px 12.5px rgba(0, 0, 0, 0.1),
    0 8px 5px rgba(0, 0, 0, 0.1);
}

.rdc-type-card--a .rdc-type-card__badge {
  background-image: linear-gradient(135deg, #ffeb6e 0%, #daba00 100%);
}

.rdc-type-card--b .rdc-type-card__badge {
  background-image: linear-gradient(135deg, #2b7fff 0%, #155dfc 100%);
}

.rdc-type-card--c .rdc-type-card__badge {
  background-image: linear-gradient(135deg, #e5e7eb 0%, #4a5565 100%);
}

.rdc-type-card__copy {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 4px;
  flex: 1 0 0;
  min-width: 0;
}

.rdc-type-card__title {
  margin: 0;
  color: #101828;
  font-size: 20px;
  font-weight: 500;
  line-height: 28px;
  letter-spacing: -0.4492px;
}

.rdc-type-card__subtitle {
  margin: 0;
  color: #6a7282;
  font-size: 14px;
  font-weight: 400;
  line-height: 20px;
  letter-spacing: -0.1504px;
}

/* Receipt mockup */
.rdc-type-card__mock {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 12px;
  box-sizing: border-box;
  width: 100%;
  height: 131px;
  padding: 26px 26px 2px;
  border: 2px solid;
  border-radius: 14px;
}

.rdc-type-card--a .rdc-type-card__mock {
  border-color: #fff085;
  background-image: linear-gradient(162deg, #fefce8 0%, #fef9c2 100%);
}

.rdc-type-card--b .rdc-type-card__mock {
  border-color: #bedbff;
  background-image: linear-gradient(162deg, #eff6ff 0%, #dbeafe 100%);
}

.rdc-type-card--c .rdc-type-card__mock {
  border-color: #e3e3e3;
  background: #fff;
}

.rdc-type-card__bar {
  display: block;
  width: 100%;
  height: 8px;
  border-radius: 999px;
}

.rdc-type-card__bar--first {
  width: 88%;
  opacity: 0.6;
}

.rdc-type-card__bar--full {
  opacity: 0.4;
}

.rdc-type-card__bar--thin {
  height: 6px;
  opacity: 0.5;
}

.rdc-type-card__mock-foot {
  margin-top: 5px;
  padding-top: 13px;
  border-top: 1px solid;
}

.rdc-type-card--a .rdc-type-card__bar { background-color: #ffdf20; }
.rdc-type-card--a .rdc-type-card__mock-foot { border-top-color: #fff085; }

.rdc-type-card--b .rdc-type-card__bar { background-color: #8ec5ff; }
.rdc-type-card--b .rdc-type-card__mock-foot { border-top-color: #bedbff; }

.rdc-type-card--c .rdc-type-card__bar { background-color: #d7d7d7; }
.rdc-type-card--c .rdc-type-card__mock-foot { border-top-color: #d7d7d7; }

/* Dark banner: Validação por categoria */
.rdc-types__banner {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  box-sizing: border-box;
  width: 100%;
  min-height: 256px;
  padding: 48px;
  overflow: clip;
  background-image: linear-gradient(170deg, #101828 0%, #1e2939 100%);
  border-radius: 16px;
}

.rdc-types__banner-title {
  margin: 0;
  color: #fff;
  font-size: 24px;
  font-weight: 500;
  line-height: 32px;
  letter-spacing: 0.0703px;
}

.rdc-types__banner-text {
  margin: 16px 0 0;
  max-width: 768px;
  color: #d1d5dc;
  font-size: 16px;
  font-weight: 400;
  line-height: 26px;
  letter-spacing: -0.3125px;
}

.rdc-types__banner-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  margin-top: 24px;
}

.rdc-types__banner-tag {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  height: 36px;
  padding: 8px 16px;
  background: rgba(255, 255, 255, 0.1);
  border-radius: 10px;
  color: #fff;
  font-size: 14px;
  font-weight: 400;
  line-height: 20px;
  letter-spacing: -0.1504px;
  white-space: nowrap;
}

.rdc-types__banner-dot {
  display: inline-block;
  flex-shrink: 0;
  width: 8px;
  height: 8px;
  border-radius: 999px;
}

.rdc-types__banner-dot--blue {
  background: #51a2ff;
  opacity: 0.62;
}

.rdc-types__banner-dot--yellow {
  background: #fdc700;
  opacity: 0.53;
}

/* Horizontal padding inside the 1440px canvas at smaller viewports */
@media (max-width: 1439.98px) {
  .rdc-page main > section.rdc-types > .rdc-types__inner {
    padding-inline: 24px;
  }
}

/* Narrow desktop / tablet — stack cards vertically, reduce hero typography */
@media (max-width: 1023.98px) {
  .rdc-page main > section.rdc-types > .rdc-types__inner {
    gap: 48px;
    padding: 72px 24px;
  }

  .rdc-types__title {
    font-size: 40px;
    line-height: 48px;
  }

  .rdc-types__subtitle {
    font-size: 16px;
    line-height: 26px;
    letter-spacing: -0.3125px;
  }

  .rdc-types__cards {
    flex-direction: column;
    gap: 24px;
  }

  .rdc-types__banner {
    padding: 32px;
  }
}

/* Mobile fine-tuning */
@media (max-width: 639.98px) {
  .rdc-types__title {
    font-size: 32px;
    line-height: 40px;
  }

  .rdc-type-card {
    padding: 24px;
  }

  .rdc-type-card__head {
    height: auto;
    gap: 14px;
  }

  .rdc-type-card__badge {
    width: 64px;
    height: 64px;
    font-size: 28px;
    line-height: 32px;
    border-radius: 14px;
  }

  .rdc-types__banner {
    padding: 28px 24px;
  }

  .rdc-types__banner-tags {
    gap: 12px;
  }
}

/* ============================================================
   Receituários físicos (Figma 9298:33129) — pixel-perfect block
   ============================================================ */
.rdc-page main > section.rdc-physical {
  width: 100%;
  background: #fff;
  font-family: 'Inter', Arial, Helvetica, sans-serif;
}

.rdc-page main > section.rdc-physical > .rdc-physical__inner {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 48px;
  width: 100%;
  max-width: 1440px;
  margin-inline: auto;
  padding: 0 0 128px;
  box-sizing: border-box;
}

.rdc-physical__header {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 12px;
  width: 100%;
}

.rdc-physical__title {
  margin: 0;
  color: #002112;
  font-size: 64px;
  font-weight: 700;
  line-height: 80px;
  letter-spacing: 0;
}

.rdc-physical__subtitle {
  margin: 0;
  color: #64748b;
  font-size: 22px;
  font-weight: 400;
  line-height: 28px;
  letter-spacing: -0.3125px;
}

.rdc-physical__body {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 32px;
  width: 100%;
}

/* Green highlight card */
.rdc-physical-highlight {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 16px;
  box-sizing: border-box;
  width: 100%;
  padding: 32px;
  background-image: linear-gradient(173.66deg, #f0fdf4 0%, #ffffff 100%);
  border: 1px solid #b9f8cf;
  border-radius: 14px;
}

.rdc-physical-highlight__title {
  margin: 0;
  color: #101828;
  font-size: 20px;
  font-weight: 500;
  line-height: 28px;
  letter-spacing: -0.4492px;
}

.rdc-physical-highlight__text {
  margin: 0;
  color: #4a5565;
  font-size: 16px;
  font-weight: 400;
  line-height: 26px;
  letter-spacing: -0.3125px;
}

/* 3-up mini cards (Impressão / Numeração / SNCR) */
.rdc-physical-cards {
  display: flex;
  align-items: stretch;
  gap: 24px;
  width: 100%;
}

.rdc-physical-card {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 12px;
  flex: 1 0 0;
  min-width: 0;
  box-sizing: border-box;
  padding: 32px;
  background: #fff;
  border: 1px solid #e5e7eb;
  border-radius: 14px;
}

.rdc-physical-card__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  box-sizing: border-box;
  width: 48px;
  height: 48px;
  padding: 0 12px;
  background: #f0fdf4;
  border-radius: 10px;
}

.rdc-physical-card__icon img {
  display: block;
  width: 24px;
  height: 24px;
  flex-shrink: 0;
}

.rdc-physical-card__title {
  margin: 0;
  color: #101828;
  font-size: 18px;
  font-weight: 500;
  line-height: 27px;
  letter-spacing: -0.4395px;
}

.rdc-physical-card__text {
  margin: 0;
  color: #4a5565;
  font-size: 14px;
  font-weight: 400;
  line-height: 22.75px;
  letter-spacing: -0.1504px;
}

/* Identificação do paciente card */
.rdc-physical-patient {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 24px;
  box-sizing: border-box;
  width: 100%;
  padding: 32px;
  background: #fff;
  border: 2px solid rgba(38, 106, 74, 0.2);
  border-radius: 14px;
}

.rdc-physical-patient__head {
  display: flex;
  align-items: flex-start;
  gap: 16px;
  width: 100%;
}

.rdc-physical-patient__icon {
  display: block;
  width: 24px;
  height: 24px;
  flex-shrink: 0;
  margin-top: 2px;
}

.rdc-physical-patient__copy {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 8px;
  flex: 1 0 0;
  min-width: 0;
}

.rdc-physical-patient__title {
  margin: 0;
  color: #101828;
  font-size: 20px;
  font-weight: 500;
  line-height: 28px;
  letter-spacing: -0.4492px;
}

.rdc-physical-patient__subtitle {
  margin: 0;
  color: #4a5565;
  font-size: 16px;
  font-weight: 400;
  line-height: 24px;
  letter-spacing: -0.3125px;
}

.rdc-physical-patient__items {
  display: flex;
  align-items: stretch;
  gap: 16px;
  width: 100%;
}

.rdc-physical-pill {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 8px;
  flex: 1 0 0;
  min-width: 0;
  box-sizing: border-box;
  padding: 16px;
  border-radius: 10px;
}

.rdc-physical-pill__title {
  margin: 0;
  font-size: 16px;
  font-weight: 500;
  line-height: 24px;
  letter-spacing: -0.3125px;
  white-space: nowrap;
}

.rdc-physical-pill__text {
  margin: 0;
  width: 100%;
  color: #4a5565;
  font-size: 14px;
  font-weight: 400;
  line-height: 20px;
  letter-spacing: -0.1504px;
}

.rdc-physical-pill--ok {
  background: #f0fdf4;
}

.rdc-physical-pill--ok .rdc-physical-pill__title {
  color: #266a4a;
}

.rdc-physical-pill--neutral {
  background: #f9fafb;
}

.rdc-physical-pill--neutral .rdc-physical-pill__title {
  color: #364153;
}

.rdc-physical-pill--info {
  background: #eff6ff;
}

.rdc-physical-pill--info .rdc-physical-pill__title {
  color: #1447e6;
}

/* Horizontal padding inside the 1440px canvas at smaller viewports */
@media (max-width: 1439.98px) {
  .rdc-page main > section.rdc-physical > .rdc-physical__inner {
    padding-inline: 24px;
  }
}

/* Narrow desktop / tablet — stack cards vertically, reduce hero typography */
@media (max-width: 1023.98px) {
  .rdc-page main > section.rdc-physical > .rdc-physical__inner {
    gap: 40px;
    padding: 0 24px 72px;
  }

  .rdc-physical__title {
    font-size: 40px;
    line-height: 48px;
  }

  .rdc-physical__subtitle {
    font-size: 18px;
    line-height: 26px;
  }

  .rdc-physical-cards,
  .rdc-physical-patient__items {
    flex-direction: column;
    gap: 16px;
  }

  .rdc-physical-pill__title {
    white-space: normal;
  }
}

/* Mobile fine-tuning */
@media (max-width: 639.98px) {
  .rdc-physical__title {
    font-size: 32px;
    line-height: 40px;
  }

  .rdc-physical__subtitle {
    font-size: 16px;
    line-height: 24px;
  }

  .rdc-physical-highlight,
  .rdc-physical-card,
  .rdc-physical-patient {
    padding: 24px;
  }
}

/* ============================================================
   Regras essenciais de prescrição (Figma 9298:33200) — pixel-perfect
   ============================================================ */
.rdc-page main > section.rdc-rules {
  width: 100%;
  font-family: 'Inter', Arial, Helvetica, sans-serif;
  background-image: linear-gradient(154.24deg, #fee2e2 0%, #fff7ed 100%);
}

.rdc-page main > section.rdc-rules > .rdc-rules__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 40px;
  width: 100%;
  max-width: 1440px;
  margin-inline: auto;
  padding: 128px 0;
  box-sizing: border-box;
}

.rdc-rules__header {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
}

.rdc-rules__chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 16px;
  background: #ffe2e2;
  border-radius: 9999px;
}

.rdc-rules__chip-icon {
  display: block;
  width: 20px;
  height: 20px;
  flex-shrink: 0;
}

.rdc-rules__chip-text {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #c10007;
  font-size: 16px;
  font-weight: 500;
  line-height: 24px;
  letter-spacing: -0.3125px;
  text-align: center;
  white-space: nowrap;
}

.rdc-rules__heading-group {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 8px;
  width: 100%;
}

.rdc-rules__title {
  margin: 0;
  width: 100%;
  color: #002112;
  font-size: 64px;
  font-weight: 700;
  line-height: 80px;
  letter-spacing: 0;
  text-align: center;
}

.rdc-rules__subtitle {
  margin: 0;
  width: 100%;
  color: #64748b;
  font-size: 22px;
  font-weight: 400;
  line-height: 28px;
  letter-spacing: -0.3125px;
  text-align: center;
}

/* Cards 2×2 */
.rdc-rules__cards {
  display: flex;
  flex-wrap: wrap;
  align-content: flex-start;
  align-items: stretch;
  gap: 24px;
  width: 100%;
}

.rdc-rule-card {
  display: flex;
  align-items: flex-start;
  gap: 16px;
  flex: 1 1 calc(50% - 12px);
  min-width: 0;
  box-sizing: border-box;
  padding: 26px;
  background: #fff;
  border: 2px solid #e5e7eb;
  border-radius: 14px;
}

.rdc-rule-card--neutral {
  border-color: #e5e7eb;
}

.rdc-rule-card--danger {
  border-color: #ffa2a2;
  filter: drop-shadow(0 4px 3px rgba(0, 0, 0, 0.1)) drop-shadow(0 2px 2px rgba(0, 0, 0, 0.1));
}

.rdc-rule-card__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  box-sizing: border-box;
  width: 56px;
  height: 56px;
  padding: 0 14px;
  border-radius: 14px;
}

.rdc-rule-card__icon--green {
  background: #f0fdf4;
}

.rdc-rule-card__icon--red {
  background: #ffe2e2;
}

.rdc-rule-card__icon img {
  display: block;
  width: 28px;
  height: 28px;
  flex-shrink: 0;
}

.rdc-rule-card__copy {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 8px;
  flex: 1 0 0;
  min-width: 0;
}

.rdc-rule-card__title {
  margin: 0;
  color: #101828;
  font-size: 18px;
  font-weight: 500;
  line-height: 27px;
  letter-spacing: -0.4395px;
}

.rdc-rule-card__text {
  margin: 0;
  color: #4a5565;
  font-size: 14px;
  font-weight: 400;
  line-height: 22.75px;
  letter-spacing: -0.1504px;
}

/* Yellow responsibility notice */
.rdc-rules__notice {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  box-sizing: border-box;
  width: 100%;
  padding: 26px;
  background: #fff;
  border: 2px solid #ffdf20;
  border-radius: 14px;
}

.rdc-rules__notice-icon {
  display: block;
  width: 24px;
  height: 24px;
  flex-shrink: 0;
  margin-top: 2px;
}

.rdc-rules__notice-copy {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 8px;
  flex: 1 0 0;
  min-width: 0;
}

.rdc-rules__notice-title {
  margin: 0;
  color: #101828;
  font-size: 16px;
  font-weight: 500;
  line-height: 24px;
  letter-spacing: -0.3125px;
}

.rdc-rules__notice-text {
  margin: 0;
  color: #4a5565;
  font-size: 14px;
  font-weight: 400;
  line-height: 22.75px;
  letter-spacing: -0.1504px;
}

/* Horizontal padding inside the 1440px canvas at smaller viewports */
@media (max-width: 1439.98px) {
  .rdc-page main > section.rdc-rules > .rdc-rules__inner {
    padding-inline: 24px;
  }
}

/* Narrow desktop / tablet — stack cards, shrink hero typography */
@media (max-width: 1023.98px) {
  .rdc-page main > section.rdc-rules > .rdc-rules__inner {
    gap: 32px;
    padding: 72px 24px;
  }

  .rdc-rules__title {
    font-size: 40px;
    line-height: 48px;
  }

  .rdc-rules__subtitle {
    font-size: 18px;
    line-height: 26px;
  }

  .rdc-rule-card {
    flex: 1 1 100%;
  }
}

/* Mobile fine-tuning */
@media (max-width: 639.98px) {
  .rdc-rules__title {
    font-size: 32px;
    line-height: 40px;
  }

  .rdc-rules__subtitle {
    font-size: 16px;
    line-height: 24px;
  }

  .rdc-rule-card,
  .rdc-rules__notice {
    padding: 20px;
  }
}

/* ============================================================
   Como funciona (Figma 9298:33272) — pixel-perfect block
   ============================================================ */
.rdc-page main > section.rdc-how {
  width: 100%;
  background: #fff;
  font-family: 'Inter', Arial, Helvetica, sans-serif;
}

.rdc-page main > section.rdc-how > .rdc-how__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 64px;
  width: 100%;
  max-width: 1440px;
  margin-inline: auto;
  padding: 128px 0;
  box-sizing: border-box;
}

.rdc-how__header {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 12px;
  width: 100%;
}

.rdc-how__title {
  margin: 0;
  width: 100%;
  color: #002112;
  font-size: 64px;
  font-weight: 700;
  line-height: 80px;
  letter-spacing: 0;
  text-align: center;
}

.rdc-how__subtitle {
  margin: 0;
  width: 100%;
  color: #64748b;
  font-size: 22px;
  font-weight: 400;
  line-height: 28px;
  letter-spacing: -0.3125px;
  text-align: center;
}

/* Steps panel */
.rdc-how__panel {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 32px;
  box-sizing: border-box;
  width: 100%;
  padding: 80px 0;
  border: 1px solid #e5e7eb;
  border-radius: 16px;
  background-image: linear-gradient(147.23deg, #f9fafb 0%, #ffffff 100%);
}

/* Each row of steps (3 cards + 2 arrows) */
.rdc-how__row {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 32px;
  width: 100%;
}

.rdc-how__arrow {
  display: block;
  width: 24px;
  height: 24px;
  flex-shrink: 0;
}

/* Card */
.rdc-how-step {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 16px;
  box-sizing: border-box;
  width: 362px;
  flex-shrink: 0;
  padding: 25px;
  background: #fff;
  border: 1px solid #f3f4f6;
  border-radius: 14px;
  filter: drop-shadow(0 1px 1.5px rgba(0, 0, 0, 0.1)) drop-shadow(0 1px 1px rgba(0, 0, 0, 0.1));
}

.rdc-how-step__head {
  display: flex;
  align-items: center;
  gap: 16px;
  width: 100%;
  min-height: 40px;
}

.rdc-how-step__number {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: 40px;
  height: 40px;
  border-radius: 9999px;
  background: #266a4a;
  color: #fff;
  font-size: 16px;
  font-weight: 700;
  line-height: 24px;
  letter-spacing: -0.3125px;
}

.rdc-how-step__title {
  margin: 0;
  color: #101828;
  font-size: 18px;
  font-weight: 500;
  line-height: 27px;
  letter-spacing: -0.4395px;
}

.rdc-how-step__media {
  display: flex;
  align-items: center;
  justify-content: center;
  box-sizing: border-box;
  width: 100%;
  height: 160px;
  padding: 24px 100px;
  border-radius: 10px;
}

.rdc-how-step__media img {
  display: block;
  width: 112px;
  height: 112px;
  flex-shrink: 0;
}

.rdc-how-step--green .rdc-how-step__media {
  background-image: linear-gradient(152.85deg, #f0fdf4 0%, #dcfce7 100%);
}

.rdc-how-step--blue .rdc-how-step__media {
  background-image: linear-gradient(152.85deg, #eff6ff 0%, #dbeafe 100%);
}

.rdc-how-step__caption {
  margin: 0;
  width: 100%;
  color: #4a5565;
  font-size: 14px;
  font-weight: 400;
  line-height: 22.75px;
  letter-spacing: -0.1504px;
  text-align: center;
}

/* Vertical connector between rows */
.rdc-how__connector {
  align-self: center;
  width: 4px;
  height: 48px;
  border-radius: 9999px;
  background-image: linear-gradient(180deg, #266a4a 0%, rgba(38, 106, 74, 0) 100%);
}

/* Horizontal padding inside the 1440px canvas at smaller viewports */
@media (max-width: 1439.98px) {
  .rdc-page main > section.rdc-how > .rdc-how__inner {
    padding-inline: 24px;
  }

  .rdc-how-step {
    width: auto;
    flex: 1 1 0;
    min-width: 0;
  }
}

/* Narrow desktop / tablet — stack rows vertically, shrink typography */
@media (max-width: 1023.98px) {
  .rdc-page main > section.rdc-how > .rdc-how__inner {
    gap: 48px;
    padding: 72px 24px;
  }

  .rdc-how__title {
    font-size: 40px;
    line-height: 48px;
  }

  .rdc-how__subtitle {
    font-size: 18px;
    line-height: 26px;
  }

  .rdc-how__panel {
    padding: 48px 24px;
    gap: 24px;
  }

  .rdc-how__row {
    flex-direction: column;
    gap: 24px;
  }

  .rdc-how-step {
    width: 100%;
    max-width: 420px;
  }

  .rdc-how__arrow {
    transform: rotate(90deg);
  }

  .rdc-how__connector {
    height: 32px;
  }
}

/* Mobile fine-tuning */
@media (max-width: 639.98px) {
  .rdc-how__title {
    font-size: 32px;
    line-height: 40px;
  }

  .rdc-how__subtitle {
    font-size: 16px;
    line-height: 24px;
  }

  .rdc-how-step__media {
    padding: 24px;
  }
}

/* ============================================================
   Prescrição eletrônica (Figma 9298:33405) — pixel-perfect block
   ============================================================ */
.rdc-page main > section.rdc-pe {
  width: 100%;
  background: #fff;
  font-family: 'Inter', Arial, Helvetica, sans-serif;
}

.rdc-page main > section.rdc-pe > .rdc-pe__inner {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 48px;
  width: 100%;
  max-width: 1440px;
  margin-inline: auto;
  padding: 0 0 128px;
  box-sizing: border-box;
}

.rdc-pe__header {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 12px;
  width: 100%;
}

.rdc-pe__title {
  margin: 0;
  width: 100%;
  color: #002112;
  font-size: 64px;
  font-weight: 700;
  line-height: 80px;
  letter-spacing: 0;
  text-align: center;
}

.rdc-pe__subtitle {
  margin: 0;
  width: 100%;
  color: #64748b;
  font-size: 22px;
  font-weight: 400;
  line-height: 28px;
  letter-spacing: -0.3125px;
  text-align: center;
}

.rdc-pe__body {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 32px;
  width: 100%;
}

/* Orange alert */
.rdc-pe-alert {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 16px;
  box-sizing: border-box;
  width: 100%;
  padding: 28px 32px;
  background: #fff7f0;
  border: 1.5px solid #ff9e66;
  border-radius: 14px;
  overflow: hidden;
}

.rdc-pe-alert__title {
  margin: 0;
  color: #21170a;
  font-size: 18px;
  font-weight: 500;
  line-height: normal;
}

.rdc-pe-alert__item {
  margin: 0;
  color: #4a3621;
  font-size: 14px;
  font-weight: 400;
  line-height: normal;
  white-space: pre;
}

.rdc-pe-alert__note {
  margin: 0;
  color: #695742;
  font-size: 13px;
  font-weight: 400;
  line-height: normal;
}

/* 3 signature cards */
.rdc-pe-cards {
  display: flex;
  align-items: stretch;
  justify-content: center;
  gap: 24px;
  width: 100%;
}

.rdc-pe-card {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 13px;
  flex: 1 1 0;
  min-width: 0;
  box-sizing: border-box;
  padding: 26px;
  background: #fff;
  border: 2px solid #e5e7eb;
  border-radius: 14px;
}

.rdc-pe-card--red {
  border-color: #ffa2a2;
}

.rdc-pe-card--blue {
  border-color: #8ec5ff;
}

.rdc-pe-card--green {
  border-color: #7bf1a8;
}

.rdc-pe-card__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  box-sizing: border-box;
  width: 48px;
  height: 48px;
  padding: 0 12px;
  border-radius: 10px;
}

.rdc-pe-card__icon--red {
  background: #ffe2e2;
}

.rdc-pe-card__icon--blue {
  background: #dbeafe;
}

.rdc-pe-card__icon--green {
  background: #dcfce7;
}

.rdc-pe-card__icon img {
  display: block;
  width: 24px;
  height: 24px;
  flex-shrink: 0;
}

.rdc-pe-card__title {
  margin: 0;
  color: #101828;
  font-size: 18px;
  font-weight: 500;
  line-height: 27px;
  letter-spacing: -0.4395px;
}

.rdc-pe-card__text {
  margin: 0;
  color: #4a5565;
  font-size: 14px;
  font-weight: 400;
  line-height: 20px;
  letter-spacing: -0.1504px;
}

.rdc-pe-card__foot {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 8px;
  width: 100%;
  padding-top: 17px;
  border-top: 1px solid #e5e7eb;
}

.rdc-pe-card__foot-row {
  display: flex;
  align-items: center;
  gap: 8px;
  width: 100%;
}

.rdc-pe-card__foot-row img {
  display: block;
  width: 16px;
  height: 16px;
  flex-shrink: 0;
}

.rdc-pe-card__foot-label {
  color: #364153;
  font-size: 12px;
  font-weight: 500;
  line-height: 16px;
}

.rdc-pe-card__foot-text {
  margin: 0;
  color: #6a7282;
  font-size: 12px;
  font-weight: 400;
  line-height: 16px;
}

/* Dark green panel "Qual assinatura usar em cada caso" */
.rdc-pe-dark {
  display: flex;
  align-items: flex-start;
  gap: 16px;
  box-sizing: border-box;
  width: 100%;
  padding: 32px 32px 32px 32px;
  border-radius: 14px;
  background-image: linear-gradient(172.56deg, #266a4a 0%, #1f5438 100%);
}

.rdc-pe-dark__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  box-sizing: border-box;
  width: 48px;
  height: 48px;
  padding: 0 12px;
  background: rgba(255, 255, 255, 0.2);
  border-radius: 10px;
}

.rdc-pe-dark__icon img {
  display: block;
  width: 24px;
  height: 24px;
  flex-shrink: 0;
}

.rdc-pe-dark__copy {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 12px;
  flex: 1 0 0;
  min-width: 0;
}

.rdc-pe-dark__title {
  margin: 0;
  color: #fff;
  font-size: 20px;
  font-weight: 500;
  line-height: 28px;
  letter-spacing: -0.4492px;
}

.rdc-pe-dark__item {
  margin: 0;
  color: #fff;
  font-size: 14px;
  font-weight: 700;
  line-height: 20px;
  letter-spacing: -0.1504px;
}

/* Light blue: Validação info card */
.rdc-pe-info {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  box-sizing: border-box;
  width: 100%;
  padding: 25px;
  background: #eff6ff;
  border: 1px solid #bedbff;
  border-radius: 14px;
}

.rdc-pe-info__icon {
  display: block;
  width: 24px;
  height: 24px;
  flex-shrink: 0;
  margin-top: 2px;
}

.rdc-pe-info__copy {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 8px;
  flex: 1 0 0;
  min-width: 0;
}

.rdc-pe-info__title {
  margin: 0;
  color: #101828;
  font-size: 16px;
  font-weight: 500;
  line-height: 24px;
  letter-spacing: -0.3125px;
}

.rdc-pe-info__text {
  margin: 0;
  color: #4a5565;
  font-size: 14px;
  font-weight: 400;
  line-height: 22.75px;
  letter-spacing: -0.1504px;
}

/* Light blue: Termos */
.rdc-pe-terms {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 14px;
  box-sizing: border-box;
  width: 100%;
  padding: 28px 32px;
  background: #f0faff;
  border: 1px solid #bddbff;
  border-radius: 14px;
  overflow: hidden;
}

.rdc-pe-terms__title {
  margin: 0;
  color: #0f1729;
  font-size: 16px;
  font-weight: 500;
  line-height: normal;
}

.rdc-pe-terms__subtitle {
  margin: 0;
  color: #4a576b;
  font-size: 14px;
  font-weight: 400;
  line-height: normal;
}

.rdc-pe-terms__item {
  margin: 0;
  color: #0f613d;
  font-size: 14px;
  font-weight: 400;
  line-height: normal;
  white-space: pre;
}

/* Horizontal padding inside the 1440px canvas at smaller viewports */
@media (max-width: 1439.98px) {
  .rdc-page main > section.rdc-pe > .rdc-pe__inner {
    padding-inline: 24px;
  }

  .rdc-pe-alert,
  .rdc-pe-terms {
    overflow-x: auto;
  }
}

/* Narrow desktop / tablet — stack cards, shrink hero typography */
@media (max-width: 1023.98px) {
  .rdc-page main > section.rdc-pe > .rdc-pe__inner {
    gap: 40px;
    padding: 0 24px 72px;
  }

  .rdc-pe__title {
    font-size: 40px;
    line-height: 48px;
  }

  .rdc-pe__subtitle {
    font-size: 18px;
    line-height: 26px;
  }

  .rdc-pe-cards {
    flex-direction: column;
    gap: 16px;
  }

  .rdc-pe-alert__item,
  .rdc-pe-alert__note,
  .rdc-pe-terms__subtitle,
  .rdc-pe-terms__item {
    white-space: normal;
  }
}

/* Mobile fine-tuning */
@media (max-width: 639.98px) {
  .rdc-pe__title {
    font-size: 32px;
    line-height: 40px;
  }

  .rdc-pe__subtitle {
    font-size: 16px;
    line-height: 24px;
  }

  .rdc-pe-alert,
  .rdc-pe-card,
  .rdc-pe-dark,
  .rdc-pe-info,
  .rdc-pe-terms {
    padding: 20px;
  }

  .rdc-pe-dark {
    flex-direction: column;
    gap: 16px;
  }
}

/* ============================================================
   SNCR (Figma 9298:33498) — pixel-perfect block
   ============================================================ */
.rdc-page main > section.rdc-sncr {
  width: 100%;
  background: linear-gradient(153.99deg, #f9fafb 0%, #ffffff 100%);
  font-family: 'Inter', Arial, Helvetica, sans-serif;
}

.rdc-page main > section.rdc-sncr > .rdc-sncr__inner {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  padding: 128px 240px;
  width: 100%;
  max-width: none;
  margin: 0;
  box-sizing: border-box;
}

.rdc-sncr__inner > * {
  width: 100%;
}

.rdc-sncr__inner {
  gap: 0;
}

.rdc-sncr__inner > .rdc-sncr__header + .rdc-sncr__body {
  margin-top: 56px;
}

.rdc-sncr__header {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
}

.rdc-sncr__chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 16px;
  background: #dbeafe;
  border-radius: 9999px;
}

.rdc-sncr__chip-icon {
  display: block;
  width: 20px;
  height: 20px;
  flex-shrink: 0;
}

.rdc-sncr__chip-text {
  color: #1447e6;
  font-size: 16px;
  font-weight: 500;
  line-height: 24px;
  letter-spacing: -0.3125px;
  text-align: center;
  white-space: nowrap;
}

.rdc-sncr__heading-group {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  width: 100%;
}

.rdc-sncr__title {
  margin: 0;
  width: 100%;
  color: #002112;
  font-size: 48px;
  font-weight: 700;
  line-height: 1.1;
  text-align: center;
}

.rdc-sncr__subtitle {
  margin: 0;
  padding: 0 197px;
  color: #64748b;
  font-size: 22px;
  font-weight: 400;
  line-height: 28px;
  letter-spacing: -0.3125px;
  text-align: center;
  white-space: nowrap;
}

.rdc-sncr__body {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 32px;
  width: 100%;
  max-width: 1195px;
  align-self: center;
}

.rdc-sncr__cards {
  display: flex;
  gap: 32px;
  align-items: stretch;
  width: 100%;
  justify-content: center;
}

.rdc-sncr-card {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 12px;
  width: 377px;
  flex-shrink: 0;
  padding: 24px;
  background: #ffffff;
  border: 1px solid #e5e7eb;
  border-radius: 14px;
  filter: drop-shadow(0 1px 1.5px rgba(0, 0, 0, 0.1)) drop-shadow(0 1px 1px rgba(0, 0, 0, 0.1));
  box-sizing: border-box;
}

.rdc-sncr-card__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  padding: 0 12px;
  border-radius: 10px;
  flex-shrink: 0;
  box-sizing: border-box;
}

.rdc-sncr-card__icon img {
  display: block;
  width: 24px;
  height: 24px;
}

.rdc-sncr-card__icon--blue {
  background: #eff6ff;
}

.rdc-sncr-card__icon--green {
  background: #f0fdf4;
}

.rdc-sncr-card__icon--orange {
  background: #fff7ed;
}

.rdc-sncr-card__title {
  margin: 0;
  color: #101828;
  font-size: 18px;
  font-weight: 500;
  line-height: 27px;
  letter-spacing: -0.4395px;
}

.rdc-sncr-card__text {
  margin: 0;
  color: #4a5565;
  font-size: 14px;
  font-weight: 400;
  line-height: 20px;
  letter-spacing: -0.1504px;
}

.rdc-sncr-timeline {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 16px;
  width: 100%;
  padding: 34px;
  background: #ffffff;
  border: 2px solid #bedbff;
  border-radius: 14px;
  box-sizing: border-box;
}

.rdc-sncr-timeline__title {
  margin: 0;
  color: #101828;
  font-size: 20px;
  font-weight: 500;
  line-height: 28px;
  letter-spacing: -0.4492px;
}

.rdc-sncr-timeline__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 12px;
  width: 100%;
}

.rdc-sncr-timeline__item {
  display: flex;
  align-items: center;
  gap: 12px;
}

.rdc-sncr-timeline__dot {
  width: 12px;
  height: 12px;
  border-radius: 9999px;
  flex-shrink: 0;
}

.rdc-sncr-timeline__dot--green {
  background: #00c950;
}

.rdc-sncr-timeline__dot--blue {
  background: #2b7fff;
  opacity: 0.53;
}

.rdc-sncr-timeline__dot--gray {
  background: #d1d5dc;
}

.rdc-sncr-timeline__text {
  margin: 0;
  color: #4a5565;
  font-size: 14px;
  font-weight: 400;
  line-height: 20px;
  letter-spacing: -0.1504px;
}

.rdc-sncr-timeline__text strong {
  font-weight: 700;
}

.rdc-sncr-timeline__text--bold {
  font-weight: 700;
}

/* Responsive — wide desktop pull-in (≤1439.98px) */
@media (max-width: 1439.98px) {
  .rdc-page main > section.rdc-sncr > .rdc-sncr__inner {
    padding: 96px 80px;
  }

  .rdc-sncr__subtitle {
    padding: 0 64px;
    white-space: normal;
  }

  .rdc-sncr-card {
    width: auto;
    flex: 1 1 0;
    min-width: 0;
  }
}

/* Responsive — tablet/medium (≤1023.98px) */
@media (max-width: 1023.98px) {
  .rdc-page main > section.rdc-sncr > .rdc-sncr__inner {
    padding: 72px 40px;
  }

  .rdc-sncr__inner > .rdc-sncr__header + .rdc-sncr__body {
    margin-top: 40px;
  }

  .rdc-sncr__title {
    font-size: 36px;
    line-height: 1.15;
  }

  .rdc-sncr__subtitle {
    padding: 0;
    font-size: 18px;
    line-height: 26px;
    white-space: normal;
  }

  .rdc-sncr__cards {
    flex-direction: column;
    gap: 16px;
  }

  .rdc-sncr-card {
    width: 100%;
  }

  .rdc-sncr-timeline {
    padding: 24px;
  }
}

/* Responsive — mobile (≤639.98px) */
@media (max-width: 639.98px) {
  .rdc-page main > section.rdc-sncr > .rdc-sncr__inner {
    padding: 56px 20px;
  }

  .rdc-sncr__title {
    font-size: 28px;
    line-height: 1.15;
  }

  .rdc-sncr__subtitle {
    font-size: 16px;
    line-height: 24px;
  }

  .rdc-sncr-card {
    padding: 20px;
  }

  .rdc-sncr-timeline {
    padding: 20px;
  }
}

/* ============================================================
   Período de transição (Figma 9298:33556) — pixel-perfect block
   ============================================================ */
.rdc-page main > section.rdc-trans {
  width: 100%;
  background: #ffffff;
  font-family: 'Inter', Arial, Helvetica, sans-serif;
}

.rdc-page main > section.rdc-trans > .rdc-trans__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 40px;
  padding: 0 363px 128px;
  width: 100%;
  max-width: none;
  margin: 0;
  box-sizing: border-box;
}

.rdc-trans__header {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 12px;
  width: 100%;
}

.rdc-trans__title {
  margin: 0;
  width: 100%;
  color: #002112;
  font-size: 48px;
  font-weight: 700;
  line-height: 1.1;
  text-align: center;
}

.rdc-trans__subtitle {
  margin: 0;
  width: 100%;
  padding: 0 296px;
  color: #64748b;
  font-size: 22px;
  font-weight: 400;
  line-height: 28px;
  letter-spacing: -0.3125px;
  text-align: center;
  white-space: nowrap;
  box-sizing: border-box;
}

.rdc-trans__body {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 40px;
  width: 100%;
  max-width: 1194px;
  align-self: center;
}

.rdc-trans__cards {
  display: flex;
  gap: 24px;
  align-items: stretch;
  justify-content: center;
  width: 100%;
}

.rdc-trans-card {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 12px;
  flex: 1 1 0;
  min-width: 0;
  padding: 25px;
  border: 1px solid transparent;
  border-radius: 14px;
  box-sizing: border-box;
}

.rdc-trans-card--yellow {
  border-color: #fff085;
  background: linear-gradient(150.37deg, #fefce8 0%, #fff7ed 100%);
}

.rdc-trans-card--blue {
  border-color: #bedbff;
  background: linear-gradient(150.37deg, #eff6ff 0%, #eef2ff 100%);
}

.rdc-trans-card--purple {
  border-color: #e9d4ff;
  background: linear-gradient(150.37deg, #faf5ff 0%, #fdf2f8 100%);
}

.rdc-trans-card__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  padding: 0 12px;
  border-radius: 10px;
  flex-shrink: 0;
  box-sizing: border-box;
}

.rdc-trans-card__icon img {
  display: block;
  width: 24px;
  height: 24px;
}

.rdc-trans-card__icon--yellow {
  background: #fef9c2;
}

.rdc-trans-card__icon--blue {
  background: #dbeafe;
}

.rdc-trans-card__icon--purple {
  background: #f3e8ff;
}

.rdc-trans-card__title {
  margin: 0;
  width: 100%;
  color: #101828;
  font-size: 18px;
  font-weight: 500;
  line-height: 27px;
  letter-spacing: -0.4395px;
}

.rdc-trans-card__text {
  margin: 0;
  width: 100%;
  color: #4a5565;
  font-size: 14px;
  font-weight: 400;
  line-height: 22.75px;
  letter-spacing: -0.1504px;
}

.rdc-trans-todo {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 12px;
  width: 100%;
  padding: 24px 32px;
  background: #f9fafb;
  border: 1px solid #e5e7eb;
  border-radius: 14px;
  box-sizing: border-box;
}

.rdc-trans-todo__title {
  margin: 0;
  color: #101828;
  font-size: 16px;
  font-weight: 500;
  line-height: 24px;
  letter-spacing: -0.3125px;
}

.rdc-trans-todo__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
  width: 100%;
}

.rdc-trans-todo__item {
  display: flex;
  align-items: center;
  gap: 8px;
}

.rdc-trans-todo__bullet {
  color: #266a4a;
  font-size: 14px;
  font-weight: 400;
  line-height: 20px;
  letter-spacing: -0.1504px;
  flex-shrink: 0;
}

.rdc-trans-todo__text {
  margin: 0;
  color: #4a5565;
  font-size: 14px;
  font-weight: 400;
  line-height: 20px;
  letter-spacing: -0.1504px;
  white-space: nowrap;
}

/* Responsive — wide desktop pull-in (≤1439.98px) */
@media (max-width: 1439.98px) {
  .rdc-page main > section.rdc-trans > .rdc-trans__inner {
    padding: 0 80px 96px;
  }

  .rdc-trans__subtitle {
    padding: 0 64px;
    white-space: normal;
  }

  .rdc-trans-todo__text {
    white-space: normal;
  }
}

/* Responsive — tablet/medium (≤1023.98px) */
@media (max-width: 1023.98px) {
  .rdc-page main > section.rdc-trans > .rdc-trans__inner {
    padding: 0 40px 72px;
    gap: 32px;
  }

  .rdc-trans__title {
    font-size: 36px;
    line-height: 1.15;
  }

  .rdc-trans__subtitle {
    padding: 0;
    font-size: 18px;
    line-height: 26px;
    white-space: normal;
  }

  .rdc-trans__cards {
    flex-direction: column;
    gap: 16px;
  }

  .rdc-trans-card {
    width: 100%;
  }

  .rdc-trans-todo {
    padding: 20px 24px;
  }
}

/* Responsive — mobile (≤639.98px) */
@media (max-width: 639.98px) {
  .rdc-page main > section.rdc-trans > .rdc-trans__inner {
    padding: 0 20px 56px;
  }

  .rdc-trans__title {
    font-size: 28px;
  }

  .rdc-trans__subtitle {
    font-size: 16px;
    line-height: 24px;
  }

  .rdc-trans-card {
    padding: 20px;
  }

  .rdc-trans-todo {
    padding: 20px;
  }

  .rdc-trans-todo__item {
    align-items: flex-start;
  }
}

/* ============================================================
   O CFM já está preparado (Figma 9298:33617) — pixel-perfect block
   ============================================================ */
.rdc-page main > section.rdc-cfm {
  position: relative;
  width: 100%;
  overflow: hidden;
  background: linear-gradient(158.97deg, #266a4a 0%, #266848 11.11%, #246546 22.22%, #246344 33.33%, #236042 44.44%, #225e40 55.56%, #215b3e 66.67%, #21593c 77.78%, #20563a 88.89%, #1f5438 100%);
  font-family: 'Inter', Arial, Helvetica, sans-serif;
}

.rdc-cfm__blobs {
  position: absolute;
  inset: 0 auto auto 0;
  width: 1551px;
  height: 642.25px;
  opacity: 0.1;
  pointer-events: none;
  z-index: 0;
}

.rdc-cfm__blob {
  position: absolute;
  display: block;
  background: #ffffff;
  border-radius: 9999px;
  filter: blur(64px);
}

.rdc-cfm__blob--tl {
  width: 288px;
  height: 288px;
  top: 40px;
  left: 40px;
}

.rdc-cfm__blob--br {
  width: 384px;
  height: 384px;
  top: 218.25px;
  left: 1127px;
}

.rdc-page main > section.rdc-cfm > .rdc-cfm__inner {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 48px;
  padding: 128px 363px;
  width: 100%;
  max-width: none;
  margin: 0;
  box-sizing: border-box;
}

.rdc-cfm__header {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 16px;
  width: 100%;
}

.rdc-cfm__title {
  margin: 0;
  color: #ffffff;
  font-size: 48px;
  font-weight: 700;
  line-height: 40px;
  letter-spacing: 0.3691px;
  text-align: center;
  white-space: nowrap;
}

.rdc-cfm__subtitle {
  margin: 0;
  color: #dcfce7;
  font-size: 22px;
  font-weight: 400;
  line-height: 28px;
  letter-spacing: -0.4395px;
  text-align: center;
  white-space: nowrap;
}

.rdc-cfm__body {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 48px;
  width: 100%;
}

.rdc-cfm__cards {
  display: flex;
  gap: 24px;
  align-items: stretch;
  justify-content: center;
  width: 100%;
}

.rdc-cfm-card {
  position: relative;
  flex: 1 1 0;
  min-width: 0;
  min-height: 252.25px;
  padding: 24px;
  background: rgba(255, 255, 255, 0.1);
  border: 1px solid rgba(255, 255, 255, 0.2);
  border-radius: 14px;
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}

.rdc-cfm-card__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 56px;
  height: 56px;
  padding: 0 14px;
  background: rgba(255, 255, 255, 0.2);
  border-radius: 14px;
  flex-shrink: 0;
  box-sizing: border-box;
  margin-bottom: 16px;
}

.rdc-cfm-card__icon img {
  display: block;
  width: 28px;
  height: 28px;
}

.rdc-cfm-card__title {
  margin: 0 0 8px;
  width: 240px;
  max-width: 100%;
  color: #ffffff;
  font-size: 18px;
  font-weight: 500;
  line-height: 27px;
  letter-spacing: -0.4395px;
}

.rdc-cfm-card__text {
  margin: 0;
  width: 240px;
  max-width: 100%;
  color: #dcfce7;
  font-size: 14px;
  font-weight: 400;
  line-height: 22.75px;
  letter-spacing: -0.1504px;
}

.rdc-cfm-pill {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  width: 100%;
  padding: 13px 25px;
  background: rgba(255, 255, 255, 0.2);
  border: 1px solid rgba(255, 255, 255, 0.3);
  border-radius: 9999px;
  box-sizing: border-box;
}

.rdc-cfm-pill__icon {
  display: block;
  width: 20px;
  height: 20px;
  flex-shrink: 0;
}

.rdc-cfm-pill__text {
  margin: 0;
  color: #ffffff;
  font-size: 16px;
  font-weight: 500;
  line-height: 24px;
  letter-spacing: -0.3125px;
  text-align: center;
  white-space: nowrap;
}

/* Responsive — wide desktop pull-in (≤1439.98px) */
@media (max-width: 1439.98px) {
  .rdc-page main > section.rdc-cfm > .rdc-cfm__inner {
    padding: 96px 80px;
  }

  .rdc-cfm__title,
  .rdc-cfm__subtitle,
  .rdc-cfm-pill__text {
    white-space: normal;
  }

  .rdc-cfm-card__title,
  .rdc-cfm-card__text {
    width: 100%;
  }
}

/* Responsive — tablet/medium (≤1023.98px) */
@media (max-width: 1023.98px) {
  .rdc-page main > section.rdc-cfm > .rdc-cfm__inner {
    padding: 72px 40px;
    gap: 32px;
  }

  .rdc-cfm__title {
    font-size: 36px;
    line-height: 44px;
  }

  .rdc-cfm__subtitle {
    font-size: 18px;
    line-height: 26px;
  }

  .rdc-cfm__cards {
    flex-wrap: wrap;
  }

  .rdc-cfm-card {
    flex: 1 1 calc(50% - 12px);
    min-width: calc(50% - 12px);
    min-height: 0;
  }

  .rdc-cfm-pill {
    padding: 12px 20px;
  }
}

/* Responsive — mobile (≤639.98px) */
@media (max-width: 639.98px) {
  .rdc-page main > section.rdc-cfm > .rdc-cfm__inner {
    padding: 56px 20px;
  }

  .rdc-cfm__title {
    font-size: 28px;
    line-height: 36px;
  }

  .rdc-cfm__subtitle {
    font-size: 16px;
    line-height: 24px;
  }

  .rdc-cfm__cards {
    flex-direction: column;
    gap: 16px;
  }

  .rdc-cfm-card {
    flex: 1 1 100%;
    min-width: 100%;
  }

  .rdc-cfm-pill__text {
    font-size: 14px;
    line-height: 20px;
  }
}

/* ============================================================
   Final CTA (Figma 9298:33852) — pixel-perfect block
   ============================================================ */
.rdc-page main > section.rdc-cta {
  position: relative;
  width: 100%;
  overflow: hidden;
  background: #266a4a;
  font-family: 'Inter', Arial, Helvetica, sans-serif;
}

.rdc-cta__blobs {
  position: absolute;
  top: 0;
  left: 184.5px;
  width: 1551px;
  height: 497px;
  opacity: 0.1;
  pointer-events: none;
  z-index: 0;
}

.rdc-cta__blob {
  position: absolute;
  display: block;
  width: 384px;
  height: 384px;
  background: #ffffff;
  border-radius: 9999px;
  filter: blur(64px);
}

.rdc-cta__blob--a {
  top: 0;
  left: 387.75px;
}

.rdc-cta__blob--b {
  top: 113px;
  left: 779.25px;
}

.rdc-page main > section.rdc-cta > .rdc-cta__inner {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 35px;
  padding: 128px 240px;
  width: 100%;
  max-width: none;
  margin: 0;
  box-sizing: border-box;
  min-height: auto;
}

.rdc-cta__header {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 16px;
  width: 100%;
}

.rdc-cta__title {
  margin: 0;
  width: 100%;
  color: #ffffff;
  font-size: 48px;
  font-weight: 700;
  line-height: normal;
  letter-spacing: 0.3691px;
  text-align: center;
}

.rdc-cta__subtitle {
  margin: 0;
  width: 100%;
  color: #dcfce7;
  font-size: 20px;
  font-weight: 400;
  line-height: 32.5px;
  letter-spacing: -0.4492px;
  text-align: center;
}

.rdc-cta__btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  padding: 20px 40px;
  background: #ffffff;
  border-radius: 14px;
  filter: drop-shadow(0 25px 25px rgba(0, 0, 0, 0.25));
  text-decoration: none;
  transition: background-color 0.2s ease;
}

.rdc-cta__btn:hover {
  background: #f0fdf4;
}

.rdc-cta__btn:focus-visible {
  outline: 2px solid #ffffff;
  outline-offset: 2px;
}

.rdc-cta__btn-text {
  color: #266a4a;
  font-size: 18px;
  font-weight: 500;
  line-height: 28px;
  letter-spacing: -0.4395px;
  text-align: center;
  white-space: nowrap;
}

.rdc-cta__btn-icon {
  display: block;
  width: 24px;
  height: 24px;
  flex-shrink: 0;
}

.rdc-cta__pills {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  gap: 32px;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
}

.rdc-cta__pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.rdc-cta__pill-dot {
  display: block;
  width: 8px;
  height: 8px;
  background: #7bf1a8;
  border-radius: 9999px;
  flex-shrink: 0;
}

.rdc-cta__pill-text {
  color: #dcfce7;
  font-size: 14px;
  font-weight: 400;
  line-height: 20px;
  letter-spacing: -0.1504px;
  white-space: nowrap;
}

/* Responsive — wide desktop pull-in (≤1439.98px) */
@media (max-width: 1439.98px) {
  .rdc-page main > section.rdc-cta > .rdc-cta__inner {
    padding: 96px 80px;
  }
}

/* Responsive — tablet/medium (≤1023.98px) */
@media (max-width: 1023.98px) {
  .rdc-page main > section.rdc-cta > .rdc-cta__inner {
    padding: 72px 40px;
    gap: 28px;
  }

  .rdc-cta__title {
    font-size: 36px;
    line-height: 1.15;
  }

  .rdc-cta__subtitle {
    font-size: 18px;
    line-height: 28px;
  }

  .rdc-cta__btn {
    padding: 16px 32px;
  }

  .rdc-cta__pills {
    gap: 20px;
  }
}

/* Responsive — mobile (≤639.98px) */
@media (max-width: 639.98px) {
  .rdc-page main > section.rdc-cta > .rdc-cta__inner {
    padding: 56px 20px;
    gap: 24px;
  }

  .rdc-cta__title {
    font-size: 28px;
    line-height: 36px;
  }

  .rdc-cta__subtitle {
    font-size: 16px;
    line-height: 26px;
  }

  .rdc-cta__btn {
    width: 100%;
    padding: 16px 24px;
  }

  .rdc-cta__btn-text {
    white-space: normal;
    font-size: 16px;
    line-height: 24px;
  }

  .rdc-cta__pills {
    flex-direction: column;
    gap: 12px;
  }
}

.rdc-no-change {
  background: #fff;
  padding: 0 clamp(20px, 12.5vw, 240px) 128px;
}

.rdc-no-change__panel {
  max-width: 1440px;
  min-height: 432px;
  margin: 0 auto;
  padding: 72px 244px;
  border-radius: 48px;
  background: #fff4f1;
}

.rdc-section-heading {
  text-align: center;
}

.rdc-section-heading h2 {
  margin: 0;
  color: var(--rdc-ink);
  font-size: 48px;
  font-weight: 700;
  line-height: 60px;
}

.rdc-section-heading p {
  margin: 12px 0 0;
  color: var(--rdc-text);
  font-size: 16px;
  line-height: 24px;
}

.rdc-no-change__cards {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 24px;
  margin-top: 32px;
}

.rdc-mini-card {
  display: flex;
  gap: 12px;
  min-height: 134px;
  padding: 24px;
  border: 1px solid #e5e7eb;
  border-radius: 10px;
  background: #fff;
}

.rdc-mini-card__icon {
  display: grid;
  width: 24px;
  height: 24px;
  flex: 0 0 24px;
  place-items: center;
  border-radius: 999px;
  border: 1px solid var(--rdc-green);
  color: var(--rdc-green);
  font-size: 13px;
  font-weight: 700;
}

.rdc-mini-card h3 {
  margin: 0;
  color: #101828;
  font-size: 16px;
  font-weight: 600;
  line-height: 24px;
}

.rdc-mini-card p {
  margin: 4px 0 0;
  color: var(--rdc-text);
  font-size: 14px;
  line-height: 20px;
}

.rdc-page main > section:nth-of-type(12) > div {
  padding-top: 128px;
  padding-bottom: 128px;
}

.rdc-page main > section:nth-of-type(12) {
  background: #f9fafb !important;
}

.rdc-page main > section:nth-of-type(12) > div {
  max-width: 1440px;
}

.rdc-page [data-rdc-faq-wrapper] {
  max-width: none !important;
}

.rdc-page footer {
  min-height: 253px;
  padding-top: 64px;
  padding-bottom: 32px;
}

@media (max-width: 1279.98px) {
  .rdc-page main > section:nth-of-type(2) > div,
  .rdc-page main > section:nth-of-type(12) > div {
    padding: 72px 24px;
  }

  .rdc-page main > section:nth-of-type(2) h2 {
    font-size: 40px;
    line-height: 48px;
  }

  .rdc-no-change {
    padding: 0 24px 72px;
  }

  .rdc-no-change__panel {
    padding: 48px 24px;
    border-radius: 28px;
  }

  .rdc-no-change__cards {
    grid-template-columns: 1fr;
  }

  .rdc-section-heading h2 {
    font-size: 36px;
    line-height: 44px;
  }
}

/* ============================================================
   Mobile (≤639.98px): titles, subtitles and section headers
   left-aligned across all RDC sections
   ============================================================ */
@media (max-width: 639.98px) {
  .rdc-page main > section .rdc-section-heading,
  .rdc-page main > section .rdc-section-heading h2,
  .rdc-page main > section .rdc-section-heading p,
  .rdc-page main > section .rdc-hero__title,
  .rdc-page main > section .rdc-hero__title-lg,
  .rdc-page main > section .rdc-hero__title-md,
  .rdc-page main > section .rdc-hero__desc,
  .rdc-page main > section .rdc-types__header,
  .rdc-page main > section .rdc-types__title,
  .rdc-page main > section .rdc-types__subtitle,
  .rdc-page main > section .rdc-physical__header,
  .rdc-page main > section .rdc-physical__title,
  .rdc-page main > section .rdc-physical__subtitle,
  .rdc-page main > section .rdc-rules__header,
  .rdc-page main > section .rdc-rules__title,
  .rdc-page main > section .rdc-rules__subtitle,
  .rdc-page main > section .rdc-how__header,
  .rdc-page main > section .rdc-how__title,
  .rdc-page main > section .rdc-how__subtitle,
  .rdc-page main > section .rdc-pe__header,
  .rdc-page main > section .rdc-pe__title,
  .rdc-page main > section .rdc-pe__subtitle,
  .rdc-page main > section .rdc-sncr__header,
  .rdc-page main > section .rdc-sncr__heading-group,
  .rdc-page main > section .rdc-sncr__title,
  .rdc-page main > section .rdc-sncr__subtitle,
  .rdc-page main > section .rdc-trans__header,
  .rdc-page main > section .rdc-trans__title,
  .rdc-page main > section .rdc-trans__subtitle,
  .rdc-page main > section .rdc-cfm__header,
  .rdc-page main > section .rdc-cfm__title,
  .rdc-page main > section .rdc-cfm__subtitle,
  .rdc-page main > section .rdc-cta__header,
  .rdc-page main > section .rdc-cta__title,
  .rdc-page main > section .rdc-cta__subtitle,
  .rdc-page main > section#faq > div > div:first-child,
  .rdc-page main > section#faq > div > div:first-child h2,
  .rdc-page main > section#faq > div > div:first-child p {
    text-align: left;
    align-items: flex-start;
  }

  /* Drop the lateral px-* padding that pulled subtitles toward the
     center in Figma (these were only meaningful on desktop) */
  .rdc-page main > section .rdc-sncr__subtitle,
  .rdc-page main > section .rdc-trans__subtitle {
    padding-left: 0;
    padding-right: 0;
  }
}
