/* =============================================================
   Laadpaalmonteur NL - main.css
   Palette: Bronze #92400E (brand) + Cobalt #1D4ED8 (CTA)
   Background: Cream #FBF7F1
   ============================================================= */

:root {
  --brand:      #92400E;
  --brand-dark: #6B2D08;
  --brand-soft: #FDF0E6;
  --cta:        #1D4ED8;
  --cta-dark:   #1A3FBE;
  --cta-light:  #EFF6FF;
  --cream:      #FBF7F1;
  --ink:        #1C1409;
  --muted:      #6B5740;
  --line:       #D4C4B0;
  --white:      #ffffff;
  --font:       Verdana, Geneva, Tahoma, sans-serif;
}

/* Reset */
*, *::before, *::after { box-sizing: border-box; }
html, body { overflow-x: hidden; }
body {
  margin: 0;
  font-family: var(--font);
  font-size: 17px;
  line-height: 1.6;
  color: var(--ink);
  background: var(--cream);
}
img, svg { max-width: 100%; height: auto; display: block; }
a { color: var(--brand); }
h1, h2, h3, h4 {
  font-family: var(--font);
  font-weight: 700;
  line-height: 1.5;
  margin: 0 0 14px;
  color: var(--brand);
}
h1 { font-size: 2.6rem; }
h2 { font-size: 1.9rem; }
h3 { font-size: 1.25rem; }
p { margin: 0 0 16px; }
ul, ol { margin: 0 0 16px; padding-left: 20px; }
li { margin-bottom: 6px; }

/* Skip link */
.lmnl-skip {
  position: absolute; left: -999px; top: 0;
  background: var(--brand); color: #fff;
  padding: 10px 16px; z-index: 200;
}
.lmnl-skip:focus { left: 8px; top: 8px; }
:focus-visible { outline: 3px solid var(--cta); outline-offset: 2px; }

/* =============================================================
   HEADER
   ============================================================= */
.lmnl-hdr {
  background: var(--cream);
  border-bottom: 3px solid var(--brand);
  position: relative;
}
.lmnl-hdr__wrap {
  max-width: 1200px;
  margin: 0 auto;
  padding: 12px 24px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
}
.lmnl-hdr__logo { display: inline-flex; flex-shrink: 0; }
.lmnl-hdr__logo img { height: 52px; width: auto; }

/* Hamburger CSS-only */
.lmnl-menu-toggle { display: none; }
.lmnl-menu-burger {
  display: none;
  flex-direction: column;
  gap: 5px;
  cursor: pointer;
  padding: 6px;
  background: transparent;
  border: 0;
}
.lmnl-menu-burger span {
  display: block;
  width: 24px; height: 2px;
  background: var(--brand);
}
.lmnl-menu-toggle:checked ~ .lmnl-menu-burger span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.lmnl-menu-toggle:checked ~ .lmnl-menu-burger span:nth-child(2) { opacity: 0; }
.lmnl-menu-toggle:checked ~ .lmnl-menu-burger span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

.lmnl-hdr__nav .lmnl-nav__list {
  list-style: none;
  margin: 0; padding: 0;
  display: flex;
  align-items: center;
  gap: 24px;
}
.lmnl-hdr__nav .lmnl-nav__list a {
  text-decoration: none;
  color: var(--brand);
  font-weight: 400;
  font-size: .97rem;
  padding: 6px 0;
}
.lmnl-hdr__nav li.lmnl-nav-cta a,
.lmnl-hdr__nav .menu-item:last-child a {
  background: var(--cta);
  color: #fff;
  padding: 10px 20px;
  border-radius: 4px;
  font-weight: 700;
}

/* =============================================================
   HERO SECTION - image left, text right
   ============================================================= */
.lmnl-hero {
  background: var(--cream);
  padding: 52px 24px 0;
}
.lmnl-hero__inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 56px;
  align-items: center;
}

/* Image colonne gauche */
.lmnl-hero__img-col { position: relative; }
.lmnl-hero__img-frame {
  border-radius: 10px;
  overflow: hidden;
  background: var(--cream);
  border: 1px solid var(--line);
}
.lmnl-hero__img-frame img {
  width: 100%;
  height: auto;
  display: block;
}

