/**
 * Layout — header, main, footer, seções e container
 */

.container {
  width: 100%;
  max-width: var(--container-max);
  margin-inline: auto;
  padding-inline: var(--container-padding);
}

.site-header {
  padding-block: var(--space-md);
  border-bottom: 1px solid rgb(255 255 255 / 0.06);
}

.site-header__brand {
  margin: 0;
  font-size: var(--text-step--1);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-text-muted);
}

.site-footer {
  position: relative;
  padding-block: calc(var(--space-xl) + var(--space-sm));
  margin-top: var(--space-xl);
  border-top: 1px solid rgb(255 255 255 / 0.06);
  background: linear-gradient(180deg, rgb(10 9 14 / 0.35), rgb(8 8 12 / 0.75));
}

.site-footer__note {
  margin: 0;
  font-size: 0.82rem;
  letter-spacing: 0.02em;
  color: rgb(163 158 148 / 0.92);
}

.section h1,
.section h2 {
  margin: 0 0 var(--space-sm);
  font-weight: 600;
  line-height: var(--line-tight);
  color: var(--color-text-primary);
}

.section h1 {
  font-size: var(--text-step-3);
}

.section h2 {
  font-size: var(--text-step-2);
}

.section {
  padding-block: var(--space-2xl);
}

.section__placeholder {
  margin: 0;
  color: var(--color-text-muted);
  font-size: var(--text-step--1);
}

/* --- Hero premium (iteração refinada) --- */

.section.section--hero {
  position: relative;
  isolation: isolate;
  min-height: var(--hero-min-height);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  border-bottom: 1px solid rgb(255 255 255 / 0.07);
  padding-block: 0;
}

.hero__backdrop {
  position: absolute;
  inset: 0;
  z-index: 0;
  overflow: hidden;
  pointer-events: none;
}

.hero__gradient {
  position: absolute;
  inset: 0;
  z-index: 0;
  background:
    radial-gradient(ellipse 120% 90% at 50% -30%, rgb(110 78 140 / 0.42), transparent 55%),
    radial-gradient(ellipse 70% 60% at 100% 35%, rgb(36 52 88 / 0.62), transparent 52%),
    radial-gradient(ellipse 55% 45% at 0% 95%, rgb(196 165 116 / 0.12), transparent 50%),
    radial-gradient(ellipse 80% 70% at 50% 120%, rgb(26 18 36 / 0.9), transparent 45%),
    linear-gradient(
      172deg,
      #06080f 0%,
      var(--color-bg-deep) 38%,
      #0f0a14 72%,
      var(--color-accent-violet-deep) 100%
    );
}

.hero__spot {
  position: absolute;
  inset: 0;
  z-index: 1;
  background: radial-gradient(ellipse 58% 52% at 16% 36%, rgb(255 248 235 / 0.055), transparent 62%);
  pointer-events: none;
}

.hero__right-ambient {
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background:
    radial-gradient(ellipse 72% 92% at 108% 42%, rgb(78 64 112 / 0.44), transparent 56%),
    radial-gradient(ellipse 48% 52% at 100% 54%, rgb(32 48 82 / 0.36), transparent 54%),
    radial-gradient(ellipse 32% 42% at 100% 68%, rgb(196 165 116 / 0.08), transparent 48%);
}

.hero__vignette {
  position: absolute;
  inset: 0;
  z-index: 2;
  background:
    radial-gradient(ellipse 88% 72% at 36% 46%, transparent 18%, rgb(0 0 0 / 0.2) 52%, rgb(0 0 0 / 0.72) 100%),
    linear-gradient(180deg, rgb(0 0 0 / 0.35) 0%, transparent 28%, transparent 72%, rgb(0 0 0 / 0.45) 100%);
  pointer-events: none;
}

.hero__rim {
  position: absolute;
  inset: 0;
  z-index: 2;
  background: linear-gradient(100deg, transparent 0%, transparent 50%, rgb(10 8 18 / 0.42) 82%, rgb(5 4 10 / 0.78) 100%);
  pointer-events: none;
  opacity: 0.78;
}

