:root{
  --bg:#fafaff;
  --surface:#ffffff;
  --text:#17171c;
  --muted:#666a78;

  --brand:#5f7cff;
  --accent:#ffd166;

  --dyn-1:var(--brand);
  --dyn-2:#9ad1ff;

  --radius:12px;
  --radius-lg:16px;

  --shadow:0 6px 18px rgba(30,30,60,.06);
  --gap:clamp(0.9rem, 2.2vw, 1.2rem);
  --section-gap:clamp(2rem, 6vh, 3.5rem);
  --container:min(1100px, 92vw);

  --border:rgba(30,30,60,.10);
  --border-soft:rgba(30,30,60,.08);
  --focus:rgba(108,140,255,.55);
}

*,
*::before,
*::after{
  box-sizing:border-box;
}

html,
body{
  height:100%;
}

html{
  scroll-behavior:smooth;
}

body{
  margin:0;
  color:var(--text);
  background:var(--bg);
  font:16px/1.6 system-ui,-apple-system,Segoe UI,Roboto,"Helvetica Neue",Arial,sans-serif;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}

img{
  max-width:100%;
  display:block;
}

button,
input,
textarea,
select{
  font:inherit;
}

a{
  color:inherit;
}

.container{
  width:var(--container);
  margin-inline:auto;
}

section{
  padding-block:var(--section-gap);
}

/* ==============================
   Toegankelijkheid
============================== */
.skip-link{
  position:absolute;
  left:-9999px;
}

.skip-link:focus{
  position:fixed;
  left:1rem;
  top:1rem;
  padding:.6rem .9rem;
  background:#fff;
  border-radius:.5rem;
  box-shadow:var(--shadow);
  z-index:9999;
}

:where(a, button, input, textarea, select, summary):focus-visible{
  outline:3px solid var(--focus);
  outline-offset:2px;
  border-radius:10px;
}

body:not(.user-tabbing) :where(a, button, input, textarea, select):focus{
  outline:none;
}

/* ==============================
   Achtergrond
============================== */
.bg-blobs,
.bg-blobs::before,
.bg-blobs::after{
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:-1;
  content:"";
}

.bg-blobs{
  background:
    radial-gradient(36vmax 36vmax at 8% 18%, rgba(108,140,255,.18), transparent 60%),
    radial-gradient(34vmax 34vmax at 92% 16%, rgba(255,209,102,.20), transparent 60%),
    radial-gradient(40vmax 40vmax at 70% 82%, rgba(140,255,210,.14), transparent 60%);
}

.bg-blobs::before{
  background:radial-gradient(28vmax 28vmax at 15% 75%, rgba(255,132,169,.14), transparent 60%);
}

.bg-blobs::after{
  background:radial-gradient(26vmax 26vmax at 85% 60%, rgba(132,165,255,.12), transparent 60%);
}

/* ==============================
   Header / navigatie
============================== */
header{
  position:sticky;
  top:0;
  z-index:50;
  background:rgba(250,250,255,.88);
  background:color-mix(in oklab, var(--bg) 84%, white 16% / 70%);
  backdrop-filter:saturate(1.1) blur(10px);
  border-bottom:1px solid rgba(30,30,60,.08);
}

.nav{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:var(--gap);
  padding:.75rem 0;
}

.brand{
  display:flex;
  align-items:center;
  gap:.65rem;
  font-weight:800;
  letter-spacing:.1px;
  text-decoration:none;
  color:inherit;
}

.logo{
  width:34px;
  height:34px;
  border-radius:10px;
  box-shadow:var(--shadow);
  background-image:url("../assets/Portretten/Ø50cm olie (3).jpg");
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
  border:1px solid rgba(255,255,255,.7);
  flex:0 0 34px;
}

nav{
  display:flex;
  gap:.35rem;
  flex-wrap:wrap;
}

nav a{
  color:var(--text);
  text-decoration:none;
  padding:.45rem .8rem;
  border-radius:999px;
  font-weight:600;
}

nav a:hover,
nav a.is-active,
nav a[aria-current="page"]{
  background:rgba(108,140,255,.12);
}

@media (max-width:720px){
  .nav{
    align-items:flex-start;
    flex-direction:column;
  }

  nav{
    width:100%;
  }
}

/* ==============================
   Typografie
============================== */
h1{
  font-size:clamp(1.9rem, 4.3vw, 3.2rem);
  line-height:1.12;
  margin:.1rem 0 .8rem;
  letter-spacing:-.02em;
}

.headline-accent{
  background:linear-gradient(90deg, var(--dyn-1), var(--dyn-2));
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}

.lead{
  color:var(--muted);
  font-size:clamp(1rem, 1.35vw, 1.1rem);
  margin:0;
}

.section-title{
  font-size:clamp(1.5rem, 2.6vw, 2.1rem);
  margin:0 0 .5rem;
}

