/* Home hero: full-width backdrop + staggered headline */
.ml-hero {
  position: relative;
  isolation: isolate;
  min-height: 70vh;
  display: grid;
  align-items: end;
  padding: 0;
  margin: 0;
  overflow: hidden;
  text-align: left;
}

/* Editorial collage: texture strip + main + detail (replace SVGs with WebP in public/hero/) */
.ml-hero__collage {
  position: absolute;
  inset: 0;
  z-index: 0;
  display: grid;
  grid-template-columns: minmax(7rem, 0.28fr) 1fr;
  grid-template-rows: 1fr minmax(6rem, 0.34fr);
  grid-template-areas:
    "texture main"
    "texture detail";
  gap: 3px;
  background: #120e0a;
}

.ml-hero__panel {
  position: relative;
  overflow: hidden;
  min-height: 0;
}

.ml-hero__panel img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

.ml-hero__panel--texture {
  grid-area: texture;
}

.ml-hero__panel--texture img {
  object-position: 40% center;
}

.ml-hero__panel--main {
  grid-area: main;
}

.ml-hero__panel--detail {
  grid-area: detail;
}

.ml-hero__panel--texture::after,
.ml-hero__panel--main::after,
.ml-hero__panel--detail::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.ml-hero__panel--texture::after {
  background: linear-gradient(90deg, rgba(18, 14, 10, 0.35), transparent 70%);
}

.ml-hero__panel--main::after {
  background:
    linear-gradient(180deg, rgba(18, 14, 10, 0.15), rgba(18, 14, 10, 0.55)),
    linear-gradient(90deg, rgba(18, 14, 10, 0.25), transparent 35%);
}

.ml-hero__panel--detail::after {
  background: linear-gradient(0deg, rgba(18, 14, 10, 0.5), transparent 55%);
}

@media (max-width: 767px) {
  .ml-hero__collage {
    grid-template-columns: 1fr;
    grid-template-rows: minmax(5.5rem, 22vh) 1fr;
    grid-template-areas:
      "texture"
      "main";
  }

  .ml-hero__panel--detail {
    display: none;
  }
}

.ml-hero__overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
  background: rgba(12, 10, 8, 0.4);
  pointer-events: none;
}

.ml-hero__content {
  position: relative;
  z-index: 2;
  max-width: 1280px;
  width: 100%;
  margin: 0 auto;
  padding: var(--ml-space-16) var(--ml-space-6) var(--ml-space-12);
  color: var(--ml-color-text-inverse);
}

.ml-hero__content--stagger > * {
  opacity: 0;
  animation: ml-hero-stagger 0.7s var(--ml-motion-ease-standard) forwards;
}

.ml-hero__content--stagger > *:nth-child(1) { animation-delay: 0.05s; }
.ml-hero__content--stagger > *:nth-child(2) { animation-delay: 0.15s; }
.ml-hero__content--stagger > *:nth-child(3) { animation-delay: 0.28s; }

@keyframes ml-hero-stagger {
  from {
    opacity: 0;
    transform: translateY(12px);
  }
  to {
    opacity: 1;
    transform: none;
  }
}

.ml-hero__tagline {
  font-family: var(--ml-font-family-serif);
  font-size: clamp(1.25rem, 2.5vw, 1.75rem);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  margin: 0 0 var(--ml-space-4);
  color: rgba(255, 248, 240, 0.88);
}

.ml-hero__brand {
  font-family: var(--ml-font-family-serif);
  font-size: clamp(2.5rem, 6vw, 4rem);
  font-weight: var(--ml-font-weight-medium);
  line-height: 1.05;
  margin: 0 0 var(--ml-space-8);
  color: var(--ml-color-text-inverse);
}

.ml-hero__cta {
  display: inline-flex;
  align-self: flex-start;
}

.ml-hero a:hover,
.ml-hero .ml-btn:hover {
  opacity: 1;
}

/* Shared home sections */
.ml-section {
  padding: var(--ml-space-12) 0;
}

.ml-section__title {
  font-size: var(--ml-font-size-2xl);
  margin: 0 0 var(--ml-space-8);
  text-align: center;
}

.ml-muted {
  color: var(--ml-color-text-secondary);
  text-align: center;
}

.ml-home-grid {
  display: grid;
  gap: var(--ml-space-6);
}

.ml-home-grid--4 {
  grid-template-columns: 1fr;
}

@media (min-width: 640px) {
  .ml-home-grid--4 {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (min-width: 1024px) {
  .ml-home-grid--4 {
    grid-template-columns: repeat(4, 1fr);
  }
}

.ml-home-featured__footer {
  margin-top: var(--ml-space-8);
  text-align: center;
}

.ml-home-about__inner {
  max-width: 42rem;
  text-align: center;
}

.ml-home-about__text {
  font-size: var(--ml-font-size-lg);
  color: var(--ml-color-text-secondary);
  line-height: var(--ml-font-line-height-relaxed);
  margin: 0;
}
