/* Luxury art-direction pass: cinematic contrast, stronger hierarchy, asymmetry */
:root {
  --vorna-gold: #b89b6d;
  --vorna-gold-soft: #a88d62;
}

.text-warmgold,
.text-mutedgold {
  color: var(--vorna-gold) !important;
}

.bg-warmgold {
  background-color: var(--vorna-gold) !important;
}

#hero.hero-cinematic {
  min-height: 760px;
  max-height: 760px;
  background-color: #070707;
  background-image:
    linear-gradient(
      90deg,
      rgba(7, 7, 7, 0.94) 0%,
      rgba(7, 7, 7, 0.82) 33%,
      rgba(7, 7, 7, 0.38) 60%,
      rgba(7, 7, 7, 0.08) 100%
    ),
    url('/assets/img/hero-model.jpg'),
    url('/public/assets/img/hero-model.jpg');
  background-repeat: no-repeat, no-repeat, no-repeat;
  background-position: 0 0, 78% center, 78% center;
  background-size: cover, 104% auto, 104% auto;
  position: relative;
}

#hero .container {
  max-width: 1280px;
  gap: 0;
}

#hero .hero-grid {
  min-height: 760px;
  padding-top: 0;
  padding-bottom: 0;
  align-items: start;
}

#hero .hero-nav {
  height: 82px;
  background: rgba(7, 7, 7, 0.78) !important;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  z-index: 80;
  left: 0;
  right: 0;
  top: 0;
  width: 100%;
}

#hero .hero-brand-logo {
  max-height: 44px;
  width: auto;
  object-fit: contain;
  display: inline-block;
}

#hero .hero-content {
  text-align: left !important;
  max-width: 560px;
  width: 100%;
  margin-left: clamp(24px, 7vw, 110px);
  padding-top: 140px;
}

#hero .hero-nav-links {
  gap: clamp(1.3rem, 2vw, 2rem);
}

#hero .hero-nav-link {
  font-size: 0.93rem !important;
  letter-spacing: 0.02em;
  color: rgba(251, 245, 236, 0.88) !important;
}

#hero .hero-empty-space {
  width: 100%;
  min-height: 1px;
}

#hero .hero-kicker {
  letter-spacing: 0.28em !important;
  font-size: 11px !important;
  opacity: 0.85;
}

#hero .hero-title {
  font-size: clamp(52px, 6vw, 88px) !important;
  line-height: 0.95 !important;
  letter-spacing: -0.012em;
  max-width: 560px;
  margin-bottom: 0.75rem !important;
}

#hero .hero-subtitle {
  font-size: clamp(18px, 1.55vw, 22px) !important;
  max-width: 460px !important;
  color: #d6d0c7;
  opacity: 0.92;
  margin-bottom: 1.1rem !important;
}

#hero .hero-cta-clean {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.38rem;
  margin-top: 0.2rem;
}

#hero .hero-cta-btn {
  padding: 0.98rem 2rem !important;
  border-radius: 0.62rem !important;
  letter-spacing: 0.045em;
  background: #b89b6d !important;
  transition: transform 0.24s ease, box-shadow 0.24s ease, filter 0.24s ease;
}

#hero .hero-cta-btn:hover {
  transform: translateY(-1px);
  box-shadow: 0 10px 26px rgba(184, 155, 109, 0.28);
  filter: brightness(1.03);
}

#hero .hero-rating {
  justify-content: flex-start;
  margin-top: 0 !important;
}

#hero .hero-urgency {
  margin-top: 0 !important;
}

#benefits {
  padding-top: clamp(3.2rem, 6vw, 5.2rem) !important;
  padding-bottom: clamp(5rem, 9vw, 8rem) !important;
}

#product-features.product-wow {
  padding-top: clamp(7rem, 12vw, 12rem) !important;
  padding-bottom: clamp(8rem, 14vw, 13rem) !important;
  background:
    radial-gradient(900px 420px at 35% 48%, rgba(184, 155, 109, 0.16), transparent 65%),
    radial-gradient(650px 300px at 60% 35%, rgba(184, 155, 109, 0.08), transparent 70%),
    linear-gradient(180deg, #070707 0%, #0c0c0d 45%, #070707 100%);
}

#product-features .product-title {
  font-size: clamp(2.2rem, 4.5vw, 4.4rem) !important;
  line-height: 1.03;
  margin-bottom: clamp(2.8rem, 5vw, 5.2rem) !important;
}

#product-features .product-stage {
  filter: drop-shadow(0 35px 90px rgba(0, 0, 0, 0.75));
}

#product-features .product-stage img {
  transform: scale(1.08);
  filter: brightness(0.86) contrast(1.14) saturate(0.9);
}

#product-features .product-copy p {
  max-width: 34ch;
}

/* Product annotation refinement (desktop editorial style) */
#product-features .product-feature-label {
  background: rgba(7, 7, 7, 0.55);
  -webkit-backdrop-filter: blur(7px);
  backdrop-filter: blur(7px);
  border-radius: 10px;
  padding: 8px 11px;
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.28);
  border: 1px solid rgba(184, 155, 109, 0.16);
  z-index: 24;
}

