html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  font: inherit;
  vertical-align: baseline;
}

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

body {
  line-height: 1;
}

ol, ul {
  list-style: none;
}

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

blockquote:before, blockquote:after, q:before, q:after {
  content: "";
  content: none;
}

h1, h2, h3, h4, h5, strong, blockquote {
  font-weight: bold;
}

em {
  font-style: italic;
}

.type-number-default, #home #process .container .steps-list li {
  font-weight: 500;
  font-size: 15rem;
  line-height: 100%;
}
@media (min-width: 64rem) {
  .type-number-default, #home #process .container .steps-list li {
    font-weight: 500;
    font-size: 20rem;
    line-height: 100%;
  }
}

.type-number-active, #home #process .container .steps-list li.active {
  font-weight: 800;
  font-size: 15rem;
  line-height: 100%;
}
@media (min-width: 64rem) {
  .type-number-active, #home #process .container .steps-list li.active {
    font-weight: 800;
    font-size: 20rem;
    line-height: 100%;
  }
}

.type-display, #contact .container h2, #fudo #intro .content .container .texts h1, #home #intro .content .container h1 {
  font-weight: 500;
  font-size: 3rem;
  line-height: 100%;
}
@media (min-width: 64rem) {
  .type-display, #contact .container h2, #fudo #intro .content .container .texts h1, #home #intro .content .container h1 {
    font-weight: 500;
    font-size: 6rem;
    line-height: 100%;
  }
}

.type-heading, #fudo section .container h2, #fudo #intro .content .container .context h2, #home section .container h2 {
  font-weight: 600;
  font-size: 3rem;
  line-height: 100%;
}
@media (min-width: 64rem) {
  .type-heading, #fudo section .container h2, #fudo #intro .content .container .context h2, #home section .container h2 {
    font-weight: 600;
    font-size: 5rem;
    line-height: 100%;
  }
}

.type-statement, #testimonial .container .content .statement {
  font-weight: 400;
  font-size: 3rem;
  line-height: 100%;
}
@media (min-width: 64rem) {
  .type-statement, #testimonial .container .content .statement {
    font-weight: 400;
    font-size: 5rem;
    line-height: 100%;
  }
}

.type-overview {
  font-weight: 400;
  font-size: 1.5rem;
  line-height: 135%;
}
@media (min-width: 64rem) {
  .type-overview {
    font-weight: 400;
    font-size: 1.75rem;
    line-height: 135%;
  }
}

.type-title, #fudo section .container aside .content .title, #home #services .services-list .service-item .content .texts .title, #home #process .container .steps-content .step .title {
  font-weight: 600;
  font-size: 2rem;
  line-height: 100%;
}
@media (min-width: 64rem) {
  .type-title, #fudo section .container aside .content .title, #home #services .services-list .service-item .content .texts .title, #home #process .container .steps-content .step .title {
    font-weight: 600;
    font-size: 3rem;
    line-height: 100%;
  }
}

.type-description-1, #fudo section .container p, #fudo #intro .content .container .context .paragraphs p, #home #work .container .description, #home #about .container .description, #home #process .container .steps-content .step .description {
  font-weight: 400;
  font-size: 1.25rem;
  line-height: 145%;
}
@media (min-width: 64rem) {
  .type-description-1, #fudo section .container p, #fudo #intro .content .container .context .paragraphs p, #home #work .container .description, #home #about .container .description, #home #process .container .steps-content .step .description {
    font-weight: 400;
    font-size: 1.5rem;
    line-height: 145%;
  }
}

.type-description-2, #home #services .services-list .service-item .content .texts .description {
  font-weight: 400;
  font-size: 1.125rem;
  line-height: 145%;
}
@media (min-width: 64rem) {
  .type-description-2, #home #services .services-list .service-item .content .texts .description {
    font-weight: 400;
    font-size: 1.25rem;
    line-height: 145%;
  }
}

.type-small-title, footer .container .title, header .container .title, #fudo #intro .content .container .texts .text, #home #work .container ul li .texts .title {
  font-weight: 600;
  font-size: 1.25rem;
  line-height: 125%;
}
@media (min-width: 64rem) {
  .type-small-title, footer .container .title, header .container .title, #fudo #intro .content .container .texts .text, #home #work .container ul li .texts .title {
    font-weight: 600;
    font-size: 1.5rem;
    line-height: 125%;
  }
}

