@import url(app.css);

/* ===== Nosotros (1 página / 3 secciones) ===== */
.about {
  position: relative;
  min-height: calc(100vh - var(--header-h));
  /* antes: overflow:hidden; (puede causar pops con ScrollTrigger) */
  /* overflow-x: hidden; */
}

.about-section {
  position: relative;
  padding: clamp(52px, 6vw, 88px) 0;
  margin-top: 70px;
}

.about-decor {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  opacity: 0.45;
}

.about .plus {
  z-index: 0;
}

/* 1) Misión / Visión */
.mv-grid {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 1fr 1px 1fr;
  gap: 44px;
  align-items: start;
}

.mv-divider {
  width: 1px;
  background: rgba(11, 43, 58, 0.14);
  height: 100%;
  margin-top: 18px;
}

.mv-card {
  text-align: center;
  max-width: 520px;
  margin: 0 auto;
}

.mv-icon img {
  height: 170px;
  width: auto;
}

.mv-title {
  margin: 18px 0 10px;
  font-size: clamp(28px, 3.2vw, 44px);
  color: var(--brand-2);
  letter-spacing: 0.2px;
}

.mv-rule {
  width: 120px;
  height: 2px;
  margin: 14px auto 20px;
  background: linear-gradient(90deg, var(--brand-2), var(--brand));
  border-radius: 999px;
  opacity: 0.85;
}

.mv-text {
  margin: 0 auto;
  max-width: 520px;
  color: rgba(11, 43, 58, 0.78);
  line-height: 1.75;
  font-size: 18px;
}

/* 2) Valores */
.values-grid {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 0.9fr 1.1fr;
  gap: 44px;
  align-items: start;
}

.values-icon img {
  height: 170px;
  width: auto;
}

.values-title {
  margin: 10px 0 12px;
  font-size: clamp(34px, 4vw, 56px);
  color: var(--brand);
}

.values-rule {
  width: 120px;
  height: 2px;
  background: linear-gradient(90deg, var(--brand-2), var(--brand));
  border-radius: 999px;
  opacity: 0.85;
  margin: 12px 0 18px;
}

.values-lead {
  margin: 0;
  color: rgba(11, 43, 58, 0.78);
  line-height: 1.8;
  font-size: 18px;
  max-width: 520px;
}

.values-list {
  display: grid;
  gap: 18px;
}

.value-item {
  color: rgba(11, 43, 58, 0.82);
  line-height: 1.65;
  font-size: 17px;
}

.value-item b {
  color: var(--brand-2);
}

.value-plus {
  display: inline-block;
  width: 26px;
  color: var(--brand);
  font-weight: 900;
}

/* 3) Cobertura */
.about-coverage {
  padding-bottom: 0;
  min-height: 520px;
}

.coverage-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.coverage-bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  opacity: 0.9;
}

.coverage-fade {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    180deg,
    rgba(255, 255, 255, 1) 0%,
    rgba(255, 255, 255, 0.85) 45%,
    rgba(255, 255, 255, 0.35) 75%,
    rgba(255, 255, 255, 0) 100%
  );
}

.coverage-inner {
  position: relative;
  z-index: 1;
  padding-top: clamp(40px, 4vw, 70px);
  padding-bottom: clamp(70px, 7vw, 120px);
}

.coverage-cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 26px;
  align-items: start;
  text-align: center;
}

.coverage-card {
  background: rgba(255, 255, 255, 0.7);
  border: 1px solid rgba(11, 43, 58, 0.08);
  border-radius: 22px;
  padding: 26px 18px;
  box-shadow: 0 14px 40px rgba(7, 7, 54, 0.07);
}

.coverage-ico img {
  height: 100px;
  width: auto;
  padding: 10px;
}

.coverage-card h3 {
  margin: 14px 0 8px;
  font-size: 30px;
  color: var(--brand-2);
}

.coverage-card p {
  margin: 0;
  color: rgba(11, 43, 58, 0.78);
  line-height: 1.6;
  font-size: 18px;
}

/* ===== Performance hints (sin duplicados) ===== */
.mv-card,
.values-left,
.value-item,
.coverage-card,
.coverage-bg img {
  will-change: transform, opacity;
  transform: translateZ(0);
}

/* ===== Anti-glitch: pre-hide de elementos animados (Nosotros) ===== */
.about [data-st] {
  opacity: 0;
  transform: translate3d(0, 18px, 0);
  will-change: transform, opacity;
}

/* Fallback: si por alguna razón ScrollTrigger no corre, mostramos contenido
   (pero sin forzar opacity para no pelear con GSAP/autoAlpha) */
.about.is-st-ready [data-st] {
  transform: none;
}

/* Responsive */
@media (max-width: 980px) {
  .mv-grid {
    grid-template-columns: 1fr;
    gap: 26px;
  }
  .mv-divider {
    display: none;
  }

  .values-grid {
    grid-template-columns: 1fr;
  }

  .coverage-cards {
    grid-template-columns: 1fr;
  }
}
