a {
  text-decoration: none;
}

.textAnimationClass {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
}

.textAnimationClassNav {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
}

.textAnimationClassContainer {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
}

.hidden {
  opacity: 0;
}

.absolute {
  position: absolute;
}

/* Fonts */
@font-face {
  font-family: NeueHaasNormal;
  src: url("./fonts/NeueHaasDisplayMedium.ttf");
}
@font-face {
  font-family: NeueHaasThin;
  src: url("./fonts/NeueHaasDisplayThin.ttf");
}
@font-face {
  font-family: NeueHaasBold;
  src: url("./fonts/NeueHaasDisplayBold.ttf");
}
/* No Select */
.noselect,
img {
  -webkit-touch-callout: none; /* iOS Safari */
  -webkit-user-select: none; /* Safari */ /* Konqueror HTML */
  -moz-user-select: none; /* Old versions of Firefox */ /* Internet Explorer/Edge */
  user-select: none; /* Non-prefixed version, currently
   supported by Chrome, Edge, Opera and Firefox */
}

.invisible {
  opacity: 0 !important;
  pointer-events: none !important;
}

input,
textarea,
button,
select,
a,
svg,
div {
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}

*::-moz-selection {
  color: #250e61;
  background-color: #ffffff;
  text-shadow: none;
}

*::selection {
  color: #250e61;
  background-color: #ffffff;
  text-shadow: none;
}

/* width */
::-webkit-scrollbar {
  width: 0;
  -webkit-user-select: auto;
          user-select: auto;
}

/* Track */
/* Handle */
/* Defaults */
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

html {
  font-size: 10px;
  width: 100%;
  height: 100vh;
  overflow-x: hidden;
  overflow-y: scroll;
  /* cursor: none; */
  font-family: NeueHaasNormal;
}

body {
  z-index: 100;
  box-sizing: border-box;
  width: 100%;
  overflow-x: hidden;
  font-size: 10px;
}

.webgl {
  position: fixed;
  top: 0;
  outline: none;
  box-sizing: border-box;
  width: 100vw;
  height: 100vh;
  z-index: 999;
  pointer-events: none;
}

main {
  position: relative;
  z-index: 1;
  background-color: #250e61;
  pointer-events: auto;
}

.scrollStartSection {
  width: 100%;
}

/* Loading Page */
.loadingPage {
  position: fixed;
  width: 100vw;
  height: 100vh;
  z-index: 9999999999;
  display: flex;
  justify-content: center;
  align-items: center;
  pointer-events: none;
  background-color: #250e61;
}

.playSection {
  width: 100%;
  height: 100%;
  position: fixed;
  -webkit-backdrop-filter: blur(10px);
          backdrop-filter: blur(10px);
  z-index: 8888888;
  display: flex;
  justify-content: center;
  align-items: center;
}

.playSectionButton {
  color: #ffffff;
  font-size: 3rem;
  cursor: pointer;
  opacity: 0;
  font-family: NeueHaasNormal;
  padding: 2rem;
  border-radius: 2rem;
  background-image: linear-gradient(to bottom right, rgba(255, 249, 233, 0.1254901961) 0%, rgba(216, 255, 255, 0.1254901961) 50%, rgba(255, 217, 255, 0.1254901961) 100%);
  -webkit-backdrop-filter: blur(1px);
          backdrop-filter: blur(1px);
  box-shadow: 0 0 0.5rem 0.1rem rgba(0, 0, 0, 0.1882352941);
  text-shadow: 0 0 5px rgba(0, 0, 0, 0.3137254902);
}

/* Hero Section */
.heroSection {
  position: relative;
  width: 100vw;
  height: 100vh;
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-direction: column;
  overflow: hidden;
  padding: 10rem;
  z-index: 9999;
}

.heroSectionTop {
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  flex-direction: row-reverse;
}

.heroSectionLogoImage {
  max-width: 70vw;
  opacity: 0;
}

.heroSectionBackgroundImage {
  width: 100%;
  z-index: -2;
  position: absolute;
  bottom: 0;
}

.heroSectionText {
  display: flex;
  justify-content: flex-start;
  align-items: flex-start;
  flex-direction: column;
  font-size: 8rem;
}

.heroSectionTextTop {
  display: flex;
  justify-content: flex-start;
  align-items: flex-start;
  flex-direction: row;
}

.heroSectionBottom {
  width: 100%;
  display: flex;
  justify-content: flex-end;
  align-items: flex-end;
}

.heroSectionScrollDown {
  display: flex;
  justify-content: center;
  align-items: center;
  opacity: 0;
}

.heroSectionScrollDownText {
  position: absolute;
}

