/* ===== Restaurant VONK — gedeeld design-systeem ===== */
:root{
  --zwart:#0D0D0D;
  --zacht:#F2E8DC;
  --beige:#E4D2B1;
  --bruin:#6B4E34;
  --groen:#5C6B55;
  --goud:#D4B48C;
  --inkt:#241c14;
  --serif:'Cormorant Garamond',Georgia,serif;
  --sans:'Jost',-apple-system,Segoe UI,sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--sans);color:var(--inkt);background:var(--zacht);font-weight:300;line-height:1.7;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
h1,h2,h3{font-family:var(--serif);font-weight:500;line-height:1.08;letter-spacing:.01em}
.wrap{max-width:1180px;margin:0 auto;padding:0 28px}
.wrap.narrow{max-width:860px}
.eyebrow{font-family:var(--sans);font-weight:400;font-size:.72rem;letter-spacing:.42em;text-transform:uppercase;color:var(--bruin)}
.btn{display:inline-block;font-family:var(--sans);font-weight:400;font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;padding:16px 34px;border:1px solid var(--inkt);color:var(--inkt);background:transparent;transition:.35s;cursor:pointer}
.btn:hover{background:var(--inkt);color:var(--zacht)}
.btn-gold{border-color:var(--goud);background:var(--goud);color:var(--zwart)}
.btn-gold:hover{background:var(--bruin);border-color:var(--bruin);color:var(--zacht)}
.btn-light{border-color:rgba(242,232,220,.7);color:var(--zacht)}
.btn-light:hover{background:var(--zacht);color:var(--zwart);border-color:var(--zacht)}
.rule{width:54px;height:1px;background:var(--goud);border:0;margin:22px 0}
.rule.c{margin-left:auto;margin-right:auto}
.muted{color:#5a4d3e}
.pad{padding:clamp(72px,11vw,140px) 0}
.pad-s{padding:clamp(54px,8vw,96px) 0}
.lead{font-size:clamp(2rem,4.4vw,3.3rem)}

/* ===== NAV ===== */
header{position:fixed;top:0;left:0;right:0;z-index:60;transition:.4s;padding:22px 0}
header.scrolled{background:rgba(13,13,13,.95);backdrop-filter:blur(8px);padding:14px 0;box-shadow:0 1px 0 rgba(212,180,140,.18)}
.nav{display:flex;align-items:center;justify-content:space-between}
.nav .logo{height:30px;transition:.4s}
header.scrolled .nav .logo{height:26px}
.nav-links{display:flex;align-items:center;gap:30px}
.nav-links>a,.has-sub>a{font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--zacht);font-weight:400;opacity:.88;transition:.3s;position:relative;white-space:nowrap}
.nav-links>a::after,.has-sub>a::after{content:'';position:absolute;left:0;bottom:-6px;width:0;height:1px;background:var(--goud);transition:.3s}
.nav-links>a:hover,.has-sub>a:hover{opacity:1}
.nav-links>a:hover::after,.has-sub>a:hover::after{width:100%}
.nav-links>a.active::after,.has-sub.active>a::after{width:100%}
.nav-links .btn{padding:11px 24px;color:var(--zwart);opacity:1}
.nav-links .btn::after{display:none}
/* dropdown */
.has-sub{position:relative}
.has-sub>a{display:inline-flex;align-items:center;gap:5px;cursor:pointer}
.has-sub .caret{width:7px;height:7px;border-right:1.4px solid currentColor;border-bottom:1.4px solid currentColor;transform:rotate(45deg) translateY(-2px);transition:.3s;opacity:.8}
.sub{position:absolute;top:calc(100% + 14px);left:50%;transform:translateX(-50%) translateY(8px);background:rgba(13,13,13,.97);backdrop-filter:blur(8px);border:1px solid rgba(212,180,140,.2);min-width:200px;padding:10px 0;opacity:0;visibility:hidden;transition:.3s;box-shadow:0 24px 50px -20px rgba(0,0,0,.6)}
.has-sub:hover .sub{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.has-sub:hover .caret{transform:rotate(225deg) translateY(2px)}
.sub a{display:block;padding:9px 24px;font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:#c3b7a4;transition:.25s}
.sub a:hover{background:rgba(212,180,140,.12);color:var(--goud);padding-left:30px}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px;z-index:70}
.burger span{width:26px;height:1.5px;background:var(--zacht);transition:.3s}

/* ===== PAGE HERO (subpagina's) ===== */
.phero{position:relative;min-height:56vh;display:flex;align-items:flex-end;color:var(--zacht);overflow:hidden}
.phero.tall{min-height:72vh;align-items:center;text-align:center;justify-content:center}
.phero-bg{position:absolute;inset:0;background-size:cover;background-position:center;transform:scale(1.04)}
.phero::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(13,13,13,.5) 0%,rgba(13,13,13,.3) 45%,rgba(13,13,13,.8) 100%)}
.phero-inner{position:relative;z-index:2;padding:0 0 clamp(40px,7vw,80px)}
.phero.tall .phero-inner{padding:0 24px}
.phero .tag{font-size:.74rem;letter-spacing:.4em;text-transform:uppercase;color:var(--goud);font-weight:400}
.phero h1{font-size:clamp(2.4rem,5.5vw,4.2rem);margin:14px 0 6px;text-shadow:0 2px 30px rgba(0,0,0,.5)}
.phero p.sub{font-size:1.05rem;max-width:560px;opacity:.92}
.phero.tall p.sub{margin:0 auto}
.crumb{position:absolute;top:calc(14px + 64px);left:0;right:0;z-index:2}
.crumb .wrap{font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:rgba(242,232,220,.7)}
.crumb a{color:var(--goud)}

