/* ============================================================ FONTES LOCAIS */
@font-face {
  font-family: 'Alexandria';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('assets/fonts/Alexandria-400.woff2') format('woff2');
}

@font-face {
  font-family: 'Alexandria';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url('assets/fonts/Alexandria-500.woff2') format('woff2');
}

@font-face {
  font-family: 'Alexandria';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url('assets/fonts/Alexandria-600.woff2') format('woff2');
}

@font-face {
  font-family: 'Alexandria';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url('assets/fonts/Alexandria-700.woff2') format('woff2');
}

@font-face {
  font-family: 'Alexandria';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url('assets/fonts/Alexandria-800.woff2') format('woff2');
}

@font-face {
  font-family: 'Alexandria';
  font-style: normal;
  font-weight: 900;
  font-display: swap;
  src: url('assets/fonts/Alexandria-900.woff2') format('woff2');
}

/* ============================================================ DESIGN SYSTEM */
:root {
  --or: #FF8A00;
  --orl: #FFB24D;
  --ord: #D96D00;
  --wh: #FFF;
  --of: #F3F7F6;
  --wm: #D9E5E2;
  --st: #B8C9C5;
  --mg: #5C7480;
  --dk: #16364B;
  --ik: #032541;
  --gn: #557F4F;
  --gnl: #73996D;
  --gnd: #3F643A;
  --fd: 'Alexandria', sans-serif;
  --fb: 'Alexandria', sans-serif;
  --mw: 1280px;
  --rsm: 4px;
  --rmd: 10px;
  --rlg: 20px;
  --rxl: 32px;
  --rp: 9999px;
  --section-title-size: clamp(27px, 2.8vw, 40px);
  --section-title-size-md: clamp(28px, 8.8vw, 40px);
  --section-title-size-sm: clamp(26px, 8.2vw, 34px);
  --section-title-line: 1.04;
}

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

html {
  scroll-behavior: smooth;
  -webkit-font-smoothing: antialiased
}

body {
  font-family: var(--fb);
  font-size: 17px;
  line-height: 1.65;
  color: var(--dk);
  background: var(--wh);
  overflow-x: hidden
}

img {
  display: block;
  max-width: 100%
}

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

a:focus-visible,
button:focus-visible {
  outline: 3px solid rgba(85, 127, 79, .35);
  outline-offset: 3px
}

.skip-link {
  position: fixed;
  top: 12px;
  left: 16px;
  z-index: 400;
  transform: translateY(-140%);
  background: var(--ik);
  color: var(--wh);
  padding: 12px 18px;
  border-radius: var(--rp);
  font-family: var(--fd);
  font-weight: 700;
  letter-spacing: .04em;
  text-transform: uppercase;
  transition: transform .2s ease
}

.skip-link:focus {
  transform: translateY(0)
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0
}

.con {
  width: 100%;
  max-width: var(--mw);
  margin: 0 auto;
  padding: 0 28px
}

.ey {
  font-family: var(--fd);
  font-weight: 700;
  font-size: 11px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--gn)
}

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  background: var(--or);
  color: var(--wh);
  font-family: var(--fd);
  font-weight: 700;
  font-size: 18px;
  letter-spacing: .04em;
  text-transform: uppercase;
  padding: 18px 38px;
  border-radius: var(--rp);
  border: none;
  cursor: pointer;
  transition: background .2s, transform .15s;
  text-decoration: none;
  line-height: 1;
  white-space: nowrap
}

.btn:hover {
  background: var(--ord);
  transform: translateY(-2px)
}

.btn:active {
  transform: translateY(0)
}

.btn-g {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: transparent;
  color: var(--dk);
  font-family: var(--fb);
  font-weight: 500;
  font-size: 15px;
  padding: 15px 26px;
  border-radius: var(--rp);
  border: 2px solid rgba(3, 37, 65, .16);
  cursor: pointer;
  transition: all .2s;
  text-decoration: none;
  white-space: nowrap
}

.btn-g:hover {
  border-color: var(--gn);
  color: var(--gn)
}

.stitle,
.ri-title,
.fcta-h {
  font-family: var(--fd);
  font-weight: 800;
  font-size: var(--section-title-size);
  line-height: var(--section-title-line);
  text-transform: uppercase;
  color: var(--ik)
}

.stitle em {
  font-style: normal;
  color: var(--gn)
}

.stitle-w {
  color: var(--wh)
}

.sbody {
  font-size: 17px;
  color: #5A5550;
  line-height: 1.7
}

.sbody strong {
  color: var(--dk);
  font-weight: 600
}

.sbody-w {
  color: rgba(255, 255, 255, .65)
}

.sbody-w strong {
  color: var(--wh)
}

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

.reveal.vis {
  opacity: 1;
  transform: translateY(0)
}

.d1 {
  transition-delay: .1s
}

.d2 {
  transition-delay: .22s
}

.d3 {
  transition-delay: .34s
}

@keyframes fu {
  from {
    opacity: 0;
    transform: translateY(28px)
  }

  to {
    opacity: 1;
    transform: translateY(0)
  }
}

.fu {
  opacity: 0;
  animation: fu .75s ease forwards
}