.deliveredSection {
  position: relative;
  width: 100vw;
  display: flex;
  justify-content: center;
  align-items: flex-start;
  padding-block: 10rem;
  gap: 5rem;
  overflow: hidden;
  z-index: 1;
  padding-left: min(10rem, 5vw);
  pointer-events: auto;
}

.deliveredSectionMiniHeader {
  font-size: 1.2rem;
  color: #7ccefa;
  white-space: nowrap;
  border: 2px solid #7ccefa;
  padding: 1rem;
  border-radius: 10rem;
  font-weight: bold;
  font-family: NeueHaasThin;
}

.deliveredSectionMarquee {
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 8rem;
  gap: 3.7rem;
  white-space: nowrap;
  text-shadow: 1px 1px #ffffff, -1px 1px #ffffff, 1px -1px #ffffff, -1px -1px #ffffff;
  color: #250e61;
  font-family: NeueHaasNormal;
}

.deliverSectionMarqueeContainer {
  height: 8.5rem;
  width: 100%;
  display: flex;
  justify-content: flex-start;
  align-items: center;
  overflow: hidden;
}

.deliveredSectionMarqueeFade {
  position: absolute;
  width: 100%;
  height: 100%;
  z-index: 10;
  background-image: linear-gradient(to right, #250e61 0%, rgba(37, 14, 97, 0) 10%);
  pointer-events: none;
}

.searchSection {
  position: relative;
  width: 100vw;
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: 9999;
}

.searchSectionContainer {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  padding-top: 8.5rem;
  padding-inline: 12.5rem;
  background-color: #e4eaf6;
  gap: 2rem;
  box-shadow: 0 2rem 3rem 0.1rem rgba(0, 0, 0, 0.3764705882);
}

.searchSectionBar {
  position: relative;
  width: 50vw;
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: #250e61;
  padding-inline: 1.4rem;
  padding-block: 0.7rem;
  gap: 1.4rem;
  border-radius: 0.5rem 0.5rem 0rem 0rem;
}

.searchSectionDotContainer {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0.5rem;
}

.searchSectionDot {
  width: 1rem;
  height: 1rem;
  border-radius: 50%;
}

#searchSectionDot1 {
  background-color: #e4eaf6;
}

#searchSectionDot2 {
  background-color: #7ccefa;
}

#searchSectionDot3 {
  background-color: #fbc372;
}

.searchSectionTextbox {
  width: 100%;
  background-color: white;
  display: flex;
  justify-content: flex-start;
  align-items: center;
  padding: 0.6rem;
  border-radius: 10rem;
  gap: 0.5rem;
  padding-left: 1rem;
  font-family: "Open Sans", sans-serif;
  color: #8d8d8d;
  font-size: 1.1rem;
}

.searchSectionPrivateImage {
  height: 1rem;
}

.searchImage {
  width: 50vw;
}

.descriptionSection {
  position: relative;
  z-index: 9999;
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  font-family: NeueHaasNormal;
  font-size: 5.1rem;
  padding-top: 13.5rem;
  padding-bottom: 40rem;
}

.descriptionSectionContainer {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
}

.descriptionSectionTextTop {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: row;
  text-align: center;
}

.descriptionSectionTextBottom {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: row;
  text-align: center;
}

.darkBlueText {
  color: #250e61;
}

.lightBlueText {
  color: #7ccefa;
}

.whiteText {
  color: #ffffff;
}

.assumptionsSection {
  position: relative;
  width: 100%;
  padding-top: 26.5rem;
  background-color: #7ccefa;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  padding-inline: min(10rem, 5vw);
}

.assumptionsSectionLeft {
  display: flex;
  justify-content: flex-start;
  align-items: flex-start;
  flex-direction: column;
  gap: 5rem;
  padding-left: min(10rem, 5vw);
  width: calc(50vw - min(10rem, 5vw) - 12.5rem);
}

.assumptionsSectionMiniHeader {
  font-size: 1.2rem;
  color: #250e61;
  white-space: nowrap;
  border: 2px solid #250e61;
  padding: 1rem;
  border-radius: 10rem;
  font-weight: bold;
  font-family: NeueHaasThin;
}

.assumptionsSectionHeader {
  font-size: 8rem;
  font-family: NeueHaasBold;
  color: #250e61;
}

.assumptionsSectionBody {
  font-size: 3rem;
  font-family: NeueHaasNormal;
  color: #ffffff;
}

.assumptionsSectionRight {
  width: calc(50vw - min(10rem, 5vw) - 12.5rem);
  overflow: hidden;
  border: 1rem solid #250e61;
  border-radius: 2.7rem;
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: #250e61;
  box-shadow: 0 2rem 3rem 0.1rem rgba(0, 0, 0, 0.062745098);
}