.type-label-1, .button.medium, #fudo #benefits ul li {
  font-weight: 500;
  font-size: 1.25rem;
  line-height: 115%;
}
@media (min-width: 64rem) {
  .type-label-1, .button.medium, #fudo #benefits ul li {
    font-weight: 500;
    font-size: 1.5rem;
    line-height: 115%;
  }
}

.type-label-2, #testimonial .container .content .person, .button.small, #fudo #intro .content .container .graphics .message, #home #work .container ul li .texts .label, #home #services .services-list .service-item .content ul li {
  font-weight: 500;
  font-size: 1.125rem;
  line-height: 115%;
}
@media (min-width: 64rem) {
  .type-label-2, #testimonial .container .content .person, .button.small, #fudo #intro .content .container .graphics .message, #home #work .container ul li .texts .label, #home #services .services-list .service-item .content ul li {
    font-weight: 500;
    font-size: 1.25rem;
    line-height: 115%;
  }
}

#home #intro {
  background: radial-gradient(circle at bottom, #ED0043, #0E0D5A 75%);
}
#home #intro .content {
  display: flex;
  justify-content: center;
}
#home #intro .content .container {
  display: flex;
  justify-content: center;
  padding-top: 10rem;
  padding-bottom: 5rem;
  gap: 2.5rem;
  flex-flow: column;
  align-items: flex-start;
}
@media (min-width: 64rem) {
  #home #intro .content .container {
    align-items: center;
    padding-top: 15rem;
    padding-bottom: 6rem;
    gap: 4rem;
  }
}
#home #intro .content .container h1 {
  color: white;
  max-width: 71.372rem;
}
@media (min-width: 64rem) {
  #home #intro .content .container h1 {
    text-align: center;
  }
}
#home #intro .content .container .graphics {
  position: relative;
}
#home #intro .content .container .graphics .blocks {
  z-index: 1;
  position: relative;
  max-height: 372px;
}
@media (min-width: 64rem) {
  #home #intro .content .container .graphics .blocks {
    max-height: none;
  }
}
#home #intro .content .container .graphics .wave {
  position: absolute;
  left: -50%;
  bottom: -32%;
}
@media (min-width: 64rem) {
  #home #intro .content .container .graphics .wave {
    left: -25%;
    bottom: 10%;
  }
}
#home section {
  padding-top: 10rem;
  padding-bottom: 10rem;
  display: flex;
  justify-content: center;
}
@media (min-width: 64rem) {
  #home section {
    padding-top: 15rem;
    padding-bottom: 15rem;
  }
}
#home section .container {
  display: flex;
  align-items: flex-start;
  gap: 4rem;
  flex-direction: column;
}
@media (min-width: 64rem) {
  #home section .container {
    align-items: center;
    gap: 6rem;
  }
}
@media (min-width: 64rem) {
  #home section .container h2 {
    text-align: center;
    max-width: 71.372rem;
  }
}
#home #process {
  background: #1B1B1B;
}
#home #process .container {
  color: white;
}
#home #process .container .steps-list {
  display: flex;
  -webkit-overflow-scrolling: touch;
  overflow-x: auto;
  overflow-y: hidden;
  width: 100vw;
  margin-left: -1rem;
  padding: 0 1rem;
}
@media (min-width: 64rem) {
  #home #process .container .steps-list {
    width: auto;
    margin-left: 0;
  }
}
#home #process .container .steps-list::-webkit-scrollbar {
  display: none;
}
#home #process .container .steps-list li {
  padding: 0.5rem 2.5rem;
  min-width: 15rem;
  border-left: 1px solid rgba(255, 255, 255, 0.2);
  text-align: center;
}
@media (min-width: 64rem) {
  #home #process .container .steps-list li {
    padding: 0 3rem;
    border-left: none;
    border-right: 1px solid rgba(255, 255, 255, 0.2);
    min-width: 19.5rem;
  }
}
#home #process .container .steps-list li.active {
  color: #ED0043;
  pointer-events: none;
}
#home #process .container .steps-list li:hover {
  background: rgba(255, 255, 255, 0.1);
  cursor: pointer;
}
@media (min-width: 64rem) {
  #home #process .container .steps-content {
    text-align: center;
    max-width: 42.25rem;
  }
}
#home #process .container .steps-content .step {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
#home #process .container .steps-content .step.hide {
  display: none;
}
#home #process .container .steps-content .step .description {
  opacity: 85%;
}
#home #services .services-list {
  display: flex;
  flex-direction: column;
  gap: 6rem;
  width: 100%;
}
#home #services .services-list .service-item {
  display: flex;
  flex-direction: column;
}
@media (min-width: 64rem) {
  #home #services .services-list .service-item {
    flex-direction: row;
    gap: 1.5rem;
  }
}
@media (min-width: 64rem) {
  #home #services .services-list .service-item .content, #home #services .services-list .service-item .image {
    width: 50%;
  }
}
#home #services .services-list .service-item .content {
  background: #F9F9F9;
  justify-content: center;
  padding: 2rem 1.5rem;
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
  border-radius: 0 0 2rem 2rem;
}
@media (min-width: 64rem) {
  #home #services .services-list .service-item .content {
    padding: 6rem;
    gap: 3rem;
    border-radius: 2.5rem;
  }
}
#home #services .services-list .service-item .content .texts {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}
#home #services .services-list .service-item .content ul li {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.5rem 0;
}
#home #services .services-list .service-item .content ul li .icon {
  background: #008582;
}
#home #services .services-list .service-item .image {
  background: #FFECEE;
  aspect-ratio: 1/1;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 2rem 2rem 0 0;
}
@media (min-width: 64rem) {
  #home #services .services-list .service-item .image {
    border-radius: 2.5rem;
  }
}
#home #services .services-list .service-item .image img {
  max-height: 19rem;
}
@media (min-width: 64rem) {
  #home #services .services-list .service-item .image img {
    max-height: 32rem;
  }
}
@media (min-width: 64rem) {
  #home #services .services-list .service-item.design-systems {
    flex-flow: row-reverse;
  }
}
#home #services .services-list .service-item.design-systems .image {
  background: #FAECFD;
}
#home #services .services-list .service-item.consulting .image {
  background: #DAF6F5;
}
@media (min-width: 64rem) {
  #home #services .services-list .service-item.training {
    flex-flow: row-reverse;
  }
}
#home #services .services-list .service-item.training .image {
  background: #FFF1BC;
}
#home #about {
  background: #1B1B1B;
}
#home #about .container {
  color: white;
}
#home #about .container figure {
  aspect-ratio: 1/1;
  display: flex;
}
@media (min-width: 64rem) {
  #home #about .container figure {
    aspect-ratio: 16/9;
  }
}
#home #about .container figure img {
  width: 100%;
  object-fit: cover;
}
#home #about .container .description {
  max-width: 42.25rem;
}
#home #work {
  background: linear-gradient(#FFECEE, white);
}
#home #work .container h2 {
  max-width: 56.875rem;
}
#home #work .container ul {
  display: flex;
  -webkit-overflow-scrolling: touch;
  overflow-x: auto;
  width: 100vw;
  margin-left: -1rem;
  gap: 1.5rem;
  padding: 0 1rem;
}
@media (min-width: 64rem) {
  #home #work .container ul {
    gap: 3rem;
    width: auto;
    margin-left: 0;
  }
}
#home #work .container ul::-webkit-scrollbar {
  display: none;
}
#home #work .container ul li {
  border-radius: 99rem;
  background: #F1F1F1;
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 15rem;
  flex-flow: column;
  aspect-ratio: 1/1;
}
@media (min-width: 64rem) {
  #home #work .container ul li {
    min-width: 18.75rem;
  }
}
#home #work .container ul li img {
  width: 7.5rem;
  height: 7.5rem;
}
@media (min-width: 64rem) {
  #home #work .container ul li img {
    width: 10rem;
    height: 10rem;
  }
}
#home #work .container ul li .texts {
  text-align: center;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