#product-features .product-feature-label > span:first-child {
  font-size: 0.92rem !important;
  line-height: 1.2;
  letter-spacing: 0.01em;
}

#product-features .product-feature-label > span:last-child {
  font-size: 0.74rem !important;
  line-height: 1.28;
  opacity: 0.78 !important;
}

#product-features .product-feature-line {
  background-color: rgba(184, 155, 109, 0.72) !important;
  z-index: 22;
}

#product-features .product-feature-label.fade-in {
  transition-duration: 0.9s;
}

#testimonials {
  padding-top: clamp(5rem, 9vw, 9rem) !important;
  padding-bottom: clamp(4.2rem, 8vw, 8rem) !important;
}

/* Footer trust bar alignment refinement */
.footer-trust-grid {
  align-items: start;
}

.footer-trust-grid > div i {
  margin-bottom: 16px !important;
}

.footer-trust-grid > div h4 {
  margin-bottom: 8px !important;
}

.footer-spacing {
  padding-top: clamp(70px, 7vw, 90px);
  padding-bottom: clamp(30px, 3.8vw, 40px);
}

.footer-trust-wrap {
  margin-bottom: clamp(60px, 6vw, 80px);
}

.footer-copy {
  font-size: 13.5px;
  color: rgba(255, 255, 255, 0.65);
  line-height: 1.4;
}

@media (max-width: 1023px) {
  #hero.hero-cinematic {
    min-height: auto;
    max-height: none;
    background-image:
      linear-gradient(
        180deg,
        rgba(7, 7, 7, 0.88) 0%,
        rgba(7, 7, 7, 0.72) 36%,
        rgba(7, 7, 7, 0.44) 68%,
        rgba(7, 7, 7, 0.2) 100%
      ),
      url('/assets/img/hero-model.jpg'),
      url('/public/assets/img/hero-model.jpg');
    background-repeat: no-repeat, no-repeat, no-repeat;
    background-position: 0 0, 68% center, 68% center;
    background-size: cover, 112% auto, 112% auto;
  }

  #hero .hero-content {
    text-align: left !important;
    margin-inline: 0;
    margin-left: 0;
    max-width: 100%;
    padding: 120px 22px 64px;
  }

  #hero .hero-grid {
    min-height: auto;
    padding-top: 0;
    padding-bottom: 0;
    gap: 0;
  }

  #hero .hero-empty-space {
    display: none;
  }

  #hero .hero-title {
    font-size: clamp(48px, 12vw, 54px) !important;
    line-height: 0.96 !important;
  }

  #hero .hero-cta-clean {
    display: flex;
    width: 100%;
    align-items: stretch;
  }

  #hero .hero-cta-btn {
    width: 100%;
    text-align: center;
  }

  #hero .hero-rating {
    justify-content: flex-start;
  }

  .footer-trust-grid {
    gap: 1.2rem 1rem !important;
  }

  .footer-trust-wrap {
    margin-bottom: 60px;
  }
}

@media (min-width: 1024px) {
  #hero .hero-grid {
    grid-template-columns: minmax(0, 0.65fr) minmax(0, 0.35fr);
  }

  /* Reposition labels to avoid overlapping mask edges/highlights */
  #product-features .feature-label-1 {
    top: calc(50% + 36px) !important;
    left: calc(50% - 460px) !important;
    text-align: left;
  }

  #product-features .feature-label-2 {
    top: calc(50% + 148px) !important;
    left: calc(50% - 430px) !important;
    text-align: left;
  }

  #product-features .feature-label-3 {
    top: calc(50% + 38px) !important;
    right: calc(50% - 458px) !important;
    text-align: right;
  }

  #product-features .feature-label-4 {
    top: calc(50% + 148px) !important;
    right: calc(50% - 428px) !important;
    text-align: right;
  }

  /* Elegant connector lines */
  #product-features .line-1-h {
    width: 118px !important;
    height: 1px !important;
    top: calc(50% + 64px) !important;
    left: calc(50% - 332px) !important;
  }

  #product-features .line-1-v {
    width: 1px !important;
    height: 30px !important;
    top: calc(50% + 64px) !important;
    left: calc(50% - 332px) !important;
  }

  #product-features .line-2-h {
    width: 132px !important;
    height: 1px !important;
    top: calc(50% + 182px) !important;
    left: calc(50% - 298px) !important;
  }

  #product-features .line-2-v {
    width: 1px !important;
    height: 28px !important;
    top: calc(50% + 154px) !important;
    left: calc(50% - 298px) !important;
  }

  #product-features .line-3-h {
    width: 118px !important;
    height: 1px !important;
    top: calc(50% + 66px) !important;
    right: calc(50% - 332px) !important;
  }

  #product-features .line-3-v {
    width: 1px !important;
    height: 30px !important;
    top: calc(50% + 66px) !important;
    right: calc(50% - 332px) !important;
  }

  #product-features .line-4-h {
    width: 132px !important;
    height: 1px !important;
    top: calc(50% + 182px) !important;
    right: calc(50% - 298px) !important;
  }

  #product-features .line-4-v {
    width: 1px !important;
    height: 28px !important;
    top: calc(50% + 154px) !important;
    right: calc(50% - 298px) !important;
  }
}
