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

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

  ul,
  ol {
    list-style: none;
  }

  body {
    min-height: 100vh;
    line-height: 1.5;
  }

  h1,
  h2,
  h3,
  h4,
  button,
  input,
  label {
    line-height: 1.1;
  }

  h1,
  h2,
  h3,
  h4 {
    text-wrap: balance;
  }

  p,
  li {
    text-wrap: pretty;
  }

  a:not([class]) {
    text-decoration-skip-ink: auto;
    color: currentColor;
  }

  input,
  button,
  select {
    font-family: inherit;
    font-size: inherit;
  }

  @media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
      transition: none !important;
      animation: none !important;
    }
  }
}

@layer page-transitions {
  /* @media (prefers-reduced-motion: no-preference) {
    html {
      scroll-behavior: smooth;
    }
  } */

  /* Animation change for dark-mode */

  @media (prefers-reduced-motion: no-preference) {
    ::view-transition-old(root) {
      animation-delay: 1s;
    }

    ::view-transition-new(root) {
      animation: circle-in-S 1s ease-out;
    }

    @media (width > 47.5rem) {
      ::view-transition-new(root) {
        animation: circle-in-L 1s ease-out;
      }
    }
  }

  /* SWUP animation changes */

  .transition-reverse-slide,
  .transition-reverse-slide-main,
  .transition-reverse-slide-opposite {
    will-change: transform;
  }

  .transition-slide,
  .transition-slide-opposite {
    opacity: 1;
    transform: translateX(0);
    transition: transform 0.3s, opacity 0.2s;
  }

  html.is-rendering .transition-slide,
  html.is-rendering .transition-slide-opposite,
  html.is-animating .transition-slide-opposite {
    opacity: 0;
    transform: translateX(-80%);
  }

  html.is-animating .transition-slide {
    opacity: 0;
    transform: translateX(80%);
  }

  .transition-reverse-slide-main {
    position: relative;
    transform: translateY(0);
    transform-origin: left;
    transition: transform 0.6s;
  }

  html.is-animating .transition-reverse-slide-main,
  html.is-rendering .transition-reverse-slide-main {
    transform: translateY(-70%);

    @media (width > 47.5rem) {
      transform: translateY(-55%);
    }

    @media (width > 62.5rem) {
      transform: translateY(-40%);
    }
  }

  .transition-reverse-slide {
    transform: translateY(0);
    transform-origin: left;
    transition: 0.3s;
    position: relative;
  }

  html.is-animating .transition-reverse-slide,
  html.is-rendering .transition-reverse-slide {
    opacity: 0;
    transform: translateY(100%);
  }

  .transition-fade {
    opacity: 1;
    transition: opacity 0.3s ease;
  }

  html.is-animating .transition-fade,
  html.is-leaving .transition-fade,
  html.is-rendering .transition-fade,
  html.is-leaving .hero__image-main-container {
    opacity: 0 !important;
    will-change: opacity;
  }

  .hero__image-main-container {
    transition: opacity 0.2s ease;
  }
}

