/* Hero Slider - Boxed, Fade Effect */
.hero-section-wrap {
  width: 100%;
  background: var(--bg);
  padding: 1.5rem 0;
}

.hero {
  position: relative !important;
  width: 100% !important;
  max-width: 1200px !important;
  margin: 0 auto !important;
  height: 420px !important;
  min-height: unset !important;
  overflow: hidden !important;
  background: #08080a !important;
  border-radius: 16px !important;
  display: block !important;
}

.hero-slide {
  position: absolute !important;
  inset: 0 !important;
  opacity: 0 !important;
  display: block !important;
  width: 100% !important;
  height: 100% !important;
  transition: opacity .7s ease !important;
}

.hero-slide.active { opacity: 1 !important; }

.hero-slide > img {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  opacity: 1 !important;
  mix-blend-mode: normal !important;
  filter: none !important;
}

.hero-slide::before {
  content: '' !important;
  position: absolute !important;
  inset: 0 !important;
  z-index: 1 !important;
  background: linear-gradient(
    to right,
    rgba(6,6,10,.9) 0%,
    rgba(6,6,10,.6) 35%,
    rgba(6,6,10,.2) 65%,
    rgba(6,6,10,.4) 100%
  ) !important;
}

.hero-content {
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  bottom: 0 !important;
  width: 50% !important;
  z-index: 2 !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;
  padding: 2rem 2.5rem !important;
}

.hero-eyebrow {
  font-size: .68rem !important;
  font-weight: 700 !important;
  letter-spacing: .14em !important;
  text-transform: uppercase !important;
  color: var(--accent) !important;
  margin-bottom: .625rem !important;
}

.hero-title {
  font-size: clamp(1.75rem, 2.8vw, 2.6rem) !important;
  font-weight: 900 !important;
  line-height: 1.12 !important;
  letter-spacing: -.03em !important;
  color: #fff !important;
  margin-bottom: .625rem !important;
}

.hero-subtitle {
  font-size: .9rem !important;
  color: rgba(255,255,255,.72) !important;
  line-height: 1.65 !important;
  margin-bottom: 1.5rem !important;
  max-width: 340px !important;
}

.hero-actions {
  display: flex !important;
  gap: .625rem !important;
}

.hero-actions .btn {
  padding: .65rem 1.5rem !important;
  font-size: .85rem !important;
  border-radius: 50px !important;
}

/* Dots */
.hero-dot {
  width: 6px !important;
  height: 6px !important;
  border-radius: 50px !important;
  border: none !important;
  background: rgba(255,255,255,.35) !important;
  cursor: pointer !important;
  padding: 0 !important;
  transition: all .35s !important;
}
.hero-dot.active {
  width: 24px !important;
  background: #fff !important;
}

/* ── MOBILE ─────────────────────── */
@media (max-width: 768px) {
  .hero-section-wrap { padding: .875rem; }

  .hero {
    height: 260px !important;
    border-radius: 14px !important;
    max-width: 100% !important;
  }

  .hero-slide::before {
    background: linear-gradient(
      to top,
      rgba(6,6,10,.92) 0%,
      rgba(6,6,10,.55) 45%,
      rgba(6,6,10,.08) 100%
    ) !important;
  }

  .hero-content {
    top: auto !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    width: 100% !important;
    padding: 1rem 1.125rem 1.25rem !important;
    justify-content: flex-end !important;
  }

  .hero-eyebrow { display: none !important; }

  .hero-title {
    font-size: clamp(1rem, 4.5vw, 1.35rem) !important;
    margin-bottom: .25rem !important;
  }

  .hero-subtitle {
    font-size: .73rem !important;
    margin-bottom: .625rem !important;
    max-width: 100% !important;
    display: -webkit-box !important;
    -webkit-line-clamp: 2 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
  }

  .hero-actions .btn {
    padding: .45rem .875rem !important;
    font-size: .73rem !important;
  }

  .hero-actions .btn:last-child { display: none !important; }

  .hero-dot { width: 5px !important; height: 5px !important; }
  .hero-dot.active { width: 16px !important; }
}
