/* =====================================================================
   Het Rechthuis aan den Amstel — site.css
   Design system: refined "waterside" — deep Amstel green + warm sand,
   brass-gold hairline accents, Cormorant Garamond display + Mulish UI.
   ===================================================================== */

:root{
  /* palette */
  --ink:        #232a22;   /* near-black, green-tinted text */
  --forest:     #1f3a30;   /* deep Amstel green — primary dark */
  --forest-2:   #2b4d40;
  --moss:       #5f7a3f;   /* refined nod to the brand green (accents) */
  --brass:      #b08d57;   /* warm gold from the brand docs */
  --brass-deep: #957338;   /* gold that passes contrast on light bg */
  --cream:      #f6f1e6;   /* page background */
  --sand:       #ece2cf;   /* warm panel */
  --paper:      #fbf8f1;   /* cards / lighter */
  --line:       #e2d8c4;   /* hairline on light */
  --muted:      #6c7065;   /* secondary text */
  --white:      #ffffff;

  --maxw: 1240px;
  --gutter: clamp(20px, 5vw, 64px);
  --radius: 4px;
  --shadow-sm: 0 1px 2px rgba(31,58,48,.06), 0 6px 18px rgba(31,58,48,.06);
  --shadow-md: 0 12px 40px rgba(31,58,48,.14);
  --ease: cubic-bezier(.22,.61,.36,1);

  --ff-serif: "Cormorant Garamond", Georgia, "Times New Roman", serif;
  --ff-sans:  "Mulish", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

*,*::before,*::after{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
body{
  margin:0;
  background:var(--cream);
  color:var(--ink);
  font-family:var(--ff-sans);
  font-size:17px;
  line-height:1.65;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; }
::selection{ background:var(--moss); color:#fff; }

/* ---------- typography ---------- */
h1,h2,h3,h4{ font-family:var(--ff-serif); font-weight:600; line-height:1.06;
  margin:0; color:var(--ink); letter-spacing:.005em; }
h1{ font-size:clamp(2.6rem, 6.2vw, 5rem); font-weight:500; }
h2{ font-size:clamp(2rem, 4.4vw, 3.4rem); font-weight:500; }
h3{ font-size:clamp(1.4rem, 2.4vw, 1.9rem); }
p{ margin:0 0 1.1em; }
p:last-child{ margin-bottom:0; }

.eyebrow{
  font-family:var(--ff-sans);
  font-size:.72rem; font-weight:700;
  letter-spacing:.26em; text-transform:uppercase;
  color:var(--brass-deep);
  display:inline-flex; align-items:center; gap:.7em;
  margin:0 0 1.1rem;
}
.eyebrow::before{ content:""; width:34px; height:1px; background:var(--brass); display:inline-block; }
.eyebrow.center{ justify-content:center; }
.eyebrow.center::after{ content:""; width:34px; height:1px; background:var(--brass); display:inline-block; }
.eyebrow.light{ color:#d8c39a; }
.eyebrow.light::before,.eyebrow.light.center::after{ background:rgba(216,195,154,.6); }

.lead{ font-size:1.18rem; line-height:1.7; color:#41463d; }
.muted{ color:var(--muted); }
.serif-quote{ font-family:var(--ff-serif); font-weight:500;
  font-size:clamp(1.6rem,3.2vw,2.6rem); line-height:1.3; font-style:italic; }

/* ---------- layout ---------- */
.wrap{ width:100%; max-width:var(--maxw); margin-inline:auto;
  padding-inline:var(--gutter); }
.section{ padding-block:clamp(64px, 9vw, 130px); }
.section--tight{ padding-block:clamp(48px,6vw,80px); }
.grid{ display:grid; gap:clamp(28px,4vw,64px); }
@media(min-width:880px){ .grid-2{ grid-template-columns:1fr 1fr; align-items:center; } }
.center{ text-align:center; }
.measure{ max-width:62ch; }
.measure-narrow{ max-width:48ch; }
.center .measure,.center .measure-narrow{ margin-inline:auto; }

/* ---------- buttons ---------- */
.btn{ --bg:var(--forest); --fg:#fff;
  display:inline-flex; align-items:center; justify-content:center; gap:.6em;
  padding:.95em 1.7em; background:var(--bg); color:var(--fg);
  font-family:var(--ff-sans); font-weight:700; font-size:.82rem;
  letter-spacing:.12em; text-transform:uppercase; border:1px solid var(--bg);
  border-radius:var(--radius); cursor:pointer; white-space:nowrap;
  transition:transform .35s var(--ease), background .3s var(--ease), color .3s var(--ease), border-color .3s var(--ease);
}
.btn:hover{ transform:translateY(-2px); }
.btn--solid:hover{ background:var(--forest-2); border-color:var(--forest-2); }
.btn--gold{ --bg:var(--brass); --fg:#3a2f18; border-color:var(--brass); }
.btn--gold:hover{ background:var(--brass-deep); border-color:var(--brass-deep); color:#fff; }
.btn--ghost{ background:transparent; color:var(--ink); border-color:rgba(35,42,34,.28); }
.btn--ghost:hover{ background:var(--ink); color:#fff; border-color:var(--ink); }
.btn--ghost-light{ background:transparent; color:#fff; border-color:rgba(255,255,255,.5); }
.btn--ghost-light:hover{ background:#fff; color:var(--forest); border-color:#fff; }
.btn-row{ display:flex; flex-wrap:wrap; gap:14px; }

.textlink{ font-weight:700; font-size:.8rem; letter-spacing:.12em; text-transform:uppercase;
  color:var(--forest); display:inline-flex; align-items:center; gap:.55em; }
.textlink::after{ content:"→"; transition:transform .3s var(--ease); }
.textlink:hover::after{ transform:translateX(5px); }
.textlink.light{ color:#fff; }

/* ---------- header / nav ---------- */
.site-header{ position:fixed; inset:0 0 auto 0; z-index:60;
  transition:background .4s var(--ease), box-shadow .4s var(--ease), transform .4s var(--ease); }
.topbar{ background:var(--forest); color:#e9e2d2; font-size:.74rem;
  letter-spacing:.06em; transition:height .4s var(--ease), opacity .3s, padding .4s; }
.topbar .wrap{ display:flex; justify-content:space-between; align-items:center;
  gap:16px; min-height:38px; white-space:nowrap; }
@media(max-width:680px){ .topbar{ display:none; } }
.topbar a{ color:#e9e2d2; }
.topbar a:hover{ color:#fff; }
.topbar .sep{ opacity:.4; margin:0 .6em; }

.navbar{ background:transparent; transition:inherit; }
.navbar .wrap{ display:flex; align-items:center; justify-content:space-between;
  gap:20px; min-height:84px; }
.brand{ display:flex; align-items:center; gap:12px; flex-shrink:0; }
.brand img{ height:44px; width:auto; transition:height .4s var(--ease), filter .4s; }
.brand .brand-chip{ background:#fff; padding:7px 12px; border-radius:3px; line-height:0;
  box-shadow:0 2px 10px rgba(0,0,0,.12); }

.nav-links{ display:flex; align-items:center; gap:clamp(14px,2vw,30px); list-style:none; margin:0; padding:0; }
.nav-links a{ font-size:.82rem; font-weight:600; letter-spacing:.04em; color:#fff;
  padding:6px 0; position:relative; transition:color .3s; white-space:nowrap; }
.nav-links a::after{ content:""; position:absolute; left:0; right:100%; bottom:-2px;
  height:1.5px; background:var(--brass); transition:right .3s var(--ease); }
.nav-links a:hover::after,.nav-links a.active::after{ right:0; }
.nav-cta{ display:flex; align-items:center; gap:10px; }
.nav-links .m-cta{ display:none; }
@media(max-width:940px){ .nav-links .m-cta{ display:block; margin-top:14px; } }

/* solid state (scrolled, or inner pages) */
.site-header.is-solid .navbar,.site-header.solid .navbar{ background:var(--paper);
  box-shadow:0 1px 0 var(--line), var(--shadow-sm); }
.site-header.is-solid .nav-links a,.site-header.solid .nav-links a{ color:var(--ink); }
.site-header.is-solid .brand img,.site-header.solid .brand img{ height:40px; }
.site-header.is-solid .brand .brand-chip,.site-header.solid .brand .brand-chip{
  background:transparent; box-shadow:none; padding:0; }
.site-header.is-solid .navbar .btn--ghost-light,.site-header.solid .navbar .btn--ghost-light{
  color:var(--ink); border-color:rgba(35,42,34,.28); }
.site-header.is-solid .navbar .btn--ghost-light:hover,.site-header.solid .navbar .btn--ghost-light:hover{
  background:var(--ink); color:#fff; }

.nav-toggle{ display:none; background:none; border:0; cursor:pointer; padding:8px; color:#fff; }
.site-header.is-solid .nav-toggle,.site-header.solid .nav-toggle{ color:var(--ink); }
.nav-toggle svg{ width:26px; height:26px; }

/* mobile nav */
@media(max-width:940px){
  .nav-links{ position:fixed; inset:0 0 0 auto; width:min(82vw,360px);
    background:var(--forest); flex-direction:column; align-items:flex-start;
    justify-content:center; gap:6px; padding:80px 40px; transform:translateX(100%);
    transition:transform .45s var(--ease); box-shadow:var(--shadow-md); }
  .nav-links.open{ transform:translateX(0); }
  .nav-links a{ color:#f3ecdd !important; font-size:1.3rem; font-family:var(--ff-serif); font-weight:500; }
  .nav-links a::after{ display:none; }
  .nav-toggle{ display:inline-flex; z-index:70; }
  .nav-cta .btn span{ display:none; }
  .nav-desktop-cta{ display:none; }
}

/* ---------- hero ---------- */
.hero{ position:relative; min-height:100svh; display:flex; align-items:flex-end;
  color:#fff; overflow:hidden; }
.hero__bg{ position:absolute; inset:0; z-index:0; }
.hero__bg img{ width:100%; height:100%; object-fit:cover; }
.hero__bg::after{ content:""; position:absolute; inset:0;
  background:
    linear-gradient(180deg, rgba(18,28,22,.5) 0%, rgba(18,28,22,.16) 34%, rgba(18,28,22,.5) 66%, rgba(16,25,20,.82) 100%),
    linear-gradient(90deg, rgba(16,25,20,.5) 0%, rgba(16,25,20,.12) 46%, rgba(16,25,20,0) 70%); }
.hero__inner{ position:relative; z-index:2; padding-bottom:clamp(56px,10vh,120px);
  padding-top:160px; }
.hero h1{ color:#fff; max-width:14ch; text-shadow:0 2px 30px rgba(0,0,0,.25); }
.hero__sub{ font-size:1.15rem; max-width:46ch; margin-top:1.3rem; color:#f4efe4;
  text-shadow:0 1px 18px rgba(12,20,15,.55); }
.hero .btn-row{ margin-top:2.2rem; }
.scroll-hint{ position:absolute; left:50%; bottom:26px; transform:translateX(-50%); z-index:2;
  color:#fff; font-size:.68rem; letter-spacing:.25em; text-transform:uppercase; opacity:.85;
  display:flex; flex-direction:column; align-items:center; gap:8px; }
.scroll-hint::after{ content:""; width:1px; height:34px; background:rgba(255,255,255,.6);
  animation:scrollpulse 2.2s var(--ease) infinite; }
@keyframes scrollpulse{ 0%{transform:scaleY(0);transform-origin:top} 50%{transform:scaleY(1);transform-origin:top} 51%{transform-origin:bottom} 100%{transform:scaleY(0);transform-origin:bottom} }

/* ---------- panels / colors ---------- */
.bg-cream{ background:var(--cream); }
.bg-paper{ background:var(--paper); }
.bg-sand{ background:var(--sand); }
.bg-forest{ background:var(--forest); color:#ece6d8; }
.bg-forest h1,.bg-forest h2,.bg-forest h3{ color:#fff; }
.bg-forest .lead{ color:#d6d2c4; }

/* ---------- figure / media ---------- */
.media{ position:relative; overflow:hidden; border-radius:var(--radius); }
.media img{ width:100%; height:100%; object-fit:cover; transition:transform 1.1s var(--ease); }
.media--tall{ aspect-ratio:4/5; }
.media--wide{ aspect-ratio:3/2; }
.media--square{ aspect-ratio:1/1; }
.media.hoverable:hover img{ transform:scale(1.05); }
.media__tag{ position:absolute; left:18px; bottom:18px; z-index:2; color:#fff;
  font-size:.72rem; font-weight:700; letter-spacing:.14em; text-transform:uppercase;
  background:rgba(31,58,48,.72); padding:7px 13px; border-radius:3px; backdrop-filter:blur(4px); }
.framed{ position:relative; }
.framed::after{ content:""; position:absolute; inset:14px; border:1px solid rgba(255,255,255,.5);
  pointer-events:none; }

/* ---------- pillar cards ---------- */
.pillars{ display:grid; gap:24px; }
@media(min-width:760px){ .pillars{ grid-template-columns:repeat(3,1fr); } }
.pillar{ background:var(--paper); border:1px solid var(--line); border-radius:var(--radius);
  overflow:hidden; display:flex; flex-direction:column;
  transition:transform .4s var(--ease), box-shadow .4s var(--ease); }
.pillar:hover{ transform:translateY(-6px); box-shadow:var(--shadow-md); }
.pillar .media{ aspect-ratio:3/2; border-radius:0; }
.pillar:hover .media img{ transform:scale(1.06); }
.pillar__body{ padding:28px 26px 30px; display:flex; flex-direction:column; gap:12px; flex:1; }
.pillar__body h3{ font-size:1.55rem; }
.pillar__body p{ color:var(--muted); font-size:.98rem; }
.pillar__body .textlink{ margin-top:auto; }

/* ---------- stat / info rows ---------- */
.facts{ display:grid; gap:18px 40px; grid-template-columns:repeat(auto-fit,minmax(150px,1fr));
  border-top:1px solid var(--line); padding-top:30px; margin-top:34px; }
.fact .n{ font-family:var(--ff-serif); font-size:2.6rem; line-height:1; color:var(--forest); }
.fact .l{ font-size:.78rem; letter-spacing:.12em; text-transform:uppercase; color:var(--muted); margin-top:8px; }

/* feature list */
.ticks{ list-style:none; margin:0; padding:0; display:grid; gap:12px; }
.ticks li{ display:flex; gap:12px; align-items:flex-start; }
.ticks li::before{ content:""; flex:0 0 auto; width:8px; height:8px; margin-top:9px;
  border:1.5px solid var(--brass); border-radius:50%; }

/* price chips */
.pricechips{ display:flex; flex-wrap:wrap; gap:10px; }
.pricechip{ display:inline-flex; align-items:baseline; gap:.5em; white-space:nowrap;
  border:1px solid var(--line); background:var(--paper); border-radius:var(--radius);
  padding:10px 16px; font-size:.9rem; line-height:1.3; }
.pricechip b{ font-family:var(--ff-serif); font-size:1.12rem; color:var(--forest); }

/* ---------- full-bleed band ---------- */
.band{ position:relative; color:#fff; }
.band__bg{ position:absolute; inset:0; }
.band__bg img{ width:100%; height:100%; object-fit:cover; }
.band__bg::after{ content:""; position:absolute; inset:0; background:rgba(20,31,25,.6); }
.band__inner{ position:relative; z-index:2; }
.band h2,.band h3,.band h1{ color:#fff; text-shadow:0 2px 22px rgba(10,16,12,.45); }
.band .serif-quote{ color:#fff; }

/* ---------- quote ---------- */
.quote-mark{ font-family:var(--ff-serif); font-size:5rem; line-height:.6; color:var(--brass); display:block; margin-bottom:.1em; }

/* ---------- footer ---------- */
.site-footer{ background:var(--forest); color:#cbc8bb; padding-block:clamp(56px,7vw,90px) 30px; font-size:.95rem; }
.site-footer a:hover{ color:#fff; }
.footer-grid{ display:grid; gap:40px; grid-template-columns:1.4fr 1fr 1fr; }
@media(max-width:760px){ .footer-grid{ grid-template-columns:1fr 1fr; } .footer-brandcol{ grid-column:1/-1; } }
.footer-brandcol .brand-chip{ background:#fff; display:inline-block; padding:10px 14px; border-radius:3px; }
.footer-col h4{ color:#fff; font-family:var(--ff-sans); font-size:.78rem; letter-spacing:.18em;
  text-transform:uppercase; margin-bottom:16px; font-weight:700; }
.footer-col ul{ list-style:none; margin:0; padding:0; display:grid; gap:9px; }
.footer-hours{ display:grid; grid-template-columns:auto auto; gap:4px 18px; justify-content:start; }
.footer-bottom{ border-top:1px solid rgba(255,255,255,.12); margin-top:44px; padding-top:22px;
  display:flex; flex-wrap:wrap; justify-content:space-between; gap:12px; font-size:.82rem; color:#9aa093; }

/* ---------- forms ---------- */
.field{ display:flex; flex-direction:column; gap:7px; margin-bottom:18px; }
.field label{ font-size:.74rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); }
.field input,.field select,.field textarea{ font-family:inherit; font-size:1rem; color:var(--ink);
  background:var(--white); border:1px solid var(--line); border-radius:var(--radius);
  padding:13px 15px; transition:border-color .25s, box-shadow .25s; }
.field input:focus,.field select:focus,.field textarea:focus{ outline:none;
  border-color:var(--moss); box-shadow:0 0 0 3px rgba(95,122,63,.16); }
.field textarea{ min-height:120px; resize:vertical; }
.form-row{ display:grid; gap:18px; }
@media(min-width:620px){ .form-row.cols-2{ grid-template-columns:1fr 1fr; } .form-row.cols-3{ grid-template-columns:1fr 1fr 1fr; } }
.form-card{ background:var(--paper); border:1px solid var(--line); border-radius:var(--radius);
  padding:clamp(24px,4vw,44px); box-shadow:var(--shadow-sm); }

/* ---------- gallery ---------- */
.gallery{ columns:3 280px; column-gap:16px; }
.gallery .media{ margin:0 0 16px; break-inside:avoid; cursor:pointer; }
.gallery .media img{ transition:transform .8s var(--ease), filter .4s; }
.gallery .media:hover img{ transform:scale(1.04); }

.lightbox{ position:fixed; inset:0; z-index:200; background:rgba(16,22,18,.94);
  display:none; align-items:center; justify-content:center; padding:5vmin; }
.lightbox.open{ display:flex; }
.lightbox img{ max-width:92vw; max-height:90vh; object-fit:contain; box-shadow:var(--shadow-md); }
.lightbox__close,.lightbox__nav{ position:absolute; background:none; border:0; color:#fff; cursor:pointer; }
.lightbox__close{ top:24px; right:30px; font-size:2.2rem; line-height:1; }
.lightbox__nav{ top:50%; transform:translateY(-50%); font-size:3rem; padding:10px 20px; opacity:.7; }
.lightbox__nav:hover{ opacity:1; }
.lightbox__nav.prev{ left:2vw; } .lightbox__nav.next{ right:2vw; }

/* ---------- page hero (inner pages) ---------- */
.page-hero{ position:relative; min-height:62vh; display:flex; align-items:flex-end; color:#fff; overflow:hidden; }
.page-hero__bg{ position:absolute; inset:0; }
.page-hero__bg img{ width:100%; height:100%; object-fit:cover; }
.page-hero__bg::after{ content:""; position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(20,30,24,.5) 0%, rgba(20,30,24,.15) 40%, rgba(20,30,24,.7) 100%); }
.page-hero__inner{ position:relative; z-index:2; padding-bottom:clamp(40px,7vh,80px); padding-top:150px; }
.page-hero h1{ color:#fff; }
.page-hero .crumbs{ font-size:.76rem; letter-spacing:.16em; text-transform:uppercase; color:#e6dcc6; margin-bottom:14px; }
.page-hero .crumbs a:hover{ color:#fff; }

/* ---------- reveal animation ---------- */
.reveal{ opacity:0; transform:translateY(26px); transition:opacity .9s var(--ease), transform .9s var(--ease); }
.reveal.in{ opacity:1; transform:none; }
@media(prefers-reduced-motion:reduce){ .reveal{ opacity:1; transform:none; } *{ scroll-behavior:auto; } }

/* ---------- misc ---------- */
.divider{ width:100%; height:1px; background:var(--line); border:0; margin:0; }
.tag-list{ display:flex; flex-wrap:wrap; gap:8px; }
.tag{ font-size:.72rem; letter-spacing:.1em; text-transform:uppercase; font-weight:700;
  color:var(--brass-deep); border:1px solid var(--line); border-radius:40px; padding:6px 14px; background:var(--paper); }
.overline-card{ background:var(--paper); border:1px solid var(--line); border-left:3px solid var(--brass);
  border-radius:var(--radius); padding:22px 24px; }

/* ---------- menukaart ---------- */
.segmented{ display:inline-flex; background:var(--sand); border:1px solid var(--line);
  border-radius:50px; padding:5px; gap:4px; }
.segmented button{ border:0; background:transparent; cursor:pointer; padding:11px 26px;
  border-radius:50px; font-family:var(--ff-sans); font-weight:700; font-size:.8rem;
  letter-spacing:.1em; text-transform:uppercase; color:var(--muted);
  transition:background .3s var(--ease), color .3s var(--ease); }
.segmented button.active{ background:var(--forest); color:#fff; box-shadow:var(--shadow-sm); }
.segmented button:hover:not(.active){ color:var(--ink); }

.menu-viewer{ display:flex; flex-direction:column; align-items:center; gap:24px;
  max-width:780px; margin-inline:auto; }
.menu-page{ display:block; border-radius:var(--radius); box-shadow:var(--shadow-md);
  background:#fff; border:1px solid var(--line); }
.menu-loading{ display:flex; align-items:center; gap:14px; color:var(--muted);
  padding:80px 0; font-size:.95rem; }
.spinner{ width:22px; height:22px; border:2.5px solid var(--line); border-top-color:var(--forest);
  border-radius:50%; animation:spin .8s linear infinite; }
@keyframes spin{ to{ transform:rotate(360deg); } }

.specials{ display:grid; gap:18px; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); }
.special{ background:var(--paper); border:1px solid var(--line); border-radius:var(--radius);
  padding:24px 22px; display:flex; flex-direction:column; gap:8px; }
.special .day{ font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; color:var(--brass-deep); font-weight:700; }
.special h3{ font-size:1.35rem; }
.special .price{ font-family:var(--ff-serif); font-size:1.6rem; color:var(--forest); margin-top:auto; }
.special--feature{ background:var(--forest); color:#ece6d8; border-color:var(--forest); }
.special--feature h3{ color:#fff; } .special--feature .day{ color:#d8c39a; }
.special--feature .price{ color:#fff; }