.fu1 {
  animation-delay: .1s
}

.fu2 {
  animation-delay: .25s
}

.fu3 {
  animation-delay: .4s
}

.fu4 {
  animation-delay: .55s
}

.fu5 {
  animation-delay: .7s
}

/* NAV */
.nav {
  position: relative;
  z-index: 200;
  padding: 14px 0;
  background: var(--wh);
  border-bottom: 1px solid rgba(3, 37, 65, .08)
}

.nav.sc {
  box-shadow: none
}

.nav-i {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px
}

.nav-logo {
  display: flex;
  align-items: center;
  gap: 0;
  text-decoration: none;
  flex-shrink: 0
}

.nav-mark {
  display: none
}

.nav-name {
  font-family: var(--fd);
  font-weight: 800;
  font-size: 21px;
  letter-spacing: .02em;
  color: var(--ik);
  line-height: 1
}

.nav-sub {
  font-family: var(--fb);
  font-size: 10px;
  font-weight: 500;
  color: var(--mg);
  letter-spacing: .06em;
  text-transform: uppercase;
  margin-top: 2px
}

.nav-ctr {
  display: flex;
  align-items: center;
  gap: 6px
}

.brand-wordmark {
  display: block;
  height: auto
}

.brand-wordmark-nav {
  width: 164px;
  max-width: 42vw
}

.npill {
  background: var(--wh);
  border: 1px solid rgba(3, 37, 65, .1);
  padding: 4px 10px;
  border-radius: var(--rp);
  font-size: 11px;
  font-weight: 600;
  color: var(--dk);
  letter-spacing: .04em;
  white-space: nowrap
}

.npill-o {
  background: var(--wh);
  color: var(--gnd);
  border: 1px solid rgba(85, 127, 79, .22);
  padding: 4px 10px;
  border-radius: var(--rp);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .04em
}

.npill-logo {
  display: block;
  height: 24px;
  width: auto
}

/* HERO */
.hero {
  position: relative;
  min-height: calc(100vh - 72px);
  display: flex;
  align-items: center;
  overflow: hidden;
  background-color: #EEF4F2;
  background-image: url('assets/fundo-principal1.webp');
  background-position: right center;
  background-repeat: no-repeat;
  background-size: cover;
  padding-top: 0
}

.hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(244, 248, 247, .98) 0%, rgba(244, 248, 247, .96) 24%, rgba(244, 248, 247, .9) 38%, rgba(244, 248, 247, .68) 50%, rgba(244, 248, 247, .28) 62%, rgba(244, 248, 247, 0) 76%);
  z-index: 1;
  pointer-events: none
}

.hero-panel {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  width: 46%;
  background: var(--ik);
  clip-path: polygon(12% 0%, 100% 0%, 100% 100%, 0% 100%);
  z-index: 0
}

.hero-panel::after {
  content: '';
  position: absolute;
  inset: 0;
  background: repeating-linear-gradient(-45deg, transparent, transparent 28px, rgba(255, 255, 255, .018) 28px, rgba(255, 255, 255, .018) 29px)
}

.hero-slash {
  position: absolute;
  inset: 0;
  background: var(--gn);
  clip-path: polygon(58.9% 0, 59.8% 0, 54.7% 100%, 53.8% 100%);
  z-index: 1
}

.hero-in {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: 1fr;
  min-height: calc(100vh - 72px);
  width: 100%;
  max-width: var(--mw);
  margin: 0 auto;
  padding: 0 28px;
  align-items: center
}

.hero-copy {
  max-width: 640px;
  padding: 64px 56px 64px 0
}

.hero-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(85, 127, 79, .10);
  border: 1px solid rgba(85, 127, 79, .24);
  padding: 7px 16px;
  border-radius: var(--rp);
  margin-bottom: 28px
}

.hero-h1 {
  font-family: var(--fd);
  font-weight: 800;
  font-size: clamp(30px, 3.4vw, 48px);
  line-height: 1.02;
  text-transform: uppercase;
  color: var(--ik);
  margin-bottom: 28px;
  letter-spacing: -.01em
}

.hero-h1 em {
  font-style: normal;
  color: var(--gn);
  display: inline
}

.hero-sub {
  font-size: 18px;
  color: #5A5550;
  line-height: 1.7;
  max-width: 460px;
  margin-bottom: 40px
}

.hero-sub strong {
  color: var(--dk);
  font-weight: 600
}

.hero-acts {
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  gap: 40px;
  margin-bottom: 44px
}

.hero-patch {
  width: 150px;
  height: auto;
  flex-shrink: 0;
}

.hero-trust {
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
  padding-top: 20px;
  border-top: 1px solid rgba(42, 37, 32, .1)
}

.ht-i {
  display: flex;
  align-items: center;
  gap: 7px;
  font-size: 13px;
  color: var(--mg);
  font-weight: 500
}

.ht-d {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--gn);
  flex-shrink: 0
}

.hero-right {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 12px;
  padding: 52px 0 52px 124px
}

.hsc {
  background: rgba(255, 255, 255, .06);
  border: 1px solid rgba(255, 255, 255, .1);
  border-radius: 17px;
  padding: 20px 22px;
  display: flex;
  align-items: center;
  gap: 14px;
  transition: background .2s
}

