/* ============================================================
   about.css — About Page
   ============================================================ */

/* ---- Hero ---- */
.about-hero {
  position: relative;
  min-height: 70vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 10rem 1.5rem 6rem;
  overflow: hidden;
}
.about-hero__bg {
  position: absolute;
  inset: 0;
  background-image: url('https://images.unsplash.com/photo-1596422846543-75c6fc197f07?auto=format&fit=crop&w=1600&q=80');
  background-size: cover;
  background-position: center;
  z-index: 0;
}
.about-hero__bg::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(5,5,5,0.65) 0%, rgba(5,5,5,0.82) 100%);
}
.about-hero__inner {
  position: relative;
  z-index: 1;
  max-width: 680px;
  margin: 0 auto;
}
.about-hero__eyebrow {
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--color-primary);
  margin-bottom: 1rem;
}
.about-hero h1 {
  font-size: clamp(3rem, 8vw, 7rem);
  line-height: 1;
  margin-bottom: 1.25rem;
}
.about-hero p {
  font-size: 1.1rem;
  color: var(--color-text-muted);
  max-width: 480px;
  margin: 0 auto;
  line-height: 1.65;
}
.about-hero__scroll {
  position: absolute;
  bottom: 2rem;
  left: 50%;
  transform: translateX(-50%);
  z-index: 1;
}
.about-hero__scroll span {
  display: block;
  width: 1px;
  height: 48px;
  background: linear-gradient(to bottom, var(--color-primary), transparent);
  margin: 0 auto;
  animation: scrollLine 1.8s ease-in-out infinite;
}
@keyframes scrollLine {
  0%   { opacity: 0; transform: scaleY(0); transform-origin: top; }
  40%  { opacity: 1; transform: scaleY(1); }
  80%  { opacity: 0; transform: scaleY(1); transform-origin: bottom; }
  100% { opacity: 0; }
}

/* ---- Shared section wrapper ---- */
.about-section {
  padding: 6rem 0;
}
.about-section:nth-child(even) { background: var(--color-bg-alt); }

.about-section__header {
  text-align: center;
  max-width: 600px;
  margin: 0 auto 3.5rem;
}
.about-section__header h2 {
  margin-top: 0.5rem;
}

.about-tag {
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--color-primary);
}

/* ---- Origin story ---- */
.about-origin {
  padding: 6rem 0;
}
.about-origin__inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 5rem;
  align-items: center;
}
.about-origin__text {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
}
.about-origin__text h2 {
  line-height: 1.1;
  margin: 0;
}
.about-origin__text p {
  color: var(--color-text-muted);
  line-height: 1.75;
  font-size: 0.97rem;
}
.about-origin__visual { position: relative; }
.about-origin__img-wrap {
  position: relative;
  border-radius: var(--radius-card);
  overflow: hidden;
  aspect-ratio: 4/3;
}
.about-origin__img-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.7s ease;
}
.about-origin__img-wrap:hover img { transform: scale(1.04); }
.about-origin__badge {
  position: absolute;
  bottom: -1.25rem;
  left: -1.25rem;
  background: var(--color-primary);
  color: #000;
  border-radius: var(--radius-card);
  padding: 1rem 1.4rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.1rem;
  font-family: var(--font-heading);
  box-shadow: 0 8px 32px rgba(246,177,36,0.35);
}
.about-origin__badge strong {
  font-size: 0.65rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  font-family: var(--font-body);
  font-weight: 700;
  opacity: 0.7;
}
.about-origin__badge span {
  font-size: 2.4rem;
  font-family: var(--font-heading);
  line-height: 1;
}

/* ---- Stats ---- */
.about-stats {
  padding: 4rem 0;
  background: var(--color-primary);
}
.about-stats__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
}
.stat-item {
  text-align: center;
  padding: 2rem 1rem;
  position: relative;
}
.stat-item + .stat-item::before {
  content: '';
  position: absolute;
  left: 0; top: 20%; bottom: 20%;
  width: 1px;
  background: rgba(0,0,0,0.15);
}
.stat-item__number {
  font-family: var(--font-heading);
  font-size: clamp(2.4rem, 4vw, 3.5rem);
  color: #000;
  line-height: 1;
}
.stat-item__unit {
  font-family: var(--font-heading);
  font-size: 1.6rem;
  color: rgba(0,0,0,0.55);
  line-height: 1;
}
.stat-item__label {
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(0,0,0,0.6);
  margin-top: 0.4rem;
}