.hero__glow {
  position: absolute;
  z-index: 2;
  border-radius: 50%;
  filter: blur(5rem);
  pointer-events: none;
}

.hero__glow--gold {
  width: min(48vw, 30rem);
  height: min(48vw, 30rem);
  bottom: -4%;
  left: -6%;
  background: var(--hero-glow-gold);
  opacity: 0.9;
}

.hero__glow--violet {
  width: min(62vw, 38rem);
  height: min(62vw, 38rem);
  top: -22%;
  right: -18%;
  background: var(--hero-glow-violet);
  opacity: 0.72;
}

.hero__glow--blue {
  width: min(48vw, 28rem);
  height: min(48vw, 28rem);
  bottom: 12%;
  right: -2%;
  background: var(--hero-glow-blue);
  opacity: 0.62;
}

.hero__deco {
  position: absolute;
  z-index: 3;
  color: var(--color-line-subtle);
}

.hero__deco--orbit {
  width: min(78vw, 34rem);
  height: auto;
  max-height: 94%;
  right: -10%;
  top: 51%;
  transform: translateY(-50%);
  opacity: 0.72;
  color: rgb(198 188 218 / 0.38);
}

.hero__deco--chart {
  width: min(115vw, 56rem);
  height: auto;
  right: -28%;
  top: 46%;
  transform: translateY(-50%) rotate(9deg);
  opacity: 0.42;
}

.hero__deco--palm {
  width: min(72vw, 26rem);
  height: auto;
  left: -14%;
  bottom: -12%;
  transform: rotate(-6deg);
  opacity: 0.55;
}

.hero__noise {
  position: absolute;
  inset: 0;
  z-index: 4;
  opacity: var(--hero-noise-opacity);
  pointer-events: none;
  mix-blend-mode: overlay;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='a'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23a)'/%3E%3C/svg%3E");
}

.hero__container {
  position: relative;
  z-index: 1;
  width: 100%;
  flex: 1;
  display: flex;
  align-items: center;
  padding-block: clamp(var(--space-xl), 5vh, var(--space-3xl));
}

.hero__grid {
  display: grid;
  gap: clamp(var(--space-xl), 4vw, var(--space-3xl));
  width: 100%;
  align-items: center;
}

.hero__content {
  max-width: var(--hero-content-max);
  padding-block: var(--space-md);
}

.hero .hero__title {
  margin: 0 0 var(--space-lg);
  font-family: var(--font-serif);
  font-weight: 400;
  font-size: clamp(1.95rem, 0.82rem + 4.1vw, 3.85rem);
  line-height: 1.06;
  letter-spacing: -0.036em;
  color: var(--color-text-primary);
  max-width: min(36rem, 100%);
  text-wrap: balance;
  text-shadow:
    0 2px 48px rgb(0 0 0 / 0.45),
    0 0 1px rgb(0 0 0 / 0.6);
}

.hero .hero__title::after {
  content: "";
  display: block;
  width: 3.75rem;
  height: 1px;
  margin-top: var(--space-xl);
  background: linear-gradient(90deg, rgb(212 188 148 / 0.85), rgb(212 188 148 / 0));
}

.hero__sub {
  margin: 0;
  margin-top: var(--space-md);
  max-width: min(34rem, 100%);
  font-size: clamp(var(--text-step--1), 0.8rem + 0.55vw, 1.1875rem);
  line-height: 1.7;
  letter-spacing: 0.01em;
  color: var(--color-text-muted-warm);
}

.hero__micro {
  margin: 0;
  margin-top: clamp(var(--space-md), 2.5vh, var(--space-lg));
  max-width: min(26rem, 100%);
  font-family: var(--font-sans);
  font-size: clamp(0.72rem, 0.66rem + 0.22vw, 0.8rem);
  font-weight: 400;
  line-height: 1.5;
  letter-spacing: 0.02em;
  font-style: italic;
  color: rgb(163 158 148 / 0.62);
}

