@font-face {
  font-family: "FontAwesome";
  src: url("../fonts/font-awesome/fontawesome-webfont.eot");
  src: url("../fonts/font-awesome/fontawesome-webfont.eot?#iefix") format("embedded-opentype"), url("../fonts/font-awesome/fontawesome-webfont.woff2") format("woff2"), url("../fonts/font-awesome/fontawesome-webfont.woff") format("woff");
  font-weight: 400;
  font-style: italic;
  font-stretch: normal;
}
@font-face {
  font-family: "Roboto";
  src: url("../fonts/Roboto/Roboto-Bold-webfont.woff") format("woff");
  font-weight: bold;
  font-style: normal;
}
@font-face {
  font-family: "Roboto";
  src: url("../fonts/Roboto/Roboto-Regular-webfont.woff") format("woff");
  font-weight: normal;
  font-style: normal;
}
@font-face {
  font-family: "Roboto";
  src: url("../fonts/Roboto/Roboto-Light-webfont.woff") format("woff");
  font-weight: 100;
  font-style: normal;
}
@font-face {
  font-family: "Exo";
  src: url("/assets/fonts/exo/Exo-Regular.woff2") format("woff2"), url("/assets/fonts/exo/Exo-Regular.woff") format("woff");
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Exo";
  src: url("/assets/fonts/exo/Exo-Light.woff2") format("woff2"), url("/assets/fonts/exo/Exo-Light.woff") format("woff");
  font-weight: 300;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Exo";
  src: url("/assets/fonts/exo/Exo-Bold.woff2") format("woff2"), url("/assets/fonts/exo/Exo-Bold.woff") format("woff");
  font-weight: bold;
  font-style: normal;
  font-display: swap;
}
.top span, .header.fixed-header .languages, .header .menu > span {
  position: absolute;
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  border: 0;
}

* {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  vertical-align: baseline;
  background: transparent;
  box-sizing: border-box;
}

th,
td,
caption {
  font-weight: normal;
}

li {
  list-style: none;
  position: relative;
}

a img {
  border: 0;
}

