/*
 * Hero - bovenste banner met afbeelding, titel, CTAs en Google rating badge
 */

.hero {
  padding:    24px 16px 64px;
  background: var(--color-bg-white);
}

.hero__inner {
  position:      relative;
  max-width:     1680px;
  margin:        0 auto;
  border-radius: var(--radius-xl);
  overflow:      hidden;
  min-height:    600px;
  background:    var(--color-primary);
}

.hero__bg {
  position:   absolute;
  inset:      0;
  width:      100%;
  height:     100%;
  object-fit: cover;
  display:    block;
}

.hero__bg-fallback {
  position:   absolute;
  inset:      0;
  background: linear-gradient(135deg, #2a3133 0%, #1a1f21 100%);
}

.hero__overlay {
  position:   absolute;
  inset:      0;
  background: linear-gradient(95deg,
                rgba(26, 31, 33, 0.85) 0%,
                rgba(26, 31, 33, 0.55) 45%,
                rgba(26, 31, 33, 0.10) 100%);
}

.hero__content {
  position:  relative;
  padding:   90px 72px;
  max-width: 760px;
  color:     #ffffff;
}

.hero__tag {
  display:         inline-flex;
  align-items:     center;
  gap:             12px;
  font-size:       12px;
  font-weight:     600;
  letter-spacing:  2px;
  text-transform:  uppercase;
  color:           var(--color-accent-pale);
  margin-bottom:   28px;
}

.hero__tag-line {
  width:      36px;
  height:     1px;
  background: var(--color-accent-pale);
}

.hero__title {
  font-family:     var(--font-heading);
  font-size:       66px;
  line-height:     1.02;
  font-weight:     var(--font-extrabold);
  margin:          0 0 24px;
  letter-spacing:  -1.8px;
  color:           #ffffff;
}

.hero__title-accent {
  color:       var(--color-icon-green);
  font-style:  italic;
  font-weight: var(--font-bold);
}

.hero__subtitle {
  font-size:   18px;
  line-height: 1.55;
  max-width:   540px;
  margin:      0 0 36px;
  color:       rgba(255, 255, 255, 0.85);
}

.hero__ctas {
  display:     flex;
  gap:         14px;
  align-items: center;
  flex-wrap:   wrap;
}

.hero__cta-primary {
  display:         inline-flex;
  align-items:     center;
  gap:             14px;
  background:      var(--color-accent);
  color:           #ffffff;
  padding:         20px 50px;
  border-radius:   999px;
  font-size:       15px;
  font-weight:     600;
  text-decoration: none;
  line-height:     1;
  white-space:     nowrap;
  transition:      background-color var(--transition-fast),
                   box-shadow var(--transition-fast);
}

.hero__cta-primary:hover {
  background: var(--color-accent-dark);
  color:      #ffffff;
  box-shadow: var(--shadow-primary-hover);
}

.hero__cta-primary svg {
  width:  16px;
  height: 16px;
}

.hero__cta-secondary {
  display:         inline-flex;
  align-items:     center;
  gap:             10px;
  color:           #ffffff;
  padding:         18px 8px 14px;
  font-size:       15px;
  font-weight:     600;
  text-decoration: none;
  border-bottom:   1px solid rgba(255, 255, 255, 0.4);
  transition:      border-color var(--transition-fast),
                   color var(--transition-fast);
}

.hero__cta-secondary:hover {
  color:        var(--color-icon-green);
  border-color: var(--color-icon-green);
}

.hero__cta-secondary svg {
  width:  16px;
  height: 16px;
}

/* ----------------------------------------
 * Hero rating badge (Google reviews)
 * ---------------------------------------- */

.hero__rating {
  position:       absolute;
  right:          40px;
  bottom:         40px;
  background:     #ffffff;
  border-radius:  16px;
  padding:        18px 22px;
  display:        flex;
  align-items:    center;
  gap:            16px;
  box-shadow:     0 14px 36px rgba(0, 0, 0, 0.18);
}

.hero__rating-logo {
  width:  36px;
  height: 36px;
}

.hero__rating-label {
  font-size:     12.5px;
  font-weight:   600;
  color:         var(--color-text-heading);
  margin-bottom: 2px;
}

.hero__rating-row {
  display:     flex;
  align-items: baseline;
  gap:         8px;
}

.hero__rating-score {
  font-size:      36px;
  font-weight:    var(--font-extrabold);
  color:          var(--color-text-heading);
  line-height:    1;
  letter-spacing: -1px;
}

.hero__rating-stars {
  display:       flex;
  gap:           2px;
  color:         #FBBC05;
  margin-bottom: 4px;
}

.hero__rating-stars svg {
  width:  13px;
  height: 13px;
}

.hero__rating-meta {
  font-size:   11px;
  color:       var(--color-text-meta);
  font-weight: 500;
}

/* ----------------------------------------
 * Responsive
 * ---------------------------------------- */

@media (max-width: 1024px) {
  .hero__content {
    padding: 64px 40px;
  }
  .hero__title {
    font-size: 48px;
  }
}

@media (max-width: 768px) {
  .hero {
    padding: 16px var(--section-padding-x) 32px;
  }
  .hero__inner {
    min-height:    auto;
    border-radius: var(--radius-lg);
  }
  .hero__content {
    padding: 48px 24px;
  }
  .hero__title {
    font-size:      36px;
    letter-spacing: -1px;
  }
  .hero__subtitle {
    font-size: 16px;
  }
  .hero__cta-primary {
    padding:   16px 32px;
    font-size: 14px;
  }
  .hero__rating {
    position:    static;
    margin:      0 24px 24px;
    padding:     14px 18px;
  }
  .hero__rating-score {
    font-size: 28px;
  }
}
