/* ============================================
   HERO SECTION
   ============================================ */
.hero {
  position: relative;
  min-height: 96vh;
  display: flex;
  align-items: center;
  overflow: hidden;
  background: var(--color-navy);
}

/* ── Hero background div (NOT an img — must set bg properties here) ── */
.hero-bg {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center 30%;
  background-repeat: no-repeat;
  background-attachment: fixed; /* parallax on desktop */
  transform: scale(1.02);       /* slight zoom-in to hide parallax edge */
  transition: transform 0.6s var(--ease-out);
}
@media (max-width: 768px) {
  /* fixed attachment causes stuttering on mobile */
  .hero-bg { background-attachment: scroll; transform: none; }
}

/* ── Directional overlay — content side darker, image side opens up ── */
.hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    108deg,
    rgba(15,23,42,0.88) 0%,
    rgba(15,23,42,0.72) 42%,
    rgba(15,23,42,0.35) 75%,
    rgba(15,23,42,0.18) 100%
  );
}

/* ── Film-grain texture overlay ── */
.hero-grain {
  position: absolute;
  inset: 0;
  pointer-events: none;
  opacity: 0.04;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");
  background-repeat: repeat;
  background-size: 180px 180px;
  mix-blend-mode: overlay;
}

/* ── Content ── */
.hero-content {
  position: relative;
  z-index: 2;
  max-width: 760px;
  padding: var(--space-24) 0 var(--space-20);
}

/* ── Eyebrow label with flanking rules ── */
.hero-eyebrow-label {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  font-family: var(--font-body);
  font-size: var(--text-xs);
  font-weight: 700;
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  color: var(--color-gold);
  margin-bottom: var(--space-5);
  white-space: nowrap;
  overflow: hidden;
}
.hero-eyebrow-rule {
  display: block;
  flex: 0 0 28px;
  height: 1px;
  background: var(--color-gold);
  opacity: 0.5;
}
.hero-eyebrow-rule--right {
  flex: 1 1 auto;  /* right rule fills remaining space */
  max-width: 120px;
}

/* ── Title ── */
.hero-title {
  font-family: var(--font-display);
  font-size: clamp(var(--text-5xl), 6vw, 76px);
  font-weight: 800;
  line-height: 1.05;
  color: var(--color-white);
  letter-spacing: var(--tracking-tight);
  margin-bottom: var(--space-6);
  border-left: 4px solid var(--color-gold);
  padding-left: var(--space-6);
}
.hero-title em {
  font-style: italic;
  font-family: var(--font-accent);
  font-weight: 400;
  color: rgba(196,168,116,0.95);
}

/* ── Subtitle / body ── */
.hero-subtitle {
  font-size: clamp(var(--text-base), 1.6vw, var(--text-lg));
  color: rgba(255,255,255,0.78);
  line-height: var(--leading-relaxed);
  max-width: 560px;
  margin-bottom: var(--space-8);
}

/* ── CTA group ── */
.hero-cta-group {
  display: flex;
  gap: var(--space-4);
  flex-wrap: wrap;
  align-items: center;
  margin-bottom: var(--space-10);
}
.hero-ghost-btn {
  color: rgba(255,255,255,0.88) !important;
  border-color: rgba(255,255,255,0.28) !important;
}
.hero-ghost-btn:hover {
  background: rgba(255,255,255,0.1) !important;
  color: var(--color-white) !important;
  border-color: rgba(255,255,255,0.55) !important;
}

/* ── Trust badges — glassmorphism pills ── */
.trust-badge-strip {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
}
.trust-badge {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-4);
  background: rgba(255,255,255,0.08);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border: 1px solid rgba(255,255,255,0.16);
  border-radius: var(--radius-full);
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: var(--tracking-wide);
  color: rgba(255,255,255,0.88);
  transition: background var(--duration-base) var(--ease-out),
              border-color var(--duration-base) var(--ease-out);
}
.trust-badge:hover {
  background: rgba(255,255,255,0.14);
  border-color: rgba(196,168,116,0.4);
  color: var(--color-white);
}
.trust-badge svg { color: var(--color-gold); flex-shrink: 0; }

/* ── Scroll indicator ── */
.hero-scroll-indicator {
  position: absolute;
  bottom: var(--space-8);
  left: 50%;
  transform: translateX(-50%);
  z-index: 2;
  display: flex;
  flex-direction: column;
  align-items: center;
  color: rgba(255,255,255,0.4);
  animation: scrollBounce 2s ease-in-out infinite;
}
@keyframes scrollBounce {
  0%, 100% { transform: translateX(-50%) translateY(0); }
  50%       { transform: translateX(-50%) translateY(8px); }
}

/* ── Final CTA section reuses hero classes ── */
.final-cta-section {
  position: relative;
  overflow: hidden;
  padding: var(--space-24) 0;
}
.final-cta-bg {
  /* inherits hero-bg styles — bg-image set inline in PHP */
  background-position: center 45%;
}
.final-cta-overlay {
  background: linear-gradient(
    160deg,
    rgba(15,23,42,0.86) 0%,
    rgba(15,23,42,0.72) 55%,
    rgba(15,23,42,0.60) 100%
  );
}
.final-cta-content {
  position: relative;
  z-index: 2;
}
.final-cta-content h2 {
  font-size: clamp(var(--text-3xl), 5vw, var(--text-5xl));
  color: var(--color-white);
  margin-bottom: var(--space-5);
}
.final-cta-content .lead-text {
  color: rgba(255,255,255,0.78);
  max-width: 600px;
  margin: 0 auto var(--space-10);
}
.final-cta-actions {
  display: flex;
  justify-content: center;
  gap: var(--space-4);
  flex-wrap: wrap;
  margin-bottom: var(--space-10);
}
.final-cta-pillars {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: var(--space-3);
}
.cta-pillar-chip {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-5);
  border: 1px solid;
  border-radius: var(--radius-full);
  font-size: var(--text-sm);
  font-weight: 500;
  text-decoration: none;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  background: rgba(255,255,255,0.07);
  transition: background var(--duration-base) var(--ease-out),
              border-color var(--duration-base) var(--ease-out);
}
.cta-pillar-chip:hover {
  background: rgba(255,255,255,0.14);
  border-color: rgba(255,255,255,0.45) !important;
}

/* Gold ornament for final CTA */
.cta-ornament {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-3);
  margin-bottom: var(--space-5);
}
.cta-ornament__line {
  display: block;
  width: 40px;
  height: 1px;
  background: var(--color-gold);
  opacity: 0.4;
}

/* ── Responsive ── */
@media (max-width: 768px) {
  .hero-title { font-size: clamp(var(--text-4xl), 10vw, var(--text-5xl)); }
  .hero-cta-group { flex-direction: column; align-items: flex-start; }
  .hero-eyebrow-label { white-space: normal; }
  .hero-eyebrow-rule--right { display: none; }
  .final-cta-content h2 { font-size: clamp(var(--text-3xl), 8vw, var(--text-4xl)); }
  .final-cta-actions { flex-direction: column; align-items: center; }
}