@layer components {
  @font-face {
    font-display: swap;
    font-family: "Barlow Condensed";
    font-style: normal;
    font-weight: 400;
    src: url("../assets/fonts/barlow-condensed-v13-latin-regular.woff2")
      format("woff2");
  }

  @font-face {
    font-display: swap;
    font-family: "Barlow Condensed";
    font-style: normal;
    font-weight: 500;
    src: url("../assets/fonts/barlow-condensed-v13-latin-500.woff2")
      format("woff2");
  }

  @font-face {
    font-display: swap;
    font-family: "Barlow Condensed";
    font-style: normal;
    font-weight: 600;
    src: url("../assets/fonts/barlow-condensed-v13-latin-600.woff2")
      format("woff2");
  }

  @font-face {
    font-display: swap;
    font-family: "Barlow Condensed";
    font-style: normal;
    font-weight: 700;
    src: url("../assets/fonts/barlow-condensed-v13-latin-700.woff2")
      format("woff2");
  }

  @font-face {
    font-display: swap;
    font-family: "Source Sans 3";
    font-style: normal;
    font-weight: 400;
    src: url("../assets/fonts/source-sans-3-v19-latin-regular.woff2")
      format("woff2");
  }

  @font-face {
    font-display: swap;
    font-family: "Source Sans 3";
    font-style: normal;
    font-weight: 700;
    src: url("../assets/fonts/source-sans-3-v19-latin-700.woff2")
      format("woff2");
  }

  :root {
    text-size-adjust: none;
    -moz-text-size-adjust: none;
    -moz-osx-font-smoothing: grayscale;
    -webkit-font-smoothing: antialiased;
    -webkit-text-size-adjust: none;
    -ms-text-size-adjust: none;

    --fs-sub-text: 0.8rem;
    --fs-body-text: 1.2rem;
    --fs-text-heading: clamp(1.5rem, 2vw, 1.75rem);
    --fs-topper-heading: clamp(1rem, 1.5vw, 1.2rem);
    --fs-sub-heading: clamp(2.75rem, 4vw, 3.5rem);
    --fs-heading: clamp(3.5rem, 6vw, 5rem);
    --fs-hero-heading: clamp(3.25rem, 5.5vw, 5rem);
    --fs-hero-text: clamp(1.25rem, 2vw, 1.5rem);
    --fs-card-heading: clamp(1.75rem, 3vw, 2.5rem);
    --fs-card-text: 1.1rem;
    --fs-nav-L-screen: clamp(1rem, 1.5vw, 1.25rem);
    --fs-nav-S-screen: clamp(1.25rem, 3vw, 1.75rem);

    --ff-headings-oswald: "Barlow Condensed", Arial, sans-serif;
    --ff-body-source: "Source Sans 3", Arial, sans-serif;

    --padd-60-100: clamp(4rem, 8vw, 6.5rem);

    --clr-lighter-white: #fafbfc;
    --clr-lighter-black: #1a1a1a;
    --clr-gray-100: #707070;
    --clr-gray-200: #4e4b66;
    --clr-blue-100: #43a4f4;
    --clr-blue-150: #1954c2;
    --clr-blue-200: #09193f;
    --clr-blue-300: #0e1320;
    --clr-navigation-shadow: #4545454d;

    --bg-primary-blue: var(--clr-blue-200);
    --bg-btn: var(--clr-blue-200);
    --bg-btn-active: var(--clr-blue-100);
    --bg-svg-decorations: var(--clr-blue-100);

    --text-body-white: var(--clr-lighter-white);
    --text-sub-heading-black: var(--clr-lighter-black);
    --text-topper-heading-gray: var(--clr-gray-100);
    --text-primary: var(--clr-gray-200);
    --text-primary-dark: var(--clr-blue-200);

    :focus-visible {
      outline: 2px solid var(--clr-blue-100);
      outline-offset: 2px;
    }
  }

  #hero-heading {
    font-size: var(--fs-hero-heading);
  }

  .cmp-main-heading {
    font-size: var(--fs-heading);
    font-weight: 600;
    color: var(--clr-lighter-white);
    max-width: 19ch;
    margin-inline: auto;
  }

  .cmp-sub-heading {
    font-size: var(--fs-sub-heading);
    color: var(--text-sub-heading-black);
    max-width: 25ch;
  }

  .cmp-topper-heading {
    font-size: var(--fs-topper-heading);
    position: relative;
    color: var(--text-topper-heading-gray);
    letter-spacing: 0.1em;
    z-index: 999;
  }

  #hero-heading,
  .cmp-main-heading,
  .cmp-sub-heading,
  .cmp-topper-heading {
    font-family: var(--ff-headings-oswald);
    text-transform: uppercase;
    line-height: 1.1;
    z-index: -1;
  }

  .cmp-main-heading,
  .cmp-sub-heading {
    margin-bottom: 1.5rem;
  }

  .cmp-sub-heading,
  .cmp-topper-heading {
    font-weight: 600;
  }

  .cmp-main-text {
    font-size: var(--fs-body-text);
    font-family: var(--ff-body-source);
    color: var(--text-primary);
    line-height: 1.5em;
    z-index: -1;
  }

  .cmp-text-heading {
    font-family: var(--ff-headings-oswald);
    font-size: var(--fs-text-heading);
    color: var(--text-sub-heading-black);
    text-transform: uppercase;
  }

  .cmp-main-btn,
  .cmp-main-btn-footer {
    display: inline-block;
    position: relative;
    font-family: var(--ff-headings-oswald);
    font-size: 1rem;
    font-weight: 600;
    color: #fff;
    background-color: var(--bg-btn);
    padding: 0.75em 3em;
    border-radius: 3em;
    text-decoration: none;
    text-transform: uppercase;
    cursor: pointer;
    z-index: 0;
    outline: none;
    border: none;
    overflow: hidden;
    box-shadow: inset 0 1px 2px #ffffff80, 0 2px 4px #00000070,
      0 4px 8px #00000050;
    transition: transform 0.2s ease-out;

    &:hover {
      animation: rotate 0.75s ease-in-out both;
      box-shadow: inset 0 1px 2px #00000005, 0 2px 4px #00000010,
        0 3px 6px #00000005;
      text-shadow: 1px 1px 20px var(--clr-blue-100);
    }

    &:after {
      background: var(--clr-lighter-white);
      content: "";
      height: 9.37rem;
      width: 3.12rem;
      left: -3.12rem;
      opacity: 0.4;
      position: absolute;
      top: -6.25rem;
      z-index: -10;
      transform: rotate(25deg) translateX(0);
      transition: transform 1.2s cubic-bezier(0.19, 1, 0.22, 1);
    }

    &:hover:after {
      transform: rotate(25deg) translateX(17.5rem);
      transition: transform 1.2s cubic-bezier(0.19, 1, 0.22, 1);
    }
  }

  .cmp-main-btn--light {
    background-color: var(--bg-btn-active);
    color: var(--text-primary-dark);
    box-shadow: inset 0 1px 2px #ffffff60, 0 4px 6px #00000050,
      0 6px 10px #00000040;

    &:hover {
      text-shadow: 1px 1px 20px var(--clr-lighter-white);
    }
  }
}

