/* =============================================
   Hogendoorn Keukens - Moderne website stijl
   ============================================= */

@font-face {
  font-family: 'Open Sans Condensed';
  src: url('../fonts/OpenSansCondensed-Light.ttf') format('truetype');
  font-weight: 300;
  font-style: normal;
}

@font-face {
  font-family: 'Shadows Into Light Two';
  src: url('../fonts/ShadowsIntoLightTwo-Regular.ttf') format('truetype');
  font-weight: normal;
  font-style: normal;
}

/* === CSS VARIABELEN === */
:root {
  --rood:       #E2001A;
  --rood-donker:#b5001a;
  --donker:     #1F1F1F;
  --bg:         #F5F5F5;
  --kaart:      #FFFFFF;
  --section-gap: 22px;
}

/* === RESET & BASE === */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  font-family: Verdana, Arial, Helvetica, sans-serif;
  font-size: 15px;
  line-height: 1.6em;
  color: var(--donker);
  background: var(--bg);
}
img { max-width: 100%; height: auto; display: block; }
a { color: var(--rood); text-decoration: none; }
a:hover { text-decoration: underline; color: var(--rood-donker); }
ul { list-style: none; }
p { margin-bottom: 10px; }
strong { font-weight: bold; }

/* === LAYOUT === */
.container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 15px;
}

/* === TOP BAR === */
.top-bar { display: none; }

/* === HEADER === */
.site-header {
  background: var(--donker);
  padding: 12px 0;
}
.site-header .container {
  display: flex;
  justify-content: center;
}
.site-header .logo img { height: 85px; width: auto; }

/* === NAVIGATION === */
.main-nav {
  background: var(--donker);
  position: relative;
  z-index: 100;
  box-shadow: 0 2px 4px rgba(0,0,0,0.3);
}
.main-nav .container {
  display: flex;
  justify-content: center;
}
.nav-toggle {
  display: none;
  position: relative;
  width: 38px;
  height: 38px;
  background: transparent;
  border: none;
  border-radius: 0;
  color: #fff;
  font-size: 0;
  cursor: pointer;
  padding: 0;
  line-height: 1;
}
.nav-toggle::before,
.nav-toggle::after {
  content: '';
  position: absolute;
  left: 9px;
  right: 9px;
  height: 2px;
  background: #fff;
  border-radius: 999px;
  transition: transform 0.18s ease, top 0.18s ease, background 0.18s ease;
}
.nav-toggle::before {
  top: 14px;
}
.nav-toggle::after {
  top: 24px;
}
.nav-toggle:hover,
.nav-toggle.open {
  background: transparent;
}
@media (hover: hover) {
  .nav-toggle:hover::before,
  .nav-toggle:hover::after {
    background: var(--rood);
  }
}
.nav-toggle.open::before,
.nav-toggle.open::after {
  background: var(--rood);
}
.nav-toggle.open::before {
  top: 19px;
  transform: rotate(45deg);
}
.nav-toggle.open::after {
  top: 19px;
  transform: rotate(-45deg);
}
.nav-menu {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  min-height: 54px;
}

/* Nav-logo: alleen zichtbaar op mobiel (header wordt verborgen) */
.nav-logo { display: none; }
.nav-logo img { height: 70px; width: auto; max-width: none; display: block; }
.nav-menu > li > a,
.nav-menu > li > a:visited {
  display: block;
  position: relative;
  z-index: 0;
  padding: 6px 32px;
  color: #fff;
  font-family: 'Open Sans Condensed', 'Arial Narrow', Arial, sans-serif;
  font-size: 18px;
  font-weight: 300;
  text-transform: uppercase;
  letter-spacing: 0.4px;
  transition: background 0.15s;
  white-space: nowrap;
}
.nav-menu > li > a:hover {
  color: rgba(255,255,255,0.65);
  text-decoration: none;
}
.nav-menu > li.active > a {
  color: #fff;
  text-decoration: none;
}
.nav-menu > li.active > a::before {
  content: '';
  position: absolute;
  inset: 0 12px;
  background: var(--rood);
  border-radius: 3px;
  z-index: -1;
}
.nav-menu > li { position: relative; }

