:root {
  --forest: #17412d;
  --forest-2: #0f2b20;
  --leaf: #4b8b4a;
  --pink: #e83f8c;
  --pink-2: #ff5aa7;
  --cream: #f7f1e8;
  --sand: #efe5d6;
  --ink: #152018;
  --muted: #68746c;
  --white: #ffffff;
  --line: rgba(21, 32, 24, .12);
  --shadow: 0 24px 70px rgba(13, 38, 28, .18);
  --radius: 28px;
  --container: 1180px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color: var(--ink);
  background: var(--cream);
  line-height: 1.55;
  overflow-x: hidden;
}
body.modal-open { overflow: hidden; }
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
button, input { font: inherit; }
.container { width: min(var(--container), calc(100% - 40px)); margin-inline: auto; }

.site-header {
  position: fixed;
  inset: 0 0 auto 0;
  z-index: 80;
  height: 82px;
  padding: 0 28px;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 24px;
  color: var(--white);
  transition: background .25s ease, box-shadow .25s ease, height .25s ease, color .25s ease;
}
.site-header.is-scrolled,
.site-header.is-open {
  height: 72px;
  color: var(--ink);
  background: rgba(255,255,255,.94);
  backdrop-filter: blur(18px);
  box-shadow: 0 10px 40px rgba(18, 37, 28, .1);
}
.brand { position: relative; display: inline-grid; align-items: center; width: clamp(150px, 15vw, 188px); min-height: 48px; }
.brand-logo { grid-area: 1 / 1; width: 100%; height: auto; max-height: 49px; object-fit: contain; transition: opacity .25s ease, transform .25s ease; }
.brand-logo-solid { opacity: 0; }
.site-header.is-scrolled .brand-logo-light,
.site-header.is-open .brand-logo-light { opacity: 0; transform: translateY(-1px); }
.site-header.is-scrolled .brand-logo-solid,
.site-header.is-open .brand-logo-solid { opacity: 1; transform: translateY(0); }
.main-nav { display: flex; justify-content: center; align-items: center; gap: 22px; font-size: .87rem; font-weight: 700; }
.main-nav a { opacity: .86; transition: color .2s ease, opacity .2s ease; }
.main-nav a:hover { color: var(--pink-2); opacity: 1; }
.nav-toggle { display: none; width: 42px; height: 42px; border: 0; background: transparent; padding: 9px; cursor: pointer; }
.nav-toggle span { display: block; height: 2px; margin: 6px 0; background: currentColor; border-radius: 99px; }

