/* ============ Tokens ============ */
:root{
  --ink:#211e1a;
  --ink-soft:#5a544c;
  --cream:#f6f1e9;
  --cream-2:#efe7db;
  --paper:#fbf8f3;
  --line:#e3d9ca;
  --sand:#d8c3a5;
  --sage:#a9b3a0;
  --gold:#b48a4e;
  --gold-deep:#9a733b;
  --shadow:0 24px 60px -30px rgba(40,32,20,.45);
  --serif:'Cormorant Garamond', Georgia, serif;
  --sans:'Jost', system-ui, sans-serif;
  --wrap:1180px;
  --r:18px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--paper);
  font-weight:300;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 28px}

h1,h2,h3{font-family:var(--serif);font-weight:500;line-height:1.08;letter-spacing:.01em}
h2{font-size:clamp(2rem,4.4vw,3.2rem)}
h3{font-size:1.4rem;font-weight:600}
em{font-style:italic}

.eyebrow{
  font-family:var(--sans);
  text-transform:uppercase;
  letter-spacing:.32em;
  font-size:.72rem;
  font-weight:400;
  color:var(--gold-deep);
  margin-bottom:1rem;
}

/* ============ Buttons ============ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  font-family:var(--sans);font-weight:400;font-size:.82rem;
  letter-spacing:.14em;text-transform:uppercase;
  padding:.95rem 1.8rem;border-radius:100px;
  transition:.3s ease;cursor:pointer;border:1px solid transparent;
}
.btn--solid{background:var(--ink);color:var(--cream)}
.btn--solid:hover{background:var(--gold-deep);transform:translateY(-2px)}
.btn--ghost{border-color:var(--ink);color:var(--ink)}
.btn--ghost:hover{background:var(--ink);color:var(--cream)}
.btn--gold{background:var(--gold);color:#241d11;font-weight:500;box-shadow:0 12px 30px -12px rgba(180,138,78,.7)}
.btn--gold:hover{background:#c99a5c;transform:translateY(-2px)}
.btn--gold .btn__arrow{margin-left:.6rem;transition:transform .3s}
.btn--gold:hover .btn__arrow{transform:translateX(4px)}

/* ============ Utility bar ============ */
.ubar{background:var(--ink);color:var(--cream-2);font-size:.76rem;letter-spacing:.06em}
.ubar__in{display:flex;align-items:center;gap:.6rem;height:38px}
.ubar__item{color:var(--cream-2);opacity:.85;transition:.2s}
a.ubar__item:hover{opacity:1;color:#fff}
.ubar__sep{opacity:.4}
.ubar__grow{flex:1}
.ubar__hours{color:var(--sand)}
@media(max-width:640px){.ubar__hours{display:none}}

/* ============ Header ============ */
.head{
  position:sticky;top:0;z-index:50;
  background:rgba(251,248,243,.82);
  backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line);
}
.head__in{display:flex;align-items:center;justify-content:space-between;height:82px}
.brand{display:flex;flex-direction:column;line-height:1}
.brand__mark{font-family:var(--serif);font-size:1.55rem;font-weight:600;letter-spacing:.02em}
.brand__mark em{color:var(--gold-deep);font-style:italic;font-weight:600}
.brand__tld{color:var(--ink-soft);font-weight:400}
.brand__sub{font-size:.64rem;letter-spacing:.28em;text-transform:uppercase;color:var(--ink-soft);margin-top:.45rem}
.nav{display:flex;align-items:center;gap:2rem}
.nav a{font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);transition:.25s;position:relative}
.nav a:not(.nav__cta):hover{color:var(--ink)}
.nav a:not(.nav__cta)::after{content:"";position:absolute;left:0;bottom:-6px;height:1px;width:0;background:var(--gold-deep);transition:.3s}
.nav a:not(.nav__cta):hover::after{width:100%}
.nav__cta{padding:.6rem 1.3rem;border:1px solid var(--ink);border-radius:100px;color:var(--ink)!important}
.nav__cta:hover{background:var(--ink);color:var(--cream)!important}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.burger span{width:26px;height:2px;background:var(--ink);transition:.3s}
.burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

@media(max-width:900px){
  .nav{
    position:fixed;inset:82px 0 auto 0;flex-direction:column;gap:0;
    background:var(--paper);border-bottom:1px solid var(--line);
    padding:1rem 28px 1.6rem;transform:translateY(-140%);transition:.4s cubic-bezier(.4,0,.2,1);
    box-shadow:var(--shadow);align-items:stretch;
  }
  .nav.open{transform:translateY(0)}
  .nav a{padding:1rem 0;border-bottom:1px solid var(--line);text-align:center}
  .nav__cta{margin-top:1rem;padding:1rem;text-align:center}
  .burger{display:flex}
}