.hero__actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-md);
  margin-top: clamp(var(--space-lg), 3.5vh, var(--space-2xl));
}

@media (min-width: 36rem) {
  .hero__actions {
    flex-wrap: nowrap;
    align-items: center;
  }

  .hero__actions .btn {
    white-space: nowrap;
    flex-shrink: 0;
  }

  .hero__actions .btn--hero-primary {
    min-height: 3.35rem;
    padding-inline: clamp(1.35rem, 2.5vw, 1.95rem);
    font-size: clamp(0.96rem, 0.88rem + 0.35vw, 1.075rem);
    letter-spacing: 0.038em;
  }

  .hero__actions .btn--hero-secondary {
    min-height: 3.35rem;
    padding-inline: clamp(0.95rem, 2vw, 1.25rem);
    font-size: clamp(0.74rem, 0.7rem + 0.22vw, 0.8125rem);
    letter-spacing: 0.095em;
  }
}

.hero__visual {
  display: none;
  position: relative;
  justify-content: center;
  align-items: center;
}

.hero__visual-frame {
  position: relative;
  z-index: 1;
  width: min(100%, var(--hero-visual-max));
  aspect-ratio: 1;
  border-radius: 50%;
  background:
    radial-gradient(circle at 32% 28%, rgb(255 255 255 / 0.06), transparent 58%),
    radial-gradient(circle at 70% 78%, rgb(90 62 120 / 0.22), transparent 55%);
  border: 1px solid rgb(255 255 255 / 0.08);
  box-shadow:
    inset 0 0 0 1px rgb(0 0 0 / 0.4),
    inset 0 1px 0 rgb(255 255 255 / 0.06),
    0 0 0 1px rgb(196 165 116 / 0.06),
    0 24px 80px rgb(0 0 0 / 0.35),
    0 0 120px rgb(60 48 90 / 0.25);
  display: grid;
  place-items: center;
  padding: 10%;
}

.hero__atlas {
  width: 100%;
  height: 100%;
  color: rgb(220 200 160 / 0.42);
  filter: drop-shadow(0 0 20px rgb(80 56 110 / 0.35));
}

@media (max-width: 35.99rem) {
  .hero__actions {
    flex-direction: column;
    align-items: stretch;
  }

  .hero__actions .btn {
    width: 100%;
    justify-content: center;
  }
}

@media (max-width: 32rem) {
  .hero__deco--orbit {
    opacity: 0.55;
    right: -16%;
  }

  .hero__deco--chart {
    opacity: 0.28;
    right: -42%;
  }

  .hero__deco--palm {
    opacity: 0.38;
    left: -20%;
  }
}

@media (min-width: 56rem) {
  .hero__grid {
    grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.9fr);
    gap: clamp(2rem, 5vw, 4.5rem);
    align-items: center;
  }

  .hero__visual {
    display: flex;
    justify-self: end;
    width: 100%;
    max-width: calc(var(--hero-visual-max) + 2rem);
  }

  .hero__visual::before {
    content: "";
    position: absolute;
    inset: -18% -28% -22% -12%;
    z-index: 0;
    pointer-events: none;
    background:
      radial-gradient(ellipse 65% 58% at 58% 42%, rgb(110 86 150 / 0.28), transparent 68%),
      radial-gradient(ellipse 48% 44% at 78% 58%, rgb(196 165 116 / 0.1), transparent 62%);
    filter: blur(38px);
    opacity: 0.95;
  }

  .hero__content {
    padding-block: var(--space-lg);
  }

  .hero .hero__title {
    max-width: min(38rem, 100%);
  }

  .hero__deco--chart {
    right: -6%;
    opacity: 0.38;
  }

  .hero__deco--orbit {
    right: -4%;
    opacity: 0.68;
    width: min(82vw, 36rem);
  }

  .hero__deco--palm {
    left: -6%;
    opacity: 0.48;
  }

  .hero__actions {
    gap: var(--space-lg);
  }
}

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

  .hero__glow {
    filter: blur(3.25rem);
  }
}