.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  border: 0; border-radius: 999px; padding: 14px 22px; cursor: pointer;
  font-weight: 800; letter-spacing: -.01em; transition: transform .2s ease, box-shadow .2s ease, background .2s ease;
}
.btn:hover { transform: translateY(-2px); }
.btn-primary { background: var(--pink); color: white; box-shadow: 0 16px 35px rgba(232, 63, 140, .32); }
.btn-primary:hover { background: #d7317d; }
.btn-outline-light { background: transparent; color: var(--white); border: 1px solid rgba(255,255,255,.6); }
.btn-block { width: 100%; }
.btn-large { padding: 17px 30px; font-size: 1.04rem; }
.cta-label-short { display: none; }

.hero { position: relative; min-height: 100svh; display: grid; align-items: center; overflow: hidden; color: var(--white); }
.hero-media, .hero-overlay { position: absolute; inset: 0; }
.hero-media img { width: 100%; height: 100%; object-fit: cover; }
.hero-overlay { background: linear-gradient(90deg, rgba(7,21,15,.88), rgba(7,21,15,.58) 46%, rgba(7,21,15,.25)), linear-gradient(0deg, rgba(7,21,15,.45), transparent 46%); }
.hero-content {
  position: relative; z-index: 2; display: grid; grid-template-columns: minmax(0, 1fr) 430px; gap: 60px; align-items: center; padding: 130px 0 72px;
}
.hero-content > * { min-width: 0; }
.eyebrow { margin: 0 0 14px; color: var(--pink); text-transform: uppercase; font-size: .78rem; font-weight: 900; letter-spacing: .18em; }
.hero h1, .section h2, .media-band h2, .final-cta h2 { font-family: "Playfair Display", Georgia, serif; letter-spacing: -.035em; line-height: .98; }
.hero h1 { margin: 0; font-size: clamp(3.3rem, 8vw, 6.9rem); max-width: 820px; }
.hero-lead { max-width: 650px; color: rgba(255,255,255,.84); font-size: clamp(1.05rem, 2vw, 1.28rem); margin: 24px 0 28px; }
.hero-proof { display: flex; flex-wrap: wrap; gap: 10px; }
.hero-proof span { border: 1px solid rgba(255,255,255,.22); background: rgba(255,255,255,.08); padding: 9px 13px; border-radius: 999px; font-size: .88rem; font-weight: 700; }

.quiz-card { position: relative; isolation: isolate; overflow: hidden; width: 100%; max-width: 100%; min-width: 0; background: rgba(255,255,255,.96); color: var(--ink); border-radius: var(--radius); padding: 28px; box-shadow: var(--shadow); border: 1px solid rgba(255,255,255,.7); }
.quiz-card > :not(.quiz-isotype) { position: relative; z-index: 1; }
.quiz-isotype { display: block; pointer-events: none; user-select: none; }
.quiz-isotype-watermark { position: absolute; top: 18px; right: 18px; z-index: 0; width: 124px; max-width: 28%; opacity: .075; }
.modal-isotype { width: 54px; margin: 0 auto 16px; opacity: .92; }
.quiz-progress { height: 7px; background: #f3d7e5; border-radius: 999px; overflow: hidden; margin-bottom: 18px; }
.quiz-progress span { display: block; height: 100%; background: var(--pink); transition: width .25s ease; }
.quiz-kicker { margin: 0 0 6px; color: var(--pink); font-size: .78rem; font-weight: 900; text-transform: uppercase; letter-spacing: .12em; }
.quiz-card h2 { margin: 0 0 10px; font-size: 1.65rem; letter-spacing: -.03em; }
.quiz-question { margin: 0 0 18px; color: var(--muted); font-weight: 600; }
.quiz-options { display: grid; gap: 12px; }
.option-btn { width: 100%; min-width: 0; text-align: left; padding: 15px 16px; border-radius: 18px; border: 1px solid var(--line); background: var(--cream); color: var(--ink); cursor: pointer; font-weight: 800; overflow-wrap: anywhere; transition: transform .2s ease, border .2s ease, background .2s ease; }
.option-btn:hover { transform: translateY(-1px); border-color: var(--pink); background: #fff; }
.hidden { display: none !important; }
.lead-form { position: relative; }
.form-isotype { width: 38px; height: auto; margin: 0 auto 14px; opacity: .88; }
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
label { display: grid; gap: 7px; font-size: .82rem; font-weight: 800; color: var(--ink); }
input { width: 100%; border: 1px solid var(--line); border-radius: 14px; padding: 13px 14px; background: #fff; color: var(--ink); outline: none; }
input:focus { border-color: var(--pink); box-shadow: 0 0 0 4px rgba(232, 63, 140, .12); }
.form-error { min-height: 20px; margin: 12px 0; color: #b42318; font-size: .86rem; font-weight: 700; }

.section { padding: 96px 0; }
.section-head { max-width: 770px; margin: 0 auto 46px; text-align: center; }
.section h2, .media-band h2, .final-cta h2 { margin: 0; font-size: clamp(2.25rem, 5vw, 4.35rem); color: var(--forest-2); }
.section-head p:not(.eyebrow), .intro-grid p, .investment p, .broker-card p, .final-cta p { color: var(--muted); font-size: 1.05rem; }
.intro-strip { background: var(--white); padding: 70px 0; }
.intro-grid { display: grid; grid-template-columns: .85fr 1fr; gap: 60px; align-items: center; }
.intro-grid h2 { font-size: clamp(2rem, 4vw, 3.3rem); }
.pillars { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.card { background: var(--white); border: 1px solid var(--line); border-radius: var(--radius); padding: 28px; box-shadow: 0 18px 50px rgba(17, 43, 30, .08); }
.icon { display: inline-grid; place-items: center; width: 48px; height: 48px; border-radius: 16px; background: rgba(232,63,140,.12); color: var(--pink); font-weight: 900; margin-bottom: 18px; }
.card h3 { margin: 0 0 10px; font-size: 1.2rem; }
.card p { color: var(--muted); margin: 0; }
.center-actions { text-align: center; margin-top: 32px; }

.media-band { position: relative; min-height: 560px; display: grid; place-items: center; overflow: hidden; color: white; }
.media-band img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.media-band::after { content: ""; position: absolute; inset: 0; background: linear-gradient(90deg, rgba(9,29,20,.80), rgba(9,29,20,.30)); }
.media-band-content { position: relative; z-index: 1; width: min(760px, calc(100% - 40px)); text-align: center; }
.media-band h2 { color: white; }
.media-band p:not(.eyebrow) { color: rgba(255,255,255,.84); font-size: 1.12rem; }
.timeline-section { background: var(--white); }
.timeline-grid { display: grid; grid-template-columns: .7fr 1fr; gap: 60px; align-items: start; }
.timeline { display: grid; gap: 12px; }
.timeline-item { display: flex; justify-content: space-between; gap: 18px; padding: 20px; border: 1px solid var(--line); border-radius: 20px; background: var(--cream); }
.timeline-item b { color: var(--forest-2); }
.timeline-item span { color: var(--muted); text-align: right; }
.timeline-item.active { background: var(--forest); color: white; }
.timeline-item.active b, .timeline-item.active span { color: white; }
.certs {
  display: grid;
  grid-template-columns: repeat(5, minmax(120px, 1fr));
  gap: 18px;
  align-items: center;
  margin-top: 32px;
}

.cert-card {
  min-height: 132px;
  padding: 22px;
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.94);
  border: 1px solid rgba(40, 40, 40, 0.08);
  box-shadow: 0 18px 40px rgba(18, 24, 20, 0.08);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transform: translateY(18px) scale(0.96);
  transition:
    opacity 600ms ease,
    transform 600ms ease,
    box-shadow 260ms ease,
    border-color 260ms ease;
  transition-delay: var(--delay, 0ms);
}

.certs.is-visible .cert-card,
.reveal.is-visible .cert-card {
  opacity: 1;
  transform: translateY(0) scale(1);
}

.cert-card:hover {
  transform: translateY(-4px) scale(1.015);
  box-shadow: 0 24px 54px rgba(18, 24, 20, 0.13);
  border-color: rgba(224, 52, 132, 0.22);
}

.cert-card img {
  width: 100%;
  max-width: 208px;
  height: auto;
  display: block;
  object-fit: contain;
}

.dark-section { background: var(--forest-2); color: white; }
.dark-section .section-head h2, .dark-section .section-head p:not(.eyebrow) { color: white; }
.brand-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
.brand-card { overflow: hidden; background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.12); border-radius: var(--radius); }
.brand-card img { width: 100%; aspect-ratio: 4 / 3; object-fit: cover; }
.brand-card div { padding: 20px; }
.brand-card h3 { margin: 0 0 8px; }
.brand-card p { margin: 0; color: rgba(255,255,255,.74); font-size: .92rem; }

.investment { background: linear-gradient(135deg, var(--cream), #fff); }
.investment-grid { display: grid; grid-template-columns: 1fr 430px; gap: 60px; align-items: center; }
.price-card { background: var(--forest); color: white; border-radius: 34px; padding: 34px; box-shadow: var(--shadow); }
.price-label { color: #ffc5df; font-weight: 900; text-transform: uppercase; letter-spacing: .12em; font-size: .75rem; }
.price-card h3 { font-family: "Playfair Display", Georgia, serif; font-size: 5rem; margin: 4px 0 20px; line-height: 1; }
dl { margin: 0; display: grid; gap: 12px; }
dl div { display: flex; justify-content: space-between; gap: 20px; padding: 15px 0; border-bottom: 1px solid rgba(255,255,255,.16); }
dt { color: rgba(255,255,255,.66); } dd { margin: 0; font-weight: 900; text-align: right; }
.reviews { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.press-strip {
  margin: 34px auto 42px;
  padding: 26px;
  border-radius: 28px;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.92), rgba(246, 241, 236, 0.88));
  border: 1px solid rgba(40, 40, 40, 0.08);
  box-shadow: 0 20px 55px rgba(18, 24, 20, 0.08);
  overflow: hidden;
}
.press-strip__eyebrow {
  margin: 0 0 18px;
  text-align: center;
  font-size: 0.86rem;
  line-height: 1.4;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(31, 39, 35, 0.66);
  font-weight: 700;
}
.press-carousel {
  position: relative;
  overflow: hidden;
  width: 100%;
  mask-image: linear-gradient(
    90deg,
    transparent 0,
    #000 12%,
    #000 88%,
    transparent 100%
  );
}
.press-carousel__track {
  display: flex;
  align-items: center;
  gap: 22px;
  width: max-content;
  animation: pressMarquee 24s linear infinite;
}
.press-carousel:hover .press-carousel__track {
  animation-play-state: paused;
}
.press-logo {
  width: 190px;
  min-width: 190px;
  height: 88px;
  padding: 18px 24px;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.86);
  border: 1px solid rgba(40, 40, 40, 0.07);
  display: flex;
  align-items: center;
  justify-content: center;
  filter: grayscale(1);
  opacity: 0.78;
  transition:
    filter 220ms ease,
    opacity 220ms ease,
    transform 220ms ease,
    border-color 220ms ease;
}
.press-logo:hover {
  filter: grayscale(0);
  opacity: 1;
  transform: translateY(-3px);
  border-color: rgba(224, 52, 132, 0.24);
}
.press-logo img {
  display: block;
  max-width: 150px;
  max-height: 52px;
  width: auto;
  height: auto;
  object-fit: contain;
}
@keyframes pressMarquee {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-50%);
  }
}
.review { background: white; padding: 28px; border-radius: var(--radius); border: 1px solid var(--line); box-shadow: 0 18px 50px rgba(17,43,30,.08); }
.review span { color: var(--pink); letter-spacing: .1em; }
.review h3 { margin: 12px 0 8px; }
.review p { margin: 0; color: var(--muted); }
.broker-section { background: linear-gradient(120deg, var(--forest), #24583e); color: white; }
.broker-card { display: flex; align-items: center; justify-content: space-between; gap: 40px; }
.broker-card h2 { color: white; max-width: 760px; }
.broker-card p { color: rgba(255,255,255,.76); max-width: 760px; }
.final-cta { text-align: center; background: var(--white); }
.final-cta p { max-width: 660px; margin: 18px auto 28px; }

.site-footer { position: relative; overflow: hidden; background: #2d2d2d; color: rgba(255,255,255,.78); padding: 56px 0 28px; }
.site-footer .container { position: relative; z-index: 1; }
.footer-watermark { position: absolute; right: max(24px, 7vw); bottom: -70px; width: min(280px, 48vw); opacity: .035; pointer-events: none; user-select: none; }
.footer-grid { display: grid; grid-template-columns: 1.1fr 1fr 1.1fr 1fr; gap: 34px; }
.footer-brand { display: inline-flex; margin-bottom: 18px; }
.footer-logo { width: 188px; max-width: 100%; height: auto; }
.site-footer h3 { margin: 0 0 12px; color: white; }
.site-footer p { margin: 0 0 9px; font-size: .92rem; }
.site-footer a:hover { color: var(--pink-2); }
.socials {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 18px;
}
.socials a {
  width: 42px;
  height: 42px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #ffffff;
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.14);
  text-decoration: none;
  transition:
    transform 220ms ease,
    background-color 220ms ease,
    color 220ms ease,
    border-color 220ms ease;
}
.socials a:hover {
  transform: translateY(-3px);
  color: #e03484;
  background: #ffffff;
  border-color: #ffffff;
}
.socials i {
  font-size: 18px;
  line-height: 1;
}
.legal { opacity: .72; }
.whatsapp-float { position: fixed; right: 18px; bottom: 18px; z-index: 70; width: 54px; height: 54px; display: grid; place-items: center; border-radius: 50%; background: #25d366; color: white; font-weight: 900; box-shadow: 0 16px 35px rgba(0,0,0,.25); }

.modal { position: fixed; inset: 0; z-index: 120; display: grid; place-items: center; padding: 20px; }
.modal[hidden] { display: none; }
.modal-backdrop { position: absolute; inset: 0; background: rgba(10,18,14,.72); backdrop-filter: blur(8px); }
.modal-dialog { position: relative; width: min(560px, 100%); max-height: calc(100svh - 40px); overflow: auto; border-radius: 32px; }
.modal-close { position: absolute; top: 14px; right: 18px; z-index: 3; width: 36px; height: 36px; border: 0; border-radius: 50%; background: rgba(21,32,24,.09); color: var(--ink); cursor: pointer; font-size: 1.45rem; line-height: 1; }
.modal-quiz { padding-top: 40px; }
.broker-dialog { background: white; padding: 32px; box-shadow: var(--shadow); }
.broker-isotype { margin: 0 0 14px; }
.broker-dialog h2 { margin: 0 0 8px; font-size: 2rem; }
.broker-dialog p { color: var(--muted); }
.broker-form { display: grid; gap: 12px; }
.toast { position: fixed; left: 50%; bottom: 24px; transform: translateX(-50%); z-index: 160; background: var(--forest-2); color: white; padding: 14px 18px; border-radius: 999px; box-shadow: var(--shadow); font-weight: 800; }

.reveal { opacity: 0; transform: translateY(22px); transition: opacity .65s ease, transform .65s ease; }
.reveal.is-visible { opacity: 1; transform: translateY(0); }

@media (max-width: 1060px) {
  .site-header { grid-template-columns: minmax(118px, 1fr) auto auto; justify-content: space-between; gap: 12px; padding: 0 16px; }
  .brand { width: clamp(118px, 28vw, 164px); min-height: 42px; }
  .nav-toggle { display: block; order: 3; }
  .header-cta { order: 2; padding: 11px 13px; font-size: .78rem; }
  .main-nav { position: fixed; top: 72px; left: 14px; right: 14px; display: none; flex-direction: column; align-items: stretch; padding: 18px; background: white; color: var(--ink); border-radius: 22px; box-shadow: var(--shadow); }
  .main-nav.is-open { display: flex; }
  .main-nav a { padding: 10px 12px; }
  .hero-content, .intro-grid, .timeline-grid, .investment-grid { grid-template-columns: 1fr; gap: 34px; }
  .hero-content { padding-top: 118px; }
  .pillars, .brand-grid, .reviews, .footer-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 980px) {
  .certs {
    grid-template-columns: repeat(3, minmax(120px, 1fr));
  }
}

@media (prefers-reduced-motion: reduce) {
  .press-carousel__track {
    animation: none;
    flex-wrap: wrap;
    justify-content: center;
    width: 100%;
  }
}

@media (max-width: 680px) {
  .container { width: min(100% - 28px, var(--container)); }
  .site-header { display: flex; height: 70px; gap: 8px; }
  .site-header.is-scrolled, .site-header.is-open { height: 66px; }
  .brand { width: clamp(112px, 31vw, 142px); min-height: 36px; }
  .header-cta { min-width: 104px; padding: 10px 12px; line-height: 1.08; white-space: nowrap; }
  .cta-label-full { display: none; }
  .cta-label-short { display: inline; }
  .main-nav { top: 66px; }
  .hero { min-height: auto; }
  .hero-overlay { background: linear-gradient(0deg, rgba(7,21,15,.88), rgba(7,21,15,.42)); }
  .hero-content { padding: 104px 0 40px; }
  .hero h1 { font-size: clamp(2.3rem, 10.8vw, 3.15rem); }
  .quiz-card { padding: 22px; border-radius: 24px; }
  .quiz-isotype-watermark { width: 96px; top: 14px; right: 14px; opacity: .06; }
  .modal-isotype { width: 48px; margin-bottom: 12px; }
  .form-grid, .pillars, .brand-grid, .reviews, .footer-grid { grid-template-columns: 1fr; }
  .section { padding: 70px 0; }
  .media-band { min-height: 460px; }
  .timeline-item { display: grid; }
  .timeline-item span { text-align: left; }
  .broker-card { display: grid; }
  .price-card h3 { font-size: 4rem; }
  dl div { display: grid; gap: 4px; }
  dd { text-align: left; }
}

@media (max-width: 640px) {
  .certs {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
  }

  .cert-card {
    min-height: 116px;
    padding: 18px;
    border-radius: 18px;
  }

  .cert-card img {
    max-width: 112px;
  }
}

@media (max-width: 700px) {
  .press-strip {
    padding: 22px 18px;
    border-radius: 22px;
  }

  .press-logo {
    width: 160px;
    min-width: 160px;
    height: 78px;
    padding: 16px 20px;
  }

  .press-logo img {
    max-width: 126px;
    max-height: 46px;
  }
}
