/* =====================================================================
   BLOCKS — named UI components
   Each block corresponds to one StreamField block template or shared include.
   ===================================================================== */

/* ====================================================================
   BLOCK — site header + navigation   (includes/site-nav.html)
   ==================================================================== */
.site-header {
  position: sticky; top: 0; z-index: 50;
  background: var(--brick);
  border-bottom: 1px solid var(--hairline);
  transition: box-shadow .2s ease;
}
.site-header.is-scrolled { box-shadow: var(--shadow-soft); }

.site-nav {
  position: relative;
  --cluster-gap: clamp(.75rem, 2vw, 1.75rem);
  min-height: var(--nav-h);
  padding-inline: var(--gutter);
  padding-block: .5rem;
}

.site-nav__brand {
  display: flex; align-items: center; gap: .65rem;
  margin-inline-end: auto;
  color: var(--ink); text-decoration: none;
}
.site-nav__mark { flex: none; color: var(--gold); }
.site-nav__wordmark { display: flex; flex-direction: column; line-height: 1.05; }
.site-nav__name { font-family: var(--font-display); font-size: 1.55rem; letter-spacing: .005em; }
.site-nav__tag {
  font-family: var(--font-body); font-size: .68rem;
  letter-spacing: .15em; text-transform: uppercase; color: var(--ink-soft);
}

.site-nav__links {
  display: flex; align-items: center;
  gap: clamp(.5rem, 1.6vw, 1.6rem);
  margin: 0; padding: 0; list-style: none;
}
.site-nav__link {
  position: relative;
  display: inline-flex; align-items: center; gap: .4rem;
  padding: .45rem .25rem;
  font-family: var(--font-body); font-size: 1rem;
  color: var(--ink); text-decoration: none;
  background: none; border: 0; cursor: pointer;
}
.site-nav__link::after {
  content: ""; position: absolute;
  left: .25rem; right: .25rem; bottom: .12rem;
  height: 1.5px; background: var(--gold);
  transform: scaleX(0); transform-origin: left;
  transition: transform .2s ease;
}
.site-nav__link:hover::after,
.site-nav__link:focus-visible::after { transform: scaleX(1); }
.site-nav__link[aria-current="page"] { color: var(--gold-deep); }
.site-nav__link[aria-current="page"]::after { transform: scaleX(1); }

.site-nav__caret {
  display: inline-block;
  width: .46rem; height: .46rem;
  border-right: 1.5px solid currentColor;
  border-bottom: 1.5px solid currentColor;
  transform: rotate(45deg) translate(-1px, -2px);
  transition: transform .2s ease;
}
.disclosure__trigger[aria-expanded="true"] .site-nav__caret {
  transform: rotate(225deg) translate(-1px, -1px);
}

.disclosure { position: relative; }
.disclosure__panel { display: none; }
.disclosure__panel.is-open { display: block; }

.disclosure__item { display: block; padding: .6rem .7rem; color: var(--ink); text-decoration: none; }
.disclosure__item + .disclosure__item { border-top: 1px solid var(--hairline); }
.disclosure__item:hover,
.disclosure__item:focus-visible { background: var(--brick-shade); }
.disclosure__item[aria-current="page"] { background: var(--brick-shade); }
.disclosure__item[aria-current="page"] .disclosure__item-title { color: var(--gold-deep); }
.disclosure__item-title { display: block; font-family: var(--font-display); font-size: 1.2rem; color: var(--ink); }
.disclosure__item-note { display: block; margin-top: .1rem; font-family: var(--font-body); font-size: .8rem; color: var(--ink-soft); }

.site-nav__lang-btn {
  display: inline-flex; align-items: center; gap: .4rem;
  padding: .42rem .62rem;
  font-family: var(--font-body); font-size: .95rem; letter-spacing: .04em;
  color: var(--ink); background: none; border: 1px solid var(--hairline);
  cursor: pointer; transition: border-color .15s ease;
}
.site-nav__lang-btn:hover { border-color: var(--gold); }
.disclosure__panel--lang { margin: 0; padding: 0; list-style: none; }
.lang__item {
  display: block; padding: .5rem .85rem;
  font-family: var(--font-body); font-size: .95rem;
  color: var(--ink); text-decoration: none;
}
.lang__item:hover, .lang__item:focus-visible { background: var(--brick-shade); }
.lang__item.is-current { color: var(--gold-deep); font-weight: 600; }

.site-nav__book {
  flex: none;
  padding: .62rem 1.3rem;
  background: var(--gold); color: var(--brick);
  font-family: var(--font-body); font-size: 1rem; letter-spacing: .015em;
  text-decoration: none;
  transition: background .15s ease;
}
.site-nav__book:hover { background: var(--gold-deep); }

