/* ============================================================
   IMAAN'S NAIL HOUSE — gedeelde stijl (editorial / cinematic)
   Huisstijl: cream #F2ECE3 · diep zwart #141019 · goud #C9A24B · wijnrood #8E1F2B
   Fonts: Bodoni Moda (display) · Cormorant Garamond (italic) · Jost (sans)
   ============================================================ */
:root{
  --cream:#F2ECE3; --cream-d:#E7DECF; --paper:#FBF7F0;
  --ink:#141019; --ink-2:#2A2430; --mut:#6B6068; --taupe:#B49A78; --gold:#C9A24B; --wine:#8E1F2B;
  --line:rgba(20,16,25,.14); --line-l:rgba(242,236,227,.18);
  --serif:"Bodoni Moda",serif; --it:"Cormorant Garamond",serif; --sans:"Jost",sans-serif;
  --sh:0 30px 80px -34px rgba(20,16,25,.55);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--sans);font-weight:300;color:var(--ink);background:var(--cream);line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden}
h1,h2,h3,h4{font-family:var(--serif);font-weight:400;line-height:1.02;letter-spacing:.005em}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
.wrap{max-width:1240px;margin:0 auto;padding:0 32px}
.eyebrow{font-family:var(--sans);font-size:.7rem;letter-spacing:.42em;text-transform:uppercase;color:var(--taupe);font-weight:400}
.it{font-family:var(--it);font-style:italic;font-weight:300}

/* toegankelijkheid: zichtbare focus + skip-link */
:focus-visible{outline:2px solid var(--gold);outline-offset:3px;border-radius:2px}
.skip{position:absolute;left:-999px;top:0;z-index:400;background:var(--ink);color:var(--cream);padding:12px 20px;border-radius:0 0 6px 0;font-size:.8rem;letter-spacing:.12em;text-transform:uppercase}
.skip:focus{left:0}

/* grain + cursor */
.grain{position:fixed;inset:0;z-index:200;pointer-events:none;opacity:.5;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.35'/%3E%3C/svg%3E")}
.glow{position:fixed;width:520px;height:520px;border-radius:50%;pointer-events:none;z-index:1;
  background:radial-gradient(circle,rgba(201,162,75,.16),transparent 62%);transform:translate(-50%,-50%);transition:opacity .6s;opacity:0;mix-blend-mode:multiply}
@media(hover:hover){.glow{opacity:1}}

/* nav zichtbaar op donkere hero (transparante staat) */
header:not(.scr) .brand-mark,header:not(.scr) .brand-mark small,header:not(.scr) .nav a.ml{color:var(--cream)}
header:not(.scr) .nav-cta{border-color:rgba(242,236,227,.65)}
header:not(.scr) .nav-cta::before{background:var(--cream)}
header:not(.scr) .nav-cta:hover{color:var(--ink)}
header:not(.scr) .burger span{background:var(--cream)}
.burger.o span{background:var(--ink)!important}
/* logo-varianten: tekst toont nu altijd; img-swap pas actief zodra logo.png er is */
.brand-mark img{height:38px;width:auto}
.brand-mark img.logo-light{display:none}
header:not(.scr) .brand-mark img.logo-dark{display:none}
header:not(.scr) .brand-mark img.logo-light{display:block}

/* bewegende gold-visual (hero + page-hero + booking) */
.fx{position:absolute;inset:0;width:100%;height:100%;z-index:1;mix-blend-mode:screen;opacity:1;pointer-events:none}

/* NAV */
header{position:fixed;inset:0 0 auto;z-index:90;transition:.55s cubic-bezier(.2,.7,.2,1)}
.nav{display:flex;align-items:center;justify-content:space-between;max-width:1240px;margin:0 auto;padding:30px 32px;transition:.5s}
header.scr{background:rgba(242,236,227,.82);backdrop-filter:blur(16px) saturate(1.1);border-bottom:1px solid var(--line)}
header.scr .nav{padding:16px 32px}
.brand-mark{font-family:var(--serif);font-size:1.4rem;letter-spacing:.04em;line-height:.86;cursor:pointer;transition:.4s;display:inline-block}
.brand-mark small{display:block;font-family:var(--sans);font-weight:300;font-size:.46rem;letter-spacing:.66em;text-transform:uppercase;margin-top:6px;color:var(--mut);text-indent:.66em}
nav ul{display:flex;gap:38px;list-style:none;align-items:center}
.nav a.ml{font-size:.76rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-2);position:relative;padding:5px 0;transition:.3s}
.nav a.ml::after{content:"";position:absolute;left:0;bottom:0;height:1px;width:0;background:currentColor;transition:.45s cubic-bezier(.2,.7,.2,1)}
.nav a.ml:hover::after,.nav a.ml.active::after{width:100%}
.nav a.ml.active{color:var(--gold)}
.nav-cta{border:1px solid var(--ink);padding:12px 24px;border-radius:40px;overflow:hidden;position:relative;z-index:1}
.nav-cta::after{display:none}.nav-cta::before{content:"";position:absolute;inset:0;background:var(--ink);transform:translateY(101%);transition:.45s cubic-bezier(.2,.7,.2,1);z-index:-1}
.nav-cta:hover{color:var(--cream)}.nav-cta:hover::before{transform:none}
.nav-cta.active{background:var(--gold);border-color:var(--gold);color:var(--ink)}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px;z-index:95}
.burger span{width:26px;height:1.5px;background:var(--ink);transition:.4s}
.burger.o span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.burger.o span:nth-child(2){opacity:0}
.burger.o span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