.hsc:hover {
  background: rgba(255, 255, 255, .09)
}

.hsc-ico {
  width: 40px;
  height: 40px;
  background: rgba(85, 127, 79, .18);
  border-radius: 9px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--gnl);
  flex-shrink: 0
}

.hsc-ico svg {
  width: 20px;
  height: 20px
}

.hsc-n {
  font-family: var(--fd);
  font-weight: 800;
  font-size: 20px;
  color: var(--wh);
  line-height: 1
}

.hsc-l {
  font-size: 12px;
  color: rgba(255, 255, 255, .58);
  margin-top: 4px;
  line-height: 1.28
}

/* TICKER */
.ticker {
  background: var(--ik);
  padding: 14px 0;
  overflow: hidden
}

.ticker-t {
  display: flex;
  width: max-content;
  animation: tick 34s linear infinite
}

.ticker-t:hover {
  animation-play-state: paused
}

@keyframes tick {
  from {
    transform: translateX(0)
  }

  to {
    transform: translateX(-50%)
  }
}

.ti {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 0 28px;
  font-family: var(--fd);
  font-weight: 800;
  font-size: 15px;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--wh);
  white-space: nowrap
}

.td {
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: rgba(115, 153, 109, .85);
  flex-shrink: 0
}

/* RISK INTRO */
.ri {
  background: var(--wh);
  padding: 96px 0
}

.ri-g {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: center
}

.ri-title {
  margin-bottom: 22px
}

.ri-title em {
  font-style: normal;
  color: var(--gn)
}

.ri-body {
  font-size: 17px;
  color: #5A5550;
  line-height: 1.7;
  margin-bottom: 32px
}

.ri-body strong {
  color: var(--dk)
}

.ri-stats {
  display: flex;
  gap: 64px;
  margin-bottom: 36px
}

.ri-sn {
  font-family: var(--fd);
  font-weight: 900;
  font-size: 44px;
  color: var(--gn);
  line-height: 1
}

.ri-sl {
  font-size: 13px;
  color: var(--mg);
  font-weight: 500;
  margin-top: 4px;
  line-height: 1.4;
  max-width: 130px
}

.ri-src {
  font-size: 12px;
  color: var(--mg);
  line-height: 1.6;
  margin: 0 0 34px
}

.ri-src a {
  color: var(--gn);
  font-weight: 600;
  text-decoration: underline
}

.ri-box {
  background: var(--ik);
  border-radius: var(--rxl);
  padding: 44px;
  position: relative;
  align-self: start;
  margin-top: 40px;
  overflow: hidden
}

.ri-box::before {
  content: '';
  position: absolute;
  bottom: -40px;
  right: -40px;
  width: 200px;
  height: 200px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(85, 127, 79, .24) 0%, transparent 70%)
}

.ri-box::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 5px;
  height: 100%;
  background: var(--gn);
  border-radius: 4px 0 0 4px
}

.ri-q {
  font-family: var(--fd);
  font-weight: 700;
  font-size: clamp(22px, 2.5vw, 30px);
  line-height: 1.25;
  color: var(--wh);
  margin-bottom: 24px;
  position: relative
}

.ri-q em {
  font-style: normal;
  color: var(--gnl)
}

.ri-list {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 12px
}

.ri-list li {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  font-size: 15px;
  color: rgba(255, 255, 255, .7);
  line-height: 1.5
}

.ri-list li strong {
  color: var(--wh)
}

.rl-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--gn);
  flex-shrink: 0;
  margin-top: 6px
}

/* SECTION HEADER CENTER */
.shc {
  text-align: center;
  max-width: 640px;
  margin: 0 auto 56px
}

.shc .ey {
  margin-bottom: 14px;
  display: block
}

.shc .stitle {
  margin-bottom: 14px
}

/* PROFESSIONS */
.prof {
  background: var(--of);
  padding: 96px 0
}

.prof-tabs {
  display: flex;
  gap: 8px;
  justify-content: center;
  flex-wrap: wrap;
  margin-bottom: 44px
}

.ptab {
  font-family: var(--fd);
  font-weight: 700;
  font-size: 13px;
  letter-spacing: .06em;
  text-transform: uppercase;
  padding: 9px 20px;
  border-radius: var(--rp);
  border: 2px solid var(--wm);
  background: var(--wh);
  color: var(--mg);
  cursor: pointer;
  transition: all .2s
}

.ptab.on,
.ptab:hover {
  background: var(--gn);
  border-color: var(--gn);
  color: var(--wh)
}

.pgroup {
  display: none
}

.pgroup.on {
  display: block
}

.pgroup[hidden] {
  display: none !important
}

.pgrid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 2px;
  background: var(--wm);
  border-radius: var(--rlg);
  overflow: hidden
}

.pc {
  background: var(--wh);
  padding: 28px 24px;
  cursor: default;
  transition: background .18s
}

.pc:hover {
  background: var(--of)
}

.pc:hover .pc-ico {
  color: var(--gn)
}

.pc-ico {
  color: var(--dk);
  margin-bottom: 14px;
  transition: color .18s
}