/* --- Seção: A experiência --- */

.section.section--experience {
  position: relative;
  isolation: isolate;
  padding-block: clamp(var(--space-2xl), 7vw, 4.5rem);
  border-top: 1px solid rgb(255 255 255 / 0.06);
  background: linear-gradient(180deg, var(--color-bg-deep) 0%, rgb(11 10 16) 55%, rgb(14 11 18) 100%);
}

.experience__atmosphere {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background:
    radial-gradient(ellipse 70% 55% at 88% 18%, rgb(30 42 68 / 0.35), transparent 58%),
    radial-gradient(ellipse 50% 45% at 12% 75%, rgb(61 47 77 / 0.22), transparent 55%),
    radial-gradient(ellipse 40% 35% at 70% 88%, rgb(196 165 116 / 0.06), transparent 50%);
  opacity: 1;
}

.experience__inner {
  position: relative;
  z-index: 1;
}

.experience__header {
  max-width: 48rem;
  margin-bottom: clamp(var(--space-2xl), 5vw, var(--space-3xl));
}

.section.section--experience .experience__title {
  margin: 0 0 var(--space-lg);
  font-family: var(--font-serif);
  font-weight: 400;
  font-size: clamp(1.7rem, 0.95rem + 2.6vw, 2.65rem);
  line-height: 1.14;
  letter-spacing: -0.025em;
  color: var(--color-text-primary);
  text-wrap: balance;
}

.experience__lead {
  margin: 0;
  max-width: 42rem;
  font-size: clamp(var(--text-step--1), 0.82rem + 0.45vw, var(--text-step-1));
  line-height: 1.68;
  letter-spacing: 0.012em;
  color: var(--color-text-muted-warm);
}

.experience__lead + .experience__lead {
  margin-top: var(--space-lg);
}

.experience__bridge {
  margin: 0 0 clamp(var(--space-xl), 3.5vw, var(--space-2xl));
  max-width: 38rem;
  font-family: var(--font-serif);
  font-size: clamp(1.05rem, 0.88rem + 0.4vw, 1.2rem);
  font-style: italic;
  font-weight: 400;
  line-height: 1.45;
  letter-spacing: 0.02em;
  color: rgb(212 188 148 / 0.78);
}

.experience__grid {
  display: grid;
  gap: var(--space-lg);
  grid-template-columns: 1fr;
}

@media (min-width: 48rem) {
  .experience__grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: var(--space-xl);
    align-items: stretch;
  }
}

/* --- Seção: Tipos de leitura --- */

.section.section--readings {
  position: relative;
  isolation: isolate;
  padding-block: clamp(var(--space-2xl), 7vw, 4.75rem);
  border-top: 1px solid rgb(255 255 255 / 0.06);
  background: linear-gradient(180deg, rgb(12 11 16) 0%, var(--color-bg-deep) 45%, rgb(10 9 14) 100%);
}

.reading-types__atmosphere {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background:
    radial-gradient(ellipse 52% 48% at 18% 22%, rgb(196 165 116 / 0.055), transparent 52%),
    radial-gradient(ellipse 58% 52% at 90% 68%, rgb(30 42 68 / 0.36), transparent 56%),
    radial-gradient(ellipse 42% 38% at 48% 100%, rgb(61 47 77 / 0.2), transparent 52%);
}

.reading-types__inner {
  position: relative;
  z-index: 1;
}

.reading-types__header {
  max-width: 46rem;
  margin-bottom: clamp(var(--space-2xl), 5vw, var(--space-3xl));
}

