/* Maison Lavabo — designwasbakken | demosite */
:root {
  --ivoor: #faf8f5;
  --krijt: #f3efe9;
  --steen: #e8e2d8;
  --inkt: #1f1d1a;
  --grafiet: #4a463f;
  --messing: #b08d57;
  --messing-d: #93733f;
  --lijn: #ddd5c8;
}
* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  font-family: "Inter", "Helvetica Neue", Arial, sans-serif;
  background: var(--ivoor);
  color: var(--inkt);
  font-size: 16.5px;
  line-height: 1.7;
  -webkit-font-smoothing: antialiased;
}
h1, h2, h3, .serif {
  font-family: "Cormorant Garamond", Georgia, serif;
  font-weight: 500;
  line-height: 1.15;
  letter-spacing: .01em;
}
h1 { font-size: clamp(2.6rem, 6vw, 4.6rem); }
h2 { font-size: clamp(1.9rem, 3.6vw, 2.7rem); margin-bottom: .5em; }
h3 { font-size: 1.45rem; }
p { color: var(--grafiet); }
a { color: inherit; text-decoration: none; }
img, svg { display: block; max-width: 100%; }

.wrap { max-width: 1180px; margin: 0 auto; padding: 0 28px; }
.label {
  display: inline-block; font-size: .72rem; letter-spacing: .28em;
  text-transform: uppercase; color: var(--messing-d); margin-bottom: 14px;
}
.lead { font-size: 1.15rem; max-width: 640px; }

/* ---------- navigatie ---------- */
header.site {
  position: sticky; top: 0; z-index: 50;
  background: rgba(250, 248, 245, .92); backdrop-filter: blur(8px);
  border-bottom: 1px solid var(--lijn);
}
.nav { display: flex; align-items: center; justify-content: space-between; height: 76px; }
.logo { font-family: "Cormorant Garamond", Georgia, serif; font-size: 1.5rem; letter-spacing: .12em; }
.logo b { color: var(--messing-d); font-weight: 600; }
nav.menu { display: flex; gap: 30px; }
nav.menu a {
  font-size: .8rem; letter-spacing: .14em; text-transform: uppercase; color: var(--grafiet);
  padding: 6px 0; border-bottom: 1px solid transparent; transition: all .25s;
}
nav.menu a:hover, nav.menu a.actief { color: var(--inkt); border-bottom-color: var(--messing); }
@media (max-width: 880px) {
  .nav { flex-direction: column; height: auto; padding: 14px 0; gap: 10px; }
  nav.menu { flex-wrap: wrap; justify-content: center; gap: 14px 20px; }
}

