.landing {
  --lp-pad-x: 20px;
  --lp-pad-y: 40px;
  --lp-red: #d93023;
  --lp-blue: #1e39c0;
  --lp-lavender: #e2e5ff;
  --lp-cyan: #00cbf5;
  --lp-alt-font: "Zalando Sans Expanded", sans-serif;
  --lp-shadow: 3px 3px 0 black;

  color: black;
  font-family: "Geologica", sans-serif;
  font-weight: 300;
  line-height: 1.25;
  overflow: hidden;
}
.landing :where(h1, h2, h3, ul, li, p) {
  margin: 0;
}
.landing img {
  display: block;
  margin: 0 auto;
}
.landing *:focus-visible {
  outline: 2px solid;
}
.landing .wrapper {
  padding: var(--lp-pad-y) var(--lp-pad-x);
}
.landing .info-cta {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  gap: 0.75em;
  margin-top: 1.5em;
}
.landing .btn {
  align-items: center;
  box-shadow: var(--lp-shadow);
  color: white;
  display: flex;
  font: 900 1.125em/1 var(--lp-alt-font);
  gap: 0.5em;
  outline-color: black;
  padding: 0.6667em 1.3333em;
  text-decoration: none;
  text-transform: uppercase;
  transition: 0.1s;
  width: fit-content;
}
.landing .btn::after {
  background: url(https://mktgen.com.br/imagens/vade-mecum-oab/27ed/arrow-btn.svg)
    center / contain no-repeat;
  content: "";
  display: block;
  flex: 0 0 0.6667em;
  height: 0.6em;
  width: 0.6667em;
}
.landing .btn.btn-red {
  background: var(--lp-red);
}
.landing .btn.btn-red:hover {
  background: var(--lp-blue);
}
.landing .btn.btn-blue {
  background: var(--lp-blue);
}
.landing .btn.btn-blue:hover {
  background: var(--lp-red);
}
.landing section:not(.intro) h2 {
  display: flex;
  flex-direction: column;
  font-size: 1.5em;
  font-weight: 300;
  line-height: 1.4;
  text-wrap: balance;
}
.landing section:not(.intro) h2 strong {
  color: var(--lp-red);
  font: 900 1.333em/1 var(--lp-alt-font);
}
.landing section:not(.intro):nth-child(odd) h2 strong {
  color: var(--lp-blue);
}

/* INTRO ---- */
.landing .intro {
  background: var(--lp-cyan)
    url(https://mktgen.com.br/imagens/vade-mecum-oab/27ed/nv/bg-intro-mb.jpg)
    center / cover no-repeat;
}
.landing .intro .wrapper {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  padding-top: 32px;
}
.landing .intro .hero {
  align-items: end;
  display: flex;
}
.landing .intro .selo {
  margin: 0 -60px 127px 0;
  z-index: 2;
}
.landing .intro .selo img {
  filter: drop-shadow(var(--lp-shadow));
}
.landing .intro .frete {
  background: var(--lp-blue);
  box-shadow: var(--lp-shadow);
  color: white;
  display: block;
  font: 900 min(3.5vw, 1.25em) / 1 var(--lp-alt-font);
  margin: -0.25em auto 0;
  padding: .3em .5em;
  position: relative;
  text-transform: uppercase;
  transform: rotate(1deg);
  width: 6.5ch;
  z-index: 2;
}
.landing .intro .heading {
  max-width: 31em;
}
.landing .intro h1 {
  font-size: 1.5em;
  font-weight: 300;
  line-height: 1;
  max-width: 18.75em;
  position: relative;
}
.landing .intro h1::before {
  background: white;
  box-shadow: var(--lp-shadow);
  content: "";
  height: 106%;
  margin-left: -3%;
  position: absolute;
  top: 8%;
  transform: rotate(1deg);
  width: 106%;
}
.landing .intro h1 span {
  display: flex;
  flex-direction: column;
  position: relative;
}
.landing .intro h1 strong {
  color: var(--lp-blue);
  font: 900 1.3333em/1 var(--lp-alt-font);
  position: relative;
}
.landing .intro h1 + p {
  background: var(--lp-red);
  box-shadow: var(--lp-shadow);
  color: var(--lp-lavender);
  font-size: 0.875em;
  line-height: 1;
  margin: 0.5em 0 0 auto;
  padding: 0.45em 1.15em;
  transform: rotate(-1deg);
  width: fit-content;
  z-index: 2;
}
.landing .intro h1 + p strong {
  color: white;
  font: 900 1.285em var(--lp-alt-font);
}
.landing .intro h2 {
  font-size: 1.25em;
  font-weight: 700;
  line-height: 1.1;
  margin: 0.8em 0 0.6em;
  max-width: 23em;
}
.landing .intro h2 + p {
  max-width: 28em;
}
.landing .intro ul {
  display: grid;
  gap: .25em;
  list-style: url(https://mktgen.com.br/imagens/vade-mecum-oab/27ed/i-check.svg);
  padding-left: 1.5em;
}
.landing .intro .preco-antigo + strong {
  font-size: 1.25em;
}
.landing .intro .info-cta {
  margin-top: 2.5em;
}
.landing .intro .preco-produto {
  position: relative;
}
.landing .intro .preco {
  color: var(--lp-blue);
  font: 900 1.5em var(--lp-alt-font);
}
.landing .intro .desconto {
  background: var(--lp-blue);
  box-shadow: var(--lp-shadow);
  color: white;
  display: none;
  font: 900 1.25em var(--lp-alt-font);
  padding: .2em .5em;
  position: absolute;
  left: 50%;
  top: -1em;
  transform: rotate(1deg);
  white-space: nowrap;
}
.landing .intro .btn {
  margin-left: auto;
  margin-right: auto;
}

/* DESTAQUES ---- */
.landing .destaques h2 {
  text-align: center;
}
.landing .destaques ul {
  display: flex;
  flex-wrap: wrap;
  gap: 32px;
  justify-content: center;
  list-style: none;
  margin: 1.5em 0;
  padding: 0;
  text-align: center;
}
.landing .destaques ul li {
  flex: 0 0 13.75em;
}
.landing .destaques ul img {
  aspect-ratio: 1;
  background: var(--lp-lavender);
  box-shadow: var(--lp-shadow);
  padding: 10px;
  transform: rotate(2deg);
}
.landing .destaques h3 {
  font-size: 1.25em;
  font-weight: 700;
  line-height: 1;
  margin: 0.8em 0 0.2em;
  text-wrap: balance;
}
.landing .destaques .btn {
  margin: 0 auto;
  max-width: 70%;
}

/* DIFERENCIAIS ---- */
.landing .diferenciais {
  background: var(--lp-cyan)
    url(https://mktgen.com.br/imagens/vade-mecum-oab/27ed/nv/bg-diferenciais-mb.jpg)
    top center / cover no-repeat;
}
.landing .diferenciais .wrapper {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  padding-top: calc(var(--lp-pad-y) / 2);
}
.landing .diferenciais .hero {
  transform: rotate(2deg);
}
.landing .diferenciais .txt {
  flex: 0 1 31.5em;
}
.landing .diferenciais h2 {
  margin-bottom: 0.3333em;
}
.landing .diferenciais details + details {
  border-top: 1px solid var(--lp-lavender);
}
.landing .diferenciais details summary {
  align-items: center;
  cursor: pointer;
  display: flex;
  font-size: 1.125em;
  justify-content: space-between;
  padding: 1.3333em 0;
}
.landing .diferenciais details summary:hover {
  color: var(--lp-blue);
}
.landing .diferenciais details[open] summary {
  padding-bottom: 0.5em;
}
.landing .diferenciais details summary::after {
  background: var(--lp-red)
    url(https://mktgen.com.br/imagens/vade-mecum-oab/27ed/i-more.svg) center
    no-repeat;
  box-shadow: var(--lp-shadow);
  content: "";
  display: block;
  flex: 0 0 20px;
  height: 20px;
  transform: rotate(2deg);
  transition: 0.1s;
  width: 20px;
}
.landing .diferenciais details:not([open]) summary:hover::after {
  background-color: var(--lp-blue);
}
.landing .diferenciais details[open] summary::after {
  background-color: white;
  background-image: url(https://mktgen.com.br/imagens/vade-mecum-oab/27ed/i-less.svg);
}
.landing .diferenciais details ul {
  display: flex;
  flex-direction: column;
  gap: 0.75em;
  padding: 0 1.25em 1.5em;
}
.landing .diferenciais details ul li::marker {
  color: var(--lp-blue);
}
.landing .diferenciais .btn {
  margin-top: 16px;
}

/* PRODUTOS ---- */
.landing .produtos {
  padding: var(--lp-pad-y) 0;
}
.landing .produtos h2 {
  margin-bottom: 1.3333em;
  padding: 0 var(--lp-pad-x);
  text-align: center;
}
.landing .produtos .product-item-info {
  background: var(--lp-lavender) !important;
  border: 0 !important;
  box-shadow: var(--lp-shadow);
}
.landing .produtos .tocart {
  border-color: var(--lp-blue);
  background: var(--lp-blue);
  font-family: inherit;
}
.landing .produtos .tocart:hover {
  border-color: var(--lp-red);
  background: var(--lp-red);
}

/* BANNER ---- */
.landing .banner {
  background: url(https://mktgen.com.br/imagens/vade-mecum-oab/27ed/bg-banner-mb.jpg)
    bottom center / contain no-repeat;
}
.landing .banner .wrapper {
  align-items: start;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  padding-top: 0;
}
.landing .banner .hero {
  pointer-events: none;
  position: relative;
  z-index: 2;
}
.landing .banner .txt {
  margin-top: -24px;
  position: relative;
}
.landing .banner .txt::before {
  background: var(--lp-lavender);
  box-shadow: var(--lp-shadow);
  content: "";
  position: absolute;
  height: 120%;
  margin: -48px 0 0 -4%;
  transform: rotate(-1deg);
  width: 108%;
}
.landing .banner .txt > div {
  padding: 8px;
  position: relative;
}
.landing .banner h2 {
  max-width: 14.5em;
}
.landing .banner h3 {
  font-size: 1.25em;
  font-weight: 700;
  line-height: 1.1;
  margin: 0.8em 0 0.4em;
  max-width: 22em;
}
.landing .banner .preco-produto {
  line-height: 1.1;
}
.landing .banner .preco-antigo {
  display: none;
}
.landing .banner .preco-antigo[style] + strong::before {
  content: "|";
  font-weight: 400;
  margin: 0 0.25em;
  opacity: 0.75;
}
.landing .banner .preco-parcelado {
  font-size: 1.25em;
}
.landing .banner .parcela {
  color: var(--lp-red);
  font: 900 1.5em var(--lp-alt-font);
}

/* > 480px ---- */
@media (min-width: 30rem) {
  .landing {
    --lp-wrapper: 30em;
  }
  .landing .wrapper {
    margin: 0 auto;
    max-width: var(--lp-wrapper);
  }
  .landing .banner {
    background-position: 50% 88px;
    background-size: 100% auto;
  }
}

/* > 768px ---- */
@media (min-width: 48rem) {
  .landing {
    --lp-pad-y: 48px;
    --lp-wrapper: 46em;
    font-size: 1.14285em;
  }
  .landing .intro .info-cta {
    gap: 2.5em;
  }
  .landing .banner .info-cta {
    gap: 1.875em;
  }
  .landing .intro .selo {
    margin-right: -80px;
  }
  .landing .intro h1 + p {
    display: flex;
    flex-direction: column;
    margin-top: -1.9em;
  }
  .landing .banner .txt {
    margin-top: -48px;
  }
  .landing .banner .txt::before {
    margin: -40px 0 0 -6%;
    width: 112%;
  }
}

/* > 992px ---- */
@media (min-width: 62rem) {
  .landing {
    --lp-pad-y: 60px;
    --lp-wrapper: 60em;
  }
}

/* > 1200px ---- */
@media (min-width: 75rem) {
  .landing {
    --lp-pad-y: 72px;
    --lp-wrapper: 71em;
  }
  .landing .intro {
    --lp-pad-y: 0;
    background-image: url(https://mktgen.com.br/imagens/vade-mecum-oab/27ed/nv/bg-intro.jpg);
  }
  .landing .intro .livro {
    margin-bottom: -80px;
  }
  .landing .intro .txt {
    padding: 20px 0 52px;
  }
  .landing .destaques {
    --lp-wrapper: 60em;
  }
  .landing .diferenciais {
    background-image: url(https://mktgen.com.br/imagens/vade-mecum-oab/27ed/nv/bg-diferenciais.jpg);
  }
  .landing .diferenciais .wrapper {
    flex-direction: row-reverse;
    padding-top: var(--lp-pad-y);
    transform: translateX(55px);
  }
  .landing .produtos {
    margin: 0 auto;
    max-width: var(--lp-wrapper);
  }
  .landing .banner {
    background-image: url(https://mktgen.com.br/imagens/vade-mecum-oab/27ed/bg-banner.jpg);
    background-size: auto 100%;
  }
  .landing .banner .wrapper {
    padding-bottom: 20px;
    transform: translateX(-55px);
  }
  .landing .banner .txt {
    margin: var(--lp-pad-y) 0 0 -40px;
  }
  .landing .banner .txt::before {
    margin: -5% 0 0 -10%;
    width: 120%;
  }
}

/* > 1360px ---- */
@media (min-width: 85rem) {
  .landing,
  .landing .destaques {
    --lp-pad-y: 80px;
    --lp-wrapper: 80em;
  }
  .landing .banner {
    background-position: 50% calc(100% + 1px);
    background-size: 100% auto;
  }
}

/* ANIMAÇÕES ---- */
@media (prefers-reduced-motion: no-preference) {
  .js .landing .anime {
    opacity: 0;
    transition: 0.5s;
  }
  .js .landing .hero.anime {
    transform: translateY(80px);
  }
  .js .landing .anime.show {
    opacity: 1;
    transform: initial !important;
  }
  .landing .diferenciais details summary {
    transition: 0.1s;
  }
}