.section.section--readings .reading-types__title {
  margin: 0 0 var(--space-lg);
  font-family: var(--font-serif);
  font-weight: 400;
  font-size: clamp(1.65rem, 0.9rem + 2.5vw, 2.55rem);
  line-height: 1.14;
  letter-spacing: -0.024em;
  color: var(--color-text-primary);
  text-wrap: balance;
}

.reading-types__intro {
  margin: 0;
  max-width: 42rem;
  font-size: clamp(var(--text-step--1), 0.82rem + 0.45vw, var(--text-step-1));
  line-height: 1.68;
  letter-spacing: 0.012em;
  color: var(--color-text-muted-warm);
}

.reading-types__note {
  margin: var(--space-lg) 0 0;
  max-width: 40rem;
  font-size: var(--text-step--1);
  line-height: 1.55;
  color: rgb(163 158 148 / 0.88);
}

.reading-types__grid {
  display: grid;
  gap: clamp(0.9rem, 2.2vw, 1.35rem);
  grid-template-columns: 1fr;
  max-width: 58rem;
  margin-inline: auto;
  align-items: stretch;
}

@media (min-width: 48rem) {
  .reading-types__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: clamp(1rem, 2vw, 1.5rem);
    grid-auto-rows: 1fr;
  }
}

/* --- Seção: Como funciona --- */

.section.section--how-it-works {
  position: relative;
  isolation: isolate;
  padding-block: clamp(var(--space-2xl), 7vw, 4.75rem);
  border-top: 1px solid rgb(255 255 255 / 0.06);
  background: linear-gradient(180deg, rgb(10 9 14) 0%, var(--color-bg-deep) 40%, rgb(12 11 18) 100%);
}

.how-it-works__atmosphere {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background:
    radial-gradient(ellipse 50% 45% at 20% 30%, rgb(61 47 77 / 0.2), transparent 55%),
    radial-gradient(ellipse 60% 50% at 85% 65%, rgb(30 42 68 / 0.34), transparent 58%),
    radial-gradient(ellipse 35% 30% at 50% 8%, rgb(196 165 116 / 0.05), transparent 50%);
}

.how-it-works__inner {
  position: relative;
  z-index: 1;
}

.how-it-works__header {
  max-width: 46rem;
  margin-bottom: clamp(var(--space-2xl), 5vw, var(--space-3xl));
}

.section.section--how-it-works .how-it-works__title {
  margin: 0 0 var(--space-lg);
  font-family: var(--font-serif);
  font-weight: 400;
  font-size: clamp(1.65rem, 0.9rem + 2.5vw, 2.55rem);
  line-height: 1.14;
  letter-spacing: -0.024em;
  color: var(--color-text-primary);
  text-wrap: balance;
}

.how-it-works__intro {
  margin: 0;
  max-width: 42rem;
  font-size: clamp(var(--text-step--1), 0.82rem + 0.45vw, var(--text-step-1));
  line-height: 1.68;
  letter-spacing: 0.012em;
  color: var(--color-text-muted-warm);
}

.how-it-works__note {
  margin: var(--space-lg) 0 0;
  max-width: 40rem;
  font-size: var(--text-step--1);
  line-height: 1.55;
  color: rgb(163 158 148 / 0.88);
}

.how-it-works__steps {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0;
  position: relative;
  max-width: 38rem;
}

.how-it-works__steps::before {
  content: "";
  position: absolute;
  left: 1.125rem;
  top: 0.5rem;
  bottom: 0.5rem;
  width: 1px;
  transform: translateX(-50%);
  background: linear-gradient(
    180deg,
    transparent,
    rgb(196 165 116 / 0.2) 8%,
    rgb(196 165 116 / 0.16) 50%,
    rgb(196 165 116 / 0.1) 92%,
    transparent
  );
  box-shadow: 0 0 14px rgb(196 165 116 / 0.06);
}

@media (min-width: 56rem) {
  .how-it-works__steps {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: clamp(0.85rem, 1.75vw, 1.35rem);
    max-width: none;
    align-items: stretch;
    isolation: isolate;
    padding-top: 0.35rem;
  }

  .how-it-works__steps::before {
    display: none;
  }
}

