/* ============================================================
   PatchPlus — About (page-scoped styles)
   Implemented from PatchPlus-About.dc.html
   Reuses shared classes from styles.css (.h2, .eyebrow, .btn*,
   [data-reveal], .nav*, .footer*). Only About-specific layout
   and hover rules live here.
   ============================================================ */

/* ---------- About hero (dark band) ---------- */
.about-hero {
  background: #1A1A1A;
  color: #FAF9F5;
  position: relative;
  overflow: hidden;
}
.about-hero__stripe {
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 6px;
  background-image: repeating-linear-gradient(180deg, #1A1A1A 0 14px, #89BF4A 14px 28px);
}
.about-hero__inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 84px 24px 72px;
}
.about-hero__eyebrow {
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #A8D65A;
  margin-bottom: 16px;
}
.about-hero__title {
  font-family: 'Archivo Black', sans-serif;
  font-size: clamp(40px, 6vw, 76px);
  line-height: 0.98;
  letter-spacing: -0.02em;
  text-transform: uppercase;
  margin: 0 0 20px;
  max-width: 16ch;
}
.about-hero__lede {
  font-size: clamp(16px, 1.5vw, 19px);
  line-height: 1.6;
  color: #D1D1CD;
  max-width: 600px;
  margin: 0;
}

/* ---------- Story ---------- */
.about-story {
  max-width: 920px;
  margin: 0 auto;
  padding: 88px 24px 24px;
}
.about-story__title {
  font-family: 'Archivo Black', sans-serif;
  font-size: clamp(26px, 3vw, 38px);
  line-height: 1.08;
  letter-spacing: -0.01em;
  text-transform: uppercase;
  margin: 0 0 24px;
}
.about-story__p {
  font-size: 17px;
  line-height: 1.75;
  color: #3A3A3A;
  margin: 0 0 18px;
}
.about-story__p--last { margin: 0; }

/* ---------- PatchPal connection ---------- */
.about-conn {
  max-width: 1200px;
  margin: 0 auto;
  padding: 64px 24px 88px;
}
.about-conn__card {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 56px;
  align-items: center;
  background: #fff;
  border: 1px solid #E8E8E5;
  border-radius: 20px;
  overflow: hidden;
}
.about-conn__media {
  aspect-ratio: 1 / 1;
  background: #F1F0EB;
}
.about-conn__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.about-conn__body {
  padding: 48px 48px 48px 8px;
}
.about-conn__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #3D7A1A;
  margin-bottom: 14px;
}
.about-conn__dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #89BF4A;
}
.about-conn__title {
  font-family: 'Archivo Black', sans-serif;
  font-size: clamp(24px, 2.6vw, 34px);
  line-height: 1.08;
  letter-spacing: -0.01em;
  text-transform: uppercase;
  margin: 0 0 16px;
}
.about-conn__text {
  font-size: 16px;
  line-height: 1.7;
  color: #5F5F5B;
  margin: 0 0 16px;
}
.about-conn__stats {
  display: flex;
  gap: 28px;
  flex-wrap: wrap;
  margin-top: 8px;
}
.about-conn__stat-num {
  font-family: 'Archivo Black', sans-serif;
  font-size: 30px;
  color: #1A1A1A;
  line-height: 1;
}
.about-conn__stat-num .unit { font-size: 18px; }
.about-conn__stat-label {
  font-size: 13px;
  color: #5F5F5B;
  margin-top: 4px;
}

/* ---------- Company details ---------- */
.about-details {
  max-width: 1200px;
  margin: 0 auto;
  padding: 88px 24px;
}
.about-details__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1px;
  background: #E8E8E5;
  border: 1px solid #E8E8E5;
  border-radius: 16px;
  overflow: hidden;
}
.about-details__cell {
  background: #fff;
  padding: 32px 28px;
}
.about-details__label {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #8A8A85;
  margin-bottom: 10px;
}
.about-details__value {
  font-weight: 700;
  font-size: 16px;
}
.about-details__value--addr {
  font-size: 15px;
  line-height: 1.5;
}

/* ---------- CTA band (dark, right hatch) ---------- */
.about-cta {
  padding: 0 24px 88px;
}
.about-cta__box {
  max-width: 1200px;
  margin: 0 auto;
  background: #1A1A1A;
  border-radius: 22px;
  padding: 60px 56px;
  position: relative;
  overflow: hidden;
  color: #FAF9F5;
}
.about-cta__hatch {
  position: absolute;
  right: 0; top: 0; bottom: 0;
  width: 10px;
  background-image: repeating-linear-gradient(180deg, #1A1A1A 0 14px, #89BF4A 14px 28px);
}
.about-cta__content { max-width: 620px; }
.about-cta__title {
  font-family: 'Archivo Black', sans-serif;
  font-size: clamp(26px, 3.2vw, 40px);
  line-height: 1.05;
  letter-spacing: -0.01em;
  text-transform: uppercase;
  color: #fff;
  margin: 0 0 16px;
}
.about-cta__text {
  margin: 0 0 28px;
  font-size: 16px;
  line-height: 1.6;
  color: #D1D1CD;
  max-width: 520px;
}

/* ---------- Responsive ---------- */
@media (max-width: 860px) {
  .about-hero__inner { padding: 64px 20px 56px; }
  .about-story { padding: 64px 20px 16px; }
  .about-conn { padding: 48px 20px 64px; }

  /* Stack image-then-text: image on top, body below reads sensibly */
  .about-conn__card {
    grid-template-columns: 1fr;
    gap: 0;
  }
  .about-conn__media { aspect-ratio: 16 / 10; }
  .about-conn__body { padding: 36px 28px; }

  .about-details { padding: 64px 20px; }
  .about-details__grid { grid-template-columns: 1fr; }

  .about-cta { padding: 0 20px 64px; }
  .about-cta__box { padding: 44px 28px; }
}