#home #work .container ul li a {
  text-decoration: none;
}
#home #work .container ul li a .texts .title {
  color: #1B1B1B;
}
#home #work .container ul li a .texts .label {
  color: #ED0043;
}
#home #work .container ul li.fudo:hover {
  background: #FFEDEB;
}
#home #work .container .description {
  max-width: 42.25rem;
}
#home #contact {
  background: #ED0043;
}
#home footer {
  background: #BE0034;
}

#fudo #intro {
  background: linear-gradient(#872100, #F24300, #FFEDEB 60%);
}
#fudo #intro .content {
  display: flex;
  justify-content: center;
}
#fudo #intro .content .container {
  display: flex;
  justify-content: center;
  padding-top: 10rem;
  padding-bottom: 10rem;
  gap: 3rem;
  flex-flow: column;
}
@media (min-width: 64rem) {
  #fudo #intro .content .container {
    align-items: center;
    gap: 6rem;
    padding-top: 15rem;
    padding-bottom: 15rem;
  }
}
#fudo #intro .content .container .texts {
  color: white;
  text-align: center;
  max-width: 56.875rem;
  display: flex;
  align-items: center;
  flex-direction: column;
  gap: 0.5rem;
}
#fudo #intro .content .container .texts .text {
  opacity: 85%;
}
#fudo #intro .content .container .graphics {
  display: flex;
  flex-direction: column;
  gap: 3rem;
  position: relative;
}
@media (min-width: 64rem) {
  #fudo #intro .content .container .graphics {
    align-items: center;
  }
}
#fudo #intro .content .container .graphics .message {
  opacity: 85%;
  color: white;
  text-align: center;
}
#fudo #intro .content .container .graphics .devices {
  display: flex;
  -webkit-overflow-scrolling: touch;
  overflow-x: auto;
  width: 100vw;
  margin-left: -1rem;
  flex-direction: row;
  position: relative;
  z-index: 1;
}
@media (min-width: 64rem) {
  #fudo #intro .content .container .graphics .devices {
    width: auto;
    margin-left: 0;
    gap: 18rem;
    overflow: visible;
  }
}
#fudo #intro .content .container .graphics .devices::-webkit-scrollbar {
  display: none;
}
#fudo #intro .content .container .graphics .devices .before, #fudo #intro .content .container .graphics .devices .after {
  max-width: 80%;
}
@media (min-width: 64rem) {
  #fudo #intro .content .container .graphics .devices .before, #fudo #intro .content .container .graphics .devices .after {
    max-width: none;
    max-height: 900px;
  }
}
@media (min-width: 64rem) {
  #fudo #intro .content .container .graphics .devices .before {
    transform: rotate(30deg);
  }
}
@media (min-width: 64rem) {
  #fudo #intro .content .container .graphics .devices .after {
    transform: rotate(-30deg);
  }
}
#fudo #intro .content .container .graphics .wave {
  position: absolute;
  bottom: -15%;
  left: -50%;
}
@media (min-width: 64rem) {
  #fudo #intro .content .container .graphics .wave {
    bottom: 25%;
    left: -32%;
  }
}
#fudo #intro .content .container .context {
  max-width: 42.25rem;
  display: flex;
  flex-flow: column;
  gap: 3rem;
}
#fudo #intro .content .container .context h2 {
  text-align: center;
  color: #872100;
}
#fudo #intro .content .container .context .paragraphs p {
  margin-bottom: 1.5rem;
}
#fudo section {
  padding-top: 10rem;
  padding-bottom: 10rem;
  display: flex;
  justify-content: center;
  border-bottom: 1px solid rgba(0, 0, 0, 0.1);
}
@media (min-width: 64rem) {
  #fudo section {
    padding-top: 15rem;
    padding-bottom: 15rem;
  }
}
#fudo section .container {
  display: flex;
  align-items: flex-start;
  gap: 4rem;
  flex-direction: column;
}
@media (min-width: 64rem) {
  #fudo section .container {
    align-items: center;
    gap: 6rem;
  }
}
@media (min-width: 64rem) {
  #fudo section .container h2 {
    text-align: center;
    max-width: 56.875rem;
  }
}
#fudo section .container figure img {
  width: 100%;
}
#fudo section .container p {
  max-width: 42.25rem;
}
#fudo section .container aside {
  display: flex;
  gap: 4rem;
  flex-direction: column;
  align-items: center;
}
@media (min-width: 64rem) {
  #fudo section .container aside {
    gap: 6rem;
  }
}
#fudo section .container aside .divider {
  width: 100%;
  height: 1px;
  background: black;
  opacity: 10%;
}
@media (min-width: 64rem) {
  #fudo section .container aside .divider {
    width: 50%;
  }
}
#fudo section .container aside .content {
  display: flex;
  gap: 1.5rem;
  flex-direction: column;
}
@media (min-width: 64rem) {
  #fudo section .container aside .content {
    flex-direction: row;
  }
}
@media (min-width: 64rem) {
  #fudo section .container aside .content figure, #fudo section .container aside .content .title {
    width: 50%;
  }
}
#fudo section .container aside .content .title {
  padding: 0 1rem;
}
@media (min-width: 64rem) {
  #fudo section .container aside .content .title {
    display: flex;
    padding: 4rem;
    align-items: center;
  }
}
#fudo #colors {
  border-bottom: none;
  background: linear-gradient(white, #F1F1F1);
}
#fudo #components {
  border-bottom: none;
}
#fudo #benefits {
  background: #FFEDEB;
  border-bottom: none;
}
#fudo #benefits h2 {
  color: #872100;
}
#fudo #benefits ul {
  display: flex;
  gap: 1.5rem;
  -webkit-overflow-scrolling: touch;
  overflow-x: auto;
  width: 100vw;
  margin-left: -1rem;
  padding: 0 1rem 0.5rem 1rem;
}
@media (min-width: 64rem) {
  #fudo #benefits ul {
    width: auto;
    margin-left: 0;
    padding: 0;
    overflow: visible;
    gap: 2.5rem;
  }
}
#fudo #benefits ul::-webkit-scrollbar {
  display: none;
}
#fudo #benefits ul li {
  border-radius: 2.5rem;
  background: white;
  min-width: 15rem;
  display: flex;
  aspect-ratio: 1/1;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 1rem;
  padding: 1.5rem;
  text-align: center;
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
}
@media (min-width: 64rem) {
  #fudo #benefits ul li {
    width: 18.75rem;
    gap: 1.5rem;
    padding: 2rem;
  }
}
#fudo #benefits ul li .icon {
  background: linear-gradient(45deg, #D7001B, #2F2E8A);
}
#fudo #contact {
  background: #F24300;
}
#fudo footer {
  background: #C63500;
}