.pc-name {
  font-family: var(--fd);
  font-weight: 700;
  font-size: 16px;
  text-transform: uppercase;
  letter-spacing: .03em;
  color: var(--ik);
  margin-bottom: 7px;
  line-height: 1.2
}

.pc-jobs {
  font-size: 13px;
  color: var(--mg);
  line-height: 1.55
}

/* SPORTS */
.sp {
  position: relative;
  background-color: var(--wh);
  background-image: url('assets/esporte-radical1.webp');
  background-position: left center;
  background-repeat: no-repeat;
  background-size: cover;
  padding: 96px 0;
  overflow: hidden;
}

.sp::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0) 35%, rgba(255, 255, 255, 0.8) 50%, rgba(255, 255, 255, 1) 65%);
  z-index: 1;
  pointer-events: none;
}

.sp .con {
  position: relative;
  z-index: 2;
}

.sp-in {
  display: flex;
  flex-direction: column;
  max-width: 580px;
  margin-left: auto;
  gap: 32px;
}

.sp-mob-img {
  display: none;
}

.sp-note {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  background: rgba(85, 127, 79, .08);
  border: 1px solid rgba(85, 127, 79, .18);
  border-radius: var(--rmd);
  padding: 16px 18px;
  margin: 20px 0 28px
}

.sp-note-ico {
  flex-shrink: 0;
  color: var(--gn);
  margin-top: 1px
}

.sp-note-t {
  font-size: 14px;
  color: var(--dk);
  line-height: 1.55
}

.sp-note-t strong {
  font-weight: 600
}

.sgrid {
  display: flex;
  flex-direction: column;
  background: transparent;
  border-radius: var(--rlg);
  overflow: hidden;
}

.sc {
  background: transparent;
  padding: 16px 12px;
  transition: background .18s;
  display: flex;
  align-items: center;
  gap: 16px;
  border-bottom: 1px solid rgba(3, 37, 65, .08);
}

.sc:last-child {
  border-bottom: none;
}

.sc:hover {
  background: rgba(255, 255, 255, 0.4);
}

.sc:hover .sc-ico {
  color: var(--gn)
}

.sc-ico {
  color: var(--dk);
  transition: color .18s;
  flex-shrink: 0;
  display: flex;
  align-items: center;
}

.sc-name {
  font-family: var(--fd);
  font-weight: 700;
  font-size: 15px;
  text-transform: uppercase;
  letter-spacing: .03em;
  color: var(--ik);
  line-height: 1.2;
}

.sc-ex {
  display: none;
}

/* COVERAGES */
.cov {
  background: var(--of);
  padding: 96px 0
}

.cgrid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2px;
  background: var(--wm);
  border-radius: var(--rlg);
  overflow: hidden;
  margin-top: 56px
}

.cc {
  background: var(--wh);
  padding: 40px 30px
}

.cc.feat {
  background: var(--ik)
}

.cc-num {
  font-family: var(--fd);
  font-weight: 900;
  font-size: 80px;
  line-height: 1;
  color: var(--wm);
  margin-bottom: 18px
}

.cc.feat .cc-num {
  color: rgba(85, 127, 79, .18)
}

.cc-ico {
  width: 50px;
  height: 50px;
  background: rgba(85, 127, 79, .12);
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--gn);
  margin-bottom: 16px
}

.cc.feat .cc-ico {
  background: rgba(85, 127, 79, .2)
}

.cc-title {
  font-family: var(--fd);
  font-weight: 700;
  font-size: 17px;
  text-transform: uppercase;
  letter-spacing: .02em;
  color: var(--ik);
  margin-bottom: 12px;
  line-height: 1.2
}

.cc.feat .cc-title {
  color: var(--wh)
}

.cc-text {
  font-size: 15px;
  color: #5A5550;
  line-height: 1.65
}

.cc.feat .cc-text {
  color: rgba(255, 255, 255, .62)
}

.cc-hl {
  margin-top: 20px;
  padding: 12px 16px;
  background: rgba(85, 127, 79, .08);
  border-left: 3px solid var(--gn);
  border-radius: 0 var(--rsm) var(--rsm) 0;
  font-size: 13px;
  font-weight: 600;
  color: var(--gnd)
}

.cc.feat .cc-hl {
  background: rgba(85, 127, 79, .16);
  color: var(--gnl)
}

/* PRICING */
.price {
  background: var(--wh);
  padding: 96px 0
}

.price-lay {
  display: grid;
  grid-template-columns: 1fr 1.4fr;
  gap: 80px;
  align-items: start
}

.price-perks {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-top: 28px
}

.perk {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  font-size: 15px;
  color: var(--dk);
  line-height: 1.5
}

.perk-d {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--gn);
  flex-shrink: 0;
  margin-top: 6px
}

.perk strong {
  font-weight: 600
}

.ptable {
  border-radius: var(--rlg);
  overflow: hidden;
  border: 2px solid var(--wm)
}

.pthead {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr;
  background: var(--ik);
  padding: 14px 24px;
  gap: 8px
}

.pth {
  font-family: var(--fd);
  font-weight: 700;
  font-size: 11px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, .9)
}