/* ============ Hero ============ */
.hero{position:relative;overflow:hidden;background:var(--cream)}
.hero__bg{
  position:absolute;inset:0;
  background:
    radial-gradient(60% 80% at 78% 20%, rgba(180,138,78,.20), transparent 60%),
    radial-gradient(50% 70% at 12% 90%, rgba(169,179,160,.28), transparent 60%),
    linear-gradient(160deg,#f7f2ea 0%,#efe6d8 100%);
}
.hero__bg::after{
  content:"";position:absolute;inset:0;opacity:.5;
  background:repeating-linear-gradient(115deg,rgba(255,255,255,0) 0 34px,rgba(255,255,255,.35) 34px 35px);
  -webkit-mask:radial-gradient(70% 90% at 80% 10%,#000,transparent 70%);
          mask:radial-gradient(70% 90% at 80% 10%,#000,transparent 70%);
}
.hero__in{position:relative;display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2rem,5vw,4.5rem);align-items:center;
  padding:clamp(3rem,7vw,5.5rem) 28px clamp(2.5rem,4vw,3.5rem)}
.hero__title{font-size:clamp(2.8rem,6.4vw,5.2rem);margin:.4rem 0 1.5rem;letter-spacing:-.01em}
.hero__title em{color:var(--gold-deep)}
.hero__lead{max-width:34rem;font-size:1.1rem;color:var(--ink-soft)}
.hero__actions{display:flex;gap:1rem;flex-wrap:wrap;margin:2.2rem 0 0}

.hero__figure{position:relative}
.hero__figure img{width:100%;height:min(34rem,58vh);object-fit:cover;border-radius:calc(var(--r) + 6px);box-shadow:var(--shadow)}
.hero__card{position:absolute;left:-14px;bottom:26px;background:var(--paper);border:1px solid var(--line);
  border-radius:14px;padding:1rem 1.3rem;display:flex;flex-direction:column;box-shadow:var(--shadow)}
.hero__card-k{font-size:.66rem;letter-spacing:.24em;text-transform:uppercase;color:var(--gold-deep)}
.hero__card-v{font-family:var(--serif);font-size:1.15rem;font-weight:600;margin-top:.15rem}

.hero__meta{position:relative;display:flex;justify-content:center;gap:2.6rem;flex-wrap:wrap;
  padding:2rem 28px clamp(2.5rem,5vw,4rem);
  margin-top:clamp(1.5rem,3vw,2.5rem);border-top:1px solid var(--line);max-width:var(--wrap);
  margin-left:auto;margin-right:auto;text-align:center}
.hero__meta div{display:flex;flex-direction:column;align-items:center}
.hero__meta strong{font-family:var(--serif);font-size:1.7rem;font-weight:600;color:var(--ink)}
.hero__meta span{font-size:.82rem;color:var(--ink-soft);letter-spacing:.03em}
@media(max-width:860px){
  .hero__in{grid-template-columns:1fr;padding-bottom:1.5rem}
  .hero__figure{order:-1}
  .hero__figure img{height:16rem}
  .hero__card{display:none}
}

/* ============ Strip ============ */
.strip{background:var(--ink);color:var(--cream)}
.strip__in{padding:clamp(3rem,6vw,4.5rem) 28px;text-align:center}
.strip__lead{font-family:var(--serif);font-size:clamp(1.5rem,3.2vw,2.2rem);font-weight:400;line-height:1.4;max-width:52rem;margin:0 auto;font-style:italic}
.strip__lead em{color:var(--sand)}

/* ============ Sections ============ */
.section{padding:clamp(4.5rem,8vw,7rem) 0}
.section--alt{background:var(--cream)}
.shead{max-width:40rem;margin:0 auto clamp(2.5rem,5vw,4rem);text-align:center}
.shead__lead{color:var(--ink-soft);margin-top:1rem;font-size:1.05rem}

.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
@media(max-width:900px){.grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.grid{grid-template-columns:1fr}}

.card{
  background:var(--paper);border:1px solid var(--line);border-radius:var(--r);
  padding:2.4rem 2rem;transition:.35s ease;position:relative;overflow:hidden;
}
.card::before{content:"";position:absolute;left:0;top:0;height:3px;width:100%;background:var(--tint,var(--sand));opacity:0;transition:.35s}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:transparent}
.card:hover::before{opacity:1}
.card__ic{width:56px;height:56px;color:var(--gold-deep);margin-bottom:1.3rem}
.card__ic svg{width:100%;height:100%}
.card h3{margin-bottom:.6rem;display:flex;align-items:center;gap:.6rem;flex-wrap:wrap}
.card p{color:var(--ink-soft);font-size:.98rem}
.card--feat{background:linear-gradient(165deg,#fff,var(--cream))}
.tag{font-family:var(--sans);font-size:.6rem;letter-spacing:.16em;text-transform:uppercase;background:var(--gold);color:#fff;padding:.28rem .6rem;border-radius:100px;font-weight:500}

/* ============ Kussens feature ============ */
.feat{background:var(--cream);padding:clamp(4.5rem,8vw,7rem) 0;overflow:hidden}
.feat__in{display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(2.5rem,6vw,5rem);align-items:center}
.feat__art{position:relative;border-radius:var(--r);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow)}
.feat__art img{width:100%;height:min(32rem,60vh);object-fit:cover;display:block}
.feat__txt h2{margin:.3rem 0 1.4rem}
.feat__txt>p{color:var(--ink-soft);font-size:1.06rem;max-width:34rem}
.ticks{list-style:none;margin:1.8rem 0 2.2rem;display:grid;gap:.9rem}
.ticks li{position:relative;padding-left:2rem;color:var(--ink)}
.ticks li::before{content:"";position:absolute;left:0;top:.55em;width:1.1rem;height:.55rem;border-left:2px solid var(--gold-deep);border-bottom:2px solid var(--gold-deep);transform:rotate(-45deg)}
@media(max-width:820px){.feat__in{grid-template-columns:1fr}.feat__art{order:-1}.feat__art img{height:18rem}}

/* ============ Merken ============ */
.brands{display:grid;grid-template-columns:1fr 1fr;gap:1.4rem;max-width:56rem;margin:0 auto}
.bcard{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:2.6rem;text-align:center;transition:.35s}
.bcard:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.bcard h3{font-size:1.7rem;margin-bottom:.7rem}
.bcard p{color:var(--ink-soft)}
@media(max-width:640px){.brands{grid-template-columns:1fr}}

/* ============ Promo ============ */
.promo{
  display:grid;grid-template-columns:1.6fr 1fr;gap:2.5rem;align-items:center;
  background:var(--ink);color:var(--cream);border-radius:calc(var(--r) + 6px);
  padding:clamp(2.5rem,5vw,4rem);overflow:hidden;position:relative;
}
.promo::before{content:"";position:absolute;inset:0;background:radial-gradient(60% 120% at 90% 10%,rgba(180,138,78,.35),transparent 60%)}
.promo__txt{position:relative}
.promo__txt .eyebrow{color:var(--sand)}
.promo__txt h2{color:var(--cream);margin-bottom:1rem}
.promo__txt p{color:#d9d2c6;margin-bottom:1.8rem;max-width:34rem}
.promo__badge{position:relative;display:grid;place-content:center;justify-items:center;text-align:center;
  width:clamp(11rem,90%,13.5rem);aspect-ratio:1;border-radius:50%;color:var(--sand);margin:0 auto;
  background:radial-gradient(circle at 50% 42%,rgba(180,138,78,.25),rgba(180,138,78,.05) 58%,transparent 72%)}
.promo__badge::before,.promo__badge::after{content:"";position:absolute;border-radius:50%;pointer-events:none}
.promo__badge::before{inset:5%;border:1px solid var(--gold)}
.promo__badge::after{inset:12%;border:1px dashed rgba(200,163,104,.55)}
.promo__badge>span{position:relative;max-width:74%}
.promo__badge-top{text-transform:uppercase;letter-spacing:.24em;font-size:.58rem;color:var(--sand)}
.promo__badge-big{font-family:var(--serif);font-size:2.7rem;font-weight:600;color:var(--gold);
  line-height:.9;margin:.35rem 0;letter-spacing:.02em;text-shadow:0 0 34px rgba(180,138,78,.45)}
.promo__badge-bot{text-transform:uppercase;letter-spacing:.14em;font-size:.66rem;color:#e0d8ca}
@media(max-width:720px){.promo{grid-template-columns:1fr}.promo__badge{margin-top:1.5rem}}

/* ============ Gallery ============ */
.gallery{display:grid;grid-template-columns:1.15fr 1fr;grid-template-rows:1fr 1fr;gap:1.2rem;height:min(38rem,80vw)}
.gallery__item{margin:0;overflow:hidden;border-radius:var(--r);border:1px solid var(--line)}
.gallery__item img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .8s cubic-bezier(.2,.7,.2,1)}
.gallery__item:hover img{transform:scale(1.05)}
.gallery__item--tall{grid-row:1 / span 2}
@media(max-width:640px){
  .gallery{grid-template-columns:1fr 1fr;grid-template-rows:auto;height:auto}
  .gallery__item{height:12rem}
  .gallery__item--tall{grid-column:1 / -1;height:16rem;grid-row:auto}
}

/* ============ Band ============ */
.band{position:relative;height:min(34rem,60vh)}
.band__img{position:absolute;inset:0;background-size:cover;background-position:center;filter:brightness(.55)}
.band__quote{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;text-align:center;padding:2rem}
.band__quote p{font-family:var(--serif);font-style:italic;color:#fff;font-size:clamp(1.7rem,4vw,3rem);line-height:1.35;max-width:40rem;text-shadow:0 2px 30px rgba(0,0,0,.4)}

/* ============ Story ============ */
.story{padding:clamp(4.5rem,8vw,7rem) 0;background:var(--cream)}
.story__in{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(2.5rem,6vw,5rem);align-items:center}
.story__figure{border-radius:var(--r);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow)}
.story__figure img{width:100%;height:min(32rem,60vh);object-fit:cover;display:block}
.story__body h2{margin:.3rem 0 1.4rem}
.story__body>p{color:var(--ink-soft);font-size:1.06rem;margin-bottom:1.1rem;max-width:38rem}
.story__stats{display:flex;gap:1rem;flex-wrap:wrap;margin-top:2rem}
.stat{flex:1;min-width:8rem;display:flex;flex-direction:column;gap:.2rem;padding:1.3rem 1.4rem;background:var(--paper);border:1px solid var(--line);border-radius:var(--r)}
.stat strong{font-family:var(--serif);font-size:2.2rem;font-weight:600;color:var(--gold-deep);line-height:1}
.stat span{color:var(--ink-soft);font-size:.86rem;letter-spacing:.02em}
@media(max-width:820px){.story__in{grid-template-columns:1fr}.story__figure{order:-1}.story__figure img{height:18rem}}

/* ============ Visit ============ */
.visit{padding:clamp(4.5rem,8vw,7rem) 0;background:var(--ink);color:var(--cream)}
.visit__in{display:grid;grid-template-columns:1.5fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:stretch}
.visit__info .eyebrow{color:var(--sand)}
.visit__info h2{color:var(--cream);margin-bottom:.8rem}
.visit__lead{color:#cfc8bb;margin-bottom:2.4rem}
.visit__cols{display:grid;grid-template-columns:1fr 1fr;gap:2.5rem}
.visit__cols h3{color:var(--sand);font-size:1rem;text-transform:uppercase;letter-spacing:.14em;margin-bottom:1rem;font-family:var(--sans);font-weight:500}
.contact{color:#e4ded3;line-height:1.9}
.contact a{border-bottom:1px solid rgba(255,255,255,.25);transition:.2s}
.contact a:hover{color:#fff;border-color:var(--sand)}
.hours{width:100%;border-collapse:collapse;font-size:.94rem}
.hours td{padding:.5rem 0;border-bottom:1px solid rgba(255,255,255,.1);color:#e4ded3}
.hours td:last-child{text-align:right;color:#fff}
.hours .closed{color:#8f887c}
@media(max-width:520px){.visit__cols{grid-template-columns:1fr;gap:2rem}}

.visit__map{
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.6rem;
  background:radial-gradient(70% 80% at 50% 30%,#2c2822,#1a1713);
  border:1px solid rgba(255,255,255,.12);border-radius:var(--r);padding:2.5rem;text-align:center;
  transition:.35s;min-height:16rem;
}
.visit__map:hover{border-color:var(--gold);transform:translateY(-4px)}
.map__pin{width:54px;height:54px;color:var(--gold)}
.map__pin svg{width:100%;height:100%}
.map__label{text-transform:uppercase;letter-spacing:.16em;font-size:.78rem;color:var(--sand)}
.map__addr{color:#cfc8bb;font-size:.9rem}
@media(max-width:820px){.visit__in{grid-template-columns:1fr}}

/* ============ Footer ============ */
.foot{background:#17140f;color:#cbc3b6}
.foot__in{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:2.5rem;padding:clamp(3rem,6vw,4.5rem) 28px 2.5rem;max-width:var(--wrap);margin:0 auto}
.foot__brand .brand__mark{color:var(--cream);font-size:1.4rem}
.foot__brand .brand__tld{color:#8f887c}
.foot__brand p{margin-top:1rem;font-size:.9rem;line-height:1.8}
.foot__nav{display:flex;flex-direction:column;gap:.7rem}
.foot__nav a{font-size:.9rem;color:#cbc3b6;transition:.2s}
.foot__nav a:hover{color:var(--sand)}
.foot__contact{display:flex;flex-direction:column;gap:.7rem;font-size:.9rem}
.foot__contact a:hover{color:var(--sand)}
.foot__bar{display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;padding:1.6rem 28px;border-top:1px solid rgba(255,255,255,.08);font-size:.78rem;color:#8f887c;max-width:var(--wrap);margin:0 auto}
@media(max-width:720px){.foot__in{grid-template-columns:1fr 1fr}.foot__brand{grid-column:1/-1}}

/* ============ Reveal ============ */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}html{scroll-behavior:auto}}
