*, *::before, *::after { box-sizing: border-box; }
body { margin: 0; padding: 0; }

/* ==========================================================================
     GHL wrapper unclip — stop GHL's section/row/column/custom-code wrappers
     from constraining height or hiding overflow on this block.
     Without this, only the first section is visible; the rest gets clipped.
     ========================================================================== */
  .c-custom-code,
  .custom-code-container,
  [class*="custom-code-"],
  .c-column,
  [class*="col-"],
  .c-row,
  [class*="row-"],
  .c-section,
  [class*="section-"]{
    height: auto !important;
    max-height: none !important;
    min-height: 0 !important;
    overflow: visible !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
  }
  /* The custom-code container's inner span GHL injects can also clamp size */
.c-custom-code > span {
    display: contents !important;
}

  /* ==========================================================================
     Design tokens — pulled directly from rothroadmap.org's compiled stylesheet
     ========================================================================== */
  .rr-app{
    display: block;
    width: 100%;
    height: auto;
    /* shadcn-style HSL channel tokens */
    --rr-bg: 220 30% 97%;
    --rr-fg: 215 50% 12%;
    --rr-card: 0 0% 100%;
    --rr-card-fg: 215 50% 12%;
    --rr-primary: 215 65% 15%;
    --rr-primary-fg: 40 45% 95%;
    --rr-muted: 220 20% 93%;
    --rr-muted-fg: 215 15% 45%;
    --rr-border: 220 20% 88%;
    --rr-destructive: 0 84.2% 60.2%;

    --rr-navy: 215 65% 15%;
    --rr-navy-light: 215 45% 25%;
    --rr-navy-dark: 215 70% 8%;
    --rr-gold: 40 45% 56%;
    --rr-gold-light: 40 50% 70%;
    --rr-gold-muted: 40 30% 80%;
    --rr-cream: 40 30% 96%;

    --rr-gradient-hero: linear-gradient(160deg, hsl(215 70% 8%) 0%, hsl(215 65% 15%) 50%, hsl(215 45% 25%) 100%);
    --rr-gradient-gold: linear-gradient(135deg, hsl(40 45% 56%) 0%, hsl(40 50% 70%) 100%);

    --rr-shadow-card: 0 4px 24px -4px hsl(215 65% 15% / .08);
    --rr-shadow-elev: 0 12px 40px -8px hsl(215 65% 15% / .12);
    --rr-shadow-gold: 0 4px 20px -4px hsl(40 45% 56% / .3);

    --rr-font-heading: 'Playfair Display', Georgia, serif;
    --rr-font-body: 'Source Sans 3', system-ui, -apple-system, sans-serif;

    color: hsl(var(--rr-fg));
    font-family: var(--rr-font-body);
    line-height: 1.5;
    -webkit-font-smoothing: antialiased;
  }
  .rr-app *, .rr-app *::before, .rr-app *::after{ box-sizing: border-box; }
  .rr-app img, .rr-app svg{ display:block; max-width:100%; }
  .rr-app a{ color:inherit; text-decoration:none; }
  .rr-app button{ font:inherit; cursor:pointer; border:0; background:transparent; color:inherit; padding:0; }
  .rr-app h1,.rr-app h2,.rr-app h3,.rr-app h4{ font-family:var(--rr-font-heading); margin:0; line-height:1.15; letter-spacing:-.01em; }
  .rr-app p{ margin:0; }

  /* container */
  .rr-container{ max-width: 1280px; margin: 0 auto; padding: 0 24px; }

  /* gradient text helper */
  .rr-text-gold-grad{
    background: var(--rr-gradient-gold);
    -webkit-background-clip:text; background-clip:text;
    -webkit-text-fill-color:transparent; color:transparent;
  }

  /* button */
  .rr-btn{
    display:inline-flex; align-items:center; gap:8px;
    background: hsl(var(--rr-gold));
    color: hsl(var(--rr-navy-dark));
    font-family: var(--rr-font-body);
    font-weight: 600;
    border-radius: 6px;
    padding: 10px 24px;
    font-size: 14px;
    letter-spacing: .025em;
    box-shadow: var(--rr-shadow-gold);
    transition: background .2s ease, box-shadow .2s ease, transform .2s ease;
  }
  .rr-btn:hover{ background: hsl(var(--rr-gold-light)); box-shadow: 0 12px 32px -8px hsl(40 45% 56% / .4); }
  .rr-btn--lg{ padding: 16px 40px; font-size: 18px; font-weight: 700; }
  .rr-btn--lg:hover{ transform: translateY(-2px); }
  .rr-btn--md{ padding: 14px 32px; font-size: 16px; font-weight: 600; }

  /* ==========================================================================
     NAV — hardened with !important so GHL's wrapper styles can't override
     ========================================================================== */
  .rr-app .rr-nav{
    position: fixed !important; top:0 !important; left:0 !important; right:0 !important; z-index:50 !important;
    background: hsl(215 70% 8% / .95) !important;
    backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
    border-bottom: 1px solid hsl(215 45% 25% / .2) !important;
  }
  .rr-app .rr-nav__row{
    display:flex !important; align-items:center !important; justify-content:space-between !important;
    padding: 16px 24px !important; max-width: 1280px !important; margin: 0 auto !important;
  }
  .rr-app .rr-nav__logo,
  .rr-app a.rr-nav__logo{
    display: flex !important; align-items: center !important;
    text-decoration: none !important;
    font-size: 0 !important;
  }
  .rr-app .rr-nav__logo-img{
    height: 48px !important; width: auto !important;
    display: block !important;
    filter: brightness(0) invert(1) !important;
  }
  .rr-app .rr-footer__logo-img{
    height: 38px !important; width: auto !important;
    display: block !important;
    filter: brightness(0) invert(1) !important;
    opacity: 0.55;
  }
  .rr-app .rr-nav__logo-accent{ color: #C2A15D !important; }
  .rr-app .rr-nav__links{ display:none; align-items:center; gap: 32px; }
  @media (min-width: 768px){ .rr-app .rr-nav__links{ display:flex !important; } }
  .rr-app .rr-nav__link,
  .rr-app a.rr-nav__link{
    color: rgba(246, 239, 222, .8) !important;
    font-family: var(--rr-font-body) !important;
    font-size: 14px !important; letter-spacing: .025em !important; text-transform: uppercase !important;
    transition: color .2s ease;
    text-decoration: none !important;
    background: transparent !important;
  }
  .rr-app .rr-nav__link:hover,
  .rr-app a.rr-nav__link:hover{ color: #C2A15D !important; }
  .rr-app .rr-nav__cta,
  .rr-app a.rr-nav__cta{
    background: #C2A15D !important; color: #0c1a30 !important;
    font-weight: 600 !important; padding: 10px 24px !important; border-radius: 6px !important;
    font-size: 14px !important; letter-spacing: .025em !important;
    box-shadow: var(--rr-shadow-gold) !important;
    text-decoration: none !important;
    transition: background .2s ease;
  }
  .rr-app .rr-nav__cta:hover,
  .rr-app a.rr-nav__cta:hover{ background: #d6b97e !important; }
  .rr-app .rr-nav__cta-ghost,
  .rr-app a.rr-nav__cta-ghost{
    background: transparent !important; color: rgba(246,239,222,.85) !important;
    border: 1px solid rgba(246,239,222,.25) !important;
    font-weight: 600 !important; padding: 9px 20px !important; border-radius: 6px !important;
    font-size: 14px !important; letter-spacing: .025em !important;
    text-decoration: none !important;
    transition: background .2s ease, border-color .2s ease;
  }
  .rr-app .rr-nav__cta-ghost:hover,
  .rr-app a.rr-nav__cta-ghost:hover{
    background: rgba(246,239,222,.08) !important;
    border-color: rgba(246,239,222,.5) !important;
    color: #f6efde !important;
  }
  .rr-app .rr-nav__mobile .rr-nav__cta-ghost{
    text-align:center !important; padding: 11px 24px !important;
    border: 1px solid rgba(246,239,222,.25) !important;
    border-radius: 6px !important;
    background: transparent !important;
  }
  .rr-app .rr-nav__burger{ display:flex !important; color: #f6efde !important; background: transparent !important; }
  @media (min-width: 768px){ .rr-app .rr-nav__burger{ display:none !important; } }
  .rr-app .rr-nav__mobile{
    display:none;
    background: hsl(215 70% 8% / .98) !important;
    border-top: 1px solid hsl(215 45% 25% / .2);
    padding: 16px 24px 24px;
  }
  .rr-app .rr-nav__mobile.is-open{ display:flex !important; flex-direction:column; gap:12px; }
  .rr-app .rr-nav__mobile a,
  .rr-app .rr-nav__mobile button{
    color: rgba(246, 239, 222, .85) !important; padding: 10px 0 !important; text-align:left !important;
    font-size: 14px !important; text-transform: uppercase !important; letter-spacing: .025em !important;
    text-decoration: none !important;
  }
  .rr-app .rr-nav__mobile .rr-nav__cta{ text-align:center !important; padding: 12px 24px !important; }

  /* spacer so first section isn't hidden behind fixed nav */
.rr-nav-spacer {
    height: 0;
}

  /* ==========================================================================
     HERO
     ========================================================================== */
.rr-hero {
    position: relative;
    min-height: 90vh;
    display: flex;
    align-items: center;
    overflow: hidden;
    background: var(--rr-gradient-hero);
}

.rr-hero__img {
    position: absolute;
    inset: 0;
    background-image: url('/assets/hero.jpg');
    background-size: cover;
    background-position: center;
    opacity: .2;
}

.rr-hero__fade {
    position: absolute;
    inset: 0;
    background: linear-gradient(to bottom, transparent 0%, transparent 50%, hsl(var(--rr-navy-dark) / .8) 100%);
}

.rr-hero__inner {
    position: relative;
    z-index: 10;
    padding: 112px 24px 80px;
    max-width: 1280px;
    margin: 0 auto;
    width: 100%;
}

.rr-hero__content {
    max-width: 768px;
}

.rr-hero__eyebrow {
    color: hsl(var(--rr-gold));
    font-size: 18px;
    letter-spacing: .15em;
    text-transform: uppercase;
    margin-bottom: 16px;
}

.rr-hero__title {
    font-size: 48px;
    font-weight: 700;
    color: hsl(var(--rr-primary-fg));
    line-height: 1.1;
    margin-bottom: 24px;
}

@media (max-width: 639px) {
    .rr-hero__inner {
        padding-top: 72px;
        padding-bottom: 48px;
    }
    .rr-hero__title {
        font-size: 36px;
    }
    .rr-hero__lede {
        font-size: 17px;
        margin-top: 12px;
    }
}

@media (min-width: 768px) {
    .rr-hero__title {
        font-size: 60px;
    }
}

@media (min-width: 1024px) {
    .rr-hero__title {
        font-size: 72px;
    }
}

.rr-hero__lede {
    color: hsl(var(--rr-primary-fg) / .7);
    font-size: 20px;
    line-height: 1.65;
    max-width: 672px;
    margin-top: 16px;
    margin-bottom: 56px;
}

@media (min-width: 768px) {
    .rr-hero__lede {
        font-size: 24px;
        margin-top: 20px;
        margin-bottom: 64px;
    }
}

.rr-hero__bullets {
    margin-top: 56px;
    display: grid;
    grid-template-columns: 1fr;
    gap: 16px;
    max-width: 768px;
}

@media (min-width: 640px) {
    .rr-hero__bullets {
        grid-template-columns: repeat(3, 1fr);
    }
}

.rr-hero__bullet {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    background: hsl(var(--rr-primary) / .4);
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
    border: 1px solid hsl(var(--rr-navy-light) / .3);
    border-radius: 8px;
    padding: 20px;
}

.rr-hero__bullet svg {
    color: hsl(var(--rr-gold));
    margin-top: 4px;
    flex-shrink: 0;
}

.rr-hero__bullet p {
    color: hsl(var(--rr-primary-fg) / .9);
    font-size: 14px;
    line-height: 1.65;
}

.rr-hero__bullet strong {
    color: hsl(var(--rr-gold));
    font-weight: 700;
}

  /* ==========================================================================
     BENEFITS
     ========================================================================== */
.rr-benefits {
    padding: 96px 0;
    background: hsl(var(--rr-bg));
}

.rr-benefits__head {
    text-align: center;
    margin-bottom: 64px;
    max-width: 672px;
    margin-left: auto;
    margin-right: auto;
}

.rr-benefits__head h2 {
    font-size: 36px;
    font-weight: 700;
    color: hsl(var(--rr-fg));
    margin-bottom: 16px;
}

@media (min-width: 768px) {
    .rr-benefits__head h2 {
        font-size: 48px;
    }
}

.rr-benefits__head p {
    font-size: 18px;
    color: hsl(var(--rr-muted-fg));
}

.rr-benefits__grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 32px;
    max-width: 1024px;
    margin: 0 auto;
}

@media (min-width: 768px) {
    .rr-benefits__grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

.rr-benefit-card {
    background: hsl(var(--rr-card));
    border: 1px solid hsl(var(--rr-border));
    border-radius: 12px;
    padding: 32px;
    box-shadow: var(--rr-shadow-card);
    transition: box-shadow .3s ease;
}

.rr-benefit-card:hover {
    box-shadow: var(--rr-shadow-elev);
}

.rr-benefit-card__icon {
    width: 56px;
    height: 56px;
    border-radius: 8px;
    background: hsl(var(--rr-gold) / .1);
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 24px;
    transition: background .3s ease;
}

.rr-benefit-card:hover .rr-benefit-card__icon {
    background: hsl(var(--rr-gold) / .2);
}

.rr-benefit-card__icon svg {
    color: hsl(var(--rr-gold));
}

.rr-benefit-card h3 {
    font-size: 20px;
    font-weight: 600;
    color: hsl(var(--rr-fg));
    margin-bottom: 12px;
}

.rr-benefit-card p {
    font-size: 16px;
    color: hsl(var(--rr-muted-fg));
    line-height: 1.65;
}

.rr-benefits__cta {
    text-align: center;
    margin-top: 48px;
}

  /* ==========================================================================
     QUIZ / FORM
     ========================================================================== */
.rr-quiz {
    padding: 96px 0;
    background: hsl(var(--rr-bg));
}

.rr-quiz__head {
    text-align: center;
    margin-bottom: 40px;
}

.rr-quiz__head h2 {
    font-size: 30px;
    font-weight: 700;
    color: hsl(var(--rr-fg));
    margin-bottom: 8px;
}

@media (min-width: 768px) {
    .rr-quiz__head h2 {
        font-size: 36px;
    }
}

.rr-quiz__head p {
    color: hsl(var(--rr-muted-fg));
}

.rr-quiz__wrap {
    max-width: 720px;
    margin: 0 auto;
}

.rr-quiz__card {
    background: transparent;
    border: 0;
    border-radius: 0;
    padding: 0;
    box-shadow: none;
    overflow: visible;
}

.rr-quiz__card iframe {
    width: 100% !important;
    border: 0 !important;
    background: transparent !important;
    display: block;
    min-height: 800px;
}

  /* ==========================================================================
     CHAIN REACTION (hidden-costs)
     ========================================================================== */
.rr-chain {
    padding: 96px 0;
    background: var(--rr-gradient-hero);
}

.rr-chain__head {
    text-align: center;
    margin-bottom: 24px;
    max-width: 672px;
    margin-left: auto;
    margin-right: auto;
}

.rr-chain__head h2 {
    font-size: 36px;
    font-weight: 700;
    color: hsl(var(--rr-primary-fg));
    margin-bottom: 16px;
}

@media (min-width: 768px) {
    .rr-chain__head h2 {
        font-size: 48px;
    }
}

.rr-chain__head p {
    font-size: 18px;
    color: hsl(var(--rr-primary-fg) / .7);
}

.rr-chain__steps {
    max-width: 768px;
    margin: 64px auto 0;
}

.rr-chain__step {
    display: flex;
    align-items: flex-start;
    gap: 16px;
    margin-bottom: 4px;
}

.rr-chain__bullet {
    display: flex;
    flex-direction: column;
    align-items: center;
    flex-shrink: 0;
}

.rr-chain__num {
    width: 40px;
    height: 40px;
    border-radius: 999px;
    background: hsl(var(--rr-gold) / .2);
    border: 1px solid hsl(var(--rr-gold) / .4);
    display: flex;
    align-items: center;
    justify-content: center;
}

.rr-chain__num span {
    font-family: var(--rr-font-heading);
    font-weight: 700;
    font-size: 14px;
    color: hsl(var(--rr-gold));
}

.rr-chain__line {
    width: 1px;
    height: 40px;
    background: hsl(var(--rr-gold) / .2);
}

.rr-chain__step:last-child .rr-chain__line {
    display: none;
}

.rr-chain__step-body {
    padding: 6px 0 16px;
}

.rr-chain__step-body h3 {
    font-size: 18px;
    font-weight: 600;
    color: hsl(var(--rr-primary-fg));
    margin-bottom: 4px;
}

.rr-chain__step-body p {
    font-size: 14px;
    line-height: 1.65;
    color: hsl(var(--rr-primary-fg) / .6);
}

.rr-chain__quote {
    margin-top: 24px;
    background: hsl(var(--rr-gold) / .05);
    border: 1px solid hsl(var(--rr-gold) / .2);
    border-radius: 12px;
    padding: 20px;
    display: flex;
    align-items: flex-start;
    gap: 12px;
}

.rr-chain__quote svg {
    color: hsl(var(--rr-gold));
    flex-shrink: 0;
    margin-top: 2px;
}

.rr-chain__quote p {
    font-size: 14px;
    line-height: 1.65;
    font-style: italic;
    color: hsl(var(--rr-primary-fg) / .7);
}

.rr-chain__damage-head {
    text-align: center;
    margin: 80px 0 40px;
}

.rr-chain__damage-head h3 {
    font-size: 24px;
    font-weight: 700;
    color: hsl(var(--rr-primary-fg));
}

@media (min-width: 768px) {
    .rr-chain__damage-head h3 {
        font-size: 30px;
    }
}

.rr-chain__damage {
    display: grid;
    grid-template-columns: 1fr;
    gap: 20px;
    max-width: 896px;
    margin: 0 auto 80px;
}

@media (min-width: 768px) {
    .rr-chain__damage {
        grid-template-columns: repeat(3, 1fr);
    }
}

.rr-damage-card {
    background: hsl(var(--rr-navy-light) / .4);
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
    border: 1px solid hsl(var(--rr-navy-light) / .3);
    border-radius: 12px;
    padding: 24px;
    transition: border-color .3s ease;
}

.rr-damage-card:hover {
    border-color: hsl(var(--rr-gold) / .3);
}

.rr-damage-card h4 {
    font-size: 18px;
    font-weight: 600;
    color: hsl(var(--rr-primary-fg));
    margin-bottom: 8px;
}

.rr-damage-card p {
    font-size: 14px;
    line-height: 1.65;
    color: hsl(var(--rr-primary-fg) / .6);
}

.rr-chain__compare-wrap {
    max-width: 768px;
    margin: 0 auto;
}

.rr-chain__compare-head {
    text-align: center;
    margin-bottom: 32px;
}

.rr-chain__compare-head h3 {
    font-size: 24px;
    font-weight: 700;
    color: hsl(var(--rr-primary-fg));
}

@media (min-width: 768px) {
    .rr-chain__compare-head h3 {
        font-size: 30px;
    }
}

.rr-chain__compare {
    display: grid;
    grid-template-columns: 1fr;
    gap: 20px;
}

@media (min-width: 768px) {
    .rr-chain__compare {
        grid-template-columns: repeat(2, 1fr);
    }
}

.rr-compare-card {
    position: relative;
    overflow: hidden;
    background: hsl(var(--rr-navy-light) / .3);
    border-radius: 12px;
    padding: 24px;
}

.rr-compare-card__bar {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 4px;
}

.rr-compare-card--bad {
    border: 1px solid hsl(var(--rr-destructive) / .2);
}

.rr-compare-card--bad .rr-compare-card__bar {
    background: hsl(var(--rr-destructive) / .4);
}

.rr-compare-card--bad .rr-compare-card__label {
    color: hsl(var(--rr-destructive) / .7);
}

.rr-compare-card--good {
    border: 1px solid hsl(var(--rr-gold) / .3);
}

.rr-compare-card--good .rr-compare-card__bar {
    background: var(--rr-gradient-gold);
}

.rr-compare-card--good .rr-compare-card__label {
    color: hsl(var(--rr-gold));
}

.rr-compare-card__label {
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: .1em;
    font-weight: 600;
    margin-bottom: 8px;
}

.rr-compare-card__num {
    font-family: var(--rr-font-heading);
    font-size: 30px;
    font-weight: 700;
    color: hsl(var(--rr-primary-fg));
    margin-bottom: 8px;
}

@media (min-width: 768px) {
    .rr-compare-card__num {
        font-size: 36px;
    }
}

.rr-compare-card--good .rr-compare-card__num {
    background: var(--rr-gradient-gold);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    color: transparent;
}

.rr-compare-card__desc {
    font-size: 14px;
    line-height: 1.65;
    color: hsl(var(--rr-primary-fg) / .5);
}

.rr-chain__compare-foot {
    text-align: center;
    margin-top: 24px;
}

.rr-chain__compare-foot p {
    font-size: 14px;
    color: hsl(var(--rr-primary-fg) / .5);
}

.rr-chain__compare-foot strong {
    color: hsl(var(--rr-gold));
    font-weight: 600;
}

  /* ==========================================================================
     STATS BAND
     ========================================================================== */
.rr-stats {
    padding: 80px 0;
    background: hsl(var(--rr-bg));
    border-top: 1px solid hsl(var(--rr-border));
    border-bottom: 1px solid hsl(var(--rr-border));
}

.rr-stats__inner {
    text-align: center;
}

.rr-stats__eyebrow {
    font-size: 14px;
    letter-spacing: .15em;
    text-transform: uppercase;
    color: hsl(var(--rr-muted-fg));
    margin-bottom: 12px;
}

.rr-stats__title {
    font-size: 30px;
    font-weight: 700;
    color: hsl(var(--rr-fg));
    margin-bottom: 8px;
}

@media (min-width: 768px) {
    .rr-stats__title {
        font-size: 36px;
    }
}

.rr-stats__lede {
    font-size: 18px;
    color: hsl(var(--rr-muted-fg));
    max-width: 672px;
    margin: 16px auto 0;
}

.rr-stats__grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 32px;
    margin: 56px auto 0;
    max-width: 768px;
}

@media (min-width: 640px) {
    .rr-stats__grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

.rr-stat__num {
    font-family: var(--rr-font-heading);
    font-weight: 700;
    font-size: 36px;
    color: hsl(var(--rr-gold));
}

.rr-stat__label {
    font-size: 14px;
    color: hsl(var(--rr-muted-fg));
    margin-top: 4px;
}

.rr-stats__cta {
    margin-top: 48px;
}

  /* ==========================================================================
     HOW IT WORKS
     ========================================================================== */
.rr-how {
    padding: 96px 0;
    background: hsl(var(--rr-cream));
}

.rr-how__head {
    text-align: center;
    margin-bottom: 64px;
}

.rr-how__head h2 {
    font-size: 36px;
    font-weight: 700;
    color: hsl(var(--rr-fg));
}

@media (min-width: 768px) {
    .rr-how__head h2 {
        font-size: 48px;
    }
}

.rr-how__grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 32px;
    max-width: 896px;
    margin: 0 auto;
}

@media (min-width: 768px) {
    .rr-how__grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

.rr-how__step {
    text-align: center;
}

.rr-how__icon {
    width: 64px;
    height: 64px;
    border-radius: 999px;
    background: hsl(var(--rr-gold) / .1);
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 20px;
}

.rr-how__icon svg {
    color: hsl(var(--rr-gold));
}

.rr-how__num {
    width: 32px;
    height: 32px;
    border-radius: 999px;
    background: hsl(var(--rr-navy));
    color: hsl(var(--rr-primary-fg));
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 16px;
    font-family: var(--rr-font-heading);
    font-weight: 700;
    font-size: 14px;
}

.rr-how__step h3 {
    font-size: 20px;
    font-weight: 600;
    color: hsl(var(--rr-fg));
    margin-bottom: 8px;
}

.rr-how__step p {
    color: hsl(var(--rr-muted-fg));
    line-height: 1.65;
}

  /* ==========================================================================
     FAQ
     ========================================================================== */
.rr-faq {
    padding: 96px 0;
    background: hsl(var(--rr-cream));
}

.rr-faq__head {
    text-align: center;
    margin-bottom: 56px;
    max-width: 672px;
    margin-left: auto;
    margin-right: auto;
}

.rr-faq__head h2 {
    font-size: 36px;
    font-weight: 700;
    color: hsl(var(--rr-fg));
    margin-bottom: 16px;
}

@media (min-width: 768px) {
    .rr-faq__head h2 {
        font-size: 48px;
    }
}

.rr-faq__head p {
    font-size: 18px;
    color: hsl(var(--rr-muted-fg));
}

.rr-faq__list {
    max-width: 768px;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.rr-faq__item {
    background: hsl(var(--rr-card));
    border: 1px solid hsl(var(--rr-border));
    border-radius: 12px;
    padding: 0 24px;
    box-shadow: var(--rr-shadow-card);
}

.rr-faq__item summary {
    list-style: none;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 20px 0;
    font-family: var(--rr-font-heading);
    font-size: 16px;
    font-weight: 600;
    color: hsl(var(--rr-fg));
}

@media (min-width: 768px) {
    .rr-faq__item summary {
        font-size: 18px;
    }
}

.rr-faq__item summary::-webkit-details-marker {
    display: none;
}

.rr-faq__chev {
    width: 16px;
    height: 16px;
    flex-shrink: 0;
    transition: transform .2s ease;
}

.rr-faq__item[open] .rr-faq__chev {
    transform: rotate(180deg);
}

.rr-faq__answer {
    padding: 0 0 20px;
    font-size: 14px;
    line-height: 1.7;
    color: hsl(var(--rr-muted-fg));
}

.rr-faq__cta {
    text-align: center;
    margin-top: 48px;
}

  /* ==========================================================================
     FOOTER
     ========================================================================== */
.rr-footer {
    padding: 48px 0;
    background: hsl(var(--rr-navy-dark));
    border-top: 1px solid hsl(var(--rr-navy-light) / .2);
}

.rr-footer__row {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
}

@media (min-width: 768px) {
    .rr-footer__row {
        flex-direction: row;
    }
}

.rr-footer__brand p:first-child {
    font-family: var(--rr-font-heading);
    font-size: 20px;
    font-weight: 700;
    color: hsl(var(--rr-primary-fg));
}

.rr-footer__brand p:last-child,
.rr-footer__brand p.rr-footer__entity,
.rr-footer__brand > p:nth-of-type(1) {
    font-size: 14px;
    color: hsl(var(--rr-primary-fg) / .4);
    margin-top: 4px;
}

.rr-footer__entity a {
    color: hsl(var(--rr-gold));
}

.rr-footer__entity a:hover {
    color: hsl(var(--rr-gold-light));
}

.rr-footer__nav {
    display: flex;
    flex-wrap: wrap;
    gap: 24px;
    justify-content: center;
}

.rr-footer__nav a {
    font-size: 14px;
    color: hsl(var(--rr-primary-fg) / .5);
    transition: color .2s ease;
}

.rr-footer__nav a:hover {
    color: hsl(var(--rr-gold));
}

.rr-footer__legal {
    margin-top: 32px;
    padding-top: 24px;
    border-top: 1px solid hsl(var(--rr-navy-light) / .1);
}

.rr-footer__legal p {
    font-size: 12px;
    line-height: 1.7;
    text-align: center;
    color: hsl(var(--rr-primary-fg) / .3);
    max-width: 672px;
    margin: 0 auto;
}