/* HERO (home) */
.hero{position:relative;height:100vh;min-height:680px;overflow:hidden;display:flex;align-items:flex-end;color:var(--cream)}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg .ph{position:absolute;inset:0;
  background:radial-gradient(130% 120% at 28% 18%,#2c1d26 0%,#1a141e 46%,#0e0a12 100%);
  animation:hue 16s ease-in-out infinite alternate;will-change:filter}
@keyframes hue{from{filter:brightness(1)}to{filter:brightness(1.16) hue-rotate(-8deg)}}
.hero-bg::after{content:"";position:absolute;inset:0;background:
  radial-gradient(80% 60% at 50% 28%,transparent,rgba(14,10,18,.32) 100%),
  linear-gradient(180deg,transparent 0%,rgba(14,10,18,.55) 100%)}
.hero-inner{position:relative;z-index:2;width:100%;padding-bottom:8vh}
.hero .tag{display:flex;align-items:center;gap:16px;margin-bottom:26px}
.hero .tag span{font-size:.7rem;letter-spacing:.4em;text-transform:uppercase;color:rgba(242,236,227,.85)}
.hero .tag i{width:46px;height:1px;background:rgba(242,236,227,.6);display:inline-block}
.hero h1{font-size:clamp(3.4rem,11vw,9rem);font-weight:500;letter-spacing:-.01em}
.hero h1 .l{display:block;overflow:hidden}
.hero h1 .l b{display:block;font-weight:inherit;transform:translateY(105%);transition:1s cubic-bezier(.16,1,.3,1)}
.hero.in h1 .l b{transform:none}
.hero h1 .l:nth-child(2) b{transition-delay:.12s}
.hero h1 em{font-family:var(--it);font-style:italic;font-weight:300;color:var(--cream)}
.hero .sub{max-width:38ch;margin:30px 0 38px;font-family:var(--it);font-style:italic;font-size:clamp(1.1rem,2vw,1.5rem);color:rgba(242,236,227,.92);opacity:0;transform:translateY(20px);transition:1s .5s}
.hero.in .sub{opacity:1;transform:none}
.hero-act{display:flex;gap:16px;flex-wrap:wrap;opacity:0;transform:translateY(20px);transition:1s .65s}
.hero.in .hero-act{opacity:1;transform:none}
.btn{display:inline-flex;align-items:center;gap:12px;font-family:var(--sans);font-size:.74rem;letter-spacing:.22em;text-transform:uppercase;padding:18px 36px;border-radius:46px;cursor:pointer;position:relative;overflow:hidden;z-index:1;transition:.4s;border:1px solid currentColor}
.btn.fill{background:var(--cream);color:var(--ink);border-color:var(--cream)}
.btn.fill::before{content:"";position:absolute;inset:0;z-index:-1;background:var(--wine);transform:translateY(101%);transition:.5s cubic-bezier(.2,.7,.2,1)}
.btn.fill:hover{color:var(--cream)}.btn.fill:hover::before{transform:none}
.btn.line{color:var(--cream)}.btn.line::before{content:"";position:absolute;inset:0;z-index:-1;background:var(--cream);transform:translateY(101%);transition:.5s cubic-bezier(.2,.7,.2,1)}
.btn.line:hover{color:var(--ink)}.btn.line:hover::before{transform:none}
.btn.dark{background:var(--ink);color:var(--cream);border-color:var(--ink)}
.btn.dark::before{content:"";position:absolute;inset:0;z-index:-1;background:var(--wine);transform:translateY(101%);transition:.5s cubic-bezier(.2,.7,.2,1)}
.btn.dark:hover::before{transform:none}
.scroll-c{position:absolute;bottom:26px;right:32px;z-index:2;font-size:.6rem;letter-spacing:.34em;text-transform:uppercase;color:rgba(242,236,227,.8);writing-mode:vertical-rl}
.scroll-c::after{content:"";display:block;width:1px;height:50px;background:rgba(242,236,227,.6);margin:12px auto 0;animation:drop 2s infinite}
@keyframes drop{0%{transform:scaleY(0);transform-origin:top}45%{transform:scaleY(1);transform-origin:top}55%{transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* PAGE-HERO (binnenpagina's) */
.phero{position:relative;min-height:54vh;display:flex;align-items:flex-end;overflow:hidden;color:var(--cream);
  background:radial-gradient(130% 120% at 28% 18%,#2c1d26 0%,#1a141e 46%,#0e0a12 100%)}
.phero .ph{position:absolute;inset:0;animation:hue 16s ease-in-out infinite alternate;will-change:filter}
.phero::after{content:"";position:absolute;inset:0;background:
  radial-gradient(80% 60% at 50% 28%,transparent,rgba(14,10,18,.32) 100%),
  linear-gradient(180deg,transparent 0%,rgba(14,10,18,.6) 100%)}
.phero-inner{position:relative;z-index:2;width:100%;padding:128px 0 60px}
.phero .tag{display:flex;align-items:center;gap:16px;margin-bottom:22px}
.phero .tag span{font-size:.7rem;letter-spacing:.4em;text-transform:uppercase;color:rgba(242,236,227,.85)}
.phero .tag i{width:46px;height:1px;background:rgba(242,236,227,.6);display:inline-block}
.phero h1{font-size:clamp(2.6rem,7.5vw,5.4rem);font-weight:500;color:var(--cream);letter-spacing:-.01em}
.phero h1 em{font-family:var(--it);font-style:italic;font-weight:300}
.phero p{margin-top:20px;font-family:var(--it);font-style:italic;font-size:clamp(1.1rem,2vw,1.5rem);color:rgba(242,236,227,.86);max-width:48ch}

/* MARQUEE */
.marq{padding:18px 0;background:var(--ink);color:var(--cream);overflow:hidden;white-space:nowrap;border-block:1px solid var(--line-l)}
.marq-t{display:inline-flex;gap:0;animation:slide 32s linear infinite}
.marq:hover .marq-t{animation-play-state:paused}
.marq-t span{font-family:var(--it);font-style:italic;font-size:1.5rem;padding:0 34px;display:inline-flex;align-items:center;gap:34px;color:rgba(242,236,227,.9)}
.marq-t span::after{content:"✦";font-style:normal;font-size:.7rem;color:var(--taupe)}
@keyframes slide{to{transform:translateX(-50%)}}

/* SECTION HEADS */
.sec{padding:140px 0;position:relative}
.sec-head{margin-bottom:70px;max-width:680px}
.sec-head.ctr{margin-inline:auto;text-align:center}
.sec-head .eyebrow{display:block;margin-bottom:20px}
.sec-head h2{font-size:clamp(2.4rem,6vw,4.4rem);font-weight:500}
.sec-head p{margin-top:22px;font-family:var(--it);font-style:italic;font-size:1.35rem;color:var(--mut)}

/* INTRO (home) */
.intro{background:var(--cream-d)}
.intro-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.intro-fig{position:relative}
.intro-fig .frame{aspect-ratio:4/5;overflow:hidden;border-radius:3px;box-shadow:var(--sh);background:linear-gradient(135deg,#cdbfa8,#e7dece)}
.intro-fig img{width:100%;height:100%;object-fit:cover;transform:scale(1.08);transition:1.6s cubic-bezier(.16,1,.3,1)}
.intro-fig.in img{transform:scale(1)}
.intro-copy h2{font-size:clamp(2.2rem,5vw,3.6rem);font-weight:500;margin:14px 0 24px}
.intro-copy p{color:var(--ink-2);margin-bottom:20px;max-width:52ch}
.intro-act{display:flex;gap:14px;flex-wrap:wrap;margin-top:30px}
.intro-act .btn.line{color:var(--ink)}
.intro-act .btn.line::before{background:var(--ink)}
.intro-act .btn.line:hover{color:var(--cream)}

/* FEATURED STRIP (home) */
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.feat-i{position:relative;overflow:hidden;border-radius:3px;aspect-ratio:4/5;background:linear-gradient(135deg,#2a2230,#3a3040)}
.feat-i img{width:100%;height:100%;object-fit:cover;transition:1.3s cubic-bezier(.16,1,.3,1)}
.feat-i:hover img{transform:scale(1.07)}
.feat-i .cap{position:absolute;inset:auto 0 0;padding:22px;background:linear-gradient(transparent,rgba(20,16,25,.85));color:var(--cream)}
.feat-i .cap span{font-size:.56rem;letter-spacing:.3em;text-transform:uppercase;color:var(--taupe)}
.feat-i .cap b{display:block;font-family:var(--it);font-style:italic;font-size:1.3rem;font-weight:400;margin-top:4px}

/* CTA BAND */
.cta-band{position:relative;overflow:hidden;color:var(--cream);text-align:center;
  background:radial-gradient(130% 120% at 28% 18%,#2c1d26 0%,#1a141e 46%,#0e0a12 100%)}
.cta-band .ph{position:absolute;inset:0;animation:hue 16s ease-in-out infinite alternate}
.cta-band .wrap{position:relative;z-index:2;padding:120px 32px}
.cta-band h2{font-size:clamp(2.2rem,6vw,4rem);font-weight:500;color:var(--cream)}
.cta-band p{margin:18px auto 34px;font-family:var(--it);font-style:italic;font-size:1.3rem;color:rgba(242,236,227,.8);max-width:44ch}

/* ATELIER */
.atelier{background:var(--cream-d)}
.at-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:80px;align-items:center}
.at-fig{position:relative}
.at-fig .frame{aspect-ratio:4/5;overflow:hidden;border-radius:3px;box-shadow:var(--sh);background:linear-gradient(135deg,#cdbfa8,#e7dece)}
.at-fig img{width:100%;height:100%;object-fit:cover;transform:scale(1.08);transition:1.6s cubic-bezier(.16,1,.3,1)}
.at-fig.in img{transform:scale(1)}
.at-fig .seal{position:absolute;bottom:-30px;left:-30px;background:var(--paper);border:1px solid var(--line);padding:24px 30px;box-shadow:var(--sh);max-width:240px}
.at-fig .seal .st{display:flex;gap:13px;align-items:center;margin-bottom:10px}
.at-fig .seal svg{width:30px;height:30px;flex:none}
.at-fig .seal b{font-family:var(--it);font-style:italic;font-size:1.35rem}
.at-fig .seal small{font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--taupe)}
.at-copy h2{font-size:clamp(2.2rem,5vw,3.6rem);font-weight:500;margin:16px 0 26px}
.at-copy p{color:var(--ink-2);margin-bottom:20px;max-width:50ch}
.at-stats{display:flex;gap:50px;margin:36px 0 38px;flex-wrap:wrap}
.at-stats b{font-family:var(--serif);font-size:2.6rem;font-weight:500;display:block;line-height:1}
.at-stats span{font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;color:var(--taupe)}
.at-values{list-style:none;margin:30px 0 0;border-top:1px solid var(--line)}
.at-values li{padding:20px 0;border-bottom:1px solid var(--line);display:grid;grid-template-columns:auto 1fr;gap:18px;align-items:start}
.at-values li b{font-family:var(--it);font-style:italic;font-size:1.3rem;color:var(--ink)}
.at-values li span{display:block;color:var(--mut);font-size:.95rem}
.at-values .num{font-family:var(--serif);color:var(--taupe)}

/* SERVICES */
.svc-list{border-top:1px solid var(--line)}
.svc-row{display:grid;grid-template-columns:64px 1.4fr 2fr auto;gap:30px;align-items:center;padding:34px 10px;border-bottom:1px solid var(--line);position:relative;transition:.5s;cursor:default}
.svc-row::before{content:"";position:absolute;inset:0;background:var(--paper);transform:scaleY(0);transform-origin:bottom;transition:.5s cubic-bezier(.2,.7,.2,1);z-index:-1}
.svc-row:hover::before{transform:scaleY(1)}
.svc-row .n{font-family:var(--serif);color:var(--taupe);font-size:1rem}
.svc-row h3{font-size:1.85rem;font-weight:500}
.svc-row h3 small{display:block;font-family:var(--sans);font-size:.72rem;font-weight:300;letter-spacing:.14em;text-transform:uppercase;color:var(--taupe);margin-top:6px}
.svc-row p{color:var(--mut);font-size:.95rem}
.svc-row .pr{font-family:var(--serif);font-size:1.7rem;font-weight:500;white-space:nowrap;justify-self:end}
.svc-row .pr small{font-family:var(--sans);font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;color:var(--taupe);display:block;text-align:right}
.note{margin-top:28px;font-size:.78rem;color:var(--taupe);letter-spacing:.04em}
.svc-sub{margin:80px 0 30px}
.svc-sub .eyebrow{display:block;margin-bottom:14px}
.svc-sub h3{font-size:clamp(1.8rem,4vw,2.6rem);font-weight:500}
.svc-sub p{margin-top:12px;font-family:var(--it);font-style:italic;font-size:1.2rem;color:var(--mut);max-width:54ch}

/* GALLERY */
.gallery{background:var(--ink);color:var(--cream)}
.gallery .eyebrow{color:var(--taupe)}.gallery .sec-head h2{color:var(--cream)}.gallery .sec-head p{color:rgba(242,236,227,.6)}
.gal{columns:3;column-gap:18px}
.gal-i{position:relative;margin-bottom:18px;break-inside:avoid;overflow:hidden;border-radius:3px;cursor:pointer;background:linear-gradient(135deg,#2a2230,#3a3040)}
.gal-i img{width:100%;height:auto;display:block;transition:1.3s cubic-bezier(.16,1,.3,1);filter:saturate(.92)}
.gal-i:hover img{transform:scale(1.07);filter:saturate(1.05)}
.gal-i .cap{position:absolute;inset:auto 0 0;padding:24px;background:linear-gradient(transparent,rgba(20,16,25,.85));transform:translateY(10px);opacity:0;transition:.5s}
.gal-i:hover .cap{transform:none;opacity:1}
.gal-i .cap span{font-size:.58rem;letter-spacing:.3em;text-transform:uppercase;color:var(--taupe)}
.gal-i .cap b{display:block;font-family:var(--it);font-style:italic;font-size:1.4rem;font-weight:400;margin-top:5px}
.gal-i.img-fail{aspect-ratio:4/5;display:flex;align-items:flex-end}
.gal-foot{text-align:center;margin-top:54px}
.ig-link{display:inline-flex;align-items:center;gap:13px;font-size:.76rem;letter-spacing:.24em;text-transform:uppercase;border-bottom:1px solid rgba(242,236,227,.5);padding-bottom:7px;transition:.4s}
.ig-link:hover{color:var(--taupe);border-color:var(--taupe)}

/* REVIEWS */
.rev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-bottom:54px}
.rev{background:var(--paper);border:1px solid var(--line);padding:38px 34px;display:flex;flex-direction:column;border-radius:3px;transition:.5s}
.rev:hover{transform:translateY(-6px);box-shadow:var(--sh)}
.rev .q{font-family:var(--serif);font-size:3rem;line-height:.6;color:var(--taupe);margin-bottom:8px}
.stars{letter-spacing:4px;margin-bottom:14px;color:var(--ink)}
.rev p{font-family:var(--it);font-style:italic;font-size:1.3rem;color:var(--ink);flex:1;margin-bottom:24px}
.rev .who{display:flex;align-items:center;gap:13px;border-top:1px solid var(--line);padding-top:18px}
.rev .who .av{width:40px;height:40px;border-radius:50%;background:var(--cream-d);display:grid;place-items:center;font-family:var(--serif);color:var(--ink-2)}
.rev .who b{font-weight:400;font-size:.96rem}.rev .who small{display:block;font-size:.64rem;letter-spacing:.12em;text-transform:uppercase;color:var(--taupe)}
.rev-form{background:var(--cream-d);border:1px solid var(--line);padding:48px;border-radius:4px;max-width:720px;margin:0 auto}
.rev-form h3{font-size:2rem;text-align:center;font-weight:500}
.rev-form .sub{text-align:center;color:var(--mut);margin:8px 0 30px;font-size:.95rem}
.field{margin-bottom:20px}
.field label{display:block;font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;color:var(--taupe);margin-bottom:9px}
.field input,.field textarea{width:100%;background:var(--paper);border:1px solid var(--line);padding:15px 17px;font-family:var(--sans);font-size:.96rem;color:var(--ink);border-radius:3px;transition:.3s}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--ink)}
.field textarea{resize:vertical;min-height:96px}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.star-pick{display:flex;gap:9px;font-size:1.8rem;color:var(--line);cursor:pointer}
.star-pick span{transition:.2s}.star-pick span.on,.star-pick span.hv{color:var(--gold)}
.err{color:var(--wine);font-size:.78rem;margin-top:6px;display:none}

/* BOOKING */
.booking{position:relative;color:var(--cream);overflow:hidden}
.booking .bg{position:absolute;inset:0;z-index:0;background-size:cover;background-position:center;background-image:linear-gradient(135deg,#241820,#3a2630)}
.booking::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(20,16,25,.86),rgba(20,16,25,.94))}
.booking .wrap{position:relative;z-index:2}
.booking .eyebrow{color:var(--taupe)}.booking .sec-head h2{color:var(--cream)}.booking .sec-head p{color:rgba(242,236,227,.7)}
.booker{max-width:780px;margin:0 auto;background:rgba(242,236,227,.05);border:1px solid var(--line-l);border-radius:6px;padding:50px;backdrop-filter:blur(6px)}
.steps{display:flex;justify-content:center;align-items:center;margin-bottom:44px}
.steps .s{display:flex;align-items:center;gap:11px;opacity:.4;transition:.4s}
.steps .s.act,.steps .s.dn{opacity:1}
.steps .dot{width:32px;height:32px;border-radius:50%;border:1px solid var(--cream);display:grid;place-items:center;font-size:.82rem;font-family:var(--serif);transition:.4s}
.steps .s.act .dot{background:var(--cream);color:var(--ink)}
.steps .s small{font-size:.64rem;letter-spacing:.16em;text-transform:uppercase}
.steps .bar{width:40px;height:1px;background:rgba(242,236,227,.3);margin:0 16px}
.pane{display:none;animation:fade .5s}.pane.act{display:block}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.opt-group-label{font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(242,236,227,.55);margin:0 0 12px}
.opt-group-label.mt{margin-top:26px}
.opts{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.opt{border:1px solid var(--line-l);padding:22px;border-radius:5px;cursor:pointer;transition:.3s;display:flex;justify-content:space-between;align-items:center;gap:12px}
.opt:hover{border-color:var(--cream)}.opt.sel{background:var(--cream);color:var(--ink);border-color:var(--cream)}
.opt b{font-family:var(--it);font-style:italic;font-size:1.3rem}.opt b small{display:block;font-family:var(--sans);font-style:normal;font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;opacity:.7;margin-top:3px}
.opt span{font-size:.85rem;opacity:.7;white-space:nowrap}
.slots{display:grid;grid-template-columns:repeat(4,1fr);gap:11px}
.slot{border:1px solid var(--line-l);padding:13px;text-align:center;border-radius:5px;cursor:pointer;font-size:.9rem;transition:.25s}
.slot:hover{border-color:var(--cream)}.slot.sel{background:var(--cream);color:var(--ink)}
.booking .field label{color:rgba(242,236,227,.55)}
.booking .field input,.booking .field textarea{background:rgba(242,236,227,.06);border-color:var(--line-l);color:var(--cream)}
.booking .field input:focus,.booking .field textarea:focus{border-color:var(--cream)}
.navb{display:flex;justify-content:space-between;margin-top:34px;gap:14px}
.bl{display:inline-flex;align-items:center;gap:10px;font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;padding:15px 32px;border-radius:46px;cursor:pointer;transition:.4s;border:1px solid var(--cream);background:var(--cream);color:var(--ink)}
.bl:hover{background:transparent;color:var(--cream)}
.bl.out{background:transparent;color:var(--cream)}.bl.out:hover{background:var(--cream);color:var(--ink)}
.summary{background:rgba(242,236,227,.05);border:1px solid var(--line-l);border-radius:6px;padding:28px;margin-bottom:26px}
.summary div{display:flex;justify-content:space-between;padding:11px 0;border-bottom:1px solid rgba(242,236,227,.1);gap:18px}
.summary div:last-child{border:none}
.summary div.total b{color:var(--gold)}
.summary span{opacity:.6;font-size:.68rem;letter-spacing:.14em;text-transform:uppercase}.summary b{font-family:var(--it);font-style:italic;font-size:1.2rem;text-align:right}
.wa{display:inline-flex;align-items:center;gap:12px;background:#25D366;color:#062f17;padding:17px 32px;border-radius:46px;font-size:.76rem;letter-spacing:.16em;text-transform:uppercase;transition:.3s}
.wa:hover{transform:translateY(-2px);filter:brightness(1.05)}
.done{text-align:center}.done .ck{width:74px;height:74px;border-radius:50%;border:1px solid var(--cream);margin:0 auto 24px;display:grid;place-items:center}

/* FOOTER */
footer{padding:110px 0 44px;background:var(--cream)}
.foot{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:50px;padding-bottom:60px;border-bottom:1px solid var(--line)}
.foot .brand-mark{font-size:2.2rem}
.foot-b p{margin-top:20px;font-family:var(--it);font-style:italic;font-size:1.2rem;color:var(--mut);max-width:30ch}
.foot-c h4{font-family:var(--sans);font-weight:400;font-size:.66rem;letter-spacing:.26em;text-transform:uppercase;color:var(--taupe);margin-bottom:20px}
.foot-c p,.foot-c a{display:block;color:var(--ink-2);margin-bottom:12px;font-size:.95rem;transition:.3s}
.foot-c a:hover{color:var(--ink);padding-left:4px}
.copy{display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;padding-top:30px;font-size:.72rem;color:var(--taupe);letter-spacing:.06em}

/* LIGHTBOX */
.lb{position:fixed;inset:0;background:rgba(20,16,25,.94);z-index:300;display:none;align-items:center;justify-content:center;padding:34px;backdrop-filter:blur(8px)}
.lb.show{display:flex;animation:fade .4s}
.lb-in{max-width:520px;width:100%;background:var(--cream);border-radius:4px;overflow:hidden;box-shadow:var(--sh)}
.lb-in img{width:100%;display:block}
.lb-in .m{padding:26px 30px}.lb-in .m span{font-size:.62rem;letter-spacing:.3em;text-transform:uppercase;color:var(--taupe)}
.lb-in .m b{display:block;font-family:var(--it);font-style:italic;font-size:1.7rem;font-weight:400;margin-top:5px}
.lb-x{position:absolute;top:26px;right:34px;width:48px;height:48px;border-radius:50%;border:1px solid rgba(242,236,227,.5);background:none;color:var(--cream);cursor:pointer;font-size:1.1rem;transition:.3s}
.lb-x:hover{background:var(--cream);color:var(--ink)}

/* DATE HINT + SLOT MESSAGE (boeker, donkere achtergrond) */
.date-hint{margin-top:12px;font-size:.82rem;color:rgba(242,236,227,.7);display:flex;flex-wrap:wrap;gap:8px;align-items:center;line-height:2}
.datechip{font-size:.76rem;border:1px solid var(--line-l);background:rgba(242,236,227,.06);color:var(--cream);padding:6px 12px;border-radius:30px;cursor:pointer;transition:.25s}
.datechip:hover{background:var(--cream);color:var(--ink)}
.slot-msg{margin-top:12px;font-size:.9rem;color:var(--taupe);font-family:var(--it);font-style:italic}

/* BEHEERPANEEL (agenda) */
.admin{max-width:940px;margin:0 auto}
.login-card{max-width:430px;margin:0 auto;background:var(--cream-d);border:1px solid var(--line);border-radius:6px;padding:42px}
.login-card h3{font-size:1.7rem;font-weight:500;text-align:center}
.login-card .sub{text-align:center;color:var(--mut);margin:8px 0 26px;font-size:.92rem}
.week-nav{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:30px;flex-wrap:wrap}
.week-nav b{font-family:var(--it);font-style:italic;font-size:1.5rem}
.week-nav .wk-btns{display:flex;gap:10px;align-items:center}
.wbtn{font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;border:1px solid var(--line);background:none;padding:10px 16px;border-radius:30px;cursor:pointer;color:var(--ink-2);transition:.3s}
.wbtn:hover:not(:disabled){border-color:var(--ink);color:var(--ink)}
.wbtn:disabled{opacity:.35;cursor:not-allowed}
.day{border:1px solid var(--line);border-radius:6px;padding:20px 22px;margin-bottom:14px;background:var(--paper)}
.day.past{opacity:.5}
.day-h{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;gap:12px}
.day-h b{font-family:var(--it);font-style:italic;font-size:1.3rem;text-transform:capitalize}
.day-all{font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;border:1px solid var(--line);background:none;padding:7px 13px;border-radius:30px;cursor:pointer;color:var(--mut);transition:.3s;white-space:nowrap}
.day-all:hover:not(:disabled){border-color:var(--ink);color:var(--ink)}
.day-slots{display:grid;grid-template-columns:repeat(8,1fr);gap:9px}
.aslot{border:1px solid var(--line);background:var(--cream);padding:11px 4px;border-radius:5px;cursor:pointer;font-size:.84rem;font-family:var(--sans);color:var(--ink-2);transition:.2s}
.aslot:hover:not(:disabled){border-color:var(--taupe)}
.aslot.on{background:var(--gold);border-color:var(--gold);color:#1a1206;font-weight:500}
.aslot:disabled,.day-all:disabled{cursor:not-allowed;opacity:.4}
.admin-bar{position:sticky;bottom:0;display:flex;justify-content:space-between;align-items:center;gap:16px;margin-top:26px;padding:18px 20px;flex-wrap:wrap;background:var(--cream-d);border:1px solid var(--line);border-radius:8px}
.admin-status{font-size:.9rem;font-family:var(--it);font-style:italic;color:var(--mut)}
.admin-note{font-size:.78rem;color:var(--taupe);margin-top:20px}

/* REVEAL */
.rv{opacity:0;transform:translateY(40px);transition:1.05s cubic-bezier(.16,1,.3,1)}
.rv.in{opacity:1;transform:none}
.d1{transition-delay:.1s}.d2{transition-delay:.2s}.d3{transition-delay:.3s}

/* RESPONSIVE */
@media(max-width:960px){
  nav ul{position:fixed;inset:0 0 0 auto;width:80%;max-width:360px;background:var(--cream);flex-direction:column;justify-content:center;gap:34px;padding:60px;transform:translateX(100%);transition:.55s cubic-bezier(.5,0,.2,1);box-shadow:var(--sh);z-index:80}
  nav ul.open{transform:none}.nav a.ml{font-size:1.05rem}.burger{display:flex}
  .at-grid,.intro-grid{grid-template-columns:1fr;gap:70px}.at-fig .seal{left:0}
  .gal{columns:2}.rev-grid{grid-template-columns:1fr 1fr}.feat-grid{grid-template-columns:1fr 1fr}
  .foot{grid-template-columns:1fr 1fr}
  .svc-row{grid-template-columns:40px 1fr auto;gap:18px}.svc-row p{display:none}
  .booker{padding:34px 24px}.opts{grid-template-columns:1fr}.slots{grid-template-columns:repeat(3,1fr)}
  .steps .s small{display:none}.steps .bar{width:26px;margin:0 9px}
}
@media(max-width:600px){
  .wrap{padding:0 20px}.sec{padding:90px 0}.gal{columns:1}.rev-grid{grid-template-columns:1fr}
  .row2{grid-template-columns:1fr}.foot{grid-template-columns:1fr}.at-stats{gap:34px}
  .feat-grid{grid-template-columns:1fr}.marq-t span{font-size:1.2rem}
  .phero-inner{padding:110px 0 48px}
}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition-duration:.001s!important}}
