* {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}
body {
  font-family: 'Geologica', sans-serif;
  background: #0e100f;
  color: #fffce1;
}
.page {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
  min-height: 100vh;
}
.block {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
  overflow: hidden;
}
.wrapper {
  max-width: 1200px;
  width: 100%;
  padding: 120px 32px;
}
.hero {
  background: #a681ff;
  position: relative;
  overflow: hidden;
}
.picture,
.picture * {
  box-sizing: border-box;
}
.picture {
  flex-shrink: 0;
  height: 1000px;
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  pointer-events: none;
  z-index: 0;
}
.ellipse-7 {
  border-radius: 50%;
  border: 2px solid #8fff72;
  width: 1200px;
  height: 1200px;
  position: absolute;
  left: 50%;
  top: 0;
  transform: translateX(-50%);
  aspect-ratio: 1;
}
.ellipse-8 {
  border-radius: 50%;
  border: 2px solid #8fff72;
  opacity: 0.5;
  width: 800px;
  height: 800px;
  position: absolute;
  left: 50%;
  top: 200px;
  transform: translateX(-50%);
  aspect-ratio: 1;
}
.ellipse-9 {
  border-radius: 50%;
  border: 2px solid #8fff72;
  opacity: 0.8;
  width: 1100px;
  height: 1100px;
  position: absolute;
  left: 50%;
  top: 50px;
  transform: translateX(-50%);
  aspect-ratio: 1;
}
.hero-key-icon {
  display: inline-block;
  vertical-align: middle;
  margin: 0 4px;
}
.hero-bg {
  position: absolute;
  left: 156px;
  top: -194px;
  width: 1200px;
  height: 1200px;
}
.hero .wrapper {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 60px;
  text-align: center;
}
.hero-logo {
  height: 160px;
  width: 300px;
  display: block;
  flex-shrink: 0;
}
.hero h1 {
  font-size: 60px;
  font-weight: 700;
  color: #0e100f;
  line-height: 1;
}
.hero .subtitle {
  font-size: 40px;
  font-weight: 400;
  color: #0e100f;
  line-height: 1.4;
}
.hero .desc {
  font-size: 20px;
  font-weight: 400;
  color: #0e100f;
  line-height: 1.4;
}
.dark {
  background: #0e100f;
}
.dark .wrapper {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 80px;
}
.benefits-row {
  display: flex;
  gap: 60px;
  align-items: center;
  justify-content: center;
  width: 100%;
}
.benefits-text {
  font-size: 20px;
  line-height: 1.4;
  width: 500px;
}
.benefits-text p {
  margin-bottom: 20px;
}
.benefits-text p:last-child {
  margin-bottom: 0;
}
.benefits-img {
  width: 500px;
  height: 500px;
  flex-shrink: 0;
}
.icons-row {
  display: flex;
  gap: 80px;
  justify-content: center;
  width: 100%;
  flex-wrap: wrap;
}
.icon-card {
  flex: 1;
  min-width: 150px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 24px;
}
.icon-card img,
.icon-card svg {
  width: 80px;
  height: 80px;
}
.icon-card p {
  font-size: 16px;
  text-align: center;
  line-height: 1.4;
}
.btn {
  background: #8fff72;
  color: #0e100f;
  font-weight: 700;
  font-size: 16px;
  padding: 16px 32px;
  border-radius: 1000px;
  border: none;
  cursor: pointer;
  text-decoration: none;
  display: inline-block;
}
.purple {
  background: #a681ff;
}
.purple .wrapper {
  display: flex;
  flex-direction: column;
  gap: 60px;
  align-items: flex-start;
}
.purple h2 {
  font-size: 60px;
  font-weight: 700;
  color: #0e100f;
  text-align: center;
  width: 100%;
}
.why-row {
  display: flex;
  gap: 60px;
  align-items: center;
  justify-content: center;
  width: 100%;
}
.why-picture {
  width: 400px;
  height: 400px;
  flex-shrink: 0;
  position: relative;
  overflow: hidden;
}
.why-picture .why-img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}
.why-text {
  font-size: 20px;
  color: #0e100f;
  width: 500px;
  line-height: 1.4;
}
.why-text p {
  margin-bottom: 20px;
}
.why-text .bold {
  font-weight: 700;
}
.cta-section .wrapper {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding-top: 120px;
  position: relative;
  z-index: 1;
}
.cta-section h2 {
  font-size: 52px;
  font-weight: 700;
  text-align: center;
  line-height: 1;
}
.cta-section .highlight {
  color: #8fff72;
}
.cta-section .desc {
  font-size: 20px;
  text-align: center;
  line-height: 1.4;
}
.cta-section .desc p {
  margin-bottom: 0;
}
.ellipse-5,
.ellipse-5 * {
  box-sizing: border-box;
}