.section-lead{
  color:var(--muted);
  margin:0 0 1rem;
}

/* ==============================
   Knoppen / chips
============================== */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border:none;
  cursor:pointer;
  text-decoration:none;
  font-weight:700;
  padding:.85rem 1rem;
  border-radius:10px;
  box-shadow:var(--shadow);
  transition:transform .12s ease, box-shadow .18s ease;
}

.btn-primary{
  background:var(--dyn-1);
  color:#fff;
}

.btn-primary:hover{
  transform:translateY(-1px);
  box-shadow:0 10px 24px rgba(95,124,255,.22);
}

.btn-ghost{
  background:#fff;
  border:1px solid var(--border);
  color:var(--text);
}

.chips{
  display:flex;
  gap:.4rem;
  flex-wrap:wrap;
}

.chip{
  display:inline-flex;
  align-items:center;
  gap:.45rem;
  padding:.35rem .7rem;
  border-radius:999px;
  background:#fff;
  border:1px solid var(--border);
  cursor:pointer;
  font-weight:700;
}

.chip.chip-active{
  background:rgba(108,140,255,.12);
  border-color:rgba(108,140,255,.28);
}

/* ==============================
   Reveal
============================== */
.reveal{
  opacity:0;
  transform:translateY(10px);
  transition:opacity .45s ease, transform .45s ease;
}

.reveal.in{
  opacity:1;
  transform:none;
}

/* ==============================
   Hero
============================== */
.hero{
  padding-block:clamp(1.8rem, 7vh, 4.6rem);
}

.hero .wrap{
  display:grid;
  grid-template-columns:1.15fr .85fr;
  gap:1.6rem;
  align-items:center;
}

@media (max-width:900px){
  .hero .wrap{
    grid-template-columns:1fr;
  }
}

.hero-card{
  background:#fff;
  border:1px solid var(--border-soft);
  border-radius:var(--radius-lg);
  padding:.9rem;
  box-shadow:var(--shadow);
  position:relative;
  overflow:hidden;
}

.rotator{
  position:relative;
  border-radius:12px;
  aspect-ratio:4/5;
}

.rotator img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  border-radius:12px;
  opacity:0;
  transition:opacity .5s ease;
}

.rotator img.active{
  opacity:1;
}

.rotator .r-ctrl{
  position:absolute;
  top:50%;
  translate:0 -50%;
  background:rgba(255,255,255,.9);
  border:1px solid rgba(30,30,60,.12);
  border-radius:10px;
  padding:.4rem .55rem;
  cursor:pointer;
}

.rotator .prev{
  left:.5rem;
}

.rotator .next{
  right:.5rem;
}

.hero-caption{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:.6rem;
  font-size:.92rem;
  color:var(--muted);
  margin:.55rem .2rem 0;
}

@media (max-width:640px){
  .hero-caption{
    flex-direction:column;
    align-items:flex-start;
  }
}

/* ==============================
   Galerie / kaarten
============================== */
.gallery-toolbar,
.toolbar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:.7rem;
  margin:.2rem 0 1rem;
  flex-wrap:wrap;
}

.gallery{
  --col:270px;
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(var(--col), 1fr));
  gap:14px;
}

.gallery.masonry{
  display:block;
  column-width:320px;
  column-gap:14px;
}

@media (max-width:640px){
  .gallery.masonry{
    column-width:240px;
  }
}

.art,
.card{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius);
  overflow:hidden;
  box-shadow:0 1px 0 rgba(0,0,0,.02);
  transition:border-color .12s ease, transform .12s ease;
}

.gallery.masonry .art,
.gallery.masonry .card{
  break-inside:avoid;
  margin:0 0 14px;
}

.art:hover,
.art:focus-within,
.card:hover,
.card:focus-within{
  border-color:rgba(30,30,60,.18);
}

.thumb{
  width:100%;
  aspect-ratio:4/5;
  background:#fff;
  overflow:hidden;
  position:relative;
}

.thumb img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

.cap{
  display:grid;
  grid-template-columns:1fr auto;
  align-items:center;
  gap:.45rem;
  padding:.6rem .75rem;
  font-size:.94rem;
  color:#2a2a34;
  border-top:1px solid rgba(30,30,60,.06);
  min-height:52px;
}