/* ===== HOME HERO ===== */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;justify-content:center;text-align:center;color:var(--zacht);overflow:hidden}
.hero-bg{position:absolute;inset:0;background:url('/assets/hero.jpg') center 38%/cover no-repeat;transform:scale(1.05)}
.hero::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(13,13,13,.55) 0%,rgba(13,13,13,.25) 38%,rgba(13,13,13,.72) 100%)}
.hero-inner{position:relative;z-index:2;padding:0 24px;max-width:820px}
.hero img.mark{height:74px;margin:0 auto 30px;filter:drop-shadow(0 4px 24px rgba(0,0,0,.4))}
.hero .tag{font-size:.8rem;letter-spacing:.46em;text-transform:uppercase;color:var(--goud);font-weight:400}
.hero h1{font-size:clamp(2.6rem,6vw,4.7rem);margin:22px 0 18px;text-shadow:0 2px 30px rgba(0,0,0,.5)}
.hero p.sub{font-size:1.05rem;letter-spacing:.04em;max-width:520px;margin:0 auto 54px;opacity:.92}
.hero .cta{display:flex;gap:18px;justify-content:center;flex-wrap:wrap;margin-top:10px}
.scroll-hint{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);z-index:2;color:var(--zacht);font-size:.66rem;letter-spacing:.3em;text-transform:uppercase;opacity:.7;display:flex;flex-direction:column;align-items:center;gap:10px}
.scroll-hint .line{width:1px;height:40px;background:linear-gradient(var(--goud),transparent);animation:pulse 2.4s infinite}
@keyframes pulse{0%,100%{opacity:.3}50%{opacity:1}}