.assumptionsSectionImage {
  width: 100%;
}

.extraSection {
  position: relative;
  background-color: #7ccefa;
  width: 100%;
  padding-top: 5rem;
  padding-bottom: 10rem;
  padding-inline: min(10rem, 5vw);
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.extraSectionImageContainer {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 3rem;
  overflow: hidden;
  width: calc(50vw - min(20rem, 10vw));
  z-index: 10;
}

.extraSectionImage {
  position: relative;
  width: 100%;
  transform: scale(1.1);
}

.extraSectionExtras {
  position: relative;
  display: flex;
  justify-content: space-evenly;
  align-items: center;
  width: calc(50vw - min(18rem, 9vw));
}

.extraSectionIconSet {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  gap: 2rem;
  width: 11rem;
  z-index: 10;
}

.extraSectionIconContainer {
  display: flex;
  justify-content: center;
  align-items: center;
  background-image: linear-gradient(to top right, #e4eaf6 0%, #bfd3ee 100%);
  padding: 3rem;
  width: 11rem;
  height: 11rem;
  border-radius: 3rem;
  box-shadow: 0 0 1rem 0.2rem rgba(0, 0, 0, 0.1254901961);
}

.extraSectionIcon {
  position: absolute;
}

.extraSectionIconLabel {
  font-size: 2.6rem;
  font-family: NeueHaasNormal;
  color: #250e61;
  position: relative;
  text-shadow: -1px 1px #e4eaf6, 1px -1px #e4eaf6, 1px 1px #e4eaf6, -1px -1px #e4eaf6;
}

.extraSectionBubble1 {
  position: absolute;
  right: -15vw;
  top: -20vw;
  width: 50vw;
  pointer-events: none;
}

.extraSectionBubble2 {
  position: absolute;
  right: -15vw;
  top: -20vw;
  filter: blur(1px);
  width: 50vw;
  pointer-events: none;
}

.extraSectionBubble3 {
  position: absolute;
  right: -15vw;
  top: -20vw;
  filter: blur(1px);
  width: 50vw;
  pointer-events: none;
}

.uiSection {
  position: relative;
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: #ffffff;
  padding-block: 10rem;
}

.uiSectionLeft {
  position: relative;
  display: flex;
  justify-content: flex-start;
  align-items: flex-start;
  flex-direction: column;
  gap: 5rem;
  z-index: 10;
  width: 50%;
  padding-left: min(20rem, 10vw);
}

.uiSectionMiniHeader {
  font-size: 1.2rem;
  color: #7ccefa;
  white-space: nowrap;
  border: 2px solid #7ccefa;
  padding: 1rem;
  border-radius: 10rem;
  font-weight: bold;
  font-family: NeueHaasThin;
}

.uiSectionHeader {
  font-size: 6rem;
  line-height: 6rem;
  z-index: 1;
  font-family: NeueHaasNormal;
}

.uiSectionBody {
  position: relative;
  font-family: "Roboto", sans-serif;
  font-weight: 300;
  font-style: normal;
  color: #919191;
  font-size: 3rem;
  padding-right: 12rem;
  font-family: NeueHaasNormal;
}

.uiSectionRight {
  position: relative;
  width: 55rem;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 5rem;
  z-index: 0;
  width: 50%;
}

.uiSectionMobile {
  position: relative;
  width: 23.75rem;
  height: 47.5rem;
  overflow: hidden;
  border-radius: 2rem;
  display: flex;
  justify-content: center;
  align-items: flex-start;
  background-color: #250e61;
}

.uiSectionMobileImage {
  width: 100%;
}

#uiSectionMobileImage1 {
  border: 0.7rem solid #250e61;
}

#uiSectionMobileImage2 {
  border: 0.7rem solid #7ccefa;
}

.mobileSection {
  position: relative;
  width: 100%;
  height: 100vh;
  background-color: #dee6f5;
  display: flex;
  justify-content: center;
  align-items: center;
  overflow: hidden;
  z-index: -1;
}

.mobileSectionLogoContainer {
  position: absolute;
  top: 0;
  width: 100%;
  height: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  overflow: hidden;
  z-index: 1;
}

.mobileSectionParallax {
  position: relative;
  width: 100%;
  height: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
}

.mobileSectionLogoImage {
  width: max(15vw, 30rem);
}

.mobileSectionLogoImageShadow {
  width: max(15vw, 30rem);
  margin-top: 2px;
  filter: brightness(0.5) blur(2px);
  position: absolute;
  z-index: -1;
}