/* Dropdown */
.nav-menu > li .dropdown {
  display: none;
  position: absolute;
  top: 100%;
  left: 0;
  background: #2a2a2a;
  min-width: 200px;
  z-index: 200;
  box-shadow: 0 4px 10px rgba(0,0,0,0.4);
}
.nav-menu > li:hover .dropdown { display: block; }
.nav-menu > li .dropdown li a,
.nav-menu > li .dropdown li a:visited {
  display: block;
  padding: 10px 16px;
  color: #ccc;
  font-size: 13px;
  border-bottom: 1px solid #3a3a3a;
  transition: background 0.15s;
}
.nav-menu > li .dropdown li:last-child a { border-bottom: none; }
.nav-menu > li .dropdown li a:hover {
  color: #fff;
  text-decoration: none;
}

/* === VERHUISBANNER === */
.move-banner {
  background: #fff3f3;
  border-top: 4px solid var(--rood);
  border-bottom: 1px solid #f0b7b7;
  color: #222;
  font-size: 14px;
  line-height: 1.55;
  box-shadow: 0 3px 10px rgba(0,0,0,0.11);
}
.move-banner .container {
  text-align: center;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: baseline;
  gap: 4px 8px;
  padding-top: 12px;
  padding-bottom: 12px;
}
.move-banner strong {
  color: var(--rood);
  font-weight: bold;
}
.move-banner-address {
  display: inline;
  margin-left: 4px;
  margin-right: 4px;
  color: #111;
  line-height: inherit;
  font-weight: 800;
  letter-spacing: 0;
  text-decoration: none;
  border-bottom: 1px solid rgba(230,0,18,0.35);
}
.move-banner-address:hover {
  color: var(--rood);
  border-bottom-color: var(--rood);
}
.move-banner-note {
  margin-left: 6px;
}