@layer base {
  html,
  body {
    min-height: 100dvh;
    overflow-x: hidden;
    -webkit-overflow-scrolling: touch;
  }

  body {
    background-color: #fff;
    font-size: 1rem;
    font-family: var(--ff-body-source);
    font-weight: 400;
    color: var(--text-primary);
    overflow-x: clip;
  }

  main {
    perspective: 1200px;
    perspective-origin: center;
  }

  /* \\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\ */
  /* \\\\\\\\\\\\\\\\\\\\\\\\\\\\\\      *** HEADER ***       \\\\\\\\\\\\\\\\\\\\\\\\\\\\\\ */
  /* \\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\ */

  #header {
    position: relative;
    top: 0;
    z-index: 1000;

    &.sticking {
      position: sticky;
      animation: slideDown 1.2s ease-out forwards;
    }
  }

  .header__container {
    width: 100%;
    background-color: var(--clr-lighter-white);
    box-shadow: 0 3px 25px var(--clr-navigation-shadow);
  }

  .wrapper--header {
    min-height: clamp(4.5rem, 11vw, 5.5rem);
    display: flex;
    justify-content: space-between;
    align-items: center;
  }

  #swup-header-container {
    display: contents;
  }

  .business-logo-container {
    position: relative;
    min-width: 10rem;
    align-self: start;
    top: 0.75rem;
    perspective: 1000px;

    @media (width > 47.5rem) {
      min-width: 12rem;
      top: 0.85rem;
    }
  }

  .business-logo {
    position: absolute;
    width: 100%;
    max-width: 10rem;
    height: auto;
    backface-visibility: hidden;
    transition: transform 0.75s;

    @media (width > 47.5rem) {
      max-width: 12rem;
      transition: transform 1.5s;
    }
  }

  .logo-front {
    transform: rotateY(180deg);
  }

  .logo-back {
    transform: rotateY(0deg);
    z-index: 2;
  }

  .hamburger-btn-box {
    display: flex;
    align-items: center;
    gap: 1.2rem;
    order: 1;
  }

  .hamburger-btn {
    width: 1.85rem;
    height: 1.5rem;
    background-color: var(--clr-blue-200);
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    cursor: pointer;
    user-select: none;
    border: none;
    z-index: 10;
    padding: 0.75rem;
    border-radius: 20%;
    background-clip: padding-box;
    box-sizing: content-box;
    touch-action: manipulation;
    transition: transform 1.2s;
    /* prettier-ignore */
    transition-timing-function: linear(0, -0.001 6.9%, -0.004 9.1%, -0.008 11%, -0.016 12.9%, -0.025 14.6%, -0.038 16.3%, -0.054 17.9%, -0.073 19.5%, -0.095 21%, -0.152 24.1%, -0.217 27%, -0.358 32.6%, -0.408 35%, -0.428 36.3%, -0.439 37.5%, -0.441 38.6%, -0.436 39.6%, -0.423 40.5%, -0.405 41.3%, -0.35 42.8%, -0.27 44.2%, -0.156 45.6%, -0.014 46.9%, 0.153 48.1%, 0.766 51.4%, 1.05 53.4%, 1.184 54.7%, 1.284 56%, 1.359 57.4%, 1.39 58.2%, 1.413 59%, 1.434 60.2%, 1.439 60.8%, 1.441 61.5%, 1.44 62.2%, 1.436 62.9%, 1.418 64.4%, 1.395 65.7%, 1.365 67.1%, 1.212 73.2%, 1.146 76.2%, 1.089 79.4%, 1.067 81%, 1.047 82.7%, 1.034 84.2%, 1.023 85.8%, 1.014 87.5%, 1.008 89.3%, 1.004 91.2%, 1.001 93.3%, 1);

    span {
      display: block;
      width: 100%;
      height: 2.5px;
      background: #c3c3c3;
      border-radius: 3px;
      opacity: 1;
      pointer-events: none !important;
      transition: transform 0.6s ease, opacity 0.3s;
    }

    &.active {
      transform: scale(1.15);

      span:first-child {
        transform: rotate(410deg) translate(0.5rem, 0.44rem);
      }
      span:nth-child(2) {
        opacity: 0;
      }
      span:last-child {
        transform: rotate(-410deg) translate(0.5rem, -0.44rem);
      }
    }

    &:hover span,
    &:focus-visible span {
      background: #fff;
    }

    @media (width > 47.5rem) {
      & {
        display: none;
      }
    }
  }

  .nav-bar {
    position: absolute;
    background-color: #fff;
    color: var(--clr-blue-200);
    font-size: var(--fs-nav-S-screen);
    font-family: var(--ff-headings-oswald);
    font-weight: 600;
    top: 100%;
    right: 0;
    left: 0;
    width: 18em;
    margin-inline: auto;
    padding: 2em;
    text-align: center;
    z-index: -1;
    border-bottom-left-radius: 4.7rem;
    border-bottom-right-radius: 4.7rem;
    box-shadow: 1px 1px 60px var(--clr-lighter-black);
    user-select: none;
    -webkit-user-select: none;
    -ms-user-select: none;
    transform: translateY(-150%);
    /* prettier-ignore */
    transition: transform 0.85s linear(0, 1 44.7%, 0.898 51.8%, 0.874 55.1%, 0.866 58.4%, 0.888 64.3%, 1 77.4%, 0.98 84.5%, 1);

    ul {
      color: var(--clr-lighter-black);
      display: flex;
      flex-direction: column;
      width: fit-content;
      margin-inline: auto;
      gap: 2rem;
      margin-bottom: 0;

      @media (width > 47.5rem) {
        font-size: var(--fs-nav-L-screen);
        flex-direction: row;
        gap: 3rem;
      }
    }

    & li:not(:last-of-type)::after {
      content: "";
      display: block;
      margin-top: 1rem;
      height: 2px;
      width: 5rem;
      background: var(--clr-gray-100);
      opacity: 0.3;
      margin-block-end: inherit;
    }

    a {
      text-decoration: none;
      color: var(--clr-lighter-black);
      transition: color 0.3s ease-out;

      &:hover {
        color: var(--clr-blue-100) !important;
        transition: color 0.2s ease-out;
      }

      &.active-link {
        font-weight: bold;
        color: var(--clr-blue-100);

        @media (width > 47.5rem) {
          & {
            position: relative;
            color: var(--clr-lighter-black);
          }

          &::after {
            content: "";
            position: absolute;
            left: 0;
            bottom: -2px;
            width: 0%;
            height: 2px;
            background-color: var(--clr-blue-100);
            transition: width 0.6s ease-out;
          }

          &.animate-underline::after {
            width: 100%;
          }
        }
      }
    }

    @media (width > 47.5rem) {
      position: relative;
      width: 100%;
      padding: 0;
      z-index: 0;
      box-shadow: none;
      border-top: none;
      transform: translateY(0);

      & li:not(:last-of-type)::after {
        position: absolute;
        height: 0;
      }
    }
  }

  .hamburger-btn__open {
    transform: translateY(-2px);
  }

  .nav-bar.no-transition {
    transition: none !important;
  }

  /* \\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\ */
  /* \\\\\\\\\\\\\\\\\\\\\\\\\\\\\\      *** HERO-SECTION ***       \\\\\\\\\\\\\\\\\\\\\\\\\ */
  /* \\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\ */

  #pg1-hero {
    position: relative;
    background-color: var(--bg-primary-blue);
    text-align: center;
    padding-top: var(--padd-60-100);
    overflow: hidden;
    clip-path: inset(0px 0px 0px 0px);

    @media (width > 47.5rem) {
      text-align: left;
    }
  }

  .pg1-hero__flex {
    display: flex;
    flex-direction: column;
    gap: clamp(4rem, 7vw, 8rem);

    @media (width > 47.5rem) {
      flex-direction: row;
    }
  }

  .hero__text-container {
    min-width: 50%;
  }

  .cmp-topper-heading--pg1-hero {
    font-size: clamp(0.875rem, 1.5vw, 1rem);
    color: var(--clr-blue-100);
  }

  .hero-text {
    font-size: var(--fs-hero-text);
    color: var(--text-body-white);
    max-width: 45ch;
    margin-inline: auto;
    margin-bottom: 1.75rem;

    span {
      color: var(--clr-blue-100);
    }

    @media (width > 47.5rem) {
      margin-inline: initial;
    }
  }

  .hero__image-main-container {
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
    max-width: 100%;
    bottom: 4rem;
    animation: pulsate-bck 10s ease-out 10s infinite;
  }

  .hero__image-main {
    display: none;
    position: relative;
    width: 100%;
    max-width: 7rem;
    height: auto;
    object-fit: contain;
    margin-top: 3rem;
    opacity: 0;
    filter: drop-shadow(4px 2px 4px rgba(0, 0, 0, 0.334))
      drop-shadow(6px 2px 8px rgba(0, 0, 0, 0.256));

    &.small-image {
      display: block;
    }

    @media (width > 47.5rem) {
      max-width: unset;
      margin-top: 1rem;
      filter: drop-shadow(6px 4px 4px rgba(0, 0, 0, 0.41))
        drop-shadow(8px 4px 8px rgba(0, 0, 0, 0.364));

      &.large-image {
        display: block;
      }

      &.small-image {
        display: none;
        opacity: 1;
      }
    }

    @media (width > 83.5rem) {
      left: 3rem;
    }

    @media (prefers-reduced-motion: reduce) {
      opacity: 1;
    }
  }

  .hero__image-main.slide-in-elliptic {
    animation: slide-in-elliptic 3s ease-out forwards;
    /* prettier-ignore */
    animation-timing-function: cubic-bezier(1, 0.4, 0.2, 1);
  }

  .cmp-main-btn--pg1-hero:first-of-type {
    margin-right: 1rem;
    color: var(--text-primary-dark);

    &:hover {
      box-shadow: 2px 2px 10px var(--bg-btn-active);
      text-shadow: 1px 1px 20px var(--clr-lighter-white);
    }
  }

  .cmp-main-btn--pg1-hero:last-of-type {
    background-color: var(--bg-primary-blue);
    color: var(--text-body-white);
    padding: 0.75em 1.5em;

    &:hover {
      box-shadow: inset 2px 2px 10px var(--bg-btn-active);
    }
  }

  .hero__svg-page-decoration {
    position: relative;
    display: block;
    margin-bottom: -3px;
    fill: #fff;
    backface-visibility: hidden;
    will-change: transform;
    transform: scaleX(-1) translateZ(0);
  }
}