.cap .title{
  font-weight:700;
  letter-spacing:.1px;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

.cap .meta{
  display:flex;
  align-items:center;
  gap:.4rem;
  flex-wrap:wrap;
  justify-content:flex-end;
}

.badge{
  display:inline-flex;
  align-items:center;
  gap:.3rem;
  padding:.18rem .5rem;
  border-radius:999px;
  background:#fff;
  border:1px solid rgba(30,30,60,.12);
  font-size:.78rem;
  color:var(--muted);
}

.quick-actions{
  position:absolute;
  right:.5rem;
  bottom:.5rem;
  display:flex;
  gap:.4rem;
}

.quick-btn{
  border:none;
  border-radius:10px;
  padding:.35rem .55rem;
  font-weight:800;
  cursor:pointer;
  background:#fff;
  border:1px solid rgba(30,30,60,.14);
  box-shadow:var(--shadow);
}

.quick-btn:hover{
  transform:translateY(-1px);
}

/* ==============================
   Muurweergave
============================== */
#werk.wall{
  background:#efefe9;
  margin:-.2rem 0 0;
  padding:2.2rem 0;
  border-top:1px solid rgba(0,0,0,.05);
  border-bottom:1px solid rgba(0,0,0,.05);
}

#werk.wall .thumb{
  border:10px solid #fff;
  box-shadow:0 8px 22px rgba(0,0,0,.08);
}

/* ==============================
   Over-pagina
============================== */
.about{
  display:grid;
  grid-template-columns:1fr;
  gap:calc(var(--gap) * 1.15);
}

.card{
  background:#fff;
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  padding:1.1rem 1.2rem;
  box-shadow:var(--shadow);
}

.maker .maker-grid{
  display:grid;
  grid-template-columns:min(520px, 100%) 1fr;
  gap:clamp(1rem, 2.2vw, 1.4rem);
  align-items:start;
}

@media (max-width:900px){
  .maker .maker-grid{
    grid-template-columns:1fr;
  }
}

.maker-portrait{
  position:relative;
  margin:0;
  padding:12px 12px 40px;
  border-radius:14px;
  background:#fff;
  border:1px solid var(--border);
  box-shadow:var(--shadow);
}

.maker-portrait img{
  width:100%;
  height:auto;
  display:block;
  border-radius:10px;
  object-fit:cover;
  aspect-ratio:4/5;
}

.maker-portrait figcaption{
  position:absolute;
  left:16px;
  bottom:12px;
  font-size:.86rem;
  color:var(--muted);
  background:rgba(255,255,255,.92);
  border:1px solid rgba(30,30,60,.12);
  padding:.18rem .5rem;
  border-radius:10px;
}

.maker-portrait .pin{
  position:absolute;
  top:-10px;
  left:18px;
  font-size:18px;
  rotate:-10deg;
  filter:drop-shadow(0 2px 2px rgba(0,0,0,.12));
}

.maker-copy .maker-quote{
  margin:.2rem 0 .9rem;
  padding:.55rem .8rem;
  border-left:4px solid var(--dyn-1);
  background:rgba(154,209,255,.10);
  background:color-mix(in oklab, #fff 90%, var(--dyn-2) 10% / 12%);
  border-radius:10px;
  font-style:italic;
  color:#2a2a34;
}

.maker-tags{
  display:flex;
  gap:.4rem;
  flex-wrap:wrap;
  list-style:none;
  padding:0;
  margin:.8rem 0 1rem;
}

.maker-tags li{
  font-size:.85rem;
  padding:.26rem .55rem;
  border-radius:999px;
  background:#fff;
  border:1px dashed rgba(30,30,60,.20);
}

.maker-links{
  display:flex;
  gap:.5rem;
  flex-wrap:wrap;
}

/* ==============================
   Room preview
============================== */
.room-card{
  display:grid;
  gap:.8rem;
}

.room-controls{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:.7rem 1rem;
  background:rgba(154,209,255,.08);
  background:color-mix(in oklab, #fff 90%, var(--dyn-2) 10% / 8%);
  padding:.75rem;
  border-radius:12px;
  border:1px solid var(--border);
}

.ctrl{
  display:flex;
  align-items:center;
  gap:.55rem;
}

.ctrl .ctrl-label{
  font-weight:900;
  white-space:nowrap;
  letter-spacing:.2px;
}

.ctrl select{
  min-width:240px;
  padding:.42rem .6rem;
  border-radius:10px;
  border:1px solid rgba(30,30,60,.2);
  background:#fff;
}

.range{
  display:flex;
  align-items:center;
  gap:.55rem;
  min-width:320px;
  flex:1 1 340px;
}

.value-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:.18rem .55rem;
  border-radius:999px;
  background:#fff;
  border:1px solid rgba(30,30,60,.12);
  font-weight:900;
  min-width:4.6ch;
}

.value-badge::after{
  content:" cm";
  margin-left:.15rem;
  opacity:.75;
  font-weight:700;
}

.slider{
  flex:1 1 200px;
  min-width:160px;
}

.tones{
  display:flex;
  align-items:center;
  gap:.4rem;
  flex-wrap:wrap;
}

.color-inline{
  display:inline-flex;
  align-items:center;
  gap:.35rem;
  padding:.18rem .5rem;
  border-radius:999px;
  border:1px solid rgba(30,30,60,.18);
  background:#fff;
}

#room-color{
  width:40px;
  height:32px;
  padding:0;
  border:none;
  background:transparent;
}