/* === HOMEPAGE SLIDER === */
.slider-wrapper {
  position: relative;
  overflow: hidden;
  background: #000;
  margin: var(--section-gap) 0;
  box-shadow: 0 3px 8px rgba(0,0,0,0.15);
}
.slider {
  display: flex;
  width: 100%;
  transition: transform 0.7s ease-in-out;
}
.slide {
  flex: 0 0 100%;
  height: 470px;
  overflow: hidden;
  position: relative;
}
.slide img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}
.slide-title {
  position: absolute;
  top: 32px;
  left: 36px;
  color: #fff;
  font-family: 'Shadows Into Light Two', cursive;
  font-size: 44px;
  text-shadow: 1px 2px 8px rgba(0,0,0,0.85), 0 0 20px rgba(0,0,0,0.5);
  pointer-events: none;
}
.slide-promo-wrap {
  position: absolute;
  bottom: 40px;
  left: 0;
  width: 240px;
  overflow: visible;
  z-index: 10;
  pointer-events: none;
}
.slide-promo {
  background: rgba(226, 0, 26, 0.72);
  color: #fff;
  padding: 12px 22px;
  font-size: 19px;
  font-weight: normal;
  width: 100%;
  line-height: 1.4;
}
.slider-badge {
  position: absolute !important;
  width: 100px !important;
  max-width: none !important;
  height: auto !important;
  top: -62px;
  right: -50px;
  z-index: 11;
  pointer-events: none;
  display: block !important;
}
.slider-dots {
  position: absolute;
  bottom: 14px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  gap: 8px;
}
.slider-dots button {
  width: 11px;
  height: 11px;
  border-radius: 50%;
  border: 2px solid rgba(255,255,255,0.8);
  background: transparent;
  cursor: pointer;
  padding: 0;
  transition: background 0.2s;
}
.slider-dots button.active {
  background: var(--rood);
  border-color: var(--rood);
}
.slider-prev, .slider-next {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  background: none;
  color: #fff;
  border: none;
  font-size: 32px;
  width: 44px;
  height: 64px;
  cursor: pointer;
  z-index: 10;
  transition: color 0.2s, opacity 0.2s;
  line-height: 1;
  opacity: 0.5;
  text-shadow: 1px 1px 6px rgba(0,0,0,0.7);
}
.slider-prev:hover, .slider-next:hover { opacity: 1; color: #fff; }
.slider-prev { left: 0; }
.slider-next { right: 0; }

@media (max-width: 768px) {
  .slider-prev, .slider-next {
    width: 52px;
    height: 80px;
    font-size: 28px;
    opacity: 0.7;
  }
}

/* === PAGE BANNER (subpagina's) === */

.page-slider .slider-wrapper {
  margin: var(--section-gap) 0;
}
.page-slider .slide {
  height: 200px;
}
.page-slider .slide img {
  object-position: right center;
}
@media (max-width: 600px) {
  .page-slider .slide {
    height: 150px;
  }
  .page-slider .slide img {
    object-position: left center;
  }
}

/* === KEUKEN TILES (homepage) === */
.kitchen-tiles {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 26px;
  margin: var(--section-gap) 0;
}
.kitchen-tile {
  background: #19161a;
  border: none;
  box-shadow: 3px 4px 10px rgba(0,0,0,0.25);
  overflow: hidden;
  text-align: center;
  transition: box-shadow 0.2s, transform 0.2s;
  display: flex;
  flex-direction: column;
  text-decoration: none;
  color: inherit;
}
.kitchen-tile:hover {
  box-shadow: 4px 6px 18px rgba(0,0,0,0.4);
  transform: translateY(-2px);
}
.kitchen-tile h3 {
  background: #19161a;
  color: #fff;
  padding: 14px 24px 10px;
  text-align: left;
  font-family: 'Shadows Into Light Two', 'Comic Sans MS', cursive;
  font-size: 28px;
  font-weight: normal;
  margin: 0;
  line-height: 1.2;
}
.kitchen-tile .tile-img {
  width: 100%;
  height: 260px;
  object-fit: cover;
  transition: opacity 0.3s ease;
}
.kitchen-tile .tile-img.fading { opacity: 0; }
.kitchen-tile .tile-body {
  padding: 10px 12px 14px;
  flex: 1;
  display: flex;
  flex-direction: column;
}
.kitchen-tile .tile-body p {
  font-size: 13px;
  color: #bbb;
  line-height: 1.6;
  margin-bottom: 12px;
  flex: 1;
}
.kitchen-tile a.btn {
  display: inline-block;
  background: var(--rood);
  color: #fff;
  padding: 5px 13px;
  font-size: 13px;
  font-weight: bold;
  letter-spacing: 0.5px;
  transition: background 0.15s;
  align-self: center;
}
.kitchen-tile a.btn:hover {
  background: var(--rood-donker);
  text-decoration: none;
}

/* === CONTENT LAYOUT (twee kolommen) === */
.content-area {
  display: flex;
  gap: 22px;
  margin: 0 0 var(--section-gap);
  align-items: flex-start;
}
.main-content { flex: 1; min-width: 0; }
.sidebar { width: 260px; flex-shrink: 0; }

/* Homepage: rij van 3 onderaan */
.home-bottom-row {
  display: flex;
  flex-direction: row;
  gap: 22px;
  align-items: stretch;
  margin: var(--section-gap) 0;
}
.home-bottom-row .sidebar-widget {
  flex: 1;
}
.home-bottom-row .sidebar-widget img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* Offerte kaart */
.offerte-card {
  background: var(--kaart);
  border: 1px solid #ddd;
  box-shadow: 2px 3px 7px rgba(0,0,0,0.08);
  padding: 22px;
  display: flex;
  flex-direction: column;
}
.offerte-card h3 {
  font-family: 'Open Sans Condensed', 'Arial Narrow', Arial, sans-serif;
  color: #222;
  font-size: 19px;
  margin-bottom: 10px;
  padding-bottom: 6px;
  border-bottom: 2px solid var(--rood);
}
.offerte-card p {
  flex: 1;
  color: #444;
  font-size: 14px;
  line-height: 1.6;
  margin-bottom: 18px;
}
.btn-offerte {
  display: inline-block;
  background: var(--rood);
  color: #fff !important;
  padding: 10px 20px;
  font-size: 13px;
  font-weight: bold;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  text-decoration: none !important;
  align-self: flex-start;
}
.btn-offerte:hover { background: var(--rood-donker); }

/* Address list met icoontjes */
.address-list {
  list-style: none;
  padding: 0;
  margin: 0;
  font-size: 14px;
  line-height: 1.5;
}
.address-list li {
  display: flex;
  gap: 9px;
  align-items: baseline;
  margin-bottom: 7px;
}
.addr-icon {
  color: var(--rood);
  font-size: 9px;
  min-width: 14px;
  flex-shrink: 0;
}

/* === CONTENT BOXEN === */
.content-box {
  background: var(--kaart);
  border: 1px solid #ddd;
  box-shadow: 2px 3px 7px rgba(0,0,0,0.08);
  padding: 22px;
  margin-bottom: var(--section-gap);
}
.content-box h1,
.content-box h2 {
  font-family: 'Open Sans Condensed', 'Arial Narrow', Arial, sans-serif;
  color: #222;
  font-size: 30px;
  font-weight: bold;
  line-height: 1.3;
  margin-bottom: 14px;
  padding-bottom: 10px;
  border-bottom: 2px solid var(--rood);
}
.content-box h3 {
  font-family: Verdana, Arial, sans-serif;
  color: #333;
  font-size: 13px;
  font-weight: bold;
  margin: 14px 0 8px;
}
.content-box ul {
  list-style: disc;
  margin-left: 20px;
  margin-bottom: 12px;
}
.content-box ul li { margin-bottom: 4px; }
.content-box .kenmerk-list {
  list-style: none;
  margin-left: 0;
}
.content-box .kenmerk-list li {
  padding-left: 20px;
  position: relative;
  margin-bottom: 6px;
}
.content-box .kenmerk-list li::before {
  content: '\2713';
  position: absolute;
  left: 0;
  color: var(--rood);
  font-weight: bold;
}


/* Welkomsttekst (homepage) */
.welcome-box {
  background: var(--kaart);
  border: 1px solid #ddd;
  box-shadow: 2px 3px 7px rgba(0,0,0,0.08);
  padding: 22px;
  margin-bottom: 0;
}
.welcome-box h1,
.welcome-box h2 {
  font-family: 'Open Sans Condensed', 'Arial Narrow', Arial, sans-serif;
  color: #222;
  font-size: 28px;
  line-height: 1.3;
  margin-bottom: 12px;
  padding-bottom: 8px;
  border-bottom: 2px solid var(--rood);
}

/* === SIDEBAR === */
.sidebar-widget { margin-bottom: 14px; }
.sidebar-widget img { width: 100%; }
.address-box {
  background: var(--kaart);
  border: 1px solid #ddd;
  box-shadow: 2px 3px 7px rgba(0,0,0,0.08);
  padding: 18px;
  font-size: 13px;
  line-height: 1.8;
}
.address-box h3 {
  font-family: 'Open Sans Condensed', 'Arial Narrow', Arial, sans-serif;
  color: #222;
  font-size: 19px;
  margin-bottom: 10px;
  padding-bottom: 6px;
  border-bottom: 2px solid var(--rood);
}
.address-box a { color: var(--rood); overflow-wrap: break-word; }
.address-box p { margin-bottom: 4px; }

/* === GALERIJ === */
.gallery-section { margin-top: 20px; }
.gallery-section h3 {
  font-family: 'Open Sans Condensed', 'Arial Narrow', Arial, sans-serif;
  color: #222;
  font-size: 20px;
  margin-bottom: 12px;
  padding-bottom: 6px;
  border-bottom: 2px solid var(--rood);
}
.gallery-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
}
.gallery-item {
  cursor: pointer;
  overflow: hidden;
  border: 2px solid transparent;
  transition: border-color 0.2s;
}
.gallery-item:hover { border-color: var(--rood); }
.gallery-item img {
  width: 100%;
  height: 110px;
  object-fit: cover;
  display: block;
  transition: transform 0.25s;
}
.gallery-item:hover img { transform: scale(1.04); }

/* === LIGHTBOX === */
.lightbox {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.88);
  z-index: 1000;
  justify-content: center;
  align-items: center;
}
.lightbox.active { display: flex; }
.lightbox-img {
  max-width: 88vw;
  max-height: 85vh;
  object-fit: contain;
  box-shadow: 0 0 40px rgba(0,0,0,0.6);
}
.lightbox-close {
  position: absolute;
  top: 18px;
  right: 24px;
  color: #fff;
  font-size: 36px;
  line-height: 1;
  cursor: pointer;
  transition: color 0.15s;
  user-select: none;
  z-index: 10;
  /* button reset (toegankelijkheid) */
  background: none;
  border: none;
  padding: 0;
  font-family: inherit;
}
.lightbox-close:hover { color: var(--rood); }
.lightbox-prev, .lightbox-next {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  background: rgba(0,0,0,0.35);
  border: none;
  color: #fff;
  font-size: 28px;
  width: 52px;
  height: 80px;
  cursor: pointer;
  z-index: 10;
  transition: background 0.2s;
  line-height: 1;
}
.lightbox-prev:hover, .lightbox-next:hover { background: rgba(0,0,0,0.65); }
.lightbox-prev { left: 0; border-radius: 0 4px 4px 0; }
.lightbox-next { right: 0; border-radius: 4px 0 0 4px; }

/* === MERKEN SECTIE === */
.brands-section {
  background: var(--kaart);
  border-top: 3px solid var(--rood);
  border-bottom: 1px solid #ddd;
  padding: 18px 0 20px;
  margin: var(--section-gap) 0 0;
  overflow: hidden;
}
.brands-section h3 {
  font-family: 'Open Sans Condensed', 'Arial Narrow', Arial, sans-serif;
  color: #333;
  font-size: 19px;
  margin-bottom: 14px;
  font-weight: bold;
}
.brands-viewport {
  width: 100%;
  overflow: hidden;
}
.brands-grid {
  display: flex;
  flex-wrap: nowrap;
  gap: 0 56px;
  align-items: center;
  width: max-content;
  padding: 0 56px 0 0;
  will-change: transform;
}
.brands-marquee {
  animation: brands-marquee 28s linear infinite;
}
.brands-viewport:hover .brands-marquee {
  animation-play-state: paused;
}
.brands-grid img {
  height: 32px;
  width: auto;
  max-width: 120px;
  flex-shrink: 0;
  object-fit: contain;
  display: inline-block;
}

@keyframes brands-marquee {
  from { transform: translateX(0); }
  to { transform: translateX(-50%); }
}

/* === FOOTER === */
.site-footer {
  background: var(--donker);
  color: #bbb;
  font-size: 13px;
}
.site-footer strong { color: #ddd; }
.site-footer a { color: #aaa; }
.site-footer a:hover { color: #fff; text-decoration: none; }

/* Footer 3 kolommen */
.footer-cols {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 32px;
  padding: 36px 0 28px;
  border-bottom: 1px solid #2e2e2e;
}
.footer-col h4 {
  color: #fff;
  font-family: 'Open Sans Condensed', 'Arial Narrow', Arial, sans-serif;
  font-size: 14px;
  font-weight: bold;
  letter-spacing: 1px;
  text-transform: uppercase;
  margin-bottom: 14px;
  padding-bottom: 7px;
  border-bottom: 2px solid var(--rood);
  display: inline-block;
}
.footer-col p { margin-bottom: 8px; line-height: 1.8; }
.footer-col ul { padding: 0; margin: 0; }
.footer-col ul li { margin-bottom: 7px; }
.footer-col ul li a { color: #aaa; }
.footer-col ul li a:hover { color: #fff; text-decoration: none; }
.footer-bottom {
  padding: 13px 0 11px;
  text-align: center;
}
.footer-bottom p { margin: 0; }

/* === RESPONSIVE === */
@media (max-width: 768px) {
  /* Header verbergen: logo zit in de nav op mobiel */
  .site-header { display: none; }

  /* Nav: hamburger rechts, logo gecentreerd */
  .main-nav .container {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    position: relative;
    padding-top: 22px;
    padding-bottom: 22px;
  }
  .nav-logo {
    display: block;
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translateX(-50%) translateY(-50%);
  }
  .nav-toggle {
    display: block;
    z-index: 2;
  }

  /* Menu klapt absoluut uit onder de nav-balk; logo beweegt niet mee */
  .nav-menu {
    display: none;
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: var(--donker);
    flex-direction: column;
    align-items: stretch;
    z-index: 300;
    box-shadow: 0 4px 10px rgba(0,0,0,0.4);
  }
  .nav-menu.open { display: flex; }
  .nav-menu > li > a,
  .nav-menu > li > a:visited {
    padding: 13px 18px;
    font-size: 13px;
    color: #fff;
    border-bottom: 1px solid #444;
  }
  .nav-menu > li:last-child > a { border-bottom: none; }
  .nav-menu > li.active > a { border-radius: 0; }
  .nav-menu > li.active > a::before {
    inset: 0;
    border-radius: 0;
  }
  .nav-menu > li .dropdown {
    position: static;
    box-shadow: none;
    background: #222;
    display: none;
  }
  .nav-menu > li.open .dropdown { display: block; }
  /* Pijltje op "Keukens" om aan te geven dat het uitklapbaar is */
  .has-dropdown > a::after {
    content: ' \25BE';
    font-size: 11px;
    opacity: 0.7;
  }
  .has-dropdown.open > a::after { content: ' \25B4'; }
  .slide { height: 260px; }
  .page-banner { height: 140px; }
  .kitchen-tiles { gap: 18px; }
  .gallery-grid { grid-template-columns: 1fr; }
  .gallery-item img { height: 220px; }
  .content-area { flex-direction: column; }
  .sidebar { width: 100%; }
  .address-box { font-size: 15px; line-height: 1.9; }
  .home-bottom-row { flex-direction: column; align-items: stretch; }

  .move-banner {
    font-size: 13px;
    line-height: 1.45;
  }
  .move-banner .container {
    display: block;
    padding-top: 10px;
    padding-bottom: 10px;
  }
  .move-banner strong {
    display: block;
    margin: 0 0 2px;
  }
  .move-banner-intro {
    display: block;
  }
  .move-banner-address {
    display: inline-block;
    margin: 2px 0 0;
  }
  .move-banner-note {
    display: block;
    margin: 4px 0 0;
  }

  .brands-section h3 { font-size: 16px; }
  .footer-cols { grid-template-columns: 1fr; gap: 24px; padding: 28px 0 20px; }
  .footer-col:nth-child(3) { display: none; }
  .slide-title { font-size: 28px; top: 18px; left: 20px; }
  .slide-promo-wrap { width: 100%; bottom: 28px; }
  .slide-promo { font-size: 13px; padding: 8px 14px; width: 185px; }
  .slider-badge { width: 72px; top: -52px; right: 10px; }
}
@media (max-width: 480px) {
  .slide { height: 190px; }
  .kitchen-tiles { grid-template-columns: 1fr; gap: 18px; }
  .kitchen-tile .tile-img { height: 220px; }
  .gallery-grid { grid-template-columns: 1fr; }
  .slide-title { font-size: 28px; top: 12px; left: 14px; }
  .slide-promo-wrap { width: 100%; bottom: 20px; }
  .slide-promo { font-size: 13px; padding: 8px 12px; width: 170px; }
  .slider-badge { width: 56px; top: -42px; right: 10px; }
}

/* === SKIP TO CONTENT === */
.skip-link {
  position: absolute;
  top: -120px;
  left: 0;
  background: var(--rood);
  color: #fff;
  padding: 10px 18px;
  font-size: 14px;
  font-weight: bold;
  z-index: 9999;
  text-decoration: none;
  transition: top 0.2s;
}
.skip-link:focus {
  top: 0;
  color: #fff;
  text-decoration: none;
}

/* === BREADCRUMB === */
.breadcrumb {
  padding: 6px 0 2px;
  font-size: 13px;
}
.breadcrumb ol {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  list-style: none;
  padding: 0;
  margin: 0;
  gap: 0;
}
.breadcrumb li { display: flex; align-items: center; color: #777; }
.breadcrumb li + li::before { content: '\203A'; margin: 0 8px; color: #bbb; }
.breadcrumb a { color: var(--rood); }
.breadcrumb a:hover { text-decoration: underline; }
.breadcrumb li[aria-current="page"] { color: #888; }

/* === KEYBOARD DROPDOWN === */
.nav-menu > li.kb-open .dropdown { display: block; }

/* === SLIDER PAUZEKNOP === */
.slider-pause {
  position: absolute;
  bottom: 14px;
  right: 14px;
  background: rgba(0,0,0,0.45);
  border: none;
  color: #fff;
  font-size: 13px;
  width: 28px;
  height: 28px;
  cursor: pointer;
  z-index: 10;
  border-radius: 3px;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0.45;
  transition: opacity 0.2s, background 0.2s;
  line-height: 1;
}
.slider-pause:hover { opacity: 1; background: var(--rood); }

/* === TOTAALCONCEPT STAPPEN === */
.steps-grid {
  display: flex;
  flex-direction: column;
  margin: 20px 0 18px;
}
.step-card {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  column-gap: 20px;
  row-gap: 2px;
  padding: 0 0 24px 0;
  background: none;
  border: none;
  text-align: left;
  position: relative;
}
.step-card:last-child { padding-bottom: 0; }
.step-card:not(:last-child)::after {
  content: '';
  position: absolute;
  left: 19px;
  top: 40px;
  bottom: 0;
  border-left: 2px dotted var(--rood);
  opacity: 0.35;
}
.step-num {
  width: 40px;
  height: 40px;
  background: var(--rood);
  color: #fff;
  border-radius: 50%;
  font-size: 18px;
  font-weight: bold;
  line-height: 40px;
  text-align: center;
  flex-shrink: 0;
  margin: 0;
}
.step-card h4 {
  flex: 1;
  font-size: 14px;
  font-weight: bold;
  color: var(--donker);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin: 10px 0 0;
}
.step-card p {
  width: 100%;
  padding-left: 60px; /* 40px cirkel + 20px gap */
  font-size: 13px;
  color: #666;
  line-height: 1.5;
  margin: 0;
}
.steps-outro {
  font-size: 14px;
  color: #555;
  border-left: 3px solid var(--rood);
  padding-left: 12px;
  margin-top: 4px !important;
}

/* === DARK MODE === */
@media (prefers-color-scheme: dark) {
  body { background: #141414; color: #b8b8b8; }
  a { color: var(--rood); }
  a:hover { color: var(--rood-donker); }

  .content-box,
  .welcome-box {
    background: #1e1e1e;
    border-color: #2c2c2c;
    box-shadow: 2px 3px 7px rgba(0,0,0,0.4);
  }
  .content-box h1,
  .content-box h2,
  .welcome-box h1,
  .welcome-box h2 { color: #e0e0e0; }
  .content-box h3 { color: #c4c4c4; }

  .address-box,
  .offerte-card {
    background: #1e1e1e;
    border-color: #2c2c2c;
  }
  .address-box h3,
  .offerte-card h3 { color: #e0e0e0; }
  .offerte-card p { color: #aaa; }

  .brands-section {
    background: #181818;
    border-color: #2c2c2c;
  }
  .brands-section h3 { color: #c0c0c0; }

  .gallery-section h3 { color: #e0e0e0; }

  .breadcrumb li { color: #888; }

  /* Google Maps: inverteer naar donker thema */
  .map-embed iframe { filter: invert(0.9) hue-rotate(180deg); }

  .site-footer { background: #0c0c0c; }
}

/* === KEUKEN-SWITCHER SLIDE-ANIMATIE === */
@keyframes ksSlideInRight {
  from { transform: translateX(56px); opacity: 0; }
  to   { transform: translateX(0);    opacity: 1; }
}
@keyframes ksSlideInLeft {
  from { transform: translateX(-56px); opacity: 0; }
  to   { transform: translateX(0);     opacity: 1; }
}
.ks-slide-from-right { animation: ksSlideInRight 0.32s ease-out both; }
.ks-slide-from-left  { animation: ksSlideInLeft  0.32s ease-out both; }

/* === SCROLL ANIMATIES === */
.anim {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 0.55s ease, transform 0.55s ease;
}
.anim.anim-visible {
  opacity: 1;
  transform: translateY(0);
}
/* Stagger voor grid-items (tot 8 kinderen) */
.anim-stagger > .anim:nth-child(1) { transition-delay: 0.00s; }
.anim-stagger > .anim:nth-child(2) { transition-delay: 0.08s; }
.anim-stagger > .anim:nth-child(3) { transition-delay: 0.16s; }
.anim-stagger > .anim:nth-child(4) { transition-delay: 0.24s; }
.anim-stagger > .anim:nth-child(5) { transition-delay: 0.32s; }
.anim-stagger > .anim:nth-child(6) { transition-delay: 0.40s; }
.anim-stagger > .anim:nth-child(7) { transition-delay: 0.48s; }
.anim-stagger > .anim:nth-child(8) { transition-delay: 0.56s; }
/* Gebruikers die geen animaties willen (toegankelijkheid) */
@media (prefers-reduced-motion: reduce) {
  .anim { opacity: 1; transform: none; transition: none; }
  .brands-marquee { animation: none; }
  .ks-slide-from-right,
  .ks-slide-from-left { animation: none; }
}

/* === FOOTER LEGAL === */
.footer-legal {
  margin-top: 6px;
  font-size: 12px;
  color: #888;
}
.footer-legal a { color: #999; }
.footer-legal a:hover { color: #fff; text-decoration: none; }


/* === BACK TO TOP === */
#back-to-top {
  position: fixed;
  bottom: 60px;
  right: 30px;
  z-index: 999;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.4s ease;
}
#back-to-top.visible {
  opacity: 0.8;
  pointer-events: auto;
}
#back-to-top.visible:hover { opacity: 1; }
#back-to-top img { display: block; }

/* === KEUKEN SWITCHER === */
/* Desktop: tabs in de content */
.kitchen-switcher {
  display: flex;
  background: #f0f0f0;
  border: 1px solid #ddd;
  margin-bottom: 16px;
}
.kitchen-switcher a {
  flex: 1;
  padding: 10px 6px;
  text-align: center;
  color: #666;
  font-family: 'Open Sans Condensed', 'Arial Narrow', Arial, sans-serif;
  font-size: 15px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  border-bottom: 3px solid transparent;
  text-decoration: none;
  transition: color 0.15s, border-color 0.15s;
}
.kitchen-switcher a.active {
  color: var(--rood);
  border-bottom-color: var(--rood);
  background: #fff;
  font-weight: bold;
}
.kitchen-switcher a:hover { color: var(--rood); text-decoration: none; }
.kitchen-switcher-mobile { display: none; }

/* Mobiel: desktop tabs verbergen, sticky balk bovenaan tonen */
@media (max-width: 768px) {
  .kitchen-switcher { display: none; }

  .kitchen-switcher-mobile {
    display: flex;
    position: sticky;
    top: 0;
    background: var(--donker);
    border-bottom: 2px solid #333;
    box-shadow: 0 2px 10px rgba(0,0,0,0.35);
    z-index: 500;
    margin: 0 0 var(--section-gap);
  }
  .kitchen-switcher-mobile a {
    flex: 1;
    padding: 11px 2px 9px;
    text-align: center;
    color: #999;
    font-size: 11px;
    font-family: 'Open Sans Condensed', 'Arial Narrow', Arial, sans-serif;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    border-bottom: 3px solid transparent;
    text-decoration: none;
    transition: color 0.15s;
  }
  .kitchen-switcher-mobile a.active {
    color: #fff;
    border-bottom-color: var(--rood);
  }
  .kitchen-switcher-mobile a:hover { color: #fff; }
}