@layer utilities {
  .wrapper {
    max-width: calc(81.25rem + 2rem);
    padding-inline: clamp(1rem, 3.5vw, 2rem);
    margin-inline: auto;
  }

  .wrapper--wide {
    max-width: calc(87.5rem + 2rem);
  }

  .wrapper--mobile-L {
    @media (width < 62.5rem) {
      max-width: calc(35.62rem + 2rem);
    }
  }

  .wrapper--mobile-S {
    @media (width < 47.5rem) {
      max-width: calc(35.62rem + 2rem);
    }
  }

  .wrapper--mobile-XS {
    @media (width < 47.5rem) {
      max-width: calc(31.25rem + 2rem);
    }
  }

  .hidden {
    display: none;
  }

  .visually-hidden {
    position: absolute;
    height: 1px;
    width: 1px;
    margin: -1px;
    overflow: hidden;
    white-space: nowrap;
    border: 0;
    clip: rect(0 0 0 0);
    clip-path: inset(50%);
  }

  .skip-to-content:not(:focus) {
    clip: rect(0 0 0 0);
    clip-path: inset(50%);
    height: 1px;
    overflow: hidden;
    position: absolute;
    white-space: nowrap;
    width: 1px;
    transform: translateY(-5rem);
  }

  .skip-to-content {
    position: absolute;
    color: #fff;
    font-size: 1.5rem;
    font-weight: 700;
    left: 1rem;
    top: 7rem;
    transition: transform 1s ease-out;
    /* prettier-ignore */
    transition-timing-function: linear( 0, 0.544 5.5%, 0.947 11.5%, 1.213 18.1%, 1.298 21.7%, 1.352 25.5%, 1.372 28.2%, 1.379 31.1%, 1.374 34.2%, 1.357 37.6%, 1.307 43.7%, 1.121 61.8%, 1.074 67.8%, 1.04 73.7%, 1.007 84.7%, 1
    );
  }
}