.mobileSectionTilt {
  position: relative;
  height: 100%;
  display: flex;
  justify-content: space-between;
  gap: 10rem;
  align-items: center;
  transform: rotateZ(30deg);
}

.mobileSectionColumn {
  position: relative;
  width: 52rem;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  gap: 10rem;
}

.mobileSectionContainer {
  position: relative;
  width: 100%;
  height: 65rem;
  overflow: hidden;
  border-radius: 2rem;
  box-shadow: 0 0 0vw 0.5vw #7ccefa, 0 0 1vw 1vw rgba(0, 0, 0, 0.1019607843);
}

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

.goalSection {
  position: relative;
  width: 100%;
  background-color: #ffffff;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  padding-block: 12rem;
}

.goalSectionMiniHeader {
  font-size: 1.2rem;
  color: #7ccefa;
  white-space: nowrap;
  border: 2px solid #7ccefa;
  padding: 1rem;
  border-radius: 10rem;
  font-weight: bold;
  font-family: NeueHaasThin;
}

.goalSectionHeader {
  color: #250e61;
  font-size: 6rem;
  padding-block: 5rem;
}

.goalSectionBody {
  color: #919191;
  font-size: 3rem;
  width: min(80rem, 90vw);
  text-align: center;
}

.goalSectionWireframeHeader {
  padding-top: 10rem;
  padding-bottom: 5rem;
  font-size: 1.8rem;
  color: #909090;
}

.goalSectionWireframes {
  position: relative;
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  padding-inline: min(10rem, 5vw);
  gap: min(5rem, 2.5vw);
}

.goalSectionWireframesLeft {
  position: relative;
  width: 50%;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: min(5rem, 2.5vw);
  flex-direction: column;
}

.goalSectionWireframeContainer {
  position: relative;
  width: calc(50vw - min(12.5rem, 6.25vw));
  height: calc((50vw - min(12.5rem, 6.25vw)) * 9 / 16);
  overflow: hidden;
}

#goalSectionWireframeContainer1 {
  border-radius: 3rem 1rem 1rem 1rem;
}

#goalSectionWireframeContainer2 {
  border-radius: 1rem 1rem 1rem 3rem;
}

.goalSectionWireframeContainerLarge {
  position: relative;
  width: calc(50vw - min(12.5rem, 6.25vw));
  height: calc((50vw - min(12.5rem, 6.25vw)) * 9 / 16 * 2 + min(5rem, 2.5vw));
  overflow: hidden;
  border-radius: 1rem 3rem 3rem 1rem;
}

.goalSectionWireframeImage {
  width: 100%;
}

#goalSectionWireframeImage2 {
  margin-top: -222%;
}

#goalSectionWireframeImage3 {
  margin-top: -65%;
}

/* Responsive */
@media screen and (max-width: 1800px) {
  html {
    font-size: 9px;
  }
}
@media screen and (max-width: 1600px) {
  html {
    font-size: 8px;
  }
}
@media screen and (max-width: 1300px) {
  html {
    font-size: 7px;
  }
}
@media screen and (max-width: 1100px) {
  html {
    font-size: 7px;
  }
  .heroSectionTop {
    align-items: center;
    flex-direction: column;
  }
  .heroSectionBottom {
    justify-content: center;
    padding-bottom: 10rem;
  }
  .heroSectionText {
    padding-top: 10rem;
  }
  .descriptionSection {
    font-size: 4rem;
  }
  .assumptionsSection {
    flex-direction: column-reverse;
  }
  .assumptionsSectionLeft {
    padding-left: 0;
    width: 100%;
  }
  .assumptionsSectionRight {
    width: 100%;
  }
  .extraSection {
    flex-direction: column;
    gap: 10rem;
  }
  .extraSectionImageContainer {
    width: 100%;
  }
  .extraSectionExtras {
    width: 100%;
  }
  .uiSectionLeft {
    width: 100%;
    padding-left: min(10rem, 5vw);
  }
  .uiSectionRight {
    width: 100%;
  }
}
@media screen and (max-width: 750px) {
  html {
    font-size: 6px;
  }
  .searchSectionContainer {
    padding-inline: 2.5vw;
  }
  .searchSectionBar {
    width: 90vw;
  }
  .searchImage {
    width: 90vw;
  }
  .uiSection {
    flex-direction: column;
    gap: 10rem;
  }
  .heroSectionText {
    font-size: 5rem;
  }
  .heroSectionTextTop {
    flex-direction: column;
  }
  .descriptionSectionTextTop, .descriptionSectionTextBottom {
    flex-direction: column;
  }
}/*# sourceMappingURL=index.css.map */