/* =========================================================
   Homepage (front-page.php)
   Aanvullend op het design system in style.css.
   ========================================================= */

/* ---------- Sectieritme ---------- */
.dkp-home-blok { padding-bottom: 32px; }
@media (min-width: 782px) {
  .dkp-home-blok { padding-bottom: 48px; }
}

/* ---------- Hero ---------- */
.dkp-home-hero {
  position: relative;
  overflow: hidden;
  text-align: center;
  padding: 28px 0 32px;
}
@media (min-width: 782px) {
  .dkp-home-hero { padding: 60px 0 52px; }
}

.dkp-home-hero__decor {
  display: none;
  position: absolute;
  font-size: 24px;
  opacity: 0.5;
  pointer-events: none;
}
@media (min-width: 782px) {
  .dkp-home-hero__decor { display: block; }
  .dkp-home-hero__decor--1 { top: 36px; left: 34px; font-size: 30px; }
  .dkp-home-hero__decor--2 { top: 120px; right: 54px; font-size: 26px; }
  .dkp-home-hero__decor--3 { bottom: 30px; left: 114px; font-size: 24px; opacity: 0.45; }
}

.dkp-home-hero__badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-weight: 700;
  font-size: 12px;
  color: var(--dkp-groen);
  background: var(--dkp-tint-groen);
  border-radius: 999px;
  padding: 5px 12px;
  margin-bottom: 16px;
}
.dkp-home-hero__badge::before { content: "\25CF"; font-size: 9px; }
@media (min-width: 782px) {
  .dkp-home-hero__badge { gap: 7px; font-size: 13px; padding: 6px 14px; margin-bottom: 20px; }
}

.dkp-home-hero__titel {
  font-size: 32px;
  line-height: 1.12;
  letter-spacing: -0.02em;
  margin: 0 auto 12px;
  max-width: 640px;
}
@media (min-width: 782px) {
  .dkp-home-hero__titel { font-size: 46px; line-height: 1.1; margin-bottom: 14px; }
}

.dkp-home-hero__sub {
  font-size: 16px;
  color: var(--dkp-subtekst);
  line-height: 1.5;
  margin: 0 auto 22px;
  max-width: 520px;
}
@media (min-width: 782px) {
  .dkp-home-hero__sub { font-size: 19px; margin-bottom: 30px; }
}

.dkp-home-hero__zoek {
  max-width: 560px;
  margin: 0 auto;
  text-align: left;
}

.dkp-home-hero__suggesties {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 7px;
  margin: 12px 0 0;
  font-size: 13px;
}
@media (min-width: 782px) {
  .dkp-home-hero__suggesties { gap: 8px; margin-top: 16px; font-size: 14px; }
}
.dkp-home-hero__suggestielabel { color: var(--dkp-subtekst); }
.dkp-home-hero__suggestie { font-weight: 700; color: var(--dkp-koraal); }
.dkp-home-hero__suggestie:hover { color: var(--dkp-koraal-donker); }

/* ---------- Categorieraster ---------- */
.dkp-home-catkaart__tekst { min-width: 0; }
.dkp-home-catkaart__tekst .dkp-catkaart__naam,
.dkp-home-catkaart__tekst .dkp-catkaart__aantal { display: block; }

@media (max-width: 599px) {
  /* Zoals in het mobiele design: icoon boven de naam, zes kaarten. */
  .dkp-home-categorieen .dkp-catkaart {
    flex-direction: column;
    align-items: flex-start;
    gap: 10px;
    padding: 16px;
    border-radius: 16px;
  }
  .dkp-home-categorieen .dkp-catkaart__icoon {
    width: 42px;
    height: 42px;
    border-radius: 12px;
    font-size: 22px;
  }
  .dkp-home-categorieen .dkp-catkaart__naam { font-size: 16px; }
  .dkp-home-categorieen .dkp-catkaart__aantal { font-size: 12px; }
  .dkp-home-categorieen .dkp-raster > :nth-child(n + 7) { display: none; }
}

/* ---------- Seizoensblok ---------- */
.dkp-home-seizoen__tekst { flex: 1; }

/* Kickerlabel: mobiel kort 'Deze maand', desktop 'Deze maand populair'. */
.dkp-home-seizoen .dkp-seizoensblok__label {
  font-size: 12px;
  margin-bottom: 8px;
}
.dkp-home-seizoen__label-lang { display: none; }
@media (min-width: 782px) {
  .dkp-home-seizoen .dkp-seizoensblok__label {
    font-size: 13px;
    margin-bottom: 10px;
  }
  .dkp-home-seizoen__label-kort { display: none; }
  .dkp-home-seizoen__label-lang { display: inline; }
}

.dkp-home-seizoen__titel {
  font-weight: 700;
  font-size: 24px;
  line-height: 1.1;
  margin: 0 0 8px;
}
@media (min-width: 782px) {
  .dkp-home-seizoen__titel { font-size: 32px; margin-bottom: 10px; }
}

.dkp-home-seizoen__intro {
  font-size: 15px;
  color: var(--dkp-subtekst);
  line-height: 1.5;
  margin: 0 0 16px;
  max-width: 420px;
}
@media (min-width: 782px) {
  .dkp-home-seizoen__intro { font-size: 17px; margin-bottom: 22px; }
}