.pth:not(:first-child) {
  text-align: center
}

.prow {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr;
  padding: 18px 24px;
  border-top: 1px solid var(--wm);
  align-items: center;
  gap: 8px;
  transition: background .15s
}

.prow:hover {
  background: var(--of)
}

.prow.pop {
  background: rgba(3, 37, 65, .045);
  border-left: 4px solid var(--gn);
  padding-left: 20px
}

.pr-cap {
  font-family: var(--fd);
  font-weight: 700;
  font-size: 16px;
  color: var(--ik);
  line-height: 1.16;
  position: relative;
}

.pr-lk {
  text-align: center;
  font-size: 14px;
  color: var(--mg);
  font-weight: 500
}

.pr-px {
  text-align: center;
  font-family: var(--fd);
  font-weight: 700;
  font-size: 20px;
  color: var(--dk)
}

.pop-b {
  position: absolute;
  top: -20px;
  left: 0;
  background: var(--or);
  color: #fff;
  font-family: var(--fd);
  font-size: 9px;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  padding: 2px 7px;
  border-radius: 4px;
}

.ptcta {
  padding: 20px 24px;
  background: var(--of);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap
}

.ptcta-n {
  font-size: 13px;
  color: var(--mg);
  line-height: 1.5;
  max-width: 280px
}

/* HOW TO */
.how {
  background: var(--of);
  padding: 96px 0
}

.steps {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 2px;
  background: var(--wm);
  border-radius: var(--rlg);
  overflow: hidden;
  margin-top: 56px
}

.step {
  background: var(--wh);
  padding: 36px 26px;
  position: relative;
  overflow: hidden
}

.step-bg {
  position: absolute;
  top: -10px;
  right: -10px;
  font-family: var(--fd);
  font-weight: 900;
  font-size: 100px;
  color: var(--of);
  line-height: 1;
  pointer-events: none;
  user-select: none
}

.step-n {
  font-family: var(--fd);
  font-weight: 900;
  font-size: 14px;
  letter-spacing: .14em;
  color: var(--gn);
  text-transform: uppercase;
  margin-bottom: 16px
}

.step-ico {
  width: 46px;
  height: 46px;
  background: rgba(85, 127, 79, .12);
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--gn);
  margin-bottom: 18px
}

.step-t {
  font-family: var(--fd);
  font-weight: 700;
  font-size: 15px;
  text-transform: uppercase;
  letter-spacing: .02em;
  color: var(--ik);
  margin-bottom: 10px;
  line-height: 1.24
}

.step-p {
  font-size: 14px;
  color: #5A5550;
  line-height: 1.6
}

/* TRANSPARENCY */
.tr {
  background: var(--wh);
  padding: 96px 0
}

.tr-g {
  display: grid;
  grid-template-columns: 1fr 1.4fr;
  gap: 80px;
  align-items: start
}

.tr-list {
  display: flex;
  flex-direction: column;
  gap: 10px
}

.tr-item {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 16px 18px;
  border-radius: var(--rmd);
  background: var(--of);
  border: 1px solid var(--wm)
}

.tr-ico {
  width: 30px;
  height: 30px;
  border-radius: 6px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 15px;
  flex-shrink: 0;
  margin-top: 1px
}

.t-y {
  background: rgba(45, 122, 79, .1);
  color: #2D7A4F
}

.t-n {
  background: rgba(204, 48, 48, .08);
  color: #CC3030
}

.t-w {
  background: rgba(255, 138, 0, .12);
  color: var(--ord);
  font-size: 14px
}

.tr-txt {
  font-size: 14px;
  color: var(--dk);
  line-height: 1.55
}

.tr-txt strong {
  font-weight: 600
}

.tr-link {
  color: var(--gn);
  font-weight: 600;
  text-decoration: underline
}

/* FAQ */
.faq {
  background: var(--of);
  padding: 96px 0
}

.faq-lay {
  display: grid;
  grid-template-columns: 1fr 1.8fr;
  gap: 80px;
  align-items: start
}

.faq-box {
  background: var(--wh);
  border-radius: var(--rlg);
  padding: 28px;
  border: 1px solid var(--wm)
}

.faq-box-mobile {
  display: none;
}

.faq-box-lbl {
  font-family: var(--fd);
  font-weight: 700;
  font-size: 13px;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--mg);
  margin-bottom: 10px
}

.faq-box-t {
  font-size: 15px;
  color: var(--dk);
  line-height: 1.55;
  margin-bottom: 18px
}

.facc {
  display: flex;
  flex-direction: column;
  gap: 2px;
  background: var(--wm);
  border-radius: var(--rlg) var(--rlg) 0 0;
  overflow: hidden
}

.fi {
  background: var(--wh);
  overflow: hidden
}

.facc>.fi:last-of-type {
  border-radius: 0
}

.fq {
  width: 100%;
  background: none;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 22px 26px;
  text-align: left;
  transition: background .15s
}

.fq:hover,
.fq.op {
  background: var(--of)
}

.fq-t {
  font-family: var(--fb);
  font-weight: 600;
  font-size: 16px;
  color: var(--ik);
  line-height: 1.4
}