.ellipse-5 {
  background: #0e100f;
  border-radius: 50%;
  width: 800px;
  height: 800px;
  position: absolute;
  left: 50%;
  top: 120%;
  transform: translate(-50%, -50%);
  z-index: 0;
}

.ellipse-6,
.ellipse-6 * {
  box-sizing: border-box;
}

.ellipse-6 {
  background: #8fff72;
  border-radius: 50%;
  width: 800px;
  height: 800px;
  position: absolute;
  left: 50%;
  top: 120%;
  transform: translate(-50%, -50%);
  filter: blur(100px);
  z-index: 0;
}

.cta-section {
  position: relative;
  overflow: hidden;
  min-height: 1100px;
}

.cta-img {
  width: 100%;
  max-width: 200px;
  position: absolute;
  top: 75%;
}
img {
  max-width: 100%;
  height: auto;
  display: block;
}

/* Mobile / Tablet (max-width: 1199px) */
@media screen and (max-width: 1199px) {
  .hero .wrapper {
    padding: 60px 24px;
    gap: 24px;
  }

  .hero .picture {
    width: 100%;
    height: 500px;
  }

  .hero .picture .ellipse-7 {
    width: 600px;
    height: 600px;
    bottom: 0;
    top: auto;
  }

  .hero .picture .ellipse-8 {
    width: 400px;
    height: 400px;
    bottom: 20%;
    top: auto;
  }

  .hero .picture .ellipse-9 {
    width: 550px;
    height: 550px;
    bottom: 5%;
    top: auto;
  }

  .hero-logo {
    width: 240px;
    height: 128px;
  }

  .hero h1 {
    font-size: 40px;
  }

  .hero .subtitle {
    font-size: 24px;
  }

  .hero .desc {
    font-size: 16px;
  }

  /* Dark block (Benefits) */
  .dark .wrapper {
    padding: 60px 24px;
    gap: 80px;
  }

  .dark .benefits-row {
    flex-direction: column-reverse;
    gap: 40px;
    align-items: center;
  }

  .dark .benefits-text {
    font-size: 16px;
    width: 100%;
    max-width: 100%;
    text-align: left;
  }

  .dark .benefits-img {
    width: 345px;
    height: 345px;
    aspect-ratio: 1;
  }

  .dark .icons-row {
    gap: 40px;
    flex-wrap: wrap;
    justify-content: center;
  }

  .dark .icon-card {
    width: 150px;
    min-width: 150px;
    gap: 24px;
  }

  /* Purple block (Why Enter) */
  .purple .wrapper {
    padding: 60px 24px;
    gap: 60px;
    align-items: flex-start;
  }

  .purple h2 {
    font-size: 40px;
  }

  .purple .why-row {
    flex-direction: column;
    gap: 40px;
    align-items: center;
  }

  .purple .why-picture {
    width: 400px;
    height: 400px;
    max-width: 100%;
  }

  .purple .why-text {
    font-size: 16px;
    width: 100%;
    max-width: 100%;
    text-align: left;
  }

  .ellipse-5 {
    top: 115%;
  }

  .ellipse-6 {
    top: 115%;
  }

  .cta-img {
    top: 70%;
  }
}
