/*
 Theme Name:   Kadence Child – KVW Grubbenvorst
 Template:     kadence
 Version:      1.0
 Author:       Walter Winter / Motion2Frame
*/

/* ================================================ */
/* ===============  DESIGN TOKENS  ================ */
/* ================================================ */

:root {
  --kvw-blauw:        #1a4fa0;
  --kvw-blauw2:       #2563c8;
  --kvw-groen:        #3aaa35;
  --kvw-rood:         #cc2200;
  --kvw-cyaan:        #00b4d8;
  --kvw-geel:         #f5c518;
  --kvw-donker:       #12233a;
  --kvw-grijs:        #f4f7fb;
  --kvw-wit:          #ffffff;
  --radius:           12px;
  --schaduw:          0 4px 24px rgba(26,79,160,0.13);
  --font-titel:       'Fredoka One', 'Trebuchet MS', sans-serif;
  --font-body:        'Nunito', 'Segoe UI', sans-serif;
}

/* Google Fonts */
@import url('https://fonts.googleapis.com/css2?family=Fredoka+One&family=Nunito:wght@400;600;700;800&display=swap');

/* ================================================ */
/* ================  TYPOGRAFIE  ================= */
/* ================================================ */

body {
  font-family: var(--font-body);
  color: var(--kvw-donker);
  background: var(--kvw-wit);
}

h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-titel);
  letter-spacing: 0.3px;
}

/* ================================================ */
/* =================  TOPBAR  ==================== */
/* ================================================ */

.kadence-top-bar {
  background-color: var(--kvw-blauw) !important;
  color: #fff !important;
  font-weight: 700;
  font-size: 13px;
}

.kadence-top-bar a { color: #fff !important; }

/* ================================================ */
/* =================  HEADER  ==================== */
/* ================================================ */

#masthead,
.site-header {
  background-color: var(--kvw-wit) !important;
  border-bottom: 3px solid var(--kvw-blauw) !important;
  box-shadow: 0 2px 16px rgba(26,79,160,0.10) !important;
}

/* Sticky header */
.kadence-sticky-header #masthead {
  box-shadow: 0 3px 20px rgba(26,79,160,0.15) !important;
}

/* ================================================ */
/* =================  NAVIGATIE  ================= */
/* ================================================ */

.nav-primary .menu > li > a,
#primary-menu > li > a {
  font-family: var(--font-titel) !important;
  font-size: 15px !important;
  text-transform: uppercase;
  letter-spacing: 0.8px;
  color: var(--kvw-donker) !important;
  transition: color 0.2s !important;
}

.nav-primary .menu > li > a:hover,
#primary-menu > li > a:hover {
  color: var(--kvw-blauw) !important;
}

.nav-primary .menu > li.current-menu-item > a {
  color: var(--kvw-blauw) !important;
  border-bottom: 3px solid var(--kvw-blauw);
  padding-bottom: 2px;
}

/* Aanmelden knop in menu */
.menu-item.menu-btn a,
.nav-primary .menu > li.menu-btn > a {
  background: var(--kvw-blauw) !important;
  color: #fff !important;
  border-radius: 50px !important;
  padding: 8px 22px !important;
  transition: background 0.2s, transform 0.2s !important;
}

.menu-item.menu-btn a:hover {
  background: var(--kvw-blauw2) !important;
  transform: translateY(-1px);
}

/* ================================================ */
/* =================  KNOPPEN  =================== */
/* ================================================ */

.wp-block-button__link,
.kb-btn,
.button {
  font-family: var(--font-titel) !important;
  font-size: 15px !important;
  letter-spacing: 1.2px;
  text-transform: uppercase;
  border-radius: 50px !important;
  padding: 13px 32px !important;
  transition: transform 0.2s ease, box-shadow 0.2s ease !important;
  border: none !important;
}

.wp-block-button__link:hover,
.kb-btn:hover {
  transform: translateY(-3px) !important;
  box-shadow: 0 8px 24px rgba(0,0,0,0.20) !important;
}