.fq.op .fq-t {
  color: var(--gn)
}

.fq-i {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: var(--wm);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--mg);
  flex-shrink: 0;
  transition: all .25s
}

.fq.op .fq-i {
  background: var(--gn);
  color: var(--wh);
  transform: rotate(45deg)
}

.fa {
  max-height: 0;
  overflow: hidden;
  transition: max-height .38s ease
}

.fa.op {
  max-height: 600px
}

.fa-in {
  padding: 18px 26px 22px;
  font-size: 15px;
  color: #5A5550;
  line-height: 1.7;
  border-top: 1px solid var(--wm)
}

.fa-in a {
  color: var(--gn);
  font-weight: 600;
  text-decoration: underline
}

.fa-in strong {
  color: var(--dk);
  font-weight: 600
}

.fa-in ul {
  margin: 10px 0 0 18px;
  display: flex;
  flex-direction: column;
  gap: 5px
}

.fa-in ul li {
  font-size: 14px
}

.fcat {
  background: var(--of);
  padding: 10px 26px;
  font-family: var(--fd);
  font-weight: 700;
  font-size: 11px;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--mg);
  border-top: 1px solid var(--wm)
}

.fcat:first-child {
  border-top: none
}

/* TRUST */
.trust {
  background: var(--ik);
  padding: 96px 0;
  position: relative;
  overflow: hidden
}

.trust::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: linear-gradient(90deg, var(--ik), var(--gn), var(--or))
}

.trust::after {
  content: 'OKENA';
  position: absolute;
  right: -40px;
  bottom: -30px;
  font-family: var(--fd);
  font-weight: 900;
  font-size: 200px;
  color: rgba(255, 255, 255, .025);
  pointer-events: none;
  user-select: none;
  line-height: 1
}

.trust-in {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: 80px;
  align-items: center
}

.trust-lr {
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
  margin-top: 28px
}

.tlp {
  height: 44px;
  padding: 0 20px;
  background: rgba(255, 255, 255, .06);
  border: 1px solid rgba(255, 255, 255, .1);
  border-radius: var(--rmd);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--fd);
  font-weight: 800;
  font-size: 15px;
  letter-spacing: .05em;
  color: rgba(255, 255, 255, .7);
  text-transform: uppercase;
  white-space: nowrap
}

.tlp-c {
  border-color: rgba(85, 127, 79, .38);
  background: rgba(85, 127, 79, .12);
  color: var(--gnl);
  font-size: 17px
}

.trust-note {
  font-size: 12px;
  color: rgba(255, 255, 255, .3);
  margin-top: 10px;
  line-height: 1.5
}

.trust-stats {
  display: grid;
  grid-template-columns: 1fr;
  gap: 2px;
  background: rgba(255, 255, 255, .05);
  border-radius: var(--rlg);
  overflow: hidden
}

.ts {
  padding: 30px;
  background: rgba(255, 255, 255, .02)
}

.ts-n {
  font-family: var(--fd);
  font-weight: 900;
  font-size: 32px;
  color: var(--gn);
  line-height: 1;
  margin-bottom: 8px
}

.ts-l {
  font-size: 14px;
  color: rgba(255, 255, 255, .45);
  line-height: 1.45
}

/* FINAL CTA */
.fcta {
  background: var(--wh);
  padding: 128px 0;
  text-align: center;
  position: relative;
  overflow: hidden
}

.fcta::before {
  content: '';
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 700px;
  height: 700px;
  background: radial-gradient(circle, rgba(85, 127, 79, .07) 0%, transparent 70%);
  pointer-events: none
}

.fcta-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(85, 127, 79, .10);
  border: 1px solid rgba(85, 127, 79, .2);
  border-radius: var(--rp);
  padding: 8px 18px;
  margin-bottom: 32px
}

.fcta-h {
  margin-bottom: 26px
}

.fcta-h em {
  font-style: normal;
  color: var(--gn);
  display: block
}

.fcta-sub {
  font-size: 18px;
  color: #5A5550;
  line-height: 1.65;
  max-width: 560px;
  margin: 0 auto 48px
}

.fcta-acts {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 14px;
  margin-bottom: 40px
}

.fcta-disc {
  font-size: 12px;
  color: var(--mg);
  max-width: 500px;
  margin: 0 auto;
  line-height: 1.65
}

/* FOOTER */
.foot {
  background: var(--ik);
  padding: 44px 0 0
}

.foot-main {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 40px;
  flex-wrap: wrap;
  padding-bottom: 40px
}

.foot-br-row {
  display: inline-flex;
  align-items: center;
  gap: 0;
  margin-bottom: 14px
}

.foot-bm {
  display: none
}

.foot-bn {
  display: none
}

.brand-wordmark-foot {
  width: 210px;
  max-width: 100%
}

.foot-bt {
  font-size: 13px;
  color: rgba(255, 255, 255, .55);
  max-width: 240px;
  line-height: 1.5
}

.foot-ct {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-top: 16px
}

.foot-ct a {
  font-size: 14px;
  color: rgba(255, 255, 255, .7);
  transition: color .2s
}

