/* ============================================
   Home Page Styles
   ============================================ */

/* ── S1 Hero ──
   Layout inherited from .page-hero (components.css).
   Only page-specific overrides below.
   ─────────────────────────────────────────────────── */
/* .hero height/min-height는 .page-hero(80vh/560) 기본값 사용 — 기획서 80vh 통일 */
.hero {
  align-items: center;
  justify-content: flex-start;
}

.hero .page-hero__bg img {
  animation: heroZoom 8s var(--ease-out) forwards;
}

.hero .page-hero__content {
  padding: var(--space-3xl) var(--space-2xl);
}

.hero .page-hero__sub {
  font-size: clamp(15px, 1.3vw, 21px);
  font-weight: 400;
  opacity: 0.9;
}

/* 모바일에서는 content가 가장 많아 flex-end로 GNB 겹침 방지 (height는 .page-hero 80vh 기본값 사용) */
@media (max-width: 767px) {
  .hero {
    align-items: flex-end;
  }
  .hero .page-hero__bg img { object-position: 45% center; }
}

/* ── S2 Foundation ── */
.foundation {
  text-align: left;
}

.foundation .card .icon {
  transition: transform 0.3s var(--ease-out);
}

.foundation .card:hover .icon {
  transform: rotate(8deg);
}

/* ── S3 Services at a Glance ── */
.services-glance .card {
  min-height: 320px;
}

.services-glance__footer {
  text-align: center;
  margin-top: var(--space-2xl);
}

@media (max-width: 767px) {
  .services-glance .card { min-height: 280px; }
}

/* ── S4 Why WIZMO (Split dark) ── */
.why-wizmo {
  background: var(--color-bg-dark);
  color: var(--color-text-invert);
  padding: 0;
}

.why-wizmo .split__content {
  gap: var(--space-xl);
}

.why-wizmo .reason {
  display: flex;
  gap: var(--space-md);
}

.why-wizmo .reason__icon {
  flex-shrink: 0;
  width: 40px;
  height: 40px;
  stroke-width: 1.4;
  stroke: currentColor;
  fill: none;
  margin-top: 2px;
}

.why-wizmo .reason__body {
  flex: 1;
}

.why-wizmo .reason__body p {
  font-size: 16px;
  line-height: 1.65;
  opacity: 0.8;
  margin-top: 8px;
}

.why-wizmo .card__divider {
  background: var(--color-text-invert);
}

/* ── S5 Fleet Preview ── */
.fleet-preview {
  background: var(--color-bg-surface);
}

.fleet-preview__intro {
  margin-top: var(--space-md);
}

.fleet-preview .card__image {
  aspect-ratio: 4 / 3;
  overflow: hidden;
  margin: -32px -28px 24px;
  border-radius: 4px 4px 0 0;
}

.fleet-preview .card__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.4s var(--ease-out);
}

.fleet-preview .card:hover .card__image img {
  transform: scale(1.03);
}

.fleet-preview .card__meta {
  font-size: 15px;
  color: var(--color-text-sub);
  margin-top: 4px;
}

.fleet-preview__footer {
  text-align: center;
  margin-top: var(--space-2xl);
}

/* ── S6a Spotlight ── */
.spotlight .split {
  align-items: center;
}

.spotlight .split__media {
  aspect-ratio: 4 / 3;
}

.spotlight .split__media img {
  border-radius: 8px;
  object-fit: contain;
}

/* ── S6b Testimonials ── */
.testimonials {
  padding-top: var(--space-2xl);
}

.testimonials__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-2xl);
}

.quote {
  font-size: 19px;
  line-height: 1.6;
  font-style: normal;
  position: relative;
  padding-left: var(--space-lg);
  border-left: 3px solid var(--color-primary);
}

.quote__author {
  margin-top: var(--space-md);
  font-style: normal;
  font-size: 16px;
  font-weight: 600;
}

.quote__title {
  font-style: normal;
  font-size: 15px;
  color: var(--color-text-sub);
}

@media (max-width: 767px) {
  .testimonials__grid {
    grid-template-columns: 1fr;
  }
}

/* ── S7a Who We Serve ── */
.who-serve .card {
  padding: var(--space-xl);
}

/* ── S7b Coverage (Split) ── */
.coverage {
  display: grid;
  grid-template-columns: 1fr 1fr;
}

.coverage__map {
  background: var(--color-bg-dark);
  position: relative;
  overflow: hidden;
}

.coverage__map img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.coverage__list {
  padding: var(--space-3xl) var(--space-2xl);
  display: flex;
  flex-direction: column;
  justify-content: center;
  max-width: 640px;
}

.coverage__item {
  display: flex;
  gap: var(--space-md);
  padding: var(--space-md) 0;
  border-bottom: 1px solid var(--color-border-light);
}

.coverage__icon {
  width: 24px;
  height: 24px;
  flex-shrink: 0;
  color: var(--color-primary);
}

.coverage__locations {
  font-size: 17px;
  line-height: 1.6;
}

.coverage__locations strong {
  font-weight: 700;
}

@media (max-width: 1023px) {
  .coverage {
    grid-template-columns: 1fr;
  }
  .coverage__map {
    aspect-ratio: 16 / 9;
  }
}

/* ── S7c Partner Trust ── */
.partner-trust {
  text-align: center;
  padding: var(--space-3xl) 0;
}

.partner-trust__text {
  font-size: 19px;
  max-width: 680px;
  margin: 0 auto;
}

.partner-trust__sub {
  font-size: 16px;
  color: var(--color-text-sub);
  margin-top: var(--space-sm);
}

.partner-trust__logos {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: var(--space-md);
  max-width: 800px;
  margin: var(--space-xl) auto 0;
}

.partner-trust__logo-slot {
  aspect-ratio: 3 / 2;
  border: 1px dashed var(--color-border-light);
  border-radius: 4px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  color: var(--color-text-sub);
}

.partner-trust__cta {
  margin-top: var(--space-lg);
}

@media (max-width: 767px) {
  .partner-trust__logos {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* ── S8 Final CTA — moved to components.css ──