.site-nav__burger {
  display: none;
  align-items: center; justify-content: center;
  width: 2.75rem; height: 2.75rem; padding: 0;
  background: none; border: 0; cursor: pointer; color: var(--ink);
}
.site-nav__burger-box { position: relative; display: block; width: 1.45rem; height: 1rem; }
.site-nav__burger-box > span,
.site-nav__burger-box > span::before,
.site-nav__burger-box > span::after {
  position: absolute; left: 0;
  width: 100%; height: 1.6px; background: currentColor;
  transition: transform .2s ease, background-color .2s ease;
}
.site-nav__burger-box > span { top: calc(50% - .8px); }
.site-nav__burger-box > span::before { content: ""; top: -.45rem; }
.site-nav__burger-box > span::after  { content: ""; top:  .45rem; }
.site-nav__burger[aria-expanded="true"] .site-nav__burger-box > span { background: transparent; }
.site-nav__burger[aria-expanded="true"] .site-nav__burger-box > span::before { transform: translateY(.45rem) rotate(45deg); }
.site-nav__burger[aria-expanded="true"] .site-nav__burger-box > span::after  { transform: translateY(-.45rem) rotate(-45deg); }

/* ====================================================================
   BLOCK — HeroBlock
   ==================================================================== */
.hero { background: linear-gradient(180deg, rgba(231,220,194,.5), rgba(231,220,194,0) 60%), var(--brick); }
.hero__inner {
  --with-sidebar-gap: var(--space-xl);
  --sidebar-width: 30rem;
  padding-block: var(--space-xl);
}
.hero__kicker { margin-bottom: var(--space-s); }
.hero__title { font-size: clamp(2.5rem, 1.6rem + 4vw, 4.25rem); max-inline-size: 14ch; }
.hero__lede { margin-block: var(--space-s) var(--space-m); max-inline-size: 42ch; font-size: 1.15rem; color: var(--ink-soft); }
.hero__media { position: relative; aspect-ratio: 7 / 6; box-shadow: var(--shadow-card); }
.hero__overlay {
  position: absolute; left: var(--space-m); bottom: var(--space-m);
  background: rgba(251,249,243,.93);
  border: 1px solid var(--hairline);
  padding: var(--space-s) var(--space-m);
  max-width: 22rem;
  backdrop-filter: blur(2px);
}

/* HeroBlock — overlay variant (homepage) */
.hero--overlay .hero__frame {
  position: relative;
  display: grid;
  padding-block: var(--space-l);
}
.hero--overlay .hero__media {
  grid-area: 1 / 1;
  aspect-ratio: auto;
  min-height: clamp(22rem, 42vw, 36rem);
  overflow: hidden;
  isolation: isolate;
}
.hero--overlay .hero__media img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 40%;
  opacity: 0.42;
  z-index: 0;
}
.hero--overlay .hero__media::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 2;
  background: var(--brick-shade);
  mix-blend-mode: hue;
}
.hero--overlay .hero__panel {
  grid-area: 1 / 1;
  align-self: end;
  justify-self: start;
  max-inline-size: min(26rem, calc(100% - var(--space-m) * 2));
  margin: var(--space-m);
  padding: var(--space-s) var(--space-m) var(--space-m);
  background: rgba(251, 249, 243, .95);
  border: 1px solid var(--hairline);
  box-shadow: var(--shadow-soft);
  -webkit-backdrop-filter: blur(2px);
  backdrop-filter: blur(2px);
}
.hero--overlay .hero__kicker { margin-bottom: var(--space-xs); }
.hero--overlay .hero__title { font-size: clamp(1.7rem, 1.25rem + 1.5vw, 2.4rem); max-inline-size: 20ch; }
.hero--overlay .hero__lede { margin-block: var(--space-xs) var(--space-s); font-size: .9rem; max-inline-size: 42ch; }

/* ====================================================================
   BLOCK — ProfileRouterBlock (homepage router, exactly 3 cards)
   ==================================================================== */
.router__head { margin-bottom: var(--space-l); }
.router__title { font-size: clamp(1.9rem, 1.4rem + 1.8vw, 2.6rem); }
.profile-grid { --grid-min: 13rem; --grid-gap: var(--space-m); }

.profile-card {
  display: flex; flex-direction: column;
  background: var(--brick);
  border: 1px solid var(--hairline);
  text-decoration: none; color: inherit;
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.profile-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-card); border-color: var(--sandstone); }
.profile-card__media { aspect-ratio: 3 / 2; }
.profile-card__body { display: flex; flex-direction: column; gap: .5rem; padding: var(--space-s) var(--space-s) var(--space-m); flex: 1; }
.profile-card__title { font-size: 1.45rem; }
.profile-card__note { color: var(--ink-soft); font-size: .95rem; flex: 1; }
.profile-card__cta { margin-top: .35rem; }