.foot-ct a:hover {
  color: rgba(255, 255, 255, .85)
}

.foot-col-t {
  font-family: var(--fd);
  font-weight: 700;
  font-size: 11px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, .5);
  margin-bottom: 14px
}

.foot-col-l {
  display: flex;
  flex-direction: column;
  gap: 8px
}

.foot-col-l a {
  font-size: 14px;
  color: rgba(255, 255, 255, .7);
  transition: color .2s
}

.foot-col-l a:hover {
  color: rgba(255, 255, 255, .85)
}

.foot-bot {
  border-top: 1px solid rgba(255, 255, 255, .07);
  padding: 20px 0;
  font-size: 12px;
  color: rgba(255, 255, 255, .45);
  line-height: 1.65;
  text-align: center
}

.foot-credit {
  text-align: center;
  padding-top: 12px;
  padding-bottom: 24px;
  display: flex;
  justify-content: center;
}

.foot-credit img {
  max-width: 140px;
  height: auto;
}

/* RESPONSIVE */
@media(max-width:1024px) {

  .con {
    padding: 0 24px
  }

  .hero-in,
  .ri-g,
  .sp-in,
  .price-lay,
  .tr-g,
  .trust-in {
    grid-template-columns: 1fr;
    gap: 48px
  }

  .faq-lay {
    grid-template-columns: 1fr;
    gap: 16px;
  }

  .faq-box-desktop {
    display: none;
  }

  .faq-box-mobile {
    display: block;
  }

  .hero-panel,
  .hero-slash {
    display: none
  }

  .hero {
    min-height: auto;
    background-position: 68% center
  }

  .hero-copy {
    max-width: 580px;
    padding: 72px 0 84px
  }

  .hero-right {
    display: none
  }

  .hero-sub {
    max-width: 560px
  }

  .ri,
  .prof,
  .sp,
  .cover,
  .price,
  .how,
  .truth,
  .faq,
  .trust {
    padding: 88px 0
  }

  .sp {
    background-image: none !important;
  }

  .sp::before {
    display: none;
  }

  .sp-mob-img {
    display: block;
    width: 100%;
    aspect-ratio: 16 / 9;
    background-image: url('assets/esporte-radical-mobile1.webp');
    background-size: cover;
    background-position: center;
    border-radius: var(--rlg);
    margin-bottom: 32px;
  }

  .sp-in {
    max-width: none;
    margin: 0;
  }

  .fcta {
    padding: 108px 0
  }

  .ri-stats {
    flex-wrap: wrap;
    gap: 40px
  }

  .ri-box {
    margin-top: 0;
    padding: 36px
  }

  .pgrid {
    grid-template-columns: repeat(2, 1fr)
  }

  .steps {
    grid-template-columns: 1fr 1fr
  }

  .cgrid {
    grid-template-columns: 1fr
  }
}

