/* =========================================================
   INFRAESTRUCTURA PAGE
   ========================================================= */

.page-content--infrastructure {
  --infra-blue: #0b84b7;
  --infra-gray: #707070;
  --infra-border: #bdbdbd;
  --infra-gap: 44px;
  width: min(1280px, calc(100% - 96px));
  margin: 106px auto 220px;
}

.infrastructure-title {
  margin: 0 0 66px;
  color: var(--infra-blue);
  font-size: clamp(2.35rem, 4.4vw, 4rem);
  font-weight: 300;
  line-height: 1.08;
  text-align: center;
}

.infrastructure-section {
  margin-top: 48px;
}

.infrastructure-section__title {
  margin: 0 0 14px;
  color: var(--infra-blue);
  font-size: clamp(2rem, 3.2vw, 3rem);
  font-weight: 300;
  line-height: 1.08;
}

.infrastructure-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 44px 28px;
  align-items: stretch;
}

.infrastructure-grid--intro {
  margin-bottom: 48px;
}

.infrastructure-card,
.infrastructure-photo-card {
  height: 286px;
  min-height: 286px;
  margin: 0;
  border: 1px solid var(--infra-border);
  border-radius: 3px;
  box-sizing: border-box;
}

.infrastructure-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-end;
  padding: 16px 18px 18px;
  background: #fff;
}

.infrastructure-card__icon {
  flex: 1 1 auto;
  width: min(184px, 84%);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 14px;
}

.infrastructure-card__icon img {
  display: block;
  width: 100%;
  max-height: 170px;
  object-fit: contain;
}

.infrastructure-card__icon img[src="#"] {
  visibility: hidden;
}

.infrastructure-card__label {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 72px;
  margin: 0;
  color: var(--infra-blue);
  font-size: clamp(0.78rem, 0.9vw, 0.95rem);
  font-weight: 300;
  line-height: 1.08;
  text-align: center;
  text-transform: uppercase;
}

.infrastructure-photo-card {
  overflow: hidden;
  background: #f2f2f2;
}

.infrastructure-photo-card img {
  display: block;
  width: 100%;
  height: 100%;
  min-height: 286px;
  object-fit: cover;
}

.infrastructure-photo-card img[src="#"] {
  visibility: hidden;
}

.infrastructure-card--empty {
  background: #fff;
}

@media (max-width: 1180px) {
  .page-content--infrastructure {
    width: min(1040px, calc(100% - 48px));
    margin: 84px auto 150px;
  }

  .infrastructure-grid {
    gap: 30px 22px;
  }

  .infrastructure-card,
  .infrastructure-photo-card,
  .infrastructure-photo-card img {
    height: 268px;
    min-height: 268px;
  }

  .infrastructure-card__icon {
    width: min(160px, 82%);
  }

  .infrastructure-card__icon img {
    max-height: 150px;
  }
}

@media (max-width: 860px) {
  .page-content--infrastructure {
    width: min(640px, calc(100% - 36px));
    margin: 64px auto 110px;
  }

  .infrastructure-title {
    margin-bottom: 44px;
  }

  .infrastructure-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 24px;
  }

  .infrastructure-section {
    margin-top: 42px;
  }

  .infrastructure-section__title {
    margin-bottom: 18px;
  }

  .infrastructure-card--empty {
    display: none;
  }
}

@media (max-width: 560px) {
  .page-content--infrastructure {
    width: min(390px, calc(100% - 28px));
    margin: 48px auto 82px;
  }

  .infrastructure-title {
    font-size: clamp(2rem, 9vw, 2.6rem);
    line-height: 1.12;
  }

  .infrastructure-section__title {
    font-size: clamp(1.75rem, 8vw, 2.25rem);
  }

  .infrastructure-grid {
    grid-template-columns: 1fr;
    gap: 18px;
  }

  .infrastructure-card,
  .infrastructure-photo-card,
  .infrastructure-photo-card img {
    height: 250px;
    min-height: 250px;
  }

  .infrastructure-card {
    padding: 22px 16px 20px;
  }

  .infrastructure-card__icon {
    width: min(176px, 88%);
  }

  .infrastructure-card__icon img {
    max-height: 176px;
  }
}