/* --- Secao: Exemplo de leitura --- */

.section.section--reading-sample {
  position: relative;
  isolation: isolate;
  padding-block: clamp(var(--space-2xl), 7vw, 4.75rem);
  border-top: 1px solid rgb(255 255 255 / 0.07);
  background: linear-gradient(180deg, rgb(11 10 16) 0%, var(--color-bg-deep) 42%, rgb(12 10 17) 100%);
}

.reading-sample__atmosphere {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background:
    radial-gradient(ellipse 52% 46% at 16% 22%, rgb(196 165 116 / 0.055), transparent 54%),
    radial-gradient(ellipse 60% 52% at 88% 66%, rgb(30 42 68 / 0.34), transparent 58%),
    radial-gradient(ellipse 42% 36% at 50% 100%, rgb(61 47 77 / 0.2), transparent 52%);
}

.reading-sample__inner {
  position: relative;
  z-index: 1;
}

.reading-sample__header {
  max-width: 48rem;
  margin-bottom: clamp(var(--space-xl), 4.5vw, var(--space-2xl));
}

.section.section--reading-sample .reading-sample__title {
  margin: 0 0 var(--space-lg);
  font-family: var(--font-serif);
  font-weight: 400;
  font-size: clamp(1.65rem, 0.9rem + 2.5vw, 2.55rem);
  line-height: 1.14;
  letter-spacing: -0.024em;
  color: var(--color-text-primary);
  text-wrap: balance;
}

.reading-sample__intro {
  margin: 0;
  max-width: 42rem;
  font-size: clamp(var(--text-step--1), 0.82rem + 0.45vw, var(--text-step-1));
  line-height: 1.68;
  letter-spacing: 0.012em;
  color: var(--color-text-muted-warm);
}

/* --- Seção: Formulário visual --- */

.section.section--oracle-form {
  position: relative;
  isolation: isolate;
  padding-block: clamp(var(--space-2xl), 7vw, 4.75rem);
  border-top: 1px solid rgb(255 255 255 / 0.07);
  background: linear-gradient(180deg, rgb(10 9 15) 0%, var(--color-bg-deep) 45%, rgb(11 10 16) 100%);
}

.oracle-form-section__atmosphere {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background:
    radial-gradient(ellipse 48% 44% at 16% 18%, rgb(196 165 116 / 0.05), transparent 56%),
    radial-gradient(ellipse 62% 52% at 88% 70%, rgb(30 42 68 / 0.33), transparent 58%),
    radial-gradient(ellipse 44% 36% at 54% 100%, rgb(61 47 77 / 0.19), transparent 52%);
}

.oracle-form-section__inner {
  position: relative;
  z-index: 1;
}

.oracle-form-section__grid {
  display: grid;
  gap: clamp(var(--space-xl), 4vw, var(--space-2xl));
  align-items: start;
}

.oracle-form-section__context {
  max-width: 32rem;
}

.section.section--oracle-form .oracle-form-section__title {
  margin: 0 0 var(--space-lg);
  font-family: var(--font-serif);
  font-weight: 400;
  font-size: clamp(1.65rem, 0.9rem + 2.5vw, 2.5rem);
  line-height: 1.14;
  letter-spacing: -0.024em;
  color: var(--color-text-primary);
  text-wrap: balance;
}

.oracle-form-section__intro {
  margin: 0;
  max-width: 30rem;
  font-size: clamp(var(--text-step--1), 0.82rem + 0.45vw, var(--text-step-1));
  line-height: 1.66;
  letter-spacing: 0.012em;
  color: var(--color-text-muted-warm);
}

.oracle-form-section__signals {
  margin: var(--space-xl) 0 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: var(--space-sm);
}