@media(max-width:768px) {
  .con {
    padding: 0 18px
  }

  .nav {
    padding: 10px 0
  }

  .nav-i {
    gap: 14px
  }

  .nav-ctr {
    display: none
  }

  .nav .btn {
    width: auto;
    padding: 10px 14px;
    font-size: 12px !important;
    flex-shrink: 0
  }

  .btn {
    font-size: 14px
  }

  .hero {
    align-items: flex-start;
    background-image: url('assets/fundo-mobile1.webp');
    background-position: center 92%;
    background-repeat: no-repeat;
    background-size: cover
  }

  .hero::before {
    background: linear-gradient(180deg, rgba(244, 248, 247, .98) 0%, rgba(244, 248, 247, .97) 16%, rgba(244, 248, 247, .92) 30%, rgba(244, 248, 247, .7) 42%, rgba(244, 248, 247, .26) 54%, rgba(244, 248, 247, .08) 62%, rgba(244, 248, 247, 0) 70%)
  }

  .hero-in {
    min-height: max(860px, calc(100svh - 64px));
    padding: 0 18px;
    align-items: start
  }

  .hero-copy {
    max-width: 100%;
    padding: 40px 0 52px
  }

  .hero-badge {
    margin-bottom: 20px;
    padding: 7px 14px
  }

  .hero-h1 {
    font-size: clamp(34px, 10vw, 46px);
    margin-bottom: 20px;
    max-width: 100%
  }

  .hero-sub {
    max-width: 360px;
    font-size: 16px;
    line-height: 1.6;
    margin-bottom: 28px
  }

  .hero-trust {
    display: none
  }

  .ht-i {
    font-size: 14px
  }

  .pgrid,
  .steps {
    grid-template-columns: 1fr
  }

  .trust-stats {
    grid-template-columns: 1fr
  }

  .hero-acts,
  .fcta-acts {
    flex-direction: column;
    align-items: flex-start
  }

  .hero-acts {
    gap: 30px;
  }

  .hero-acts .btn {
    width: auto;
    min-width: 0;
    padding: 16px 22px;
    font-size: 15px
  }

  .fcta-acts {
    align-items: center
  }

  .ri,
  .prof,
  .sp,
  .cover,
  .price,
  .how,
  .truth,
  .faq,
  .trust,
  .fcta {
    padding: 72px 0
  }

  .sp-mob-img {
    aspect-ratio: 4 / 3;
    margin-bottom: 24px;
  }

  .sp-note {
    margin: 16px 0 20px;
  }

  .sp-in {
    gap: 16px;
  }

  .sp-in>.reveal.d3 {
    margin-top: 8px !important;
  }

  .stitle,
  .ri-title,
  .fcta-h {
    font-size: var(--section-title-size-md)
  }

  .ri-title br {
    display: none
  }

  .ri-body {
    font-size: 16px
  }

  .ri-stats {
    gap: 24px
  }

  .ri-sn {
    font-size: 38px
  }

  .ri-sl {
    max-width: none;
    font-size: 14px
  }

  .ri-box {
    padding: 30px 24px
  }

  .ri-q {
    font-size: clamp(20px, 6.8vw, 28px)
  }

  .ri-list li {
    font-size: 14px
  }

  .shc {
    margin-bottom: 42px
  }

  .foot-main {
    flex-direction: column;
    gap: 32px
  }

  .foot-main>div {
    width: 100%
  }

  .foot-bt {
    max-width: 100%
  }

  .prof-tabs {
    gap: 6px;
    justify-content: center;
    flex-wrap: wrap;
    overflow: visible;
    margin: 0 0 36px;
    padding: 0
  }

  .ptab {
    white-space: normal;
    flex: 0 1 auto
  }

  .pc,
  .sc,
  .step,
  .cc {
    padding: 24px 20px
  }

  .ptable {
    border-radius: 16px
  }

  .pthead {
    display: none
  }

  .prow {
    grid-template-columns: 1fr;
    gap: 10px;
    padding: 18px
  }

  .pr-cap,
  .pr-lk,
  .pr-px {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    text-align: left !important
  }

  .pr-cap::before,
  .pr-lk::before,
  .pr-px::before {
    font-family: var(--fd);
    font-size: 10px;
    font-weight: 700;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: var(--mg)
  }

  .pr-cap::before {
    content: 'Capital Segurado'
  }

  .pop-b {
    left: auto;
    right: 0;
  }

  .pr-lk::before {
    content: 'Nº da Sorte'
  }

  .pr-px::before {
    content: 'Pagamento único anual'
  }

  .ptcta {
    padding: 18px
  }

  .ptcta .btn {
    width: auto;
    max-width: 100%
  }

  .steps {
    margin-top: 40px
  }

  .step-bg {
    font-size: 84px
  }

  .faq-box {
    padding: 24px
  }

  .fq {
    padding: 20px 18px
  }

  .fa-in {
    padding: 16px 18px 20px
  }

  .fcat {
    padding: 10px 18px
  }

  .trust::after {
    font-size: 120px;
    right: -20px;
    bottom: -14px
  }

  .brand-wordmark-nav {
    width: 152px
  }

  .brand-wordmark-foot {
    width: 180px
  }

  .fcta-h {
    margin-bottom: 20px
  }

  .fcta-sub {
    font-size: 15px;
    line-height: 1.6;
    margin-bottom: 28px
  }

  .fcta-disc {
    max-width: 100%
  }
}

@media(max-width:560px) {
  .con {
    padding: 0 16px
  }

  .nav-i {
    gap: 10px
  }

  .nav .btn {
    width: 48%;
    justify-content: center;
    padding: 9px 12px;
    font-size: 12px !important
  }

  .btn {
    font-size: 14px
  }

  .brand-wordmark-nav {
    width: 128px
  }

  .npill-logo {
    height: 20px
  }

  .hero-in {
    min-height: 840px;
    padding: 0 16px
  }

  .hero-copy {
    padding: 32px 0 42px
  }

  .hero-h1 {
    font-size: clamp(30px, 11vw, 38px)
  }

  .hero-sub {
    max-width: 100%;
    font-size: 15px
  }

  .hero-trust {
    max-width: 100%;
    gap: 10px
  }

  .hero-acts .btn,
  .fcta-acts .btn {
    min-width: 0
  }

  .hero-acts .btn {
    width: auto;
    padding: 14px 18px;
    font-size: 14px
  }

  .fcta-acts .btn {
    width: auto;
    padding: 16px 22px;
    font-size: 15px
  }

  .ri-stats {
    flex-direction: column;
    align-items: flex-start;
    gap: 18px
  }

  .ri-sn {
    font-size: 36px
  }

  .ptab {
    padding: 9px 16px;
    font-size: 12px
  }

  .fq {
    padding: 18px 16px
  }

  .fq-t {
    font-size: 15px
  }

  .fa-in {
    padding: 14px 16px 18px
  }

  .ts {
    padding: 24px
  }

  .stitle,
  .ri-title,
  .fcta-h {
    font-size: var(--section-title-size-sm)
  }

  .fcta-sub {
    font-size: 14px
  }

  .fcta-acts .btn {
    width: auto;
    padding: 14px 18px;
    font-size: 14px
  }
}

@media(prefers-reduced-motion:reduce) {

  .reveal,
  .fu {
    opacity: 1 !important;
    transform: none !important;
    animation: none !important;
    transition: none !important
  }

  .ticker-t {
    animation: none !important
  }
}