/* ============================================
   WOOPREMIUM — Homepage
   Version: 1.0.0
   ============================================ */

/* ============ HERO ============ */
.wp-hero {
  height: 85vh;
  min-height: 500px;
  max-height: 700px;
  position: relative;
  display: flex;
  align-items: flex-end;
  overflow: hidden;
}
.wp-hero__bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}
.wp-hero__bg img,
.wp-hero__bg video {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.wp-hero::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(0deg, rgba(26,26,26,.85) 0%, rgba(26,26,26,.3) 40%, rgba(26,26,26,.05) 70%);
  z-index: 1;
}
.wp-hero .wp-container {
  position: relative;
  z-index: 2;
  padding-bottom: 80px;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}
/* Force left-alignment on hero container */
.wp-homepage .wp-hero .wp-container {
  align-items: flex-start;
  text-align: left;
}
.wp-hero__title {
  font-family: var(--wp-serif, Georgia, serif);
  font-size: 3.5rem;
  font-weight: 400;
  color: #ffffff;
  line-height: 1.15;
  letter-spacing: -.02em;
  max-width: 700px;
  margin-bottom: 24px;
}
.wp-hero__cta {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 14px 36px;
  background: var(--wp-gold, #b8960c);
  color: #ffffff;
  font-size: .875rem;
  font-weight: 600;
  letter-spacing: .08em;
  text-transform: uppercase;
  border-radius: var(--wp-r-sm, 6px);
  text-decoration: none;
  transition: background .2s, transform .15s;
}
.wp-hero__cta:hover {
  background: #ffffff;
  color: var(--wp-text, #1a1a1a);
  transform: translateY(-2px);
}
.wp-hero__cta svg { width: 16px; height: 16px; }
.wp-hero__scroll {
  position: absolute;
  bottom: 32px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 2;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  color: rgba(255,255,255,.5);
  font-size: .6875rem;
  letter-spacing: .1em;
  text-transform: uppercase;
}
.wp-hero__scroll-line {
  width: 1px;
  height: 40px;
  background: linear-gradient(180deg, rgba(255,255,255,.4), rgba(255,255,255,0));
  animation: wpScrollPulse 2s ease-in-out infinite;
}
@keyframes wpScrollPulse { 0%,100%{opacity:.4} 50%{opacity:1} }

/* ============ USPs ============ */
.wp-usps-home {
  background: var(--wp-dark, #1a1a1a);
  padding: 48px 0;
}
.wp-usps-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 32px;
}
.wp-usp-home {
  text-align: center;
}
.wp-usp-home__icon {
  width: 32px;
  height: 32px;
  margin: 0 auto 12px;
  color: var(--wp-gold, #b8960c);
}
.wp-usp-home__icon svg { width: 100%; height: 100%; }
.wp-usp-home__title {
  font-family: var(--wp-serif, Georgia, serif);
  font-size: 1rem;
  font-weight: 400;
  color: var(--wp-dark-text, #e8e4de);
  margin-bottom: 4px;
}
.wp-usp-home__text {
  font-size: .8125rem;
  color: var(--wp-dark-text-2, #a09890);
  line-height: 1.5;
}

/* ============ COLLECTIES ============ */
.wp-collecties {
  padding: 0;
}

/* Hero category: 50/50 split */
/* Desktop: hide mobile-only elements */
.wp-collectie-mobile-intro { display: none; }
.wp-collecties-row .wp-collectie-row__hero-card { display: none; }

.wp-collectie-hero {
  display: flex;
  flex-wrap: wrap;
  min-height: 500px;
  background: var(--wp-dark, #1a1a1a);
}
.wp-collectie-hero__image {
  flex: 1 1 300px;
  min-width: 300px;
  position: relative;
  overflow: hidden;
}
.wp-collectie-hero__image a {
  display: block;
  width: 100%;
  height: 100%;
}
.wp-collectie-hero__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  min-height: 500px;
  transition: transform .7s var(--wp-ease);
}
.wp-collectie-hero__image:hover img { transform: scale(1.03); }
.wp-collectie-hero__image-overlay {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 32px;
  background: linear-gradient(0deg, rgba(26,26,26,.6) 0%, rgba(26,26,26,0) 100%);
}
.wp-collectie-hero__image-name {
  font-family: var(--wp-serif, Georgia, serif);
  font-size: 1.5rem;
  font-weight: 400;
  color: #ffffff;
}
.wp-collectie-hero__content {
  flex: 1 1 300px;
  min-width: 300px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 72px 72px;
  background: var(--wp-dark, #1a1a1a);
}
.wp-collectie-hero__title {
  font-family: var(--wp-serif, Georgia, serif);
  font-size: 2rem;
  font-weight: 400;
  color: var(--wp-dark-text, #e8e4de);
  line-height: 1.3;
  margin-bottom: 24px;
}
.wp-collectie-hero__desc {
  font-size: .9375rem;
  color: var(--wp-dark-text-2, #a09890);
  line-height: 1.7;
}

/* Sub-category cards row — tight against hero */
.wp-collecties-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 3px;
  margin-top: 3px;
}
.wp-collectie-card {
  position: relative;
  overflow: hidden;
  aspect-ratio: 16 / 10;
  display: block;
  text-decoration: none;
}
.wp-collectie-card img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .7s var(--wp-ease);
}
.wp-collectie-card:hover img { transform: scale(1.05); }
.wp-collectie-card__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(0deg, rgba(26,26,26,.7) 0%, rgba(26,26,26,.15) 60%);
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 24px;
}
.wp-collectie-card__name {
  font-family: var(--wp-serif, Georgia, serif);
  font-size: 1.25rem;
  font-weight: 400;
  color: #ffffff;
  margin-bottom: 4px;
}
.wp-collectie-card__count {
  font-size: .75rem;
  color: var(--wp-dark-text-2, #a09890);
}

/* ============ UITGELICHT ============ */
.wp-uitgelicht {
  background: var(--wp-surface, #f5f3ef);
  padding: 96px 0;
}
.wp-uitgelicht__desc {
  font-size: .9375rem;
  color: var(--wp-text-2, #5c5650);
  line-height: 1.7;
  max-width: 600px;
  margin-bottom: 56px;
}
.wp-uitgelicht-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
  margin-bottom: 32px;
}
/* Product cards reuse .wp-archive-card from archive CSS or inline */

/* ============ INSPIRATIE / BLOG ============ */
.wp-inspiratie {
  display: flex;
  flex-wrap: wrap;
  min-height: 480px;
}
.wp-inspiratie__image {
  flex: 0 0 35%;
  min-width: 280px;
  position: relative;
  overflow: hidden;
}
.wp-inspiratie__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  min-height: 480px;
}
.wp-inspiratie__content {
  flex: 1 1 300px;
  min-width: 300px;
  padding: 64px 56px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.wp-inspiratie__title {
  font-family: var(--wp-serif, Georgia, serif);
  font-size: 1.75rem;
  font-weight: 400;
  margin-bottom: 16px;
}
.wp-inspiratie__desc {
  font-size: .9375rem;
  color: var(--wp-text-2, #5c5650);
  margin-bottom: 56px;
  line-height: 1.6;
}
.wp-blog-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-bottom: 24px;
}
.wp-blog-card {
  display: block;
  text-decoration: none;
  color: var(--wp-text, #1a1a1a);
  border-radius: var(--wp-r, 8px);
  overflow: hidden;
  transition: box-shadow .2s;
}
.wp-blog-card:hover { box-shadow: 0 4px 16px rgba(0,0,0,.06); }
.wp-blog-card__img {
  aspect-ratio: 4 / 3;
  overflow: hidden;
}
.wp-blog-card__img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .5s var(--wp-ease);
}
.wp-blog-card:hover .wp-blog-card__img img { transform: scale(1.04); }
.wp-blog-card__title {
  font-family: var(--wp-sans);
  font-size: .9375rem;
  font-weight: 500;
  padding: 12px 12px 4px;
  line-height: 1.4;
}
.wp-blog-card__date {
  font-size: .6875rem;
  color: var(--wp-text-3, #8a837c);
  padding: 0 12px 12px;
}

/* ============ DIENSTEN ============ */
.wp-diensten {
  padding: 96px 0;
}
.wp-diensten__desc {
  font-size: .9375rem;
  color: var(--wp-text-2, #5c5650);
  line-height: 1.7;
  max-width: 600px;
  margin: 0 auto 48px;
  text-align: center;
}
.wp-diensten-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.wp-dienst {
  display: block;
  text-decoration: none;
  color: var(--wp-text, #1a1a1a);
  border-radius: var(--wp-r, 8px);
  overflow: hidden;
  border: 1px solid var(--wp-border-light, #eae6df);
  transition: border-color .2s, box-shadow .2s;
}
.wp-dienst:hover {
  border-color: var(--wp-gold, #b8960c);
  box-shadow: 0 4px 20px rgba(0,0,0,.04);
}
.wp-dienst__image {
  aspect-ratio: 16 / 9;
  overflow: hidden;
}
.wp-dienst__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .5s var(--wp-ease);
}
.wp-dienst:hover .wp-dienst__image img { transform: scale(1.03); }
.wp-dienst__body { padding: 24px; }
.wp-dienst__title {
  font-family: var(--wp-serif, Georgia, serif);
  font-size: 1.125rem;
  font-weight: 400;
  margin-bottom: 10px;
}
.wp-dienst__text {
  font-size: .9375rem;
  color: var(--wp-text-2, #5c5650);
  line-height: 1.6;
}

/* ============ BINNENKIJKEN BIJ ============ */
.wp-projecten {
  padding: 96px 0;
  background: var(--wp-surface, #f5f3ef);
}
.wp-projecten-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 24px;
}
.wp-project-card {
  position: relative;
  border-radius: var(--wp-r-lg, 12px);
  overflow: hidden;
  aspect-ratio: 16 / 10;
  display: block;
  text-decoration: none;
}
.wp-project-card img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .7s var(--wp-ease);
}
.wp-project-card:hover img { transform: scale(1.04); }
.wp-project-card__content {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 32px;
  background: linear-gradient(0deg, rgba(26,26,26,.85) 0%, rgba(26,26,26,.4) 60%, rgba(26,26,26,0) 100%);
}
.wp-project-card__title {
  font-family: var(--wp-serif, Georgia, serif);
  font-size: 1.25rem;
  font-weight: 400;
  color: #ffffff;
  margin-bottom: 6px;
}
.wp-project-card__desc {
  font-size: .8125rem;
  color: rgba(255,255,255,.8);
  line-height: 1.5;
  max-width: 500px;
}

/* ============ MERKEN ============ */
.wp-merken {
  background: var(--wp-white, #ffffff);
  padding: 72px 0;
  border-top: 1px solid var(--wp-border-light, #eae6df);
  border-bottom: 1px solid var(--wp-border-light, #eae6df);
}
.wp-merken__title {
  font-family: var(--wp-serif, Georgia, serif);
  font-size: 1.5rem;
  font-weight: 400;
  color: var(--wp-text, #1a1a1a);
  margin-bottom: 16px;
  text-align: center;
}
.wp-merken__desc {
  font-size: .9375rem;
  color: var(--wp-text-2, #5c5650);
  line-height: 1.7;
  max-width: 600px;
  margin: 0 auto 48px;
  text-align: center;
}
.wp-merken-grid {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 48px;
  flex-wrap: wrap;
}
.wp-merk {
  height: 36px;
  display: flex;
  align-items: center;
  transition: filter .3s;
  filter: grayscale(100%);
}
.wp-merk:hover { filter: grayscale(0%); }
.wp-merk img {
  height: 36px;
  width: auto;
  max-width: 100px;
  object-fit: contain;
}

/* ============ REVIEWS ============ */
.wp-reviews {
  padding: 96px 0;
}
.wp-reviews__desc {
  font-size: .9375rem;
  color: var(--wp-text-2, #5c5650);
  line-height: 1.7;
  max-width: 600px;
  margin: 0 auto 48px;
  text-align: center;
}
.wp-reviews-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 32px;
}
.wp-review {
  padding: 32px;
  border: 1px solid var(--wp-border-light, #eae6df);
  border-radius: var(--wp-r, 8px);
}
.wp-review__stars {
  display: flex;
  gap: 2px;
  margin-bottom: 16px;
  color: var(--wp-gold, #b8960c);
}
.wp-review__stars svg { width: 16px; height: 16px; fill: currentColor; }
.wp-review__text {
  font-size: .9375rem;
  line-height: 1.7;
  color: var(--wp-text-2, #5c5650);
  margin-bottom: 20px;
  font-style: italic;
}
.wp-review__author {
  font-size: .8125rem;
  font-weight: 600;
  color: var(--wp-text, #1a1a1a);
}
.wp-review__location {
  font-size: .75rem;
  color: var(--wp-text-3, #8a837c);
}

/* ============ PLAN BEZOEK ============ */
.wp-plan-bezoek {
  background: var(--wp-dark, #1a1a1a);
  padding: 96px 0;
  text-align: center;
}
.wp-plan-bezoek__title {
  font-family: var(--wp-serif, Georgia, serif);
  font-size: 2.5rem;
  font-weight: 400;
  color: #ffffff;
  margin-bottom: 20px;
}
.wp-plan-bezoek__text {
  font-size: 1rem;
  color: var(--wp-dark-text, #e8e4de);
  max-width: 520px;
  margin: 0 auto 40px;
  line-height: 1.7;
}
.wp-plan-bezoek__cta {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 16px 40px;
  background: var(--wp-gold, #b8960c);
  color: #ffffff;
  font-size: .875rem;
  font-weight: 600;
  letter-spacing: .08em;
  text-transform: uppercase;
  border-radius: var(--wp-r-sm, 6px);
  text-decoration: none;
  transition: background .2s, transform .15s;
}
.wp-plan-bezoek__cta:hover {
  background: #ffffff;
  color: var(--wp-text, #1a1a1a);
  transform: translateY(-2px);
}
.wp-plan-bezoek__cta svg { width: 18px; height: 18px; }

/* Newsletter reuses .wp-newsletter from archive CSS */

/* ============ SECTION HELPERS ============ */
/* Section title: when followed by a desc, 16px bottom. When directly above content, 48px */
.wp-section-title {
  font-family: var(--wp-serif, Georgia, serif);
  font-size: 2rem;
  font-weight: 400;
  margin-bottom: 48px;
  letter-spacing: -.01em;
}
/* Grids and content blocks: margin-top for spacing */
.wp-uitgelicht-grid,
.wp-blog-grid,
.wp-diensten-grid,
.wp-projecten-grid,
.wp-reviews-grid,
.wp-merken-grid {
  margin-top: 48px;
}
/* Collecties row tight against hero — no gap */
.wp-collecties-row {
  margin-top: 3px;
}
.wp-section-title--center { text-align: center; }
.wp-section-title--italic { font-style: italic; }
.wp-section-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: .875rem;
  font-weight: 600;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--wp-text, #1a1a1a);
  text-decoration: none;
  transition: gap .2s var(--wp-ease), color .2s;
}
.wp-section-link:hover { gap: 12px; color: var(--wp-gold, #b8960c); }
.wp-section-link svg { width: 16px; height: 16px; }

/* ============ TYPOGRAPHY & COLOR OVERRIDES ============ */
.wp-homepage .wp-hero__title,
.wp-homepage h1.wp-hero__title {
  color: #ffffff;
  font-family: var(--wp-serif, Georgia, serif);
  font-size: 3.5rem;
  font-weight: 400;
  line-height: 1.15;
  letter-spacing: -.02em;
  text-shadow: 0 2px 20px rgba(0,0,0,.3);
}
.wp-homepage .wp-hero__cta {
  color: #ffffff;
  background: var(--wp-gold, #b8960c);
  align-self: flex-start;
  margin: 0;
}
.wp-homepage .wp-hero__cta:hover {
  color: var(--wp-text, #1a1a1a);
  background: #ffffff;
}
.wp-homepage .wp-usp-home__title {
  color: var(--wp-dark-text, #e8e4de);
  font-family: var(--wp-serif, Georgia, serif);
  font-weight: 400;
  font-size: 1rem;
}
.wp-homepage .wp-usp-home__text {
  color: var(--wp-dark-text-2, #a09890);
  font-family: var(--wp-sans);
}
.wp-homepage .wp-section-title {
  font-family: var(--wp-serif, Georgia, serif);
  font-weight: 400;
  color: var(--wp-text, #1a1a1a);
}
.wp-homepage .wp-collectie-card__name {
  font-family: var(--wp-serif, Georgia, serif);
  color: #ffffff;
  font-weight: 400;
}
.wp-homepage .wp-collectie-hero__title {
  font-family: var(--wp-serif, Georgia, serif);
  color: var(--wp-dark-text, #e8e4de);
  font-weight: 400;
}
.wp-homepage .wp-collectie-hero__desc {
  color: var(--wp-dark-text-2, #a09890);
  font-family: var(--wp-sans);
}
.wp-homepage .wp-collectie-hero__image-name {
  font-family: var(--wp-serif, Georgia, serif);
  color: #ffffff;
  font-weight: 400;
}
.wp-homepage .wp-uitgelicht__desc {
  color: var(--wp-text-2, #5c5650);
  font-family: var(--wp-sans);
}
.wp-homepage .wp-diensten__desc {
  color: var(--wp-text-2, #5c5650);
  font-family: var(--wp-sans);
}
.wp-homepage .wp-reviews__desc {
  color: var(--wp-text-2, #5c5650);
  font-family: var(--wp-sans);
}
.wp-homepage .wp-inspiratie__title {
  font-family: var(--wp-serif, Georgia, serif);
  font-weight: 400;
  color: var(--wp-text, #1a1a1a);
}
.wp-homepage .wp-inspiratie__desc {
  color: var(--wp-text-2, #5c5650);
  font-family: var(--wp-sans);
}
.wp-homepage .wp-blog-card__title {
  font-family: var(--wp-serif, Georgia, serif);
  font-weight: 400;
}
.wp-homepage .wp-dienst__title {
  font-family: var(--wp-serif, Georgia, serif);
  font-weight: 400;
}
.wp-homepage .wp-dienst__text {
  color: var(--wp-text-2, #5c5650);
  font-family: var(--wp-sans);
}
.wp-homepage .wp-project-card__title {
  font-family: var(--wp-serif, Georgia, serif);
  color: #ffffff;
  font-weight: 400;
}
.wp-homepage .wp-merken__title {
  color: var(--wp-text, #1a1a1a);
  font-family: var(--wp-serif, Georgia, serif);
  font-weight: 400;
}
.wp-homepage .wp-merken__desc {
  color: var(--wp-text-2, #5c5650);
  font-family: var(--wp-sans);
}
.wp-homepage .wp-review__text {
  color: var(--wp-text-2, #5c5650);
  font-family: var(--wp-sans);
}
.wp-homepage .wp-review__author {
  color: var(--wp-text, #1a1a1a);
  font-family: var(--wp-sans);
}
.wp-homepage .wp-plan-bezoek__title {
  color: #ffffff;
  font-family: var(--wp-serif, Georgia, serif);
  font-weight: 400;
}
.wp-homepage .wp-plan-bezoek__text {
  color: var(--wp-dark-text, #e8e4de);
  font-family: var(--wp-sans);
}
.wp-homepage .wp-plan-bezoek__cta {
  color: #ffffff;
  background: var(--wp-gold, #b8960c);
}
.wp-homepage .wp-plan-bezoek__cta:hover {
  color: var(--wp-text, #1a1a1a);
  background: #ffffff;
}
/* Section links */
.wp-homepage .wp-section-link {
  font-family: var(--wp-sans);
  color: var(--wp-text, #1a1a1a);
}
.wp-homepage .wp-section-link:hover {
  color: var(--wp-gold, #b8960c);
}
/* Archive card overrides (reused from archive page) */
.wp-homepage .wp-archive-card__name,
.wp-homepage h3.wp-archive-card__name {
  font-family: var(--wp-serif, Georgia, serif);
  font-weight: 400;
}

/* ============ INSPIRATIE PAGE ============ */
.wp-inspiratie-section {
  padding: 64px 0 72px;
}
.wp-inspiratie-section .wp-section-title {
  font-family: var(--wp-serif, Georgia, serif);
  font-size: 1.75rem;
  font-weight: 400;
  color: var(--wp-text, #1a1a1a);
  margin-bottom: 32px;
}
.wp-inspiratie-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 32px;
}
.wp-inspiratie-grid .wp-blog-card__title {
  font-family: var(--wp-serif, Georgia, serif);
  font-weight: 400;
}
/* Inspiratie filter chips */
.wp-inspiratie-filters {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  margin-bottom: 32px;
}
.wp-filter-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 16px;
  border: 1px solid var(--wp-border, #ddd8d0);
  border-radius: 999px;
  background: transparent;
  color: var(--wp-text-2, #5c5650);
  font-family: var(--wp-sans);
  font-size: .8125rem;
  font-weight: 500;
  cursor: pointer;
  transition: border-color .2s, background .2s, color .2s;
  white-space: nowrap;
}
.wp-filter-chip:hover {
  border-color: var(--wp-gold, #b8960c);
  color: var(--wp-text, #1a1a1a);
}
.wp-filter-chip.is-active {
  background: var(--wp-cta, #1a1a1a);
  border-color: var(--wp-cta, #1a1a1a);
  color: var(--wp-white, #fff);
}
.wp-filter-chip.is-active .wp-filter-chip__count {
  color: rgba(255,255,255,.6);
}
.wp-filter-chip__count {
  font-size: .6875rem;
  color: var(--wp-text-3, #8a837c);
}
/* Hide filtered cards */
.wp-blog-card.is-hidden {
  display: none;
}

.wp-diensten__cta-wrap {
  text-align: center;
  margin-top: 32px;
}

/* Diensten page: full archive view */
.wp-diensten--page { padding: 64px 0 80px; }
.wp-diensten--page .wp-diensten-grid {
  grid-template-columns: repeat(3, 1fr);
}
.wp-dienst__image--placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--wp-surface, #f5f3ef);
  color: var(--wp-text-3, #8a837c);
}
.wp-dienst__link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-top: 12px;
  font-family: var(--wp-sans);
  font-size: .8125rem;
  font-weight: 600;
  color: var(--wp-gold, #b8960c);
  transition: gap .2s;
}
.wp-dienst:hover .wp-dienst__link { gap: 10px; }

/* Allow more than 2 project cards */
.wp-projecten-grid--full {
  grid-template-columns: repeat(2, 1fr);
}

/* ============ RESPONSIVE ============ */
@media (max-width: 1024px) {
  .wp-inspiratie-grid { grid-template-columns: repeat(2, 1fr); gap: 24px; }
  .wp-diensten--page .wp-diensten-grid { grid-template-columns: repeat(2, 1fr); }
  .wp-uitgelicht-grid { grid-template-columns: repeat(3, 1fr); }
  .wp-hero__title,
  .wp-homepage .wp-hero__title,
  .wp-homepage h1.wp-hero__title { font-size: 2.5rem; }
  .wp-blog-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 768px) {
  /* Hero */
  .wp-hero { height: 70vh; min-height: 400px; max-height: 550px; }
  .wp-hero__title,
  .wp-homepage .wp-hero__title,
  .wp-homepage h1.wp-hero__title { font-size: 1.5rem; max-width: 100%; overflow-wrap: break-word; }
  .wp-hero .wp-container { padding-bottom: 48px; }
  .wp-hero__cta { font-size: .75rem; padding: 12px 24px; }
  .wp-hero__scroll { display: none; }

  /* Mobile intro for collecties — only shown on mobile */
  .wp-collectie-mobile-intro {
    display: block;
    background: var(--wp-dark, #1a1a1a);
    padding: 40px 0 24px;
  }
  .wp-collectie-mobile-intro .wp-section-title {
    color: var(--wp-dark-text, #e8e4de);
    margin-bottom: 12px;
    font-size: 1.375rem;
  }
  .wp-collectie-mobile-intro__text {
    color: var(--wp-dark-text-2, #a09890);
    font-size: .875rem;
    line-height: 1.6;
  }

  /* Hide the hero split entirely on mobile — hero cat joins the grid */
  .wp-collectie-hero { display: none; }
  .wp-collectie-row__hero-card { display: block; }

  /* All categories in 2x2 grid (including the hero cat via mobile-only grid) */
  .wp-collecties-row { grid-template-columns: repeat(2, 1fr); gap: 2px; margin-top: 0; }
  .wp-collectie-card { aspect-ratio: 1 / 1; }

  /* USPs: horizontal scrolling strip */
  .wp-usps-home { padding: 0; overflow: hidden; }
  .wp-usps-home .wp-container { max-width: 100%; padding: 0; }
  .wp-usps-grid,
  .wp-homepage .wp-usps-grid {
    display: flex;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    gap: 0;
    margin: 0;
  }
  .wp-usps-grid::-webkit-scrollbar { display: none; }
  .wp-usp-home,
  .wp-homepage .wp-usp-home {
    flex: 0 0 auto;
    scroll-snap-align: start;
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 14px 20px;
    white-space: nowrap;
    border-right: 1px solid rgba(0,0,0,.08);
  }
  .wp-usp-home:last-child { border-right: none; }
  .wp-usp-home__icon {
    display: block;
    width: 16px;
    height: 16px;
    margin: 0;
    flex-shrink: 0;
  }
  .wp-usp-home__title,
  .wp-homepage .wp-usp-home__title { font-size: .75rem; margin-bottom: 0; letter-spacing: .01em; font-family: var(--wp-sans); font-weight: 500; }
  .wp-usp-home__text { display: none; }

  /* Blog: hide decorative side image */
  .wp-inspiratie__image { display: none; }
  .wp-inspiratie__content { padding: 48px var(--wp-gutter, 16px); }

  /* Newsletter button: center instead of right-aligned */
  .wp-newsletter .gform_wrapper input[type="submit"],
  .wp-newsletter .gform_wrapper button[type="submit"] {
    width: 100%;
    text-align: center;
  }

  /* Collecties hero: stack vertically */
  .wp-collectie-hero__content { padding: 40px var(--wp-gutter, 16px); }
  .wp-collectie-hero__image img { min-height: 250px; }
  .wp-collectie-hero__title { font-size: 1.5rem; }
  .wp-collecties-row { grid-template-columns: 1fr; gap: 2px; margin-top: 2px; }

  /* Products */
  .wp-uitgelicht-grid { grid-template-columns: repeat(2, 1fr); gap: 12px; }

  /* Inspiratie */
  .wp-inspiratie__content { padding: 40px var(--wp-gutter, 16px); }
  .wp-inspiratie__title { font-size: 1.375rem; }
  .wp-blog-grid { grid-template-columns: 1fr; }
  .wp-inspiratie-grid { grid-template-columns: repeat(2, 1fr); gap: 16px; }
  .wp-projecten-grid--full { grid-template-columns: 1fr; }

  /* Diensten */
  .wp-diensten-grid { grid-template-columns: 1fr; }

  /* Projecten */
  .wp-projecten-grid { grid-template-columns: 1fr; }
  .wp-project-card { aspect-ratio: 16 / 9; }
  .wp-project-card__desc { display: none; }
  .wp-project-card__title { font-size: 1rem; }

  /* Reviews */
  .wp-reviews-grid { grid-template-columns: 1fr; }

  /* Plan bezoek */
  .wp-plan-bezoek__title { font-size: 1.75rem; }
  .wp-plan-bezoek__cta { font-size: .8125rem; padding: 14px 32px; }

  /* General */
  .wp-section-title { font-size: 1.5rem; }
  .wp-collectie-card { aspect-ratio: 16 / 9; }

  /* Nieuwsbrief form stacking */
  .wp-homepage .nieuwsbrief__form,
  .wp-newsletter .gform_wrapper .gform_footer { flex-direction: column; }
}

/* ============ SPACING FIX ============ */
/* All grids/content get padding-top for breathing room after desc text */
.wp-homepage .wp-uitgelicht-grid,
.wp-homepage .wp-blog-grid,
.wp-homepage .wp-diensten-grid,
.wp-homepage .wp-projecten-grid,
.wp-homepage .wp-reviews-grid,
.wp-homepage .wp-merken-grid,
.wp-homepage .wp-reviews .trustindex-widget,
.wp-homepage .wp-reviews [class*="trustindex"] {
  padding-top: 16px;
}

/* Plan bezoek: more spacing between elements */
.wp-homepage .wp-plan-bezoek__title {
  margin-bottom: 0;
}
.wp-homepage .wp-plan-bezoek__text {
  margin-top: 24px;
}
.wp-homepage .wp-plan-bezoek__cta {
  margin-top: 40px;
  display: inline-flex;
  padding: 16px 40px;
}

/* Nieuwsbrief: base styles (used on homepage, contact, etc.) */
.wp-newsletter {
  background: var(--wp-surface, #f5f3ef);
  padding: 72px 0;
}
.wp-newsletter__inner {
  max-width: 560px;
  margin: 0 auto;
  text-align: center;
}
.wp-newsletter__label {
  font-size: .75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .15em;
  color: var(--wp-text-3, #8a837c);
  margin-bottom: 12px;
  font-family: var(--wp-sans);
}
.wp-newsletter h2 {
  font-family: var(--wp-serif, Georgia, serif);
  font-size: 1.75rem;
  font-weight: 400;
  font-style: italic;
  color: var(--wp-text, #1a1a1a);
  margin-bottom: 12px;
}
.wp-newsletter__desc {
  font-size: .9375rem;
  color: var(--wp-text-2, #5c5650);
  font-family: var(--wp-sans);
  margin-bottom: 32px;
}
/* Gravity Form inside newsletter */
.wp-newsletter .gform_wrapper {
  max-width: 420px;
  margin: 0 auto;
}
.wp-newsletter .gform_wrapper .gform_body {
  width: 100%;
}
.wp-newsletter .gform_wrapper input[type="email"],
.wp-newsletter .gform_wrapper input[type="text"] {
  width: 100% !important;
  padding: 14px 16px !important;
  border: 1.5px solid var(--wp-border, #ddd8d0) !important;
  border-radius: var(--wp-r-sm, 6px) !important;
  font-family: var(--wp-sans) !important;
  font-size: .9375rem !important;
  background: var(--wp-white, #fff) !important;
}
.wp-newsletter .gform_wrapper input[type="email"]:focus {
  border-color: var(--wp-gold, #b8960c) !important;
  outline: none !important;
}
.wp-newsletter .gform_wrapper .gform_footer,
.wp-newsletter .gform_wrapper .gform_page_footer {
  text-align: center !important;
  display: flex !important;
  justify-content: center !important;
}
.wp-newsletter .gform_wrapper input[type="submit"],
.wp-newsletter .gform_wrapper button[type="submit"] {
  padding: 12px 32px !important;
  background: var(--wp-cta, #1a1a1a) !important;
  color: var(--wp-white, #fff) !important;
  font-size: .8125rem !important;
  font-weight: 600 !important;
  letter-spacing: .08em !important;
  text-transform: uppercase !important;
  border-radius: var(--wp-r-sm, 6px) !important;
  border: none !important;
  font-family: var(--wp-sans) !important;
  margin-top: 8px !important;
  width: auto !important;
  display: inline-block !important;
}

/* ============ WCAG: Focus states ============ */
.wp-homepage :focus-visible {
  outline: 2px solid var(--wp-gold, #b8960c);
  outline-offset: 2px;
}
.wp-homepage :focus:not(:focus-visible) {
  outline: none;
}

/* ============ WCAG: Reduced motion ============ */
@media (prefers-reduced-motion: reduce) {
  .wp-homepage .wp-fade-in,
  .wp-homepage .wp-stagger-in {
    transition: none;
    opacity: 1;
    transform: none;
  }
  .wp-homepage .wp-hero__scroll-line { animation: none; }
  .wp-homepage .wp-collectie-card img,
  .wp-homepage .wp-collectie-hero__image img,
  .wp-homepage .wp-project-card img,
  .wp-homepage .wp-blog-card__img img,
  .wp-homepage .wp-dienst__image img,
  .wp-homepage .product-card__img {
    transition: none;
  }
}