/* Primair blauw */
/* .wp-block-button.is-style-fill .wp-block-button__link {
  background: var(--kvw-blauw) !important;
  color: #fff !important;
} */

/* Groen */
.wp-block-button.is-style-groen .wp-block-button__link {
  background: var(--kvw-groen) !important;
  color: #fff !important;
}

/* Rood */
.wp-block-button.is-style-rood .wp-block-button__link {
  background: var(--kvw-rood) !important;
  color: #fff !important;
}

/* Outline wit (voor op donkere achtergrond) */
.wp-block-button.is-style-outline .wp-block-button__link {
  background: transparent !important;
  border: 2.5px solid #fff !important;
  color: #fff !important;
}

/* ================================================ */
/* ============  KLEURBLOKKEN (3-GRID)  =========== */
/* ================================================ */

/* Gebruik een Kadence Row met 3 kolommen + klasse .kvw-kleurblokken */
.kvw-kleurblokken {
  gap: 0;
  margin-top: 0px !important;
  margin-bottom: 0px !important;
}

.kvw-kleurblokken .wp-block-column:nth-child(1),
.kvw-kleurblokken .kadence-column:nth-child(1) {
  background-color: #ED008C !important;
}

.kvw-kleurblokken .wp-block-column:nth-child(2),
.kvw-kleurblokken .kadence-column:nth-child(2) {
  background-color: #17469E !important;
}

.kvw-kleurblokken .wp-block-column:nth-child(3),
.kvw-kleurblokken .kadence-column:nth-child(3) {
  background-color: #00ADEF !important;
}

.kvw-kleurblokken .wp-block-column,
.kvw-kleurblokken .kadence-column {
  padding: 44px 36px !important;
  transition: filter 0.2s;
}

.kvw-kleurblokken .wp-block-column:hover,
.kvw-kleurblokken .kadence-column:hover {
  filter: brightness(1.07);
}

.kvw-kleurblokken h2,
.kvw-kleurblokken .wp-block-heading {
  font-family: var(--font-titel) !important;
  font-weight: bold;
  color: #fff !important;
  font-size: 2rem !important;
  margin-bottom: 10px !important;
  margin-top: 0px !important;
}

.kvw-kleurblokken p {
  color: rgba(255,255,255,0.92) !important;
  font-weight: 600 !important;
  margin-bottom: 20px !important;
}

/* Blok-knop stijl in de kleurblokken */
.kvw-kleurblokken .wp-block-button__link {
  background: rgba(255,255,255,0.2) !important;
  border: 2.5px solid #fff !important;
  color: #fff !important;
}

.kvw-kleurblokken .wp-block-button__link:hover {
  background: rgba(255,255,255,0.38) !important;
}

/* ================================================ */
/* ============  SECTIE TITELS  ================== */
/* ================================================ */

.wp-block-heading,
.entry-title {
  font-family: var(--font-titel) !important;
}

/* Sectie-label boven de titel (kleine blauwe tekst) */
.kvw-label {
  font-family: var(--font-titel);
  font-size: 12px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--kvw-blauw);
  display: block;
  margin-bottom: 6px;
}

/* Streep onder sectie h2 */
.wp-block-heading.has-text-align-center::after,
.kvw-sectie-titel::after {
  content: '';
  display: block;
  width: 56px;
  height: 4px;
  background: var(--kvw-blauw);
  border-radius: 2px;
  margin: 12px auto 0;
}

/* ================================================ */
/* ============  DATUM BANNER  =================== */
/* ================================================ */

.kvw-datum-banner {
  background-color: var(--kvw-blauw) !important;
  text-align: center;
  padding: 48px 40px !important;
}

.kvw-datum-banner p,
.kvw-datum-banner .wp-block-paragraph {
  font-family: var(--font-titel) !important;
  font-size: clamp(1.2rem, 2.5vw, 1.8rem) !important;
  color: #fff !important;
}

.kvw-datum-banner strong { color: var(--kvw-geel) !important; }

/* ================================================ */
/* ========  AFWISSELENDE SECTIE KLEUREN  ======== */
/* ================================================ */