.dkp-home-seizoen__vellen { display: none; }
@media (min-width: 782px) {
  .dkp-home-seizoen__vellen { display: flex; gap: 14px; }
}
.dkp-home-seizoen__vel {
  display: block;
  width: 140px;
  aspect-ratio: 3 / 4;
  border-radius: 16px;
  overflow: hidden;
  background: #FFFFFF;
  border: 1px solid var(--dkp-lijn);
  box-shadow: 0 8px 20px rgba(35, 33, 48, 0.08);
  transition: box-shadow 0.2s ease;
}
.dkp-home-seizoen__vel:hover { box-shadow: var(--dkp-schaduw-hover); }
.dkp-home-seizoen__vel img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  background: #FFFFFF;
  display: block;
}

/* ---------- Populair nu: scrollen op mobiel, raster op desktop ---------- */
.dkp-home-scrollraster {
  display: flex;
  gap: 12px;
  overflow-x: auto;
  padding-bottom: 8px;
  -webkit-overflow-scrolling: touch;
}
.dkp-home-scrollraster > * { width: 160px; flex: none; }
@media (min-width: 900px) {
  .dkp-home-scrollraster {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 18px;
    overflow: visible;
    padding-bottom: 0;
  }
  .dkp-home-scrollraster > * { width: auto; }
}

/* ---------- Op leeftijd ---------- */
/* 2x2 op mobiel en tablet, 4 naast elkaar op desktop (geen weeskaart). */
@media (min-width: 600px) and (max-width: 899px) {
  .dkp-home-leeftijdraster { grid-template-columns: repeat(2, 1fr); }
}

.dkp-leeftijdkaart {
  display: block;
  border: 1px solid var(--dkp-lijn);
  border-radius: 18px;
  padding: 20px;
  color: var(--dkp-inkt);
  transition: box-shadow 0.2s ease;
}
@media (min-width: 782px) {
  .dkp-leeftijdkaart { padding: 24px; }
}
.dkp-leeftijdkaart:hover,
.dkp-leeftijdkaart:focus-visible {
  box-shadow: 0 10px 22px rgba(35, 33, 48, 0.10);
  color: var(--dkp-inkt);
}
.dkp-leeftijdkaart__icoon {
  display: block;
  font-size: 30px;
  margin-bottom: 12px;
}
.dkp-leeftijdkaart__bereik {
  display: block;
  font-family: var(--dkp-font-kop);
  font-weight: 600;
  font-size: 19px;
}
.dkp-leeftijdkaart__label {
  display: block;
  color: var(--dkp-subtekst);
  font-size: 14px;
  margin-top: 2px;
}

/* ---------- Generator uitgelicht ---------- */
.dkp-home-generator__nieuw {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  font-weight: 700;
  font-size: 12px;
  color: var(--dkp-geel);
  margin-bottom: 8px;
}
@media (min-width: 782px) {
  .dkp-home-generator__nieuw { font-size: 13px; margin-bottom: 12px; }
}

.dkp-home-generator__titel {
  font-weight: 700;
  font-size: 24px;
  line-height: 1.15;
  margin: 0 0 8px;
}
@media (min-width: 782px) {
  .dkp-home-generator__titel { font-size: 32px; margin-bottom: 12px; }
}

.dkp-home-generator__intro {
  font-size: 15px;
  line-height: 1.5;
  margin: 0 0 18px;
  max-width: 440px;
}
@media (min-width: 782px) {
  .dkp-home-generator__intro { font-size: 17px; line-height: 1.55; margin-bottom: 24px; }
}

.dkp-home-generator__kaart { display: none; }
@media (min-width: 782px) {
  .dkp-home-generator__kaart {
    display: block;
    width: 260px;
    flex: none;
    background: var(--dkp-papier);
    border-radius: 16px;
    padding: 18px;
    color: var(--dkp-inkt);
  }
}
.dkp-home-generator__kaartlabel {
  font-size: 13px;
  color: var(--dkp-subtekst);
  margin-bottom: 8px;
}
.dkp-home-generator__prompt {
  font-weight: 600;
  font-size: 16px;
  background: var(--dkp-mist);
  border-radius: 10px;
  padding: 12px 14px;
  margin-bottom: 14px;
}
.dkp-home-generator__resultaat {
  aspect-ratio: 1;
  border-radius: 12px;
  background: repeating-linear-gradient(45deg, #FBF9F4, #FBF9F4 10px, var(--dkp-mist) 10px, var(--dkp-mist) 20px);
  border: 1px solid var(--dkp-lijn);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 34px;
}
.dkp-home-generator__resultaat span { opacity: 0.55; }

/* ---------- Nieuwste kleurplaten: compactere kaarten ---------- */
.dkp-home-nieuwkaart { border-radius: 14px; }
.dkp-home-nieuwkaart .dkp-kaart__inhoud { padding: 10px; }
.dkp-home-nieuwkaart .dkp-kaart__titel { font-size: 13px; line-height: 1.2; }
.dkp-home-nieuwkaart .dkp-kaart__gratis { display: none; }

/* ---------- Kort uitlegblok ---------- */
.dkp-home-uitleg {
  max-width: 760px;
  margin: 0 auto;
  text-align: center;
  padding-bottom: 40px;
}
@media (min-width: 782px) {
  .dkp-home-uitleg { padding-bottom: 56px; }
}
.dkp-home-uitleg h2 { margin: 0 0 12px; }
.dkp-home-uitleg p {
  font-size: 16px;
  color: var(--dkp-subtekst);
  line-height: 1.65;
  margin: 0;
}
@media (min-width: 782px) {
  .dkp-home-uitleg p { font-size: 17px; }
}
.dkp-home-uitleg a { font-weight: 700; color: var(--dkp-koraal); }
.dkp-home-uitleg a:hover { color: var(--dkp-koraal-donker); }