/* ---------- hero ---------- */
.hero {
  position: relative; overflow: hidden; text-align: center;
  padding: clamp(70px, 12vw, 150px) 28px clamp(60px, 10vw, 130px);
  background:
    radial-gradient(1100px 480px at 50% -10%, #fffdf9 0%, transparent 60%),
    linear-gradient(175deg, var(--krijt) 0%, var(--ivoor) 55%, var(--steen) 130%);
  border-bottom: 1px solid var(--lijn);
}
.hero h1 { max-width: 820px; margin: 0 auto 22px; }
.hero .lead { margin: 0 auto 38px; }
.hero-svg { width: min(420px, 70vw); margin: 0 auto 38px; opacity: .9; }

.hero-foto { width: min(880px, 92vw); margin: 6px auto 40px; }
.hero-foto img {
  width: 100%; height: clamp(260px, 38vw, 430px); object-fit: cover;
  border-radius: 14px; box-shadow: 0 24px 60px rgba(31, 29, 26, .18);
  border: 1px solid var(--lijn);
}

/* ---------- knoppen ---------- */
.btn {
  display: inline-block; padding: 15px 38px; font-size: .78rem;
  letter-spacing: .22em; text-transform: uppercase;
  border: 1px solid var(--inkt); color: var(--inkt); transition: all .3s;
}
.btn:hover { background: var(--inkt); color: var(--ivoor); }
.btn.goud { border-color: var(--messing-d); color: var(--messing-d); }
.btn.goud:hover { background: var(--messing-d); color: #fff; }

/* ---------- secties ---------- */
section.blok { padding: clamp(60px, 9vw, 110px) 0; }
section.blok.getint { background: var(--krijt); border-top: 1px solid var(--lijn); border-bottom: 1px solid var(--lijn); }
.sectiekop { text-align: center; max-width: 680px; margin: 0 auto clamp(36px, 6vw, 64px); }
.sectiekop .lead { margin: 0 auto; }

/* ---------- kaarten / grids ---------- */
.grid { display: grid; gap: 30px; }
.g3 { grid-template-columns: repeat(3, 1fr); }
.g4 { grid-template-columns: repeat(4, 1fr); }
.g2 { grid-template-columns: repeat(2, 1fr); }
@media (max-width: 980px) { .g3, .g4 { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .g3, .g4, .g2 { grid-template-columns: 1fr; } }

.kaart {
  background: #fff; border: 1px solid var(--lijn);
  transition: transform .35s, box-shadow .35s;
}
.kaart:hover { transform: translateY(-5px); box-shadow: 0 18px 44px rgba(31, 29, 26, .09); }
.kaart .beeld {
  background: linear-gradient(160deg, var(--krijt) 0%, var(--steen) 100%);
  padding: 38px 30px; border-bottom: 1px solid var(--lijn);
}
.kaart .beeld svg { width: 70%; margin: 0 auto; }
.kaart .beeld.foto { padding: 0; }
.kaart .beeld.foto img { width: 100%; height: 230px; object-fit: cover; }
.kaart .tekst { padding: 24px 26px 28px; }
.kaart .tekst h3 { margin-bottom: 6px; }
.kaart .tekst .sub { font-size: .78rem; letter-spacing: .18em; text-transform: uppercase; color: var(--messing-d); }
.kaart .tekst p { font-size: .95rem; margin-top: 10px; }
.kaart .prijs { margin-top: 14px; font-family: "Cormorant Garamond", Georgia, serif; font-size: 1.25rem; }
.kaart .prijs span { font-size: .8rem; color: var(--grafiet); font-family: "Inter", sans-serif; }

/* ---------- usp-rij ---------- */
.usps { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; border: 1px solid var(--lijn); background: #fff; }
.usp { padding: 34px 30px; border-right: 1px solid var(--lijn); }
.usp:last-child { border-right: none; }
.usp .nr { font-family: "Cormorant Garamond", Georgia, serif; font-size: 2rem; color: var(--messing); }
.usp h3 { font-size: 1.15rem; margin: 6px 0 6px; }
.usp p { font-size: .9rem; }
@media (max-width: 980px) { .usps { grid-template-columns: repeat(2, 1fr); } .usp:nth-child(2) { border-right: none; } }
@media (max-width: 600px) { .usps { grid-template-columns: 1fr; } .usp { border-right: none; border-bottom: 1px solid var(--lijn); } }

/* ---------- citaat ---------- */
.citaat { text-align: center; max-width: 760px; margin: 0 auto; }
.citaat blockquote { font-family: "Cormorant Garamond", Georgia, serif; font-size: clamp(1.5rem, 3vw, 2.1rem); font-style: italic; color: var(--inkt); }
.citaat cite { display: block; margin-top: 18px; font-size: .78rem; letter-spacing: .2em; text-transform: uppercase; font-style: normal; color: var(--messing-d); }

/* ---------- materiaal / tweeluik ---------- */
.tweeluik { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(30px, 6vw, 80px); align-items: center; }
@media (max-width: 880px) { .tweeluik { grid-template-columns: 1fr; } }
.paneel {
  background: linear-gradient(150deg, var(--krijt), var(--steen));
  border: 1px solid var(--lijn); padding: clamp(34px, 5vw, 64px);
}
.paneel svg { width: 75%; margin: 0 auto; }
.paneel.foto { padding: 0; overflow: hidden; }
.paneel.foto img { width: 100%; height: clamp(280px, 32vw, 420px); object-fit: cover; display: block; }
.specs { list-style: none; margin-top: 18px; }
.specs li { padding: 10px 0; border-bottom: 1px solid var(--lijn); font-size: .95rem; color: var(--grafiet); display: flex; justify-content: space-between; gap: 18px; }
.specs li b { color: var(--inkt); font-weight: 600; }

/* ---------- tabellen ---------- */
table.net { width: 100%; border-collapse: collapse; background: #fff; border: 1px solid var(--lijn); font-size: .95rem; }
table.net th { text-align: left; padding: 13px 18px; background: var(--inkt); color: var(--ivoor); font-weight: 500; letter-spacing: .06em; font-size: .85rem; }
table.net td { padding: 12px 18px; border-bottom: 1px solid var(--lijn); color: var(--grafiet); vertical-align: top; }
table.net tr:nth-child(even) td { background: var(--krijt); }

/* ---------- faq ---------- */
details.faq { background: #fff; border: 1px solid var(--lijn); margin-bottom: 12px; }
details.faq summary { cursor: pointer; padding: 18px 24px; font-family: "Cormorant Garamond", Georgia, serif; font-size: 1.2rem; list-style: none; position: relative; }
details.faq summary::after { content: "+"; position: absolute; right: 24px; color: var(--messing-d); font-size: 1.4rem; }
details.faq[open] summary::after { content: "—"; font-size: 1rem; }
details.faq .antwoord { padding: 0 24px 20px; font-size: .96rem; color: var(--grafiet); }

/* ---------- formulier ---------- */
form.netjes { display: grid; gap: 16px; }
form.netjes label { font-size: .75rem; letter-spacing: .18em; text-transform: uppercase; color: var(--grafiet); }
form.netjes input, form.netjes textarea, form.netjes select {
  width: 100%; padding: 13px 15px; border: 1px solid var(--lijn); background: #fff;
  font-family: inherit; font-size: .96rem; color: var(--inkt);
}
form.netjes input:focus, form.netjes textarea:focus { outline: 1.5px solid var(--messing); }

/* ---------- footer ---------- */
footer.site { background: var(--inkt); color: #c9c2b6; margin-top: 0; }
footer.site .boven { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 40px; padding: 64px 0 48px; }
@media (max-width: 880px) { footer.site .boven { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px) { footer.site .boven { grid-template-columns: 1fr; } }
footer.site h4 { color: var(--ivoor); font-size: .78rem; letter-spacing: .22em; text-transform: uppercase; margin-bottom: 16px; font-weight: 500; }
footer.site a { display: block; padding: 4px 0; font-size: .92rem; transition: color .25s; }
footer.site a:hover { color: var(--messing); }
footer.site p { color: #c9c2b6; font-size: .92rem; }
footer.site .logo { color: var(--ivoor); margin-bottom: 12px; }
footer.site .onder { border-top: 1px solid #3a362f; padding: 22px 0; font-size: .78rem; display: flex; justify-content: space-between; flex-wrap: wrap; gap: 8px; color: #8d867a; }

/* ---------- breadcrumb-hero (subpagina's) ---------- */
.subhero { text-align: center; padding: clamp(54px, 8vw, 96px) 28px; background: linear-gradient(175deg, var(--krijt), var(--ivoor)); border-bottom: 1px solid var(--lijn); }
.subhero .lead { margin: 14px auto 0; }

/* ---------- stijlsectie (inspiratie) ---------- */
.stijl { display: grid; grid-template-columns: 1fr 1fr; border: 1px solid var(--lijn); background: #fff; margin-bottom: 36px; }
.stijl:nth-child(even) .stijl-beeld { order: 2; }
.stijl-beeld { background: linear-gradient(150deg, var(--krijt), var(--steen)); display: flex; align-items: center; justify-content: center; padding: 48px; }
.stijl-beeld svg { width: 75%; max-width: 330px; }
.stijl-beeld.foto { padding: 0; }
.stijl-beeld.foto img { width: 100%; height: 100%; min-height: 320px; object-fit: cover; display: block; }
.stijl-tekst { padding: clamp(30px, 4.5vw, 58px); }
.stijl-tekst .modellen { margin-top: 16px; font-size: .85rem; letter-spacing: .04em; color: var(--messing-d); }
@media (max-width: 820px) { .stijl { grid-template-columns: 1fr; } .stijl:nth-child(even) .stijl-beeld { order: 0; } }
