/* home.css
   Home page add-ons ONLY.
   - Leaves hero image + divider section untouched (those are in style.css)
   - Adds spacing and new content blocks between/around them
   - rem sizing
*/

.home-wrap {
  width: min(1100px, 100%);
  margin: 0 auto;
  padding-inline: clamp(1rem, 4vw, 1.5rem);
}

/* Intro section under hero image */
.home-intro {
  padding: 2.5rem 0 1.25rem;
}

.home-intro__card {
  border-radius: 1.25rem;
  padding: 1.5rem;
  background: rgba(255, 255, 255, 0.92);
  border: 0.0625rem solid rgba(0, 0, 0, 0.08);
  box-shadow: 0 1.2rem 2.6rem rgba(0, 0, 0, 0.08);
}

.home-kicker {
  font-size: 0.95rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  opacity: 0.75;
}

.home-title {
  margin-top: 0.75rem;
  font-size: clamp(1.6rem, 3vw, 2.2rem);
  line-height: 1.15;
  font-weight: 800;
  color: #1b1b1b;
  text-decoration: none;
}

.home-subtitle {
  margin-top: 0.8rem;
  font-size: 1.1rem;
  line-height: 1.7;
  opacity: 0.9;
}

/* CTA buttons */
.home-cta {
  margin-top: 1.15rem;
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
}

.home-btn {
  display: inline-block;
  padding: 0.85rem 1.15rem;
  border-radius: 999px;
  font-size: 1rem;
  font-weight: 700;
  text-decoration: none;
  transition: transform 180ms ease, opacity 180ms ease, box-shadow 180ms ease;
}

.home-btn:hover {
  transform: translateY(-0.08rem);
  opacity: 0.95;
  box-shadow: 0 1rem 2rem rgba(0, 0, 0, 0.15);
}

.home-btn--primary {
  background: #1a237e;
  color: #fff;
}

.home-btn--ghost {
  background: #fff;
  color: #1a237e;
  border: 0.0625rem solid rgba(26, 35, 126, 0.35);
}

/* mini grid */
.home-mini-grid {
  margin-top: 1.25rem;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.85rem;
}

.home-mini {
  border-radius: 1.1rem;
  padding: 1rem;
  background: #ffffff;
  border: 0.0625rem solid rgba(0, 0, 0, 0.08);
  box-shadow: 0 0.9rem 2rem rgba(0, 0, 0, 0.06);
  text-decoration: none;
  color: inherit;
  transition: transform 180ms ease, box-shadow 180ms ease;
}

.home-mini:hover {
  transform: translateY(-0.12rem);
  box-shadow: 0 1.2rem 2.4rem rgba(0, 0, 0, 0.10);
}

.home-mini h3 {
  font-size: 1.25rem;
  font-weight: 800;
  text-decoration: none;
  color: #1b1b1b;
}

.home-mini p {
  margin-top: 0.55rem;
  font-size: 1rem;
  line-height: 1.6;
  opacity: 0.88;
}

/* badges row */
.home-badges {
  margin-top: 1.25rem;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.85rem;
}

.home-badge {
  border-radius: 1.1rem;
  padding: 1rem;
  background: #fff;
  border: 0.0625rem solid rgba(0, 0, 0, 0.08);
  box-shadow: 0 0.9rem 2rem rgba(0, 0, 0, 0.06);

  display: grid;
  grid-template-columns: 6.5rem 1fr;
  align-items: center;
  gap: 0.85rem;
}

.home-badge img {
  width: 100%;
  height: 4.5rem;
  object-fit: contain;
  background: rgba(255, 255, 255, 0.96);
  padding: 0.6rem;
  border-radius: 0.9rem;
}

.home-badge strong {
  display: block;
  font-size: 1.05rem;
}

.home-badge span {
  display: block;
  font-size: 0.95rem;
  opacity: 0.9;
}

/* spacing between hero and divider (requested) */
.home-space {
  height: 2.25rem;
}

/* after divider section */
.home-after {
  padding: 3rem 0 2rem;
}

.home-section-header {
  text-align: center;
  max-width: 75ch;
  margin: 0 auto;
}

.home-section-title {
  font-size: clamp(1.6rem, 2.8vw, 2rem);
  font-weight: 800;
  color: #1b1b1b;
  text-decoration: none;
}

.home-section-lead {
  margin-top: 0.75rem;
  font-size: 1.1rem;
  line-height: 1.7;
  opacity: 0.9;
}

/* content cards */
.home-cards {
  margin-top: 1.6rem;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}

.home-card {
  border-radius: 1.25rem;
  padding: 1.25rem;
  background: #fff;
  border: 0.0625rem solid rgba(0, 0, 0, 0.08);
  box-shadow: 0 1.1rem 2.4rem rgba(0, 0, 0, 0.07);
  transition: transform 180ms ease, box-shadow 180ms ease;
}

.home-card:hover {
  transform: translateY(-0.12rem);
  box-shadow: 0 1.4rem 2.8rem rgba(0, 0, 0, 0.10);
}

.home-card h3 {
  font-size: 1.25rem;
  font-weight: 800;
  text-decoration: none;
  color: #1b1b1b;
}

.home-card p {
  margin-top: 0.7rem;
  font-size: 1rem;
  line-height: 1.7;
  opacity: 0.9;
}

/* corporate logos */
.home-partners {
  padding: 2.75rem 0 3.25rem;
  background: #f6f6f6;
}

.home-logos {
  margin-top: 1.25rem;
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 1rem;
  align-items: center;
}

.home-logo {
  border-radius: 1.25rem;
  background: #fff;
  border: 0.0625rem solid rgba(0, 0, 0, 0.08);
  box-shadow: 0 1.1rem 2.4rem rgba(0, 0, 0, 0.06);
  padding: 1rem;
  display: grid;
  place-items: center;
  transition: transform 180ms ease, box-shadow 180ms ease;
}

.home-logo:hover {
  transform: translateY(-0.12rem);
  box-shadow: 0 1.4rem 2.8rem rgba(0, 0, 0, 0.10);
}

.home-logo img {
  width: 100%;
  max-height: 4.75rem;
  object-fit: contain;
  box-shadow: none;
}

/* responsive */
@media (max-width: 992px) {
  .home-mini-grid {
    grid-template-columns: 1fr;
  }
  .home-badges {
    grid-template-columns: 1fr;
  }
  .home-cards {
    grid-template-columns: 1fr;
  }
  .home-logos {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 600px) {
  .home-intro {
    padding: 2rem 0 1rem;
  }
  .home-space {
    height: 1.5rem;
  }
}