.room{
  position:relative;
  border:1px solid var(--border);
  border-radius:14px;
  background:#f4f4f0;
  box-shadow:var(--shadow);
  overflow:hidden;
  min-height:360px;
  padding:1.8rem 1.8rem 2.6rem;
}

.room .floor{
  position:absolute;
  left:0;
  right:0;
  bottom:0;
  height:22%;
  background:linear-gradient(#e8e1d8, #d7cec3);
  border-top:1px solid rgba(30,30,60,.08);
}

.art-on-wall{
  position:relative;
  width:100%;
  height:100%;
  display:grid;
  place-items:center;
}

.art-on-wall img{
  display:block;
  height:auto;
  max-width:96%;
  object-fit:contain;
  background:transparent;
}

.art-on-wall img.frame{
  padding:16px;
  border-radius:6px;
}

.art-on-wall img.frame.light{
  background:#fff;
  border:1px solid rgba(0,0,0,.14);
  box-shadow:inset 0 0 0 6px #fff;
}

.art-on-wall img.frame.dark{
  background:#111;
  border:1px solid rgba(0,0,0,.35);
  box-shadow:inset 0 0 0 6px #111;
}

.art-on-wall img.frame.oak{
  background:#fefdf9;
  border:1px solid #8b6b3e;
  box-shadow:inset 0 0 0 10px #caa66a;
}

.art-on-wall figcaption{
  position:absolute;
  left:1rem;
  bottom:1rem;
  background:rgba(255,255,255,.92);
  border:1px solid rgba(30,30,60,.12);
  border-radius:10px;
  padding:.26rem .55rem;
  font-size:.88rem;
  color:var(--muted);
}

/* ==============================
   Contact
============================== */
#contact .contact-wrap{
  display:grid;
  gap:clamp(1rem, 2.2vw, 1.3rem);
}

#contact .contact-card{
  background:#fff;
  border:1px solid var(--border);
  border-radius:14px;
  padding:1.1rem 1.2rem;
  box-shadow:var(--shadow);
}

#contact .direct-bar{
  display:flex;
  align-items:center;
  gap:.7rem;
  flex-wrap:wrap;
  background:rgba(154,209,255,.10);
  background:color-mix(in oklab, #fff 90%, var(--dyn-2) 10% / 12%);
  border:1px solid var(--border);
  border-radius:18px;
  padding:.8rem .9rem;
}

#contact .direct-title{
  font-weight:900;
  letter-spacing:.2px;
  padding:.3rem .6rem;
  border-radius:999px;
  background:#fff;
  border:1px solid var(--border);
}

#contact .pill{
  display:inline-flex;
  align-items:center;
  gap:.45rem;
  padding:.55rem .8rem;
  border-radius:999px;
  background:#fff;
  border:1px solid rgba(30,30,60,.12);
  text-decoration:none;
  color:inherit;
  word-break:break-word;
}

#contact .pill svg{
  width:16px;
  height:16px;
  flex:0 0 16px;
}

@media (max-width:640px){
  #contact .direct-bar{
    align-items:flex-start;
    border-radius:14px;
  }

  #contact .pill{
    width:100%;
    justify-content:flex-start;
  }
}

/* ==============================
   Footer
============================== */
footer{
  padding:2rem 0;
  color:var(--muted);
  text-align:center;
}

/* ==============================
   Lightbox
============================== */
#lightbox{
  border:none;
  padding:0;
  background:transparent;
}

#lightbox::backdrop{
  background:rgba(10,12,20,.6);
  backdrop-filter:blur(2px);
}

#lightbox .lb-wrap{
  position:relative;
  max-width:min(92vw, 1200px);
  margin:auto;
}

#lightbox .lb-img{
  width:100%;
  height:auto;
  display:block;
  border-radius:12px;
  background:#fff;
}

#lightbox .lb-bar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  color:#fff;
  margin:.5rem .2rem 0;
}

#lightbox .lb-title{
  font-weight:800;
}

#lightbox .lb-actions{
  display:flex;
  gap:.4rem;
  flex-wrap:wrap;
}

#lightbox .icon-btn{
  background:rgba(255,255,255,.14);
  color:#fff;
  border:none;
  border-radius:9px;
  padding:.45rem .6rem;
  cursor:pointer;
}

@media (max-width:640px){
  #lightbox .lb-bar{
    flex-direction:column;
    align-items:flex-start;
  }
}

/* ==============================
   Minder beweging
============================== */
@media (prefers-reduced-motion:reduce){
  html{
    scroll-behavior:auto;
  }

  *{
    transition:none !important;
    animation:none !important;
  }
}