#hero {
  min-height: 75vw;
}

.layer {
  min-height: 85vw;
}

.layer-bg {
  background-image: url(./assets/images/our-app-layer-bg.svg);
}

.layer-1 {
  background-image: url(./assets/images/our-app-layer-1.svg);
  background-position-x: right;
}

.layer-2 {
  background-image: url(./assets/images/our-app-layer-2.svg);
}

.layer-3 {
  background-image: url(./assets/images/our-app-layer-3.svg);
  background-position: bottom center;
  background-size: contain;
}

.layer-4 {
  background-image: url(./assets/images/our-app-layer-4.svg);
  background-position: bottom center;
  background-size: contain;
}

.bg-effect {
  background-image: url(../assets/images/our-app-bg.svg);
  background-size: cover;
  background-position: right 130px;
  background-repeat: no-repeat;
  position: absolute;
  z-index: 0;
  height: 160%;
  width: 100%;
  top: 0;
  left: 0;
}

.section-water-layer {
  position: relative;
}
.section-water-layer::before {
  content: "";
  height: 144px;
  position: absolute;
  top: 0;
  width: 100%;
  z-index: 1;
  transform: translateY(-100%);
  background: linear-gradient(0deg, rgb(230, 240, 230) 1%, rgba(253, 187, 45, 0) 98%);
}
.section-water-layer img {
  width: 100%;
  object-fit: cover;
  object-position: bottom center;
  height: auto;
}

.banner-content {
  display: flex;
  min-height: 100vh;
  padding-top: 10rem;
  justify-content: space-between;
}
.banner-content .banner-content-left h1 {
  color: #3399fe;
  font-size: 72px;
  font-weight: 700;
  line-height: 119%;
  letter-spacing: -2.4px;
  max-width: 567px;
  padding-bottom: 33px;
  padding-top: 8rem;
}
.banner-content .banner-content-left p {
  color: #3e3e3e;
  font-size: 21px;
  font-weight: 500;
  line-height: 140%;
}
.banner-content .banner-content-right img {
  user-select: none;
}

@media (min-width: 1920px) {
  .banner-content {
    max-width: 118rem;
    padding-top: 20rem;
  }
  .banner-content .banner-content-left {
    width: 50%;
  }
  .banner-content .banner-content-left h1 {
    font-size: 6.5rem;
  }
  .banner-content .banner-content-left p {
    font-size: 2.3rem;
    max-width: 58rem;
  }
  .banner-content .banner-content-right {
    width: 50%;
  }
  .banner-content .banner-content-right img {
    width: 100%;
    height: auto;
  }
}
@media (max-width: 1250px) {
  .banner-content .banner-content-right img {
    width: 480px;
    height: 480px;
  }
}
@media (max-width: 992px) {
  .banner-content {
    flex-direction: column;
    align-items: center;
    padding-top: 16vw;
  }
  .banner-content .banner-content-left {
    width: 100%;
  }
  .banner-content .banner-content-left h1 {
    text-align: center;
    margin-left: auto;
    margin-right: auto;
    padding-top: 0;
  }
  .banner-content .banner-content-left p {
    max-width: 567px;
    text-align: center;
    margin-left: auto;
    margin-right: auto;
    padding-bottom: 2.4rem;
  }
  .banner-content .banner-content-right {
    width: 100%;
    transform: translate3d(0, 0, 0) !important;
  }
  .banner-content .banner-content-right img {
    width: 580px;
    height: 580px;
    margin-left: auto;
    margin-right: auto;
  }
}
@media (max-width: 768px) {
  .banner-content .banner-content-left h1 {
    font-size: 2.5rem;
    letter-spacing: 0.5px;
    padding-bottom: 1.7rem;
  }
  .banner-content .banner-content-left p {
    font-size: 1rem;
    max-width: 27rem;
    line-height: 138%;
    padding-bottom: 1.5rem;
  }
  .banner-content .banner-content-right img {
    width: 100%;
    height: auto;
    max-width: 500px;
  }
  .layer-bg {
    background-image: url(./assets/images/our-app-layer-bg-mobile.svg);
  }
  .layer-1 {
    background-image: url(./assets/images/our-app-layer-1-mobile.svg);
    background-position-x: right;
  }
  .layer-2 {
    background-image: url(./assets/images/our-app-layer-2-mobile.svg);
    background-position-x: right;
  }
  .layer-3 {
    background-image: url(./assets/images/our-app-layer-3-mobile.svg);
    background-position-x: right;
    background-size: contain;
  }
  .layer-4 {
    background-image: url(./assets/images/our-app-layer-4-mobile.svg);
    background-position-x: left;
    background-size: contain;
  }
  .bg-effect {
    background-image: url(../assets/images/our-app-bg-mobile.svg);
    background-position: right top;
  }
  .section-water-layer img {
    height: 170px;
    object-position: 84%;
  }
}
@media (max-width: 600px) {
  .banner-content {
    padding-top: 33vw;
    min-height: auto;
  }
}
.banner-overlay {
  height: 100px;
  position: absolute;
  bottom: 0;
  width: 100%;
  z-index: 1;
  background: linear-gradient(0deg, rgb(255, 255, 255) 1%, rgba(253, 187, 45, 0) 98%);
}