/* ---- Why grid ---- */
.about-why { background: var(--color-bg-alt); }
.why-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
}
.why-card {
  background: rgba(255,255,255,0.03);
  border: 1px solid var(--color-border-subtle);
  border-radius: var(--radius-card);
  padding: 2rem 1.75rem;
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
  transition: border-color var(--transition), background var(--transition);
}
.why-card:hover {
  border-color: rgba(246,177,36,0.35);
  background: rgba(246,177,36,0.04);
}
.why-card__icon {
  width: 44px;
  height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(246,177,36,0.12);
  border-radius: 10px;
  color: var(--color-primary);
}
.why-card__icon svg { width: 22px; height: 22px; }
.why-card h3 {
  font-size: 1rem;
  font-weight: 600;
  margin: 0;
}
.why-card p {
  font-size: 0.875rem;
  color: var(--color-text-muted);
  line-height: 1.7;
  margin: 0;
}

/* ---- Photo strip ---- */
.about-photostrip {
  overflow: hidden;
  padding: 0;
}
.photostrip__track {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
}
.photostrip__item {
  aspect-ratio: 3/2;
  overflow: hidden;
}
.photostrip__item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.6s ease;
}
.photostrip__item:hover img { transform: scale(1.06); }

/* ---- Journey editorial rows ---- */
.about-journey {
  padding: 6rem 0;
  background: var(--color-bg);
}
.journey__top {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2rem 4rem;
  align-items: end;
  margin-bottom: 3.5rem;
  padding-bottom: 3rem;
  border-bottom: 1px solid var(--color-border-subtle);
}
.journey__top h2 { margin: 0.4rem 0 0; }
.journey__intro-text {
  font-size: 1rem;
  color: var(--color-text-muted);
  line-height: 1.7;
  max-width: 440px;
  justify-self: end;
  align-self: end;
  margin: 0;
}

.jl {
  list-style: none;
  padding: 0;
  margin: 0;
}

.jl__row {
  display: grid;
  grid-template-columns: 110px 1px 1fr auto;
  gap: 0 2.5rem;
  align-items: center;
  padding: 2rem 0;
  border-bottom: 1px solid var(--color-border-subtle);
  position: relative;
  cursor: default;
  transition: background 0.25s ease;
}
.jl__row:first-child { border-top: 1px solid var(--color-border-subtle); }
.jl__row:hover { background: rgba(246,177,36,0.03); }
.jl__row:hover .jl__year { color: var(--color-primary); }

.jl__year {
  font-family: var(--font-heading);
  font-size: 3rem;
  color: rgba(246,177,36,0.55);
  line-height: 1;
  transition: color 0.25s ease;
  letter-spacing: 0.02em;
}

.jl__sep {
  background: var(--color-border-subtle);
  align-self: stretch;
  margin: 0.5rem 0;
  width: 1px;
}

.jl__body { padding: 0.25rem 0; }
.jl__body h3 {
  font-size: 1rem;
  font-weight: 600;
  margin: 0 0 0.35rem;
  line-height: 1.3;
}
.jl__body p {
  font-size: 0.85rem;
  color: var(--color-text-muted);
  line-height: 1.7;
  max-width: 520px;
  margin: 0;
}

/* right-side badges */
.jl__flag {
  font-size: 1.6rem;
  line-height: 1;
  justify-self: end;
  align-self: center;
}
.jl__tag-pill,
.jl__stat-pill,
.jl__now-pill {
  justify-self: end;
  align-self: center;
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 0.3rem 0.65rem;
  border-radius: 999px;
  white-space: nowrap;
}
.jl__tag-pill {
  color: var(--color-primary);
  border: 1px solid rgba(246,177,36,0.35);
  background: rgba(246,177,36,0.07);
}
.jl__stat-pill {
  color: var(--color-text-muted);
  border: 1px solid var(--color-border-subtle);
  background: rgba(255,255,255,0.04);
}
.jl__now-pill {
  color: #000;
  background: var(--color-primary);
  border: 1px solid var(--color-primary);
}

/* current row highlight */
.jl__row--now {
  background: rgba(246,177,36,0.04);
}
.jl__row--now .jl__year {
  color: var(--color-primary);
}
.jl__row--now .jl__body h3 {
  color: var(--color-primary);
}