/* ===== INTRO / TEKSTBLOK ===== */
.intro{text-align:center}
.intro .body{max-width:680px;margin:0 auto;font-size:1.12rem;color:#4a3f31}
.intro .body p+p{margin-top:18px}
.prose{max-width:680px;font-size:1.08rem;color:#4a3f31}
.prose.c{margin:0 auto;text-align:center}
.prose p+p{margin-top:18px}
.prose h3{font-size:1.7rem;margin:34px 0 10px;color:var(--inkt)}
.prose ul{list-style:none;margin:18px 0}
.prose ul li{position:relative;padding-left:26px;margin-bottom:10px}
.prose ul li::before{content:'';position:absolute;left:0;top:11px;width:8px;height:8px;background:var(--goud);transform:rotate(45deg)}

/* ===== VALUES ===== */
.values{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin-top:62px;max-width:920px;margin-left:auto;margin-right:auto}
.val{text-align:center;padding:8px}
.val .ic{margin:0 auto 14px;width:34px;height:34px}
.val .ic svg{width:34px;height:34px;stroke:var(--bruin);fill:none;stroke-width:1.25;stroke-linecap:round;stroke-linejoin:round}
.val h4{font-family:var(--sans);font-weight:500;font-size:.78rem;letter-spacing:.24em;text-transform:uppercase;color:var(--inkt);margin-bottom:8px}
.val p{font-size:.84rem;color:#6a5c4c;line-height:1.55}

/* ===== SPLIT ===== */
.split{display:grid;grid-template-columns:1fr 1fr;align-items:center;gap:0}
.split.dark{background:var(--zwart);color:var(--zacht)}
.split .img{min-height:560px;background-size:cover;background-position:center}
.split .txt{padding:clamp(48px,7vw,96px)}
.split .txt h2{font-size:clamp(2rem,4vw,3rem);margin:14px 0 6px}
.split.dark .eyebrow{color:var(--goud)}
.split .txt p{margin-bottom:16px;max-width:460px}
.split.dark .txt p{color:#cfc3b2}
.split.rev .img{order:2}

/* ===== MENU ===== */
.menu{background:var(--inkt);color:var(--zacht)}
.menu .head{text-align:center;margin-bottom:56px}
.menu .head h2{font-size:clamp(2.2rem,5vw,3.4rem);margin:14px 0}
.menu-grid{display:grid;grid-template-columns:1fr 1fr;gap:54px 64px}
.menu-grid.one{grid-template-columns:1fr;max-width:720px;margin:0 auto}
.mcard h3{font-size:1.7rem;color:var(--goud);margin-bottom:4px}
.mcard .sub{font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:#9c8f7c;margin-bottom:22px}
.mitem{display:flex;align-items:baseline;gap:12px;margin-bottom:16px;flex-wrap:wrap}
.mitem .nm{font-family:var(--serif);font-size:1.22rem;color:var(--zacht)}
.mitem .dot{flex:1;border-bottom:1px dotted rgba(212,180,140,.4);transform:translateY(-4px);min-width:18px}
.mitem .pr{font-size:.92rem;color:var(--goud);font-weight:400}
.mitem .ds{flex-basis:100%;display:block;font-size:.82rem;color:#a99c89;line-height:1.5;margin-top:2px;font-weight:300}
.mnote{text-align:center;margin-top:54px;font-size:.86rem;color:#9c8f7c}
.mnote a{color:var(--goud);border-bottom:1px solid var(--goud)}
.menu.light{background:var(--zacht);color:var(--inkt)}
.menu.light .mcard h3{color:var(--bruin)}
.menu.light .mcard .sub{color:#9a8b76}
.menu.light .mitem .nm{color:var(--inkt)}
.menu.light .mitem .pr{color:var(--bruin)}
.menu.light .mitem .ds{color:#6a5c4c}
.menu.light .mnote{color:#6a5c4c}

/* ===== CARDS / CONCEPTEN ===== */
.cards{background:var(--zacht)}
.cards .head{text-align:center;margin-bottom:58px}
.cards .head h2{font-size:clamp(2.2rem,5vw,3.4rem);margin:14px 0}
.cgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.cgrid.two{grid-template-columns:repeat(2,1fr);max-width:880px;margin:0 auto}
.cgrid.three-price{grid-template-columns:repeat(3,1fr)}
.cc{position:relative;background:linear-gradient(168deg,#fff 0%,#fdfaf3 100%);border:1px solid rgba(107,78,52,.12);border-radius:5px;padding:44px 36px 40px;transition:transform .5s cubic-bezier(.2,.7,.2,1),box-shadow .5s,border-color .5s;overflow:hidden}
.cc::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--goud),var(--bruin));transform:scaleX(0);transform-origin:left;transition:transform .55s ease}
.cc:hover{transform:translateY(-9px);box-shadow:0 30px 64px -32px rgba(36,28,20,.55);border-color:rgba(212,180,140,.55)}
.cc:hover::before{transform:scaleX(1)}
.cc .ic{display:flex;align-items:center;justify-content:center;width:64px;height:64px;margin-bottom:26px;border-radius:50%;background:radial-gradient(circle at 32% 28%,#f7eddc,#ecdcc2);box-shadow:inset 0 0 0 1px rgba(212,180,140,.35);transition:transform .5s,background .5s}
.cc:hover .ic{transform:scale(1.07) rotate(-3deg);background:radial-gradient(circle at 32% 28%,#f2e3cc,#e4d0ad)}
.cc .ic svg{width:28px;height:28px;stroke:var(--bruin);fill:none;stroke-width:1.3;stroke-linecap:round;stroke-linejoin:round}
.cc h3{font-size:1.5rem;margin-bottom:11px}
.cc p{font-size:.9rem;color:#6a5c4c;line-height:1.62}
.cc .price{font-family:var(--serif);font-size:2rem;color:var(--bruin);margin:8px 0 4px}
.cc .price small{font-family:var(--sans);font-size:.78rem;color:#9a8b76;letter-spacing:.06em}
.cc .tagpill{display:inline-block;font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;color:var(--bruin);border:1px solid var(--goud);padding:5px 12px;margin-top:16px}

/* ===== FOOD BAND ===== */
.band{position:relative;height:54vh;min-height:380px;display:flex;align-items:center;justify-content:center;overflow:hidden;background:var(--inkt)}
.band-bg{position:absolute;inset:0;background-size:cover;background-position:center 55%;background-repeat:no-repeat;background-attachment:fixed}
.band::after{content:'';position:absolute;inset:0;background:rgba(13,13,13,.5)}
.band-inner{position:relative;z-index:2;text-align:center;padding:0 24px}
.band .tagline{font-family:var(--serif);font-style:italic;font-size:clamp(1.8rem,4.5vw,3.2rem);color:var(--zacht);letter-spacing:.02em;text-shadow:0 2px 30px rgba(0,0,0,.6)}
@media(max-width:880px){.band-bg{background-attachment:scroll}}

/* ===== STEPS ===== */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:50px}
.step{text-align:center;padding:10px}
.step .n{font-family:var(--serif);font-size:2.6rem;color:var(--goud);line-height:1}
.step h4{font-family:var(--sans);font-weight:500;font-size:.82rem;letter-spacing:.18em;text-transform:uppercase;margin:14px 0 8px}
.step p{font-size:.88rem;color:#6a5c4c}

/* ===== TEAM ===== */
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;margin-top:54px}
.tcard{background:#fff;border:1px solid rgba(107,78,52,.14);padding:34px 26px;text-align:center;transition:.4s}
.tcard:hover{transform:translateY(-5px);box-shadow:0 22px 50px -28px rgba(36,28,20,.5);border-color:var(--goud)}
.tcard .avatar{width:88px;height:88px;border-radius:50%;margin:0 auto 20px;background:var(--inkt);color:var(--goud);display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:2rem;border:1px solid var(--goud)}
.tcard h3{font-size:1.4rem;margin-bottom:2px}
.tcard .role{font-size:.68rem;letter-spacing:.22em;text-transform:uppercase;color:var(--bruin);margin-bottom:14px}
.tcard p{font-size:.88rem;color:#6a5c4c;font-style:italic}

/* ===== INFO / CONTACT GRID ===== */
.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:0;background:#fff;border:1px solid rgba(107,78,52,.14)}
.info-grid .col{padding:clamp(36px,5vw,60px)}
.info-grid .map{min-height:380px;background-size:cover;background-position:center}
.info-grid iframe{width:100%;height:100%;min-height:380px;border:0;display:block;filter:grayscale(.2) sepia(.1)}
.info-line{display:flex;gap:14px;align-items:flex-start;margin-bottom:22px}
.info-line .ic{width:22px;height:22px;flex:0 0 22px;margin-top:3px}
.info-line .ic svg{width:22px;height:22px;stroke:var(--bruin);fill:none;stroke-width:1.3;stroke-linecap:round;stroke-linejoin:round}
.info-line .lbl{font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;color:#9a8b76;display:block;margin-bottom:2px}
.info-line a,.info-line span.v{font-size:1.02rem;color:var(--inkt)}
.info-line a:hover{color:var(--bruin)}

/* ===== HOURS TABLE ===== */
.hours{max-width:360px}
.hours .row{display:flex;justify-content:space-between;padding:9px 0;border-bottom:1px solid rgba(107,78,52,.12);font-size:.95rem}
.hours .row span:first-child{color:#6a5c4c}
.hours .row span:last-child{color:var(--inkt)}
.hours .row.closed span:last-child{color:#b04a32}
.hours .note{font-size:.84rem;color:#8a7d6b;margin-top:14px}

/* ===== RESERVE CTA ===== */
.reserve{position:relative;color:var(--zacht);text-align:center;overflow:hidden}
.reserve-bg{position:absolute;inset:0;background:url('/assets/samen.jpg') center 60%/cover no-repeat}
.reserve::after{content:'';position:absolute;inset:0;background:rgba(13,13,13,.66)}
.reserve .inner{position:relative;z-index:2;max-width:640px;margin:0 auto}
.reserve h2{font-size:clamp(2.2rem,5vw,3.5rem);margin:16px 0 10px}
.reserve p{opacity:.92;margin-bottom:32px;font-size:1.05rem}
.reserve .phone{font-family:var(--serif);font-size:2rem;color:var(--goud);display:inline-block;margin-bottom:30px}

/* ===== CTA-STRIP ===== */
.ctastrip{background:var(--zwart);color:var(--zacht);text-align:center}
.ctastrip h2{font-size:clamp(1.8rem,4vw,2.8rem);margin-bottom:10px}
.ctastrip .eyebrow{color:var(--goud)}
.ctastrip p{color:#cfc3b2;max-width:520px;margin:0 auto 28px}

/* ===== FOOTER ===== */
footer{background:var(--zwart);color:var(--zacht)}
.foot-grid{display:grid;grid-template-columns:1.3fr 1fr 1fr 1fr;gap:40px;padding:clamp(64px,9vw,104px) 0 0}
.foot-grid img.fmark{height:34px;margin-bottom:24px}
.foot-grid p,.foot-grid a{color:#c3b7a4;font-size:.92rem;line-height:1.85}
.foot-grid a:hover{color:var(--goud)}
.foot-grid h4{font-family:var(--sans);font-weight:500;font-size:.74rem;letter-spacing:.24em;text-transform:uppercase;color:var(--goud);margin-bottom:18px}
.foot-grid .lk{display:block}
.hours-row{display:flex;justify-content:space-between;max-width:280px;font-size:.88rem;color:#c3b7a4;padding:3px 0}
.hours-row span:last-child{color:var(--zacht)}
.socials{display:flex;gap:18px;margin-top:18px;flex-wrap:wrap}
.socials a{font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;border-bottom:1px solid transparent;transition:.3s}
.socials a:hover{border-color:var(--goud);color:var(--goud)}
.foot-bottom{border-top:1px solid rgba(212,180,140,.16);margin-top:64px;padding:26px 0;text-align:center}
.foot-bottom p{font-size:.76rem;letter-spacing:.08em;color:#8a7d6b}
.foot-bottom .slogan{font-family:var(--serif);font-style:italic;font-size:1.05rem;color:var(--goud);margin-bottom:6px}

/* ===== reveal ===== */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .9s ease,transform .9s ease}
.reveal.in{opacity:1;transform:none}

/* ===== RESPONSIVE ===== */
@media(max-width:980px){
  .nav-links{gap:22px}
  .foot-grid{grid-template-columns:1fr 1fr;gap:40px}
}
@media(max-width:880px){
  .nav-links{position:fixed;inset:0 0 0 auto;width:80%;max-width:340px;flex-direction:column;justify-content:flex-start;gap:6px;background:rgba(13,13,13,.98);transform:translateX(100%);transition:.4s;padding:96px 36px 40px;overflow-y:auto;align-items:flex-start}
  .nav-links.open{transform:none}
  .nav-links>a,.has-sub>a{font-size:.92rem;padding:12px 0}
  .has-sub{width:100%}
  .sub{position:static;transform:none;opacity:1;visibility:visible;background:transparent;border:0;box-shadow:none;padding:0 0 8px 16px;min-width:0}
  .sub a{padding:8px 0;font-size:.8rem}
  .has-sub .caret{display:none}
  .nav-links .btn{margin-top:14px}
  .burger{display:flex}
  .split{grid-template-columns:1fr}
  .split .img{min-height:340px}
  .split.rev .img{order:0}
  .menu-grid{grid-template-columns:1fr;gap:42px}
  .cgrid,.cgrid.three-price{grid-template-columns:1fr 1fr}
  .values{grid-template-columns:repeat(2,1fr);gap:30px 14px}
  .team-grid{grid-template-columns:1fr 1fr;gap:18px}
  .steps{grid-template-columns:1fr 1fr;gap:30px 18px}
  .info-grid{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:540px){
  .cgrid,.cgrid.two,.cgrid.three-price{grid-template-columns:1fr}
  .team-grid{grid-template-columns:1fr}
  .mitem .nm{white-space:normal}
  .hero p.sub{font-size:.96rem}
  .foot-grid{grid-template-columns:1fr}
}