th,
td {
  vertical-align: top;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

address {
  font-style: normal;
}

article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section,
pre {
  display: block;
}

blockquote,
q {
  quotes: none;
}

ins {
  background-color: #ccc;
  color: #160f2c;
  text-decoration: none;
}

del {
  text-decoration: line-through;
}

abbr[title],
dfn[title] {
  border-bottom: 1px dotted;
  cursor: help;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

hr {
  display: block;
  height: 1px;
  border: 0;
  border-top: 1px solid #ccc;
  margin: 1em 0;
  padding: 0;
}

input,
select {
  vertical-align: middle;
}

a {
  text-decoration: none;
}

img {
  max-width: 100%;
}

.container {
  position: relative;
  width: 100%;
}

.content {
  margin: 0 max(1.125rem, 1.25vw);
  padding: 1em 0;
}

.header {
  background: #160f2c;
  color: #fff;
  padding: 5px 0.5em;
  z-index: 10;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 1000;
  overflow: hidden;
  -webkit-transition: 0.5s ease-in-out all;
  -moz-transition: 0.5s ease-in-out all;
  transition: 0.5s ease-in-out all;
  text-align: center;
}
@media screen and (min-width: 960px) {
  .header {
    display: flex;
  }
}
.header .content {
  width: 100%;
  padding: 0;
  margin: 0;
  display: flex;
  gap: 1em;
  align-items: center;
  justify-content: space-between;
}
.header .logo {
  flex: 1;
  display: inline-block;
  text-align: left;
  padding-left: max(2vw, 1em);
}
.header .logo a {
  display: flex;
}
.header .logo img {
  width: 190px;
}
@media screen and (min-width: 960px) {
  .header .logo img {
    width: 270px;
  }
}
.header .languages {
  text-align: right;
  white-space: nowrap;
  margin-bottom: 0.5em;
}
.header .languages li {
  display: inline-block;
  text-transform: uppercase;
  font-size: max(0.8rem, 0.8vw);
}
.header .languages li + li::before {
  content: "|";
  margin-right: 5px;
  color: #F394D3;
}
.header .languages li a {
  color: #4DE3F4;
}
@media screen and (min-width: 960px) {
  .header .languages li a span {
    position: absolute;
    width: 1px;
    height: 1px;
    margin: -1px;
    padding: 0;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    border: 0;
  }
  .header .languages li a.es::before {
    content: "ES";
  }
  .header .languages li a.en::before {
    content: "EN";
  }
}
.header .languages li a.activate {
  font-weight: bold;
  color: #F129AD;
}
.header .languages li a:link, .header .languages li a:visited, .header .languages li a:hover, .header .languages li a:active {
  text-decoration: none;
}
.header .navigations {
  text-align: left;
}
@media screen and (max-width: 960px) {
  .header .navigations {
    visibility: hidden;
    width: 0;
    top: 48px;
    position: fixed;
  }
  .header .navigations.toggle {
    background-color: #160f2c;
    visibility: visible;
    height: calc(100vh - 50px);
    bottom: 0;
    width: 210px;
    top: 48px;
    padding: 0.5em 1em;
    right: 0;
    display: flex;
    z-index: 8;
    flex-direction: column-reverse;
    justify-content: flex-end;
    -webkit-transition: 0.5s ease-in-out all;
    -moz-transition: 0.5s ease-in-out all;
    transition: 0.5s ease-in-out all;
  }
}
.header nav.main-menu {
  padding: 0.5rem;
}
.header nav.main-menu li {
  font-size: max(0.8rem, 1.25vw);
  display: block;
  white-space: nowrap;
}
@media screen and (min-width: 960px) {
  .header nav.main-menu li {
    display: inline-block;
  }
}
.header nav.main-menu li + li {
  margin: 0 0 0 1em;
}
@media screen and (max-width: 960px) {
  .header nav.main-menu li + li {
    margin: 1em 0 0 0;
  }
  .header nav.main-menu li + li:last-child {
    padding-top: 1em;
  }
}
.header nav.main-menu a:link, .header nav.main-menu a:visited, .header nav.main-menu a:hover, .header nav.main-menu a:active {
  text-transform: uppercase;
  text-decoration: none;
  color: #4DE3F4;
}
@media screen and (min-width: 960px) {
  .header nav.main-menu a:link, .header nav.main-menu a:visited, .header nav.main-menu a:hover, .header nav.main-menu a:active {
    padding-bottom: 8px;
  }
}
.header nav.main-menu a:link.l1 strong, .header nav.main-menu a:visited.l1 strong, .header nav.main-menu a:hover.l1 strong, .header nav.main-menu a:active.l1 strong {
  background-color: #F129AD;
  color: #fff;
  border-radius: 25px;
  border-color: #F129AD;
}
.header nav.main-menu a:link.active, .header nav.main-menu a:visited.active, .header nav.main-menu a:hover.active, .header nav.main-menu a:active.active {
  color: #F129AD;
  border-bottom: 2px solid #F129AD;
}
.header nav.main-menu a:link.active.l1, .header nav.main-menu a:visited.active.l1, .header nav.main-menu a:hover.active.l1, .header nav.main-menu a:active.active.l1 {
  border-bottom: 0;
}
.header nav.main-menu a:link.active.l1 strong, .header nav.main-menu a:visited.active.l1 strong, .header nav.main-menu a:hover.active.l1 strong, .header nav.main-menu a:active.active.l1 strong {
  color: #fff;
  background-color: #F129AD;
  border-color: #F129AD;
}
.header nav.main-menu a:link:hover, .header nav.main-menu a:visited:hover, .header nav.main-menu a:hover:hover, .header nav.main-menu a:active:hover {
  border-bottom: 2px solid #F129AD;
}
.header nav.main-menu a:link:hover.l1, .header nav.main-menu a:visited:hover.l1, .header nav.main-menu a:hover:hover.l1, .header nav.main-menu a:active:hover.l1 {
  border-bottom: 0;
}
@media screen and (min-width: 960px) {
  .header.fixed-header .logo img {
    width: 200px;
    -webkit-transition: 0.5s ease-in-out all;
    -moz-transition: 0.5s ease-in-out all;
    transition: 0.5s ease-in-out all;
  }
}

.hamburger {
  width: 34px;
  height: 28px;
  position: relative;
  margin: 5px;
  -webkit-transform: rotate(0deg);
  -moz-transform: rotate(0deg);
  -o-transform: rotate(0deg);
  transform: rotate(0deg);
  -webkit-transition: 0.5s ease-in-out;
  -moz-transition: 0.5s ease-in-out;
  -o-transition: 0.5s ease-in-out;
  transition: 0.5s ease-in-out;
  cursor: pointer;
}
@media screen and (min-width: 960px) {
  .hamburger {
    display: none;
  }
}
.hamburger span {
  display: block;
  position: absolute;
  height: 3px;
  width: 100%;
  background: #fff;
  border-radius: 3px;
  opacity: 1;
  left: 0;
  -webkit-transform: rotate(0deg);
  -moz-transform: rotate(0deg);
  -o-transform: rotate(0deg);
  transform: rotate(0deg);
  -webkit-transition: 0.25s ease-in-out;
  -moz-transition: 0.25s ease-in-out;
  -o-transition: 0.25s ease-in-out;
  transition: 0.25s ease-in-out;
}
.hamburger span.child1 {
  top: 0px;
}
.menu.toggle .hamburger span.child1 {
  top: 10px;
  width: 0%;
  left: 50%;
}
.hamburger span.child2, .hamburger span.child3 {
  top: 11px;
}
.menu.toggle .hamburger span.child2 {
  -webkit-transform: rotate(45deg);
  -moz-transform: rotate(45deg);
  -o-transform: rotate(45deg);
  transform: rotate(45deg);
}
.menu.toggle .hamburger span.child3 {
  -webkit-transform: rotate(-45deg);
  -moz-transform: rotate(-45deg);
  -o-transform: rotate(-45deg);
  transform: rotate(-45deg);
}
.hamburger span.child4 {
  top: 22px;
}
.menu.toggle .hamburger span.child4 {
  top: 10px;
  width: 0%;
  left: 50%;
}

.footer {
  text-align: center;
  color: #fff;
  background: #80165C;
}
.footer .content {
  display: flex;
  justify-content: space-between;
}
.footer .content div {
  display: flex;
  align-items: center;
  gap: 1em;
}
.footer .content img {
  height: 1.1em;
  vertical-align: middle;
}
.footer .content nav li {
  margin-left: 1em;
  display: inline-block;
}
.footer .content nav li a {
  color: #fff;
}
@media screen and (min-width: 640px) {
  .footer {
    text-align: left;
  }
  .footer .content nav {
    float: right;
  }
}

main {
  background-color: #fff;
  position: relative;
}
main > * {
  padding: max(7vw, 1em) 0;
}

.Page main {
  padding: 2em 0;
  background-color: #F3E4EE;
}
.Page main .content {
  max-width: 90vw;
  margin: 1em auto;
  padding: 15vw 0 0 0;
}
@media screen and (min-width: 800px) {
  .Page main .content {
    padding: 8vw 0 0 0;
  }
}
.Page main .content .paper-content {
  margin-top: max(7vw, 1em);
  background-color: #fff;
  padding: 4vw;
  border-radius: 1vw;
}
.Page main .content .paper-content h2 {
  text-align: left;
}
.Page main .content .paper-content h2:not(:first-child) {
  padding-top: max(7vw, 1em);
  margin-top: 4vw;
}
.Page main .content .ol-topics {
  padding-left: 1em;
  margin-bottom: 2em;
}

html {
  font-size: max(1.125rem, 1.25vw);
}

body {
  font-family: "Roboto", sans-serif;
  color: #5B3E67;
  background-color: #160f2c;
  line-height: 1.45;
}

h1, h2, h3, h4 {
  font-family: "Exo", sans-serif;
  font-weight: bold;
  letter-spacing: -0.2px;
}

h2 {
  font-size: max(2.5rem, 4vw);
  text-align: center;
}

.t-l2 {
  margin-bottom: 1em;
}
@media screen and (min-width: 640px) {
  .t-l2 {
    margin-bottom: 2em;
  }
}

.t-l3 {
  margin-bottom: 0.5em;
}
@media screen and (min-width: 640px) {
  .t-l3 {
    margin-bottom: 1em;
  }
}

p {
  margin-bottom: 1em;
}

a:link, a:visited, a:hover, a:active {
  color: #F129AD;
}

.facebook {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
.facebook::before {
  font-family: "FontAwesome", Arial, Helvetica, sans-serif;
  content: "\f09a";
  margin-right: 5px;
  display: inline-block;
}

.twitter {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
.twitter::before {
  font-family: "FontAwesome", Arial, Helvetica, sans-serif;
  content: "\f099";
  margin-right: 5px;
  display: inline-block;
}

.linkedin {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
.linkedin::before {
  font-family: "FontAwesome", Arial, Helvetica, sans-serif;
  content: "\f08c";
  margin-right: 5px;
  display: inline-block;
}

.gitlab {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
.gitlab::before {
  font-family: "FontAwesome", Arial, Helvetica, sans-serif;
  content: "\f296";
  margin-right: 5px;
  display: inline-block;
}

input.input, textarea {
  display: block;
  font-size: 1.5rem;
  color: #5B3E67;
  width: 100%;
  background: #fff;
  padding: 0.5em;
  border-radius: 5px;
  border: 1px solid #F3E4EE;
  margin-bottom: 1em;
}

::-webkit-input-placeholder {
  color: #775187;
}

:-moz-placeholder {
  color: #775187;
} /* FF 18 */
::-moz-placeholder {
  color: #775187;
} /* FF 19+ */
:-ms-input-placeholder {
  color: #775187;
}

.top {
  position: absolute;
  bottom: -1em;
  right: 1em;
}
.top::before {
  content: url("../img/up.svg");
  display: block;
  width: 24px;
}
a strong {
  text-transform: none;
  border: 1px solid;
  padding: 8px 1em;
  font-weight: normal;
  white-space: nowrap;
}

.submit:hover {
  box-shadow: inset 0 -3.25em 0 0 #fff;
  color: #160f2c;
  -webkit-transition: 0.4s ease-in-out all;
  -moz-transition: 0.4s ease-in all;
  transition: 0.4s ease-in all;
  cursor: pointer;
}

body.openLB {
  overflow: hidden;
}
body h3 + p {
  margin-left: auto;
  margin-right: auto;
}
@media screen and (min-width: 800px) {
  body h3 + p {
    max-width: 70vw;
  }
}
body section {
  content-visibility: auto;
}

.welcome {
  padding: 15vw 0 0 0;
  background: linear-gradient(180deg, rgb(77, 227, 244) 0%, rgb(181, 31, 130) 100%);
}
@media screen and (min-width: 800px) {
  .welcome {
    padding: 8vw 0 0 0;
  }
}
.welcome .content {
  position: relative;
  color: #fff;
  display: grid;
  gap: 1em;
  margin: 0;
  align-items: center;
  justify-content: space-around;
}
@media screen and (min-width: 800px) {
  .welcome .content {
    grid-template-columns: 2fr 1fr;
    min-height: 55svh;
  }
}
.welcome .content h2 {
  font-size: 6vh;
  text-shadow: 0 0 7px #651655;
  line-height: 1;
}
@media screen and (min-width: 800px) {
  .welcome .content h2 {
    font-size: 5vw;
  }
}
.welcome .content h2 span {
  display: block;
  white-space: nowrap;
}
.welcome .content h2 span.ooo-title-big {
  font-size: 1.5em;
}
.welcome .content h2 span.ooo-title-small {
  font-size: 0.65em;
}
.welcome .content h2, .welcome .content h3, .welcome .content p {
  text-align: center;
  max-width: 670px;
}
.welcome .content h3 {
  font-weight: 100;
  margin-bottom: 1em;
}
.welcome .content .welcome-img {
  background-image: url(/assets/img/contestia-infografia-800.webp);
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;
  width: 90vw;
  aspect-ratio: 16/9;
}
@media screen and (min-width: 800px) {
  .welcome .content .welcome-img {
    background-image: url(/assets/img/contestia-infografia.webp);
    width: 100%;
  }
}

.beneficios {
  background: rgb(22, 15, 44);
  background: linear-gradient(0deg, rgb(22, 15, 44) 40%, rgb(181, 31, 130) 100%);
  color: #fff;
  text-align: center;
}
.beneficios h2 {
  color: #4DE3F4;
  text-shadow: 0 0 7px #F129AD;
}
.beneficios .beneficiosList {
  display: grid;
  width: 100%;
  gap: 1em;
  margin: 2em 0;
  text-align: left;
}
@media screen and (min-width: 768px) {
  .beneficios .beneficiosList {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media screen and (min-width: 1024px) {
  .beneficios .beneficiosList {
    grid-template-columns: repeat(4, 1fr);
  }
}
.beneficios .beneficiosList > div {
  border: 3px solid #437093;
  background-color: #160F2C;
  border-radius: 25px;
  padding: 2em 1em 1em;
  flex-basis: 100%;
  box-shadow: 0px 0px 16px 1px rgba(0, 0, 0, 0.05);
}
.beneficios .beneficiosList > div.visible {
  transform: rotate(-2deg);
}
.beneficios .beneficiosList > div.oculto {
  transform: rotate(0deg) translateY(100px);
}
.beneficios .beneficiosList > div h3 {
  margin-bottom: 1em;
  text-align: center;
}
.beneficios .beneficiosList > div:nth-child(even) {
  transform: rotate(2deg);
}
.beneficios .beneficiosList > div:nth-child(even).oculto {
  transform: rotate(0deg) translateY(80px);
}
.beneficios .beneficiosList .img {
  text-align: center;
  margin-bottom: 1em;
  filter: drop-shadow(0 0 8px #1CF1FF);
}
.beneficios .beneficiosList .img > * {
  max-width: 65vw;
  fill: #9A2D6A;
}
@media screen and (min-width: 768px) {
  .beneficios .beneficiosList .img > * {
    max-width: 18vw;
  }
}

.use-contestia {
  padding: 1em;
}
.use-contestia div {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  align-items: center;
  gap: 0;
}
@media screen and (min-width: 800px) {
  .use-contestia div {
    max-width: 70vw;
    margin: 0 auto;
    gap: 3em;
  }
}
.use-contestia div img {
  aspect-ratio: 4/3;
  filter: grayscale(100) contrast(100);
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.como-funciona {
  --stack-cards-gap: 6vw;
  background-color: #FFEAF8;
  text-align: center;
  position: relative;
}
.como-funciona::before, .como-funciona::after {
  content: "";
  display: block;
  width: 4vw;
  height: 4vw;
  background-color: #fff;
  clip-path: polygon(0% 0%, 100% 100%, 0% 100%);
  position: absolute;
  bottom: 0;
  left: 0;
}
.como-funciona::after {
  left: auto;
  right: 0;
  clip-path: polygon(100% 0%, 100% 100%, 0% 100%);
}
.como-funciona h3 {
  font-size: max(2.5rem, 4vw);
  margin: 0.5em 0;
  text-transform: uppercase;
}
.como-funciona h4 {
  font-size: max(1.5rem, 3vw);
  margin-bottom: 0.5em;
  line-height: 1.2em;
}
.como-funciona ul {
  margin-top: 4vw;
}
.como-funciona > .section-content-01 {
  background: rgb(255, 179, 229);
  background: linear-gradient(0deg, rgb(255, 179, 229) 40%, rgb(255, 234, 248) 100%);
}
.como-funciona > .section-content-01 h3 {
  color: #F129AD;
}
.como-funciona > .section-content-01 .stack-cards__item:first-child {
  background-color: #5B3E67;
  color: #fff;
}
@media screen and (min-width: 800px) {
  .como-funciona > .section-content-01 .stack-cards__item:first-child .stack-card-content {
    grid-template-columns: 1fr 1fr;
  }
}
.como-funciona > .section-content-01 .stack-cards__item:first-child .stack-card-img {
  filter: drop-shadow(5px 5px 20px #160f2c);
  transform: rotate(4deg);
  grid-column-start: 1;
  grid-row-start: 1;
}
@media screen and (min-width: 800px) {
  .como-funciona > .section-content-01 .stack-cards__item:first-child .stack-card-img {
    grid-column-start: initial;
    grid-row-start: initial;
  }
}
.como-funciona > .section-content-01 .stack-cards__item:first-child .stack-card-img.oculto {
  transform: rotate(-4deg) translateY(2em);
}
.como-funciona > .section-content-01 .stack-cards__item:nth-child(2) {
  background-color: #F189CE;
  color: #fff;
}
@media screen and (min-width: 800px) {
  .como-funciona > .section-content-01 .stack-cards__item:nth-child(2) .stack-card-content {
    grid-template-columns: 1fr 1fr;
  }
}
.como-funciona > .section-content-01 .stack-cards__item:nth-child(2) .stack-card-img {
  grid-column-start: 1;
  grid-row-start: 1;
  filter: drop-shadow(5px 5px 20px #7b2c60);
  transform: rotate(-4deg);
}
.como-funciona > .section-content-01 .stack-cards__item:nth-child(2) .stack-card-img.oculto {
  transform: rotate(4deg) translateY(2em);
}
.como-funciona > .section-content-01 .stack-cards__item:nth-child(3) {
  background-color: #FFF;
}
@media screen and (min-width: 800px) {
  .como-funciona > .section-content-01 .stack-cards__item:nth-child(3) .stack-card-content {
    grid-template-columns: 1fr 1fr;
  }
}
.como-funciona > .section-content-01 .stack-cards__item:nth-child(3) .stack-card-img {
  filter: drop-shadow(5px 5px 20px #888);
  transform: rotate(4deg);
  grid-column-start: 1;
  grid-row-start: 1;
}
@media screen and (min-width: 800px) {
  .como-funciona > .section-content-01 .stack-cards__item:nth-child(3) .stack-card-img {
    grid-column-start: initial;
    grid-row-start: initial;
  }
}
.como-funciona > .section-content-01 .stack-cards__item:nth-child(3) .stack-card-img.oculto {
  transform: rotate(-4deg) translateY(2em);
}
.como-funciona > .section-content-02 {
  background: rgb(255, 180, 229);
  background: linear-gradient(180deg, rgb(255, 180, 229) 40%, rgb(75, 69, 123) 100%);
}
.como-funciona > .section-content-02 h3 {
  color: #80165C;
}
.como-funciona > .section-content-02 .stack-cards__item:first-child {
  background-color: #FFC2EA;
}
@media screen and (min-width: 800px) {
  .como-funciona > .section-content-02 .stack-cards__item:first-child .stack-card-content {
    grid-template-columns: 1fr 1fr;
  }
}
.como-funciona > .section-content-02 .stack-cards__item:first-child .stack-card-img {
  filter: drop-shadow(5px 5px 20px #888);
  transform: rotate(-4deg);
  grid-column-start: 1;
  grid-row-start: 1;
}
.como-funciona > .section-content-02 .stack-cards__item:first-child .stack-card-img.oculto {
  transform: rotate(4deg) translateY(2em);
}
.como-funciona > .section-content-02 .stack-cards__item:nth-child(2) {
  background-color: #FDE5FF;
}
@media screen and (min-width: 800px) {
  .como-funciona > .section-content-02 .stack-cards__item:nth-child(2) .stack-card-content {
    grid-template-columns: 1fr 1fr;
  }
}
.como-funciona > .section-content-02 .stack-cards__item:nth-child(2) .stack-card-img {
  filter: drop-shadow(5px 5px 20px #888);
  transform: rotate(4deg);
  grid-column-start: 1;
  grid-row-start: 1;
}
@media screen and (min-width: 800px) {
  .como-funciona > .section-content-02 .stack-cards__item:nth-child(2) .stack-card-img {
    grid-column-start: initial;
    grid-row-start: initial;
  }
}
.como-funciona > .section-content-02 .stack-cards__item:nth-child(2) .stack-card-img.oculto {
  transform: rotate(-4deg) translateY(2em);
}
.como-funciona > .section-content-02 .stack-cards__item:nth-child(3) {
  background-color: #F1E5FF;
}
@media screen and (min-width: 800px) {
  .como-funciona > .section-content-02 .stack-cards__item:nth-child(3) .stack-card-content {
    grid-template-columns: 1fr 1fr;
  }
}
.como-funciona > .section-content-02 .stack-cards__item:nth-child(3) .stack-card-img {
  filter: drop-shadow(5px 5px 20px #888);
  transform: rotate(-4deg);
  grid-column-start: 1;
  grid-row-start: 1;
}
.como-funciona > .section-content-02 .stack-cards__item:nth-child(3) .stack-card-img img {
  border-radius: 1em;
  border: 0.5em solid #fff;
}
.como-funciona > .section-content-02 .stack-cards__item:nth-child(3) .stack-card-img.oculto {
  transform: rotate(4deg) translateY(2em);
}
.como-funciona > .section-content-03 {
  background: rgb(75, 69, 123);
  background: linear-gradient(180deg, rgb(75, 69, 123) 40%, rgb(255, 233, 248) 100%);
  color: #fff;
}
.como-funciona > .section-content-03 .stack-cards__item:first-child {
  background-color: #FFA0A0;
}
@media screen and (min-width: 800px) {
  .como-funciona > .section-content-03 .stack-cards__item:first-child .stack-card-content {
    grid-template-columns: 1fr 1fr;
  }
}
.como-funciona > .section-content-03 .stack-cards__item:first-child .stack-card-img {
  filter: drop-shadow(5px 5px 20px #888);
  transform: rotate(4deg);
  grid-column-start: 1;
  grid-row-start: 1;
}
@media screen and (min-width: 800px) {
  .como-funciona > .section-content-03 .stack-cards__item:first-child .stack-card-img {
    grid-column-start: initial;
    grid-row-start: initial;
  }
}
.como-funciona > .section-content-03 .stack-cards__item:first-child .stack-card-img.oculto {
  transform: rotate(-4deg) translateY(2em);
}
.como-funciona > .section-content-03 .stack-cards__item:nth-child(2) {
  background-color: #FFC9AB;
}
@media screen and (min-width: 800px) {
  .como-funciona > .section-content-03 .stack-cards__item:nth-child(2) .stack-card-content {
    grid-template-columns: 1fr 1fr;
  }
}
.como-funciona > .section-content-03 .stack-cards__item:nth-child(2) .stack-card-img {
  filter: drop-shadow(5px 5px 20px #888);
  transform: rotate(-4deg);
  grid-column-start: 1;
  grid-row-start: 1;
}
.como-funciona > .section-content-03 .stack-cards__item:nth-child(2) .stack-card-img.oculto {
  transform: rotate(4deg) translateY(2em);
}
.como-funciona > .section-content-03 .stack-cards__item:nth-child(3) {
  background-color: #E5F2FF;
  color: #5B3E67;
}
@media screen and (min-width: 800px) {
  .como-funciona > .section-content-03 .stack-cards__item:nth-child(3) .stack-card-content {
    grid-template-columns: 1fr 1fr;
  }
}
.como-funciona > .section-content-03 .stack-cards__item:nth-child(3) .stack-card-img {
  filter: drop-shadow(5px 5px 20px #888);
  transform: rotate(4deg);
  grid-column-start: 1;
  grid-row-start: 1;
}
@media screen and (min-width: 800px) {
  .como-funciona > .section-content-03 .stack-cards__item:nth-child(3) .stack-card-img {
    grid-column-start: initial;
    grid-row-start: initial;
  }
}
.como-funciona > .section-content-03 .stack-cards__item:nth-child(3) .stack-card-img.oculto {
  transform: rotate(-4deg) translateY(2em);
}
.como-funciona .stack-cards__item {
  min-height: 50vh;
  transform-origin: center;
  color: #5B3E67;
  border-radius: 20px;
  border-radius: 20px;
  box-shadow: 0px -10px 10px 0px rgba(45, 0, 22, 0.2);
  border: 1px solid #160F2C;
  padding: 2vw max(5vw, 20px);
  margin-bottom: 0.5em;
  margin-left: auto;
  margin-right: auto;
}
@media screen and (min-width: 800px) {
  .como-funciona .stack-cards__item {
    top: 8svw;
  }
}
@media screen and (min-width: 800px) {
  .como-funciona .stack-cards__item {
    max-width: 90vw;
  }
}
@media screen and (min-width: 768px) {
  .como-funciona .stack-cards__item {
    max-width: 80vw;
    position: sticky;
    top: 10svw;
    margin-bottom: 0;
  }
}
@media screen and (min-width: 1024px) {
  .como-funciona .stack-cards__item {
    max-width: 70vw;
  }
}
.como-funciona .stack-cards__item .stack-card-content {
  display: grid;
  gap: max(3vw, 30px);
  text-align: left;
}

.integration .content {
  display: grid;
}
.integration h2 {
  margin-bottom: 4vw;
}
.integration img {
  margin: auto;
}
.integration ul {
  justify-content: center;
  display: flex;
  flex-wrap: wrap;
}
@media screen and (min-width: 768px) {
  .integration ul {
    font-size: 2rem;
  }
}
.integration ul li {
  display: flex;
  align-items: center;
}
.integration ul li img {
  height: 1.3em;
  margin-right: 0.3em;
}
.integration ul li:not(:last-child)::after {
  content: ", ";
  display: inline;
  padding-right: 0.5em;
}

.testimonials {
  background-color: #5B3E67;
  color: #fff;
  position: relative;
}
.testimonials::before, .testimonials::after {
  content: "";
  display: block;
  width: 20vw;
  height: 8vw;
  background-color: #fff;
  clip-path: polygon(0% 0%, 100% 0%, 20% 50%, 0% 100%);
  position: absolute;
  top: 0;
  left: 0;
}
.testimonials::after {
  left: auto;
  right: 0;
  clip-path: polygon(0 0, 100% 0%, 100% 100%, 80% 50%);
}
.testimonials .card-container {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: 1em;
}
@media screen and (min-width: 1024px) {
  .testimonials .card-container {
    grid-template-columns: repeat(3, 1fr);
  }
}
.testimonials .card {
  width: 100%;
  aspect-ratio: 1/1;
  min-height: 400px;
  perspective: 1000px;
  position: relative;
}
.testimonials .card .card-inner {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  transform-style: preserve-3d;
  transition: transform 0.6s ease-in-out;
  transform-origin: center;
}
.testimonials .card:hover .card-inner {
  transform: rotateY(180deg);
}
.testimonials .card .card-front, .testimonials .card .card-back {
  position: absolute;
  width: 100%;
  height: 100%;
  backface-visibility: hidden;
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 20px;
}
.testimonials .card .card-front {
  background-color: #fff;
}
.testimonials .card .card-front img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 20px;
}
.testimonials .card .card-back {
  background-color: #160F2C;
  color: #fff;
  transform: rotateY(180deg);
  padding: 1em 2em;
  font-size: clamp(14px, 1.2vw, 50px);
  font-weight: 100;
}
.testimonials .card .card-back .more-info {
  color: #F129AD;
  cursor: pointer;
}
.testimonials .card .card-back:has(.more-info) {
  border: 4px solid #F129AD;
}
.testimonials .card .card-back p {
  text-align: center;
}
.testimonials .card .card-back p.testimonio {
  font-style: italic;
}
.testimonials .card .card-back p.testimonio::after, .testimonials .card .card-back p.testimonio::before {
  font-size: 1.2em;
  display: inline-block;
  content: '"';
}
.testimonials .card .card-back p strong {
  display: block;
}
.testimonials .card .card-back p small {
  font-size: 0.8em;
}
.testimonials .card.oculto {
  transform: translateY(100px);
  filter: blur(2px);
}

.demo {
  overflow-y: auto;
  height: 100svh;
}
.demo h2 {
  font-size: max(2rem, 4vw);
  position: sticky;
  z-index: 2;
  top: 0;
  padding: 10px 46px 10px 10px;
  background-color: rgba(174, 238, 245, 0.8);
}
.demo .btn-close {
  position: fixed;
  top: 0;
  right: 0;
  z-index: 3;
}
.demo .content {
  text-align: center;
  display: grid;
  align-items: center;
  justify-content: center;
}
.demo .content a {
  color: #F129AD;
}
.demo .content p {
  margin-bottom: 0.5em;
  font-size: 1em;
  text-align: left;
}
.demo .form {
  margin: 1em auto;
  padding: 4vw;
  border-radius: 10px;
  background-color: #fff;
  box-shadow: 10px 10px 20px 90 #5B3E67;
}
@media screen and (min-width: 800px) {
  .demo .form {
    margin: 1em auto 3em;
  }
}
.demo .form form > div {
  text-align: left;
  margin: 1em 0;
}
@media screen and (min-width: 800px) {
  .demo .form form > div {
    display: grid;
    grid-column-gap: 1em;
    grid-template-columns: 1fr 1fr;
    grid-template-rows: auto auto;
  }
  .demo .form form > div .message {
    grid-column: 1/span 2;
  }
}
.demo .form label {
  font-weight: bold;
}
.demo .form input.input, .demo .form textarea {
  font-family: "Roboto", sans-serif;
  color: #5B3E67;
  font-size: 1em;
}
.demo .form .submit {
  color: #fff;
  background-color: #F129AD;
  padding: 0.5em 1em;
  border-radius: 25px;
  transition: all 0.2s ease-in-out;
  transform: scale(1);
  display: inline-block;
  font-size: 1em;
}
.demo .form .submit:hover {
  transition: all 0.2s ease-in-out;
  transform: scale(1.1);
  color: #F129AD;
}
.demo .form textarea {
  height: 5em;
}
.demo .location::before {
  content: url(../img/location.svg);
  width: 1em;
  margin-right: 10px;
  display: inline-block;
}

.visible {
  transition: all 1.5s ease-in-out;
  opacity: 1;
}

.oculto {
  transition: all 0.5s ease-in-out;
  opacity: 0;
}

.buttons-cta {
  text-align: center;
  margin: 1em 0;
}

.btn {
  color: #fff;
  background-color: #F129AD;
  cursor: pointer;
  padding: 0.5em 1em;
  border-radius: 25px;
  transition: all 0.2s ease-in-out;
  transform: scale(1);
  display: inline-block;
}
.btn:hover {
  transition: all 0.2s ease-in-out;
  transform: scale(1.1);
}

.btn-close {
  padding: 0.5em;
  text-align: right;
}
.btn-close div {
  display: inline-block;
  font-size: 1.4em;
  font-weight: bold;
  cursor: pointer;
  color: #F129AD;
  background-color: #fff;
  border-radius: 50%;
  width: 1.4em;
  text-align: center;
}

.lightbox {
  top: -1000vh;
  position: fixed;
  background-color: #AEEEF5;
  z-index: 1000;
  width: 100svw;
  height: 100svh;
  transition: opacity 0.5s ease-in-out;
  opacity: 0;
  pointer-events: none;
}
.lightbox.open {
  top: 0;
  opacity: 1;
  transition: opacity 0.5s ease-in-out;
  pointer-events: all;
}

#testimonial-samantha .demo {
  display: flex;
}
#testimonial-samantha .lightbox-content {
  padding: 2em;
  border-radius: 15px;
  overflow: auto;
  box-shadow: 0px -10px 10px 0px rgba(45, 0, 22, 0.2);
  background: #fff;
}
@media screen and (min-width: 1024px) {
  #testimonial-samantha .lightbox-content {
    max-width: 80vw;
    margin: auto;
  }
}
#testimonial-samantha .lightbox-content p {
  font-style: italic;
}
#testimonial-samantha img {
  margin: 0 2vw 3vw 0;
  padding: 1em;
  background-color: #fff;
  border-radius: 5px;
  transform: rotate(3deg);
  box-shadow: 0px -10px 10px 0px rgba(45, 0, 22, 0.2);
  border: 1px solid #f2f2f2;
}
@media screen and (min-width: 768px) {
  #testimonial-samantha img {
    float: left;
    max-width: 50vw;
  }
}
@media screen and (min-width: 1024px) {
  #testimonial-samantha img {
    margin: 0 2vw 3vw 0;
    max-width: 25vw;
  }
}
#testimonial-samantha .signature {
  text-align: right;
}
#testimonial-samantha .signature strong {
  display: block;
}

.js-open-lightbox {
  cursor: pointer;
}

iframe.ct-video-xmas {
  width: 100%;
  height: 100vh;
  padding-bottom: 0;
}
main:has(iframe.ct-video-xmas) {
  background-color: #160f2c;
  margin: 0;
}

.faqs-page main {
  background: #2D2F51;
  color: #fff;
  min-height: calc(100vh - 3.5em);
}
.faqs-page main h1 {
  font-size: max(2.5rem, 4vw);
  padding: 0.5em 0 1em;
}
.faqs-page main h2 {
  text-align: left;
  font-size: max(2rem, 3vw);
  margin-bottom: 1em;
}
.faqs-page main h3 {
  padding-top: 1em;
  margin-top: 1em;
  display: flex;
  line-height: 2em;
  cursor: pointer;
}
.faqs-page main h3:hover {
  color: #F129AD;
}
.faqs-page main h3.open {
  padding-bottom: 1em;
  color: #F129AD;
}
.faqs-page main h3.open::after {
  transform: rotate(45deg);
}
.faqs-page main h3::after {
  content: "+";
  display: block;
  margin-left: auto;
  vertical-align: middle;
  font-size: 2em;
  width: 1em;
  height: 1em;
  transform: rotate(0deg);
  transition: all 1s ease-in-out;
  cursor: pointer;
}
.faqs-page main div + h3 {
  border-top: 1px dashed rgba(255, 255, 255, 0.3333333333);
}
.faqs-page main .faqs-menu {
  border-bottom: 1px dashed #EDECEC;
  padding-bottom: 1em;
  margin-bottom: 1em;
}
.faqs-page main .faqs-menu ul {
  position: sticky;
  top: 8vw;
  font-size: 1.5em;
}
.faqs-page main .faqs-menu li {
  padding: 0.8em 0;
  cursor: pointer;
  line-height: 1em;
}
.faqs-page main .faqs-menu li.open, .faqs-page main .faqs-menu li:hover {
  color: #F129AD;
}
@media screen and (min-width: 800px) {
  .faqs-page main .faqs-menu {
    border-bottom: none;
  }
}
.faqs-page main .faqs-content {
  display: grid;
  gap: 1em;
}
.faqs-page main .faqs-content a {
  color: #F129AD;
  text-decoration: underline;
}
@media screen and (min-width: 800px) {
  .faqs-page main .faqs-content {
    grid-template-columns: 4fr 8fr;
  }
}
.faqs-page main .js-faq-block {
  height: 0;
  opacity: 0;
  transition: all 1s;
  margin-top: 0;
  z-index: 0;
  pointer-events: none;
}
.faqs-page main .js-faq-block.open {
  pointer-events: all;
  margin-top: -1em;
  height: initial;
  opacity: 1;
  z-index: 2;
}
.faqs-page main .js-faq-block div {
  height: 0;
  opacity: 0;
  transition: all 1s;
  margin-top: 0;
  z-index: 0;
  pointer-events: none;
}
.faqs-page main .js-faq-block div.open {
  margin-top: -1em;
  height: initial;
  opacity: 1;
  z-index: 2;
  pointer-events: all;
}