.kvw-grijs-bg { background-color: var(--kvw-grijs) !important; }
.kvw-blauw-bg { background-color: var(--kvw-blauw) !important; }
.kvw-groen-bg { background-color: var(--kvw-groen) !important; }

.kvw-blauw-bg *,
.kvw-groen-bg * {
  color: #fff !important;
}

.kvw-groen-bg a.wp-block-button__link {
  color: var(--kvw-groen) !important;
  font-weight: bold;
}

/* ================================================ */
/* ==============  SPONSOR KAARTEN  ============== */
/* ================================================ */

/* sponsor slider margin top aanpassen */
.n2-section-smartslider > div.n2-ss-margin {
  margin-top: 30px !important;
  margin-bottom: 30px !important;
}

.kvw-sponsoren {
  margin-bottom: 0px !important;
}
.kvw-sponsor-kaart {
  background: var(--kvw-grijs);
  border-radius: var(--radius);
  padding: 28px 40px;
  text-align: center;
  transition: box-shadow 0.2s, transform 0.2s;
}

.kvw-sponsor-kaart:hover {
  box-shadow: var(--schaduw);
  transform: translateY(-3px);
}

/* Afbeeldingen in sponsor sectie */
.kvw-sponsoren .wp-block-image img {
  filter: grayscale(20%);
  transition: filter 0.3s, transform 0.3s;
  border-radius: var(--radius);
}

.kvw-sponsoren .wp-block-image img:hover {
  filter: grayscale(0%);
  transform: scale(1.05);
}

/* ================================================ */
/* ==================  FOOTER  =================== */
/* ================================================ */
.site-middle-footer-wrap {
  padding-left: 36px;
  padding-right: 36px;
}
.footer-navigation .menu {
  display: block !important;
}
.site-footer,
#colophon {
  background-color: var(--kvw-donker) !important;
  color: #a8bbd4 !important;
}

.site-footer a,
#colophon a {
  color: #a8bbd4 !important;
  transition: color 0.2s;
}

.site-footer a:hover,
#colophon a:hover {
  color: #fff !important;
}

.site-footer .widget-title,
#colophon .widget-title {
  font-family: var(--font-titel) !important;
  color: #fff !important;
  font-size: 1.1rem;
}

.site-footer .footer-html,
.kadence-footer-bottom {
  background-color: var(--kvw-blauw) !important;
  color: rgba(255,255,255,0.80) !important;
  text-align: center;
  font-size: 13px;
  padding: 14px 40px !important;
}
.site-bottom-footer-inner-wrap {
  padding: 0 !important;
}
/* ================================================ */
/* ==============  ANIMATIES / HOVER  ============= */
/* ================================================ */

/* Zachte fade-in voor Kadence blokken */
.kadence-block-column,
.wp-block-column {
  animation: kvwFadeUp 0.55s ease both;
}

@keyframes kvwFadeUp {
  from { opacity: 0; transform: translateY(18px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Blurb / info blok hover */
.kb-info-box,
.kadence-info-box {
  transition: transform 0.25s ease, box-shadow 0.25s ease;
  border-radius: var(--radius) !important;
}

.kb-info-box:hover,
.kadence-info-box:hover {
  transform: translateY(-4px);
  box-shadow: var(--schaduw);
}

/* ================================================ */
/* ==============  MOBIEL RESPONSIVE  ============= */
/* ================================================ */

@media (max-width: 768px) {
  .kvw-kleurblokken .wp-block-columns {
    flex-wrap: wrap;
  }

  .kvw-kleurblokken .wp-block-column {
    flex-basis: 100% !important;
  }

  .wp-block-button__link {
    padding: 12px 24px !important;
    font-size: 14px !important;
  }
}
/* Tekst in hero Cover blok bovenaan uitlijnen */
.wp-block-cover .wp-block-cover__inner-container {
  justify-content: flex-start !important;
  align-items: flex-start !important;
}

.wp-block-cover {
  align-items: flex-start !important;
}
.wp-block-cover__inner-container h1 {
  margin-bottom: 0 !important;
}