/* Texte colonne droite */
.lmnl-hero__txt h1 {
  color: var(--brand);
  font-size: 2.7rem;
  margin-bottom: 16px;
}
.lmnl-hero__sub {
  font-size: 1.1rem;
  color: var(--muted);
  margin-bottom: 24px;
  line-height: 1.6;
}
.lmnl-hero__bullets {
  list-style: none;
  margin: 0 0 28px;
  padding: 0;
}
.lmnl-hero__bullets li {
  padding: 7px 0 7px 22px;
  position: relative;
  font-size: 1rem;
  color: var(--ink);
  margin-bottom: 2px;
}
.lmnl-hero__bullets li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 10px; height: 10px;
  border-radius: 50%;
  background: var(--brand);
}
.lmnl-hero__cta-btn {
  display: inline-block;
  background: var(--cta);
  color: #fff;
  font-weight: 700;
  font-size: 1rem;
  padding: 14px 32px;
  border-radius: 4px;
  text-decoration: none;
  border: 0;
  cursor: pointer;
}
.lmnl-hero__cta-btn:hover { background: var(--cta-dark); color: #fff; }

/* =============================================================
   FORM BANDEAU - pleine largeur, fond Bronze
   ============================================================= */
.lmnl-form {
  background: var(--brand);
  padding: 40px 24px;
  margin-top: 40px;
}
.lmnl-form__inner { max-width: 1200px; margin: 0 auto; }
.lmnl-form__title {
  color: #fff;
  font-size: 1.5rem;
  margin-bottom: 6px;
}
.lmnl-form__sub {
  color: #F5D9B8;
  font-size: .95rem;
  margin-bottom: 20px;
}
.lmnl-form__msg {
  padding: 12px 16px;
  border-radius: 4px;
  margin-bottom: 16px;
  font-weight: 700;
}
.lmnl-form__msg--ok  { background: var(--cream); color: var(--ink); }
.lmnl-form__msg--err { background: var(--cream); color: var(--ink); }

/* Honeypot */
.lmnl-form__hp {
  position: absolute;
  left: -9999px;
  width: 1px; height: 1px;
  overflow: hidden;
}

/* Rij 1: 3 colonnes */
.lmnl-form__grid3 {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 16px;
  margin-bottom: 16px;
}
/* Rij 2: 3 + bouton */
.lmnl-form__grid3b {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr auto;
  gap: 16px;
  align-items: end;
}
.lmnl-form__fld label {
  display: block;
  font-size: .85rem;
  font-weight: 700;
  color: #F5D9B8;
  margin-bottom: 5px;
}
.lmnl-form__fld input {
  width: 100%;
  font-family: var(--font);
  font-size: 16px;
  padding: 11px 13px;
  border: 0;
  border-radius: 4px;
  background: #fff;
  color: var(--ink);
}
.lmnl-form__fld input::placeholder { color: #a08060; }
.lmnl-form__btn {
  background: var(--cta);
  color: #fff;
  font-family: var(--font);
  font-weight: 700;
  font-size: 1rem;
  padding: 11px 28px;
  border: 0;
  border-radius: 4px;
  cursor: pointer;
  white-space: nowrap;
  height: 46px;
}
.lmnl-form__btn:hover { background: var(--cta-dark); }

/* =============================================================
   MERKEN BENTO
   ============================================================= */
.lmnl-merken { padding: 64px 24px; background: #fff; }
.lmnl-merken__inner { max-width: 1200px; margin: 0 auto; }
.lmnl-merken__inner h2 { color: var(--brand); margin-bottom: 10px; }
.lmnl-merken__sub { color: var(--muted); margin-bottom: 32px; font-size: 1.05rem; }

.lmnl-merken__bento {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr;
  grid-template-rows: auto auto;
  gap: 12px;
}
.lmnl-merken__bento-item {
  background: var(--cream);
  border: 2px solid var(--line);
  border-radius: 6px;
  padding: 20px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 10px;
}
.lmnl-merken__bento-item img {
  max-height: 90px;
  width: auto;
  aspect-ratio: 5/3;
  object-fit: contain;
}
.lmnl-merken__bento-item span {
  font-weight: 700;
  color: var(--brand);
  font-size: .95rem;
}
/* Large = col 1, row 1+2 */
.lmnl-merken__bento-item--large {
  grid-column: 1;
  grid-row: 1 / 3;
  border-color: var(--brand);
}
.lmnl-merken__bento-item--large img { max-height: 140px; }
/* Wide = col 2+3, row 2 */
.lmnl-merken__bento-item--wide {
  grid-column: 2 / 4;
  grid-row: 2;
  flex-direction: row;
  gap: 20px;
}

/* =============================================================
   WERKWIJZE
   ============================================================= */
.lmnl-werkwijze { padding: 64px 24px; background: var(--cream); }
.lmnl-werkwijze__inner { max-width: 1000px; margin: 0 auto; }
.lmnl-werkwijze__inner h2 { color: var(--brand); margin-bottom: 10px; }
.lmnl-werkwijze__sub { color: var(--muted); margin-bottom: 36px; font-size: 1.05rem; }

.lmnl-werkwijze__steps {
  list-style: none;
  margin: 0; padding: 0;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 28px;
}
.lmnl-werkwijze__step {
  display: flex;
  gap: 18px;
  align-items: flex-start;
  background: #fff;
  border-radius: 8px;
  padding: 24px;
  border: 1px solid var(--line);
}
.lmnl-step-num {
  background: var(--brand);
  color: #fff;
  font-weight: 700;
  font-size: 1.1rem;
  min-width: 36px;
  height: 36px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.lmnl-step-body h3 { margin-bottom: 8px; color: var(--brand); font-size: 1.1rem; }
.lmnl-step-body p { margin: 0; color: var(--muted); font-size: .97rem; }

/* =============================================================
   CONTENT article
   ============================================================= */
.lmnl-content { padding: 64px 24px; background: #fff; }
.lmnl-content__inner { max-width: 900px; margin: 0 auto; }
.lmnl-content__inner h2 { color: var(--brand); }
.lmnl-content__inner h3 { color: var(--brand); }
.lmnl-content__inner a { color: var(--brand); }
.lmnl-content__inner ul li { color: var(--ink); }
.lmnl-content__inner ol li { color: var(--ink); }

/* =============================================================
   TARIEVEN
   ============================================================= */
.lmnl-tarieven { padding: 64px 24px; background: var(--cream); }
.lmnl-tarieven__inner { max-width: 1200px; margin: 0 auto; }
.lmnl-tarieven__inner h2 { color: var(--brand); margin-bottom: 10px; }
.lmnl-tarieven__sub { color: var(--muted); margin-bottom: 36px; }

.lmnl-tarieven__grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 24px;
}
.lmnl-tarieven__card {
  background: #fff;
  border: 2px solid var(--line);
  border-radius: 6px;
  padding: 30px 24px;
}
.lmnl-tarieven__card--featured {
  border-color: var(--brand);
  border-width: 2px;
  position: relative;
}
.lmnl-tarieven__card--featured::before {
  content: none;
}
.lmnl-tarieven__card h3 { color: var(--brand); margin-bottom: 8px; }
.lmnl-tarieven__price {
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--brand);
  margin-bottom: 16px;
}
.lmnl-tarieven__card ul {
  list-style: none;
  padding: 0;
  margin: 0 0 24px;
}
.lmnl-tarieven__card ul li {
  padding: 6px 0 6px 18px;
  position: relative;
  color: var(--ink);
  font-size: .97rem;
}
.lmnl-tarieven__card ul li::before {
  content: '';
  position: absolute;
  left: 0; top: 50%;
  transform: translateY(-50%);
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--brand);
}
.lmnl-tarieven__btn {
  display: block;
  text-align: center;
  text-decoration: none;
  background: var(--brand);
  color: #fff;
  font-weight: 700;
  font-size: .97rem;
  padding: 12px 20px;
  border-radius: 4px;
}
.lmnl-tarieven__btn--cta { background: var(--cta); }
.lmnl-tarieven__btn:hover { opacity: .9; color: #fff; }

/* =============================================================
   FAQ
   ============================================================= */
.lmnl-faq { padding: 64px 24px; background: #fff; }
.lmnl-faq__inner { max-width: 900px; margin: 0 auto; }
.lmnl-faq__inner h2 { color: var(--brand); margin-bottom: 32px; }

.lmnl-faq__list { margin: 0; padding: 0; }
.lmnl-faq__item {
  border-bottom: 1px solid var(--line);
  padding: 20px 0;
}
.lmnl-faq__item:first-child { border-top: 1px solid var(--line); }
.lmnl-faq__item dt {
  font-weight: 700;
  color: var(--brand);
  margin-bottom: 8px;
  font-size: 1.05rem;
}
.lmnl-faq__item dd {
  margin: 0;
  color: var(--muted);
  line-height: 1.7;
}

/* =============================================================
   CTA FINAL
   ============================================================= */
.lmnl-cta {
  background: var(--brand);
  padding: 64px 24px;
  text-align: center;
}
.lmnl-cta__inner { max-width: 800px; margin: 0 auto; }
.lmnl-cta__inner h2 { color: #fff; margin-bottom: 12px; }
.lmnl-cta__inner p { color: #F5D9B8; margin-bottom: 28px; }
.lmnl-cta__btn {
  display: inline-block;
  background: var(--cta);
  color: #fff;
  font-weight: 700;
  font-size: 1.1rem;
  padding: 16px 40px;
  border-radius: 4px;
  text-decoration: none;
}
.lmnl-cta__btn:hover { background: var(--cta-dark); color: #fff; }

/* =============================================================
   FOOTER
   ============================================================= */
.lmnl-ftr {
  background: var(--brand-dark);
  padding: 40px 24px;
  color: #F5D9B8;
}
.lmnl-ftr__inner { max-width: 1200px; margin: 0 auto; text-align: center; }
.lmnl-ftr__brand {
  font-size: 1.3rem;
  font-weight: 700;
  color: #fff;
  margin-bottom: 8px;
}
.lmnl-ftr__txt { font-size: .95rem; margin-bottom: 16px; color: #F5D9B8; }
.lmnl-ftr__nav { margin-bottom: 16px; }
.lmnl-ftr__nav a {
  color: #F5D9B8;
  text-decoration: none;
  margin: 0 12px;
  font-size: .9rem;
}
.lmnl-ftr__nav a:hover { color: #fff; }
.lmnl-ftr__copy { font-size: .82rem; color: #d4b896; margin: 0; }

/* =============================================================
   RESPONSIVE
   ============================================================= */
@media (max-width: 1024px) {
  .lmnl-form__grid3b { grid-template-columns: 1fr 1fr; }
  .lmnl-form__grid3b .lmnl-form__fld--btn { grid-column: 1 / 3; }
  .lmnl-form__btn { width: 100%; height: auto; padding: 12px 20px; }
  .lmnl-tarieven__grid { grid-template-columns: 1fr 1fr; }
  .lmnl-tarieven__card:last-child { grid-column: 1 / 3; }
}

@media (max-width: 900px) {
  .lmnl-hero__inner { grid-template-columns: 1fr; gap: 32px; }
  .lmnl-hero__img-col { order: 2; }
  .lmnl-hero__txt { order: 1; }
  .lmnl-werkwijze__steps { grid-template-columns: 1fr; }
  .lmnl-menu-burger { display: flex; }
  .lmnl-hdr__nav { display: none; }
  .lmnl-menu-toggle:checked ~ .lmnl-hdr__nav {
    display: block;
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: var(--cream);
    border-bottom: 2px solid var(--brand);
    z-index: 100;
    padding: 12px 24px 20px;
  }
  .lmnl-menu-toggle:checked ~ .lmnl-hdr__nav .lmnl-nav__list {
    flex-direction: column;
    align-items: flex-start;
    gap: 4px;
  }
  .lmnl-merken__bento { grid-template-columns: 1fr 1fr; }
  .lmnl-merken__bento-item--large { grid-row: 1; grid-column: 1 / 3; }
  .lmnl-merken__bento-item--wide { grid-column: 1 / 3; }
}

@media (max-width: 680px) {
  body { font-size: 16px; }
  h1 { font-size: 1.9rem; }
  h2 { font-size: 1.5rem; }
  .lmnl-hero { padding: 32px 20px 0; }
  .lmnl-hero__txt h1 { font-size: 2.1rem; }
  .lmnl-form__grid3 { grid-template-columns: 1fr; }
  .lmnl-form__grid3b { grid-template-columns: 1fr; }
  .lmnl-form__grid3b .lmnl-form__fld--btn { grid-column: 1; }
  .lmnl-tarieven__grid { grid-template-columns: 1fr; }
  .lmnl-tarieven__card:last-child { grid-column: 1; }
  .lmnl-merken__bento { grid-template-columns: 1fr; }
  .lmnl-merken__bento-item--large { grid-column: 1; }
  .lmnl-merken__bento-item--wide { grid-column: 1; flex-direction: column; }
}