/* ====================================================================
   BLOCK — FacilityGridBlock
   ==================================================================== */
.facility-grid {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-m);
  justify-content: center;
  padding: 0; margin: 0; list-style: none;
}
.facility {
  flex: 1 1 8rem;
  max-inline-size: 12rem;
  display: flex; flex-direction: column; align-items: center; gap: .85rem;
  text-align: center;
}
.facility__icon {
  display: grid; place-items: center;
  width: 3rem; height: 3rem;
  color: var(--gold-deep);
}
.facility__icon svg { width: 1.7rem; height: 1.7rem; }
.facility__label { font-family: var(--font-body); font-size: 1rem; color: var(--ink); }

/* ====================================================================
   BLOCK — FeatureBlock (zakelijk differentiator: gastendiner)
   ==================================================================== */
.feature {
  --with-sidebar-gap: var(--space-l);
  --sidebar-width: 24rem;
  --with-sidebar-align: stretch;
}
.feature__media { position: relative; min-height: 18rem; aspect-ratio: 3 / 2; box-shadow: var(--shadow-card); }
.feature__body { display: flex; flex-direction: column; justify-content: center; gap: var(--space-xs); }
.feature__title { font-size: clamp(1.8rem, 1.4rem + 1.6vw, 2.4rem); max-inline-size: 16ch; }
.feature__note { color: var(--ink-soft); }
.feature--accent {
  background: var(--brick-shade);
  border: 1px solid var(--hairline);
  border-top: 2px solid var(--gold);
  padding: var(--space-l);
}

/* FeatureBlock — overlay variant */
.feature--overlay {
  position: relative;
  display: grid;
  padding: 0;
}
.feature--overlay .feature__media {
  grid-area: 1 / 1;
  margin: 0;
  aspect-ratio: auto;
  min-height: clamp(20rem, 40vw, 32rem);
  overflow: hidden;
  isolation: isolate;
}
.feature--overlay .feature__media::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 2;
  background: var(--brick-shade);
  mix-blend-mode: hue;
}
.feature--overlay .feature__body {
  grid-area: 1 / 1;
  align-self: end;
  justify-self: end;
  max-inline-size: min(30rem, calc(100% - var(--space-m) * 2));
  margin: var(--space-m);
  padding: var(--space-m) var(--space-l) var(--space-l);
  background: rgba(251, 249, 243, .95);
  border: 1px solid var(--hairline);
  border-top: 2px solid var(--gold);
  box-shadow: var(--shadow-soft);
  -webkit-backdrop-filter: blur(2px);
  backdrop-filter: blur(2px);
}

/* ====================================================================
   BLOCK — RoomTeaserBlock
   ==================================================================== */
.room-grid { --grid-min: 15rem; --grid-gap: var(--space-m); }
.room-card { display: flex; flex-direction: column; text-decoration: none; color: inherit; }
.room-card__media { aspect-ratio: 16 / 10; margin-bottom: var(--space-s); }
.room-card__title { font-size: 1.5rem; margin-bottom: .3rem; }
.room-card__meta { color: var(--ink-soft); font-size: .95rem; margin-bottom: var(--space-s); }
.room-card__cta { margin-top: auto; }
.room-teaser__foot { margin-top: var(--space-l); text-align: center; }

/* ====================================================================
   BLOCK — GuestQuoteBlock
   ==================================================================== */
.guest-quote { background: var(--brick-shade); }
.guest-quote__inner { padding-block: var(--space-xl); text-align: center; }
.guest-quote blockquote {
  margin: 0 auto; max-inline-size: 36ch;
  font-family: var(--font-display); font-style: italic; font-weight: 500;
  font-size: clamp(1.6rem, 1.2rem + 1.8vw, 2.3rem); line-height: 1.4;
}
.guest-quote cite {
  display: block; margin-top: var(--space-m);
  font-family: var(--font-body); font-style: normal;
  font-size: .78rem; letter-spacing: .16em; text-transform: uppercase; color: var(--ink-soft);
}

/* ====================================================================
   BLOCK — LocationBlock
   ==================================================================== */