/* ---- Service areas ---- */
.about-areas { background: var(--color-bg-alt); }
.areas-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
}
.area-card {
  background: rgba(255,255,255,0.03);
  border: 1px solid var(--color-border-subtle);
  border-radius: var(--radius-card);
  padding: 2rem 1.75rem 2.25rem;
  transition: border-color var(--transition);
}
.area-card:hover { border-color: rgba(246,177,36,0.3); }
.area-card__flag {
  font-size: 2.2rem;
  line-height: 1;
  margin-bottom: 0.85rem;
}
.area-card h3 {
  font-size: 1.1rem;
  font-weight: 600;
  margin: 0 0 1rem;
  color: var(--color-text);
}
.area-card__list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0.55rem;
}
.area-card__list li {
  font-size: 0.875rem;
  color: var(--color-text-muted);
  padding-left: 1rem;
  position: relative;
}
.area-card__list li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0.55em;
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: var(--color-primary);
}

/* ---- Driver promise ---- */
.about-promise {
  padding: 6rem 0;
}
.about-promise__inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 5rem;
  align-items: center;
}
.about-promise__visual {
  border-radius: var(--radius-card);
  overflow: hidden;
  aspect-ratio: 4/3;
}
.about-promise__visual img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.7s ease;
}
.about-promise__visual:hover img { transform: scale(1.04); }
.about-promise__text {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
}
.about-promise__text h2 {
  line-height: 1.1;
  margin: 0;
}
.about-promise__text p {
  color: var(--color-text-muted);
  line-height: 1.75;
  font-size: 0.97rem;
}
.promise-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}
.promise-list li {
  display: flex;
  align-items: center;
  gap: 0.65rem;
  font-size: 0.9rem;
  color: var(--color-text-muted);
}
.promise-list svg {
  width: 16px;
  height: 16px;
  color: var(--color-primary);
  flex-shrink: 0;
}

/* ---- CTA ---- */
.about-cta {
  padding: 6rem 0;
  background: var(--color-bg-alt);
  text-align: center;
}
.about-cta__inner {
  max-width: 560px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1.25rem;
}
.about-cta h2 {
  margin: 0;
}
.about-cta p {
  color: var(--color-text-muted);
  font-size: 1rem;
}
.about-cta__btns {
  display: flex;
  gap: 0.85rem;
  flex-wrap: wrap;
  justify-content: center;
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 900px) {
  .about-origin__inner,
  .about-promise__inner {
    grid-template-columns: 1fr;
    gap: 2.5rem;
  }
  .about-promise__inner { direction: ltr; }
  .about-origin__badge { bottom: -1rem; left: 0; }
  .why-grid { grid-template-columns: 1fr 1fr; }
  .areas-grid { grid-template-columns: 1fr; gap: 1rem; }
  .about-stats__grid { grid-template-columns: repeat(2, 1fr); }
  .stat-item:nth-child(3)::before { display: none; }
  .photostrip__track { grid-template-columns: repeat(3, 1fr); }
  .photostrip__track .photostrip__item:nth-child(n+4) { display: none; }
  .journey__top { grid-template-columns: 1fr; gap: 1rem; }
  .journey__intro-text { justify-self: start; max-width: 100%; }
  .jl__row { grid-template-columns: 80px 1px 1fr auto; gap: 0 1.5rem; }
  .jl__year { font-size: 2.2rem; }
}
@media (max-width: 600px) {
  .about-hero { min-height: 60vh; padding: 8rem 1.25rem 4rem; }
  .why-grid { grid-template-columns: 1fr; }
  .about-stats__grid { grid-template-columns: repeat(2, 1fr); }
  .jl__row { grid-template-columns: 64px 1px 1fr; gap: 0 1.25rem; padding: 1.5rem 0; }
  .jl__flag, .jl__tag-pill, .jl__stat-pill, .jl__now-pill { display: none; }
  .jl__year { font-size: 1.8rem; }
  .photostrip__track { grid-template-columns: repeat(2, 1fr); }
  .photostrip__track .photostrip__item:nth-child(n+3) { display: none; }
  .about-cta__btns { flex-direction: column; align-items: stretch; }
  .about-cta__btns .btn { text-align: center; }
}