@layer animations {
  @keyframes slide-in-elliptic {
    0% {
      transform: translateX(800px) rotateY(30deg) scale(0);
      transform-origin: -250% 50%;
      opacity: 0;
    }
    100% {
      transform: translateX(0) rotateY(0) scale(1);
      transform-origin: 1800px 50%;
      opacity: 1;
    }
  }

  @keyframes pulsate-bck {
    0% {
      transform: scale(1);
    }
    50% {
      transform: scale(0.95);
    }
    100% {
      transform: scale(1);
    }
  }

  @keyframes roll-in {
    0% {
      transform: translateX(800px) rotate(540deg);
      opacity: 0;
    }
    100% {
      transform: translateX(0) rotate(0deg);
      opacity: 1;
    }
  }

  @keyframes circle-in-L {
    /* For larger screens */
    from {
      clip-path: circle(0% at 50% 0%);
    }
    to {
      clip-path: circle(100% at 50% 0%);
    }
  }

  @keyframes circle-in-S {
    /* For mobile screens */
    from {
      clip-path: circle(0% at 50% 0%);
    }
    to {
      clip-path: circle(130% at 50% 0%);
    }
  }

  @keyframes circle-out {
    from {
      translate: 0 0;
    }
    to {
      translate: -100% 0;
    }
  }

  @keyframes rotate-diagonal-small-s {
    from {
      transform: rotate3d(1, 10, 10, -180deg);
      transform-origin: 100% 0%;
    }
    to {
      opacity: 1;
      transform: rotate3d(1, 1, 0, 0deg);
      transform-origin: 100% 0%;
    }
  }

  @keyframes rotate-diagonal-large-s {
    from {
      transform: rotate3d(1, 1, 0, -180deg);
      transform-origin: 100% 0%;
    }
    to {
      opacity: 1;
      transform: rotate3d(1, 1, 0, 0deg);
      transform-origin: 100% 0%;
    }
  }
}