.location {
  --sidebar-width: 24rem;
  --with-sidebar-align: stretch;
}
.location__body { display: flex; flex-direction: column; justify-content: center; gap: var(--space-m); }
.location__title { font-size: clamp(1.8rem, 1.4rem + 1.6vw, 2.4rem); max-inline-size: 14ch; }
.location__list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: var(--space-s); }
.location__list li { display: flex; gap: .75rem; align-items: flex-start; }
.location__list svg { flex: none; width: 1.25rem; height: 1.25rem; color: var(--gold); margin-top: .15rem; }
.location__media { position: relative; min-height: 20rem; aspect-ratio: 5 / 3; box-shadow: var(--shadow-card); }
.location__pin {
  position: absolute; inset: 0; display: grid; place-items: center;
  color: var(--gold-deep); pointer-events: none;
}
.location__pin svg { width: 2.25rem; height: 2.25rem; filter: drop-shadow(0 2px 3px rgba(54,50,43,.25)); }

/* ====================================================================
   BLOCK — RichTextCTABlock (prompt card)
   ==================================================================== */
.prompt-card {
  background: var(--brick-shade);
  border: 1px solid var(--hairline);
  padding: var(--space-l);
}
.prompt-card__title { font-size: clamp(1.7rem, 1.3rem + 1.5vw, 2.2rem); margin-bottom: var(--space-s); }
.prompt-card__body { max-inline-size: 54ch; color: var(--ink-soft); margin-bottom: var(--space-m); }

/* ====================================================================
   BLOCK — CTABlock (booking band)
   ==================================================================== */
.cta-band { background: var(--ink); color: var(--brick); }
.cta-band__inner { padding-block: var(--space-xl); text-align: center; }
.cta-band__title {
  font-size: clamp(1.9rem, 1.4rem + 2vw, 2.8rem);
  color: var(--brick); margin-bottom: var(--space-m);
}
.cta-band__note {
  margin-top: var(--space-s);
  font-family: var(--font-mono); font-size: .8rem; letter-spacing: .03em;
  color: rgba(231,220,194,.7);
}

/* ====================================================================
   BLOCK — FooterBlock   (includes/site-footer.html)
   ==================================================================== */
.site-footer { background: var(--brick); color: var(--ink); border-top: 1px solid var(--hairline); }
.site-footer__inner { padding-block: var(--space-xl); }
.site-footer__grid { --grid-min: 13rem; --grid-gap: var(--space-l); }
.site-footer__col h2 {
  font-family: var(--font-body); font-weight: 600;
  font-size: .74rem; letter-spacing: .18em; text-transform: uppercase;
  color: var(--gold-deep);
  margin-bottom: var(--space-s);
}
.site-footer__list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: .55rem; }
.site-footer__list li { color: var(--ink-soft); }
.site-footer a:not(.button) { color: var(--ink); text-decoration: none; transition: color .15s ease; }
.site-footer a:not(.button):hover { color: var(--gold-deep); text-decoration: underline; text-underline-offset: 3px; }
.site-footer__langs { font-family: var(--font-mono); font-size: .85rem; letter-spacing: .06em; color: var(--ink-soft); margin-bottom: var(--space-m); }
.site-footer__langs-list { list-style: none; margin: 0 0 var(--space-m); padding: 0; display: flex; flex-wrap: wrap; gap: .35rem .6rem; }
.site-footer__lang { font-family: var(--font-mono); font-size: .8rem; letter-spacing: .1em; color: var(--ink-soft); text-decoration: none; transition: color .15s ease; }
.site-footer__lang:hover { color: var(--gold-deep); }
.site-footer__lang.is-current { color: var(--gold-deep); font-weight: 600; pointer-events: none; }
.site-footer__bar {
  margin-top: var(--space-l); padding-top: var(--space-m);
  border-top: 1px solid var(--hairline);
  display: flex; align-items: center; justify-content: space-between; gap: 1rem; flex-wrap: wrap;
  font-size: .85rem; color: var(--ink-soft);
}
.site-footer__mark { color: var(--gold); }

/* ====================================================================
   BLOCK — EventListBlock
   ==================================================================== */
.event-list { --stack-gap: 0; list-style: none; margin: 0; padding: 0; }
.event-item {
  display: grid;
  grid-template-columns: 3.5rem 1fr auto;
  gap: var(--space-m);
  align-items: center;
  padding-block: var(--space-m);
  border-bottom: 1px solid var(--hairline);
}
.event-item--next { background: rgba(170,134,56,.06); margin-inline: calc(var(--space-m) * -1); padding-inline: var(--space-m); border-radius: 4px; }
.event-item__month {
  font-family: var(--font-mono); font-size: .8rem; letter-spacing: .1em;
  text-transform: uppercase; color: var(--gold-deep);
  text-align: center;
}
.event-item__body { display: flex; flex-direction: column; gap: .25rem; }
.event-item__title { font-weight: 600; }
.event-item__desc { font-size: .9rem; color: var(--ink-soft); }
.event-item__link { white-space: nowrap; font-size: .875rem; }
