.service-page {
  padding: 6rem 1.5rem;
}


.service-hero {
  text-align: center;
  margin-bottom: 2rem;
}

.service-hero h1 {
  font-size: var(--fs-service-hero-title);
  line-height: 1.15;
}

.service-hero-text {
  max-width: 760px;
  margin: 1.25rem auto 0;
  font-size: var(--fs-service-hero-text);
  line-height: 1.65;
  opacity: 0.9;
}

.service-intro {
  max-width: 820px;
  margin: 0 auto 3.5rem;
  text-align: center;
}

.service-intro p {
  font-size: var(--fs-body);
  line-height: 1.75;
  opacity: 0.9;
  margin-bottom: 1.2rem;
}

.service-intro p:last-child {
  margin-bottom: 0;
}


.service-features {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 350px), 350px));
  gap: 2rem;
  margin-bottom: 6rem;
  justify-content: center;

}

.feature-card {
  width: min(100%, 350px);
  box-sizing: border-box;
  justify-self: center;
  position: relative;
  overflow: hidden;

  border: 2px solid transparent;
  border-radius: 20px;
  background:
    linear-gradient(rgba(2, 6, 23, 0.9), rgba(2, 6, 23, 0.9)) padding-box,
    linear-gradient(135deg, #4BE3ED, #4B73F4, #694BF4, #C137EB) border-box;

  padding: 2rem;
  text-align: center;
  opacity: 0;
  transform: translateY(30px);
  transition:
    opacity 0.4s ease,
    transform 0.4s ease,
    box-shadow 0.25s ease;
  will-change: transform, opacity;
}



.feature-card:hover {
  transform: translateY(-6px);
  box-shadow:
    0 0 35px rgba(75, 223, 255, 0.25),
    0 0 65px rgba(186, 43, 251, 0.25);
}

.feature-card h3 {
  margin-bottom: 0.75rem;
  font-size: var(--fs-service-card-title);
}

.feature-card p {
  font-size: var(--fs-service-card-text);
  opacity: 0.85;
}

.feature-card.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.service-cta {
  position: relative;
  text-align: center;
  padding: 4rem 2rem;

  background:
    linear-gradient(180deg,
      rgba(15, 23, 42, 0.75),
      rgba(15, 23, 42, 0.55));

  backdrop-filter: blur(18px) saturate(140%);
  -webkit-backdrop-filter: blur(18px) saturate(140%);

  border-radius: 28px;

  border: 1px solid rgba(255, 255, 255, 0.18);

  box-shadow:
    0 25px 80px rgba(0, 0, 0, 0.55),
    inset 0 1px 0 rgba(255, 255, 255, 0.08);

  overflow: hidden;
  transition:
    transform 0.3s ease,
    box-shadow 0.3s ease;
}

.service-cta::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 28px;
  padding: 1px;

  background: linear-gradient(135deg,
      #4BE3ED,
      #4B73F4,
      #694BF4,
      #C137EB);

  mask:
    linear-gradient(#000 0 0) content-box,
    linear-gradient(#000 0 0);

  -webkit-mask:
    linear-gradient(#000 0 0) content-box,
    linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;

  pointer-events: none;
}


.service-cta h2 {
  font-size: var(--fs-service-cta-title);
  margin-bottom: 1rem;
}

.service-cta p {
  max-width: 640px;
  margin: 0 auto 2rem;
  opacity: 0.85;
  font-size: var(--fs-service-cta-text);
}

@media (max-width: 779px){
.service-features {
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 250px), 250px));
}

.feature-card {
  width: min(100%, 250px);
}
}

@media (max-width: 579px){
.service-features {
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 250px), 250px));
}

.feature-card {
  width: min(100%, 250px);
}
}