.section-group {
  background-color: white;
  position: relative;
  padding-top: 120px;
  overflow: hidden;
}
.section-group article {
  position: relative;
}
.section-group article:nth-of-type(odd) .group-content {
  flex-direction: row-reverse;
}
.section-group article .group-content {
  min-height: 900px;
  display: flex;
  align-items: center;
  gap: 40px;
}
.section-group article .group-content .group-content-left {
  width: 50%;
}
.section-group article .group-content .group-content-left h2 {
  color: #3399fe;
  font-size: 60px;
  font-weight: 700;
  line-height: 110%;
  letter-spacing: -2.4px;
  padding-bottom: 34px;
}
.section-group article .group-content .group-content-left p {
  color: #3e3e3e;
  font-size: 21px;
  font-weight: 500;
  line-height: 140%;
}
.section-group article .group-content .group-content-right {
  width: 50%;
}
.section-group article .group-content .group-content-right img {
  width: 100%;
  height: auto;
  user-select: none;
}

@media (min-width: 1920px) {
  .section-group article .group-content {
    max-width: 105rem;
    gap: 125px;
  }
  .section-group article .group-content .group-content-left {
    width: 50%;
  }
  .section-group article .group-content .group-content-left h2 {
    font-size: 88px;
    width: 850px;
  }
  .section-group article .group-content .group-content-left p {
    font-size: 23px;
    max-width: 700px;
  }
  .section-group article .group-content .group-content-right {
    width: 50%;
  }
}
@media (max-width: 1600px) {
  .layer {
    background-size: contain;
  }
  .section-group .bg-effect {
    background-size: contain;
  }
}
@media (max-width: 992px) {
  .layer {
    background-size: cover;
  }
  #hero {
    min-height: 130vw;
  }
  .section-group article .group-content,
  .section-group article:nth-of-type(odd) .group-content {
    flex-direction: column;
  }
  .section-group article .group-content .group-content-left,
  .section-group article:nth-of-type(odd) .group-content .group-content-left {
    width: 100%;
  }
  .section-group article .group-content .group-content-left h2,
  .section-group article .group-content .group-content-left p,
  .section-group article:nth-of-type(odd) .group-content .group-content-left h2,
  .section-group article:nth-of-type(odd) .group-content .group-content-left p {
    text-align: center;
  }
  .section-group article .group-content .group-content-right,
  .section-group article:nth-of-type(odd) .group-content .group-content-right {
    width: 100%;
  }
  .section-group article .group-content .group-content-right img,
  .section-group article:nth-of-type(odd) .group-content .group-content-right img {
    width: 100%;
    height: auto;
    max-width: 500px;
    margin: auto;
  }
}
@media (max-width: 768px) {
  #hero {
    min-height: 108vw;
  }
  .section-group {
    padding-bottom: 0;
  }
  .section-group article .group-content {
    min-height: 800px;
  }
  .section-group article .group-content .group-content-left h2 {
    max-width: 600px;
    margin-left: auto;
    margin-right: auto;
    font-size: 38px;
    letter-spacing: -1px;
    padding-bottom: 18px;
  }
  .section-group article .group-content .group-content-left p {
    line-height: 138%;
    padding-bottom: 1.5rem;
    padding-left: 10px;
    padding-right: 10px;
    font-size: 1rem;
    max-width: 27rem;
    margin-left: auto;
    margin-right: auto;
  }
}
@media (max-width: 600px) {
  #hero {
    min-height: 183vw;
  }
  .banner-content .banner-content-right img {
    max-width: 300px;
  }
  .section-group {
    padding-top: 20px;
  }
  .section-group article .group-content {
    gap: 0;
    min-height: auto;
  }
  .section-group article .group-content .group-content-left h2 {
    font-size: 32px;
    letter-spacing: -0.5px;
    padding: 0 10px 18px;
    text-shadow: 0 0 22px #ffffff;
  }
  .section-group article .group-content .group-content-left p {
    max-width: 334px;
  }
  .section-group article:not(:last-of-type) .group-content {
    padding-bottom: 140px;
  }
}