.oracle-form-section__signal {
  position: relative;
  margin: 0;
  padding-left: 1rem;
  font-family: var(--font-sans);
  font-size: 0.86rem;
  line-height: 1.5;
  color: rgb(181 174 163 / 0.9);
}

.oracle-form-section__signal::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.5rem;
  width: 0.42rem;
  height: 1px;
  background: rgb(196 165 116 / 0.6);
}

@media (min-width: 64rem) {
  .oracle-form-section__grid {
    grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr);
    gap: clamp(var(--space-xl), 5vw, var(--space-3xl));
  }
}

/* --- Seção: CTA final --- */

.section.section--final-cta {
  position: relative;
  isolation: isolate;
  padding-block: clamp(var(--space-2xl), 7vw, 4.75rem);
  border-top: 1px solid rgb(255 255 255 / 0.07);
  background: linear-gradient(180deg, rgb(9 8 13) 0%, var(--color-bg-deep) 42%, rgb(10 9 14) 100%);
}

.final-cta__atmosphere {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background:
    radial-gradient(ellipse 46% 42% at 18% 28%, rgb(196 165 116 / 0.055), transparent 56%),
    radial-gradient(ellipse 62% 52% at 84% 68%, rgb(30 42 68 / 0.34), transparent 58%),
    radial-gradient(ellipse 44% 36% at 50% 100%, rgb(61 47 77 / 0.2), transparent 52%);
}

.final-cta__inner {
  position: relative;
  z-index: 1;
}

.final-cta__panel {
  max-width: 52rem;
  margin-inline: auto;
  padding: clamp(var(--space-xl), 4vw, var(--space-2xl));
  border-radius: var(--radius-md);
  border: 1px solid rgb(255 255 255 / 0.08);
  border-top: 1px solid rgb(196 165 116 / 0.24);
  background: linear-gradient(176deg, rgb(38 31 50 / 0.26) 0%, rgb(16 14 22 / 0.92) 42%, rgb(8 8 12 / 0.98) 100%);
  box-shadow:
    inset 0 1px 0 rgb(255 255 255 / 0.06),
    inset 0 -1px 0 rgb(0 0 0 / 0.2),
    0 16px 52px rgb(0 0 0 / 0.33);
  text-align: center;
}

.section.section--final-cta .final-cta__title {
  margin: 0 0 var(--space-lg);
  font-family: var(--font-serif);
  font-weight: 400;
  font-size: clamp(1.75rem, 1.05rem + 2.1vw, 2.8rem);
  line-height: 1.13;
  letter-spacing: -0.025em;
  color: var(--color-text-primary);
  text-wrap: balance;
}

.final-cta__text {
  margin: 0 auto;
  max-width: 42rem;
  font-size: clamp(var(--text-step--1), 0.82rem + 0.4vw, var(--text-step-1));
  line-height: 1.66;
  letter-spacing: 0.012em;
  color: var(--color-text-muted-warm);
}

.final-cta__actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--space-md);
  margin-top: var(--space-xl);
}

.final-cta__note {
  margin: var(--space-lg) 0 0;
  padding-top: var(--space-sm);
  border-top: 1px solid rgb(255 255 255 / 0.08);
  font-size: 0.82rem;
  line-height: 1.5;
  letter-spacing: 0.01em;
  color: rgb(163 158 148 / 0.9);
}

@media (max-width: 35.99rem) {
  .final-cta__actions {
    flex-direction: column;
    align-items: stretch;
  }

  .final-cta__actions .btn {
    width: 100%;
  }
}

@media (max-width: 32rem) {
  .reading-sample__header,
  .how-it-works__header,
  .reading-types__header,
  .experience__header,
  .oracle-form-section__context {
    margin-bottom: var(--space-xl);
  }

  .sample-report,
  .oracle-form,
  .final-cta__panel {
    padding: var(--space-md);
  }

  .oracle-form__submit,
  .final-cta__actions .btn,
  .hero__actions .btn {
    min-height: 3rem;
  }
}