:root {
  font-family: Inter, sans-serif;
  font-feature-settings: "liga" 1, "calt" 1;
}

@supports (font-variation-settings: normal) {
  :root {
    font-family: InterVariable, sans-serif;
  }
}
*, *:before, *:after {
  box-sizing: border-box;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
  text-size-adjust: none;
}

html, body {
  color: #1B1B1B;
  overflow-x: hidden;
}

.container {
  padding: 0 1rem;
  width: 100%;
  max-width: 90rem;
}
@media (min-width: 64rem) {
  .container {
    padding: 0 2rem;
  }
}

.button {
  border-radius: 99rem;
  display: flex;
  width: fit-content;
  text-decoration: none;
}
.button.medium {
  padding: 1rem 2rem;
}
.button.small {
  padding: 0.75rem 1.5rem;
}
.button.flat.primary {
  color: #1B1B1B;
  background: white;
}
.button.flat.primary:hover {
  background: rgba(255, 255, 255, 0.85);
}
.button.flat.secondary {
  color: white;
  background: rgba(255, 255, 255, 0.1);
}
.button.flat.secondary:hover {
  background: rgba(255, 255, 255, 0.2);
}
.button.surfaced {
  color: #131377;
  box-shadow: 0 0 0 5px rgba(255, 255, 255, 0.25);
  background: linear-gradient(white, #C2C2F7);
}
.button.surfaced:hover {
  color: #BE0034;
  background: linear-gradient(white, #FFECEE);
}

.icon {
  background-color: #1B1B1B;
}
.icon.size-32 {
  width: 2rem;
  height: 2rem;
}
.icon.size-96 {
  width: 6rem;
  height: 6rem;
}
.icon.badge {
  -webkit-mask: url("../img/icon-badge.svg");
}
.icon.check {
  -webkit-mask: url("../img/icon-check.svg");
}

header {
  display: flex;
  justify-content: center;
}
header .container {
  padding-top: 1rem;
  padding-bottom: 1rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
header .container .title {
  color: white;
}
header .container .desktop {
  display: none;
}
@media (min-width: 64rem) {
  header .container .desktop {
    display: flex;
    gap: 1rem;
  }
}
@media (min-width: 64rem) {
  header .container .mobile {
    display: none;
  }
}

#contact {
  padding: 15rem 0;
  display: flex;
  align-items: center;
  flex-direction: column;
}
@media (min-width: 64rem) {
  #contact {
    padding: 20rem 0;
  }
}
#contact .container {
  display: flex;
  justify-content: center;
}
#contact .container h2 {
  color: white;
  text-align: center;
  max-width: 71.372rem;
}
#contact .container h2 a {
  color: white;
}

footer {
  display: flex;
  justify-content: center;
}
footer .container {
  padding-top: 1rem;
  padding-bottom: 1rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
footer .container .title {
  color: white;
}
footer .container ul {
  display: flex;
  gap: 1rem;
}

#testimonial {
  background: #1B1B1B;
}
@media (min-width: 64rem) {
  #testimonial .container {
    align-items: center;
  }
}
#testimonial .container .content {
  max-width: 71.372rem;
  gap: 1.5rem;
  display: flex;
  flex-direction: column;
}
@media (min-width: 64rem) {
  #testimonial .container .content {
    text-align: center;
  }
}
#testimonial .container .content .statement {
  color: white;
}
#testimonial .container .content .person {
  color: white;
  opacity: 85%;
}
