/* about.css — page-specific styles for About template */

/* Make hero match the original layout intent (taller than hero--sm) */
.hero--about{
  min-height: 80vh;
}
@media (max-width: 768px){
  .hero--about{ min-height: 70vh; }
}

/* Slightly narrower hero text like in the source template */
.hero__content--about{
  max-width: 58rem;
  padding-top: 3rem;
  padding-bottom: 3rem;
}

/* About sections spacing (source used padding-top:0 + small margin) */
.about-section{
  padding-top: 0;
  margin-top: 12px;
}
.about-narrow{
  max-width: 72rem;
  margin: 0 auto;
}

/* Media blocks */
.about-media{
  border-radius: 18px;
  overflow: hidden;
  width: 100%;
  aspect-ratio: 4 / 3;
}
.about-media img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.about-media--wide{
  aspect-ratio: 21 / 9;
}
.about-media--values{
  margin-top: 1.25rem;
  aspect-ratio: 16 / 9;
}

/* KPI cards */
.about-kpi{
  text-align: center;
  padding: 1.1rem 0;
}
.about-kpi__value{
  font-size: 2.1rem;
  font-weight: 800;
}
.about-kpi__label{
  margin-top: .3rem;
}

/* “What we offer” center header */
.about-centerhead{
  max-width: 48rem;
  margin: 0 auto 2rem;
  text-align: center;
}
.about-centerhead .card-title{
  margin-bottom: .5rem;
}

/* Values grid */
.about-values{
  display: grid;
  gap: 1.2rem;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  margin-top: 1rem;
}
.about-values__title{
  font-weight: 700;
  margin-bottom: .25rem;
}

/* Contact block */
.about-contact{
  margin-top: 1rem;
  display: grid;
  gap: .8rem;
}
.about-contact__row{
  display: grid;
  gap: .2rem;
}
.about-contact__label{
  font-size: .78rem;
  text-transform: uppercase;
  letter-spacing: .18em;
  opacity: .85;
}

/* Bullet list cleanup (if not already in global CSS) */
.list-clean{
  list-style: none;
  margin: .75rem 0 0;
  padding: 0;
  display: grid;
  gap: .45rem;
}
.list-clean li::before{
  content: "• ";
}

/* Responsive layout helpers for About (kept page-scoped) */
.about-grid{
  display: grid;
  gap: 2rem;
  grid-template-columns: minmax(0, 1.05fr) minmax(0, 1.2fr);
  align-items: center;
}
.about-mission{
  display: grid;
  gap: 2rem;
  grid-template-columns: minmax(0, 1.25fr) minmax(0, 1fr);
  align-items: center;
}
.about-visit{
  display: grid;
  gap: 1.75rem;
  grid-template-columns: minmax(0, 1.3fr) minmax(0, 1fr);
  align-items: flex-start;
}
.about-kpis{
  display: grid;
  gap: 1rem;
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

@media (max-width: 1024px){
  .about-grid,
  .about-mission,
  .about-visit{
    grid-template-columns: minmax(0, 1fr);
  }
  .about-visit{ gap: 1.25rem; }
  .about-kpis{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 640px){
  .about-kpis{ grid-template-columns: minmax(0, 1fr); }
  .about-grid,
  .about-mission{ gap: 1.5rem; }
}

/* =========================================================
   FIX: About page grids (What we offer / Our values)
   ========================================================= */

/* 1) What we offer: 4 карточки должны занимать всю ширину (без пустых колонок) */
.about-page .feature-grid,
body.page-about .feature-grid{
  grid-template-columns: 1fr;
  align-items: stretch;
}
@media (min-width: 640px){
  .about-page .feature-grid,
  body.page-about .feature-grid{
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (min-width: 1024px){
  .about-page .feature-grid,
  body.page-about .feature-grid{
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}

/* чтобы карточки растягивались по высоте одинаково */
.about-page .feature-card,
body.page-about .feature-card{
  height: 100%;
  display: flex;
}
.about-page .feature-card__body,
body.page-about .feature-card__body{
  height: 100%;
  display: flex;
  flex-direction: column;
}

/* 2) Our values: делаем аккуратную сетку 3x2 на десктопе (вместо длинной строки) */
.about-page .about-values,
body.page-about .about-values{
  grid-template-columns: 1fr;
}
@media (min-width: 640px){
  .about-page .about-values,
  body.page-about .about-values{
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (min-width: 1024px){
  .about-page .about-values,
  body.page-about .about-values{
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}
