:root {
  --color-primary: #6d7bff;
  --color-accent: #fdc134;
  --color-text-main: #1e364c;
  --brand-mixed: #2E4470;
  --color-text-muted: #607086;
  --color-bg-section: #ffffff;
  --color-check: #fdc134;
}

/* =========================
   HERO NUEVO - SOLUCIONES
   ========================= */

.hero--new {
  padding: 140px 0 32px;
  position: relative;
}
.services-page .hero--new .container {
  position: relative;
  z-index: 1;
}

.hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.9fr);
  gap: 72px;
  align-items: flex-start;
}

.hero-content {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
}

.hero-description-text {
  text-align: left;
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
  margin-top: 0;
  max-width: 560px;
}

.services-page .hero-content {
  text-align: left;
  align-items: flex-start;
}

.services-page .hero-content h1,
.services-page .hero-content .hero-title {
  text-align: left;
}


.hero-description-text p {
  font-size: 18px;
  line-height: 1.5;
  font-weight: 400;
  margin-top: 70px;
  color: #ffffff;
}

.hero-arrow {
  margin-top: 32px;
  display: flex;
  justify-content: center;
  margin-bottom: -24px;
}

.hero-arrow-icon {
  width: 120px;
  height: 120px;
  color: var(--color-accent);
  stroke-width: 3.5;
  stroke-linecap: round;
  stroke-linejoin: round;
  margin-top: 4px;
  animation: bounceDown 2s infinite;

}

/* .hero-arrow-icon path {
  stroke: var(--gold-600) !important;
  stroke-width: 6 !important;
  stroke-linecap: round !important;
  stroke-linejoin: round !important;
  fill: none !important;
} */

@media (max-width: 1024px) {
  .hero--new {
    padding: 130px 0 32px;
  }

  .hero-grid {
    gap: 48px;
  }

  .hero-description-text {
    margin-top: 0;
    max-width: 100%;
  }
  .hero-content {
    text-align: left;
  }
}

@media (max-width: 900px) {
  .hero--new {
    padding: 120px 0 32px;
  }

  .hero-grid {
    grid-template-columns: 1fr;
    gap: 24px; 
  }

  .hero-content {
    text-align: left;
  }

  .hero-description-text {
    margin-top: 0;
    text-align: left;
    align-items: flex-start;
    gap: 0.75rem; 
  }

  .hero-description-text p {
    margin-top: 12px;   
    font-size: 15px;    
    line-height: 1.5;
  }

  .hero-arrow {
    margin-top: 16px;
    margin-bottom: -16px;
  }

  .hero-arrow svg {
    margin: 0 auto;
  }
  .hero-arrow-icon {
  width: 80px;
  height: 80px;
  stroke-width: 2.5;

}
}



/* =========================
   SECCIÓN SERVICIOS
   ========================= */

.services-section {
  position: relative;
  padding: 40px 0 100px;
  background: var(--color-bg-section);
}

.services-section::before {
  content: "brackiabrackiabrackia\A rackiabrackiabrackia\A ackiabrackiabrackia\A kiabrackiabrackia\A iabrackiabrackia\A brackiabrackiabrackia\A rackiabrackiabrackia\A ackiabrackiabrackia\A ckiabrackiabrackia\A ckiabrackiabrackia";
  position: absolute;
  left: 0%;
  right: -10%;
  top: -8%;    
  font-size: 260px;
  font-weight: 700;
  line-height: 0.8;
  text-transform: lowercase;
  color: rgba(109, 123, 255, 0.04);
  white-space: pre;
  pointer-events: none;
  z-index: 0;
}

.services-section .services-container {
  position: relative;
  z-index: 1;
}

.services-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  row-gap: 72px;
}

.service-card {
  max-width: 520px;
}

.service-card:nth-child(odd) {
  margin-left: 0;
  margin-right: auto;
}


.service-card:nth-child(even) {
  margin-left: auto;
  margin-right: 0;
  text-align: right;
}


.service-card:nth-child(even) .service-title,
.service-card:nth-child(even) .service-text,
.service-card:nth-child(even) .service-tag,
.service-card:nth-child(even) .service-benefits {
  text-align: right;
}

.service-card:nth-child(even) .service-benefits {
  display: inline-block;
  text-align: left;
  margin-top: 8px;
}

.service-title {
  font-size: 24px;
  line-height: 1.4;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--brand-mixed);
  margin: 0 0 12px;
}

.service-text {
  font-size: 15px;
  line-height: 1.7;
  color: var(--color-text-muted);
  margin: 0 0 20px;
}

.service-tag {
  font-size: 14px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: var(--color-accent);
  margin: 0 0 8px;
}

.service-benefits {
  list-style: none;
  margin: 0;
  padding: 0;
}

.service-benefits li {
  position: relative;
  padding-left: 22px;
  font-size: 14px;
  line-height: 1.8;
  color: var(--color-text-main);
}

.service-benefits li::before {
  content: "✓";
  position: absolute;
  left: 0;
  top: 0.1em;
  font-size: 14px;
  font-weight: 700;
  color: var(--color-check);
}



@media (max-width: 992px) {
  .services-section {
    padding: 72px 0 88px;
  }

  .services-grid {
    grid-template-columns: minmax(0, 1fr);
    row-gap: 56px;
  }

  .service-card {
    max-width: none;
  }
}

@media (max-width: 600px) {
  .service-title {
    font-size: 18px;  
    line-height: 1.4;
  }

  .service-text,
  .service-benefits li {
    font-size: 13px; 
  }
}
