:root{
  --green-900:#101a14;
  --green-800:#152419;
  --green-700:#1d3024;
  --green-600:#234032;
  --green-500:#2f5340;
  --olive:#6f7e3c;
  --mustard:#cba23f;
  --mustard-300:#e0c074;
  --mustard-600:#a8842c;
  --cream:#f5efe0;
  --cream-200:#ece2cd;
  --ink:#19231b;
  --line:rgba(20,32,26,.14);
  --serif:"Fraunces",Georgia,serif;
  --sans:"Hanken Grotesk",system-ui,sans-serif;
  --shadow:0 24px 60px -28px rgba(16,26,20,.55);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);
  background:var(--cream);
  color:var(--ink);
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
/* subtle paper grain */
body::before{
  content:"";position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.05;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%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)'/%3E%3C/svg%3E");
  mix-blend-mode:multiply;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
section{position:relative;z-index:2;scroll-margin-top:96px}
.wrap{width:min(1180px,92%);margin-inline:auto}
.eyebrow{
  font-family:var(--sans);font-weight:700;font-size:.78rem;letter-spacing:.28em;
  text-transform:uppercase;color:var(--mustard-600);display:inline-flex;align-items:center;gap:.7rem;
}
.eyebrow.light{color:var(--mustard-300)}
.eyebrow::before,.eyebrow::after{content:"";width:26px;height:1px;background:currentColor;opacity:.7}
.eyebrow.solo::after{display:none}
h1,h2,h3{font-family:var(--serif);line-height:1.04;font-weight:900;letter-spacing:-.01em}
.btn{
  display:inline-flex;align-items:center;gap:.6rem;font-family:var(--sans);font-weight:700;
  font-size:.95rem;letter-spacing:.01em;padding:.95rem 1.7rem;border-radius:100px;cursor:pointer;
  border:1.5px solid transparent;position:relative;overflow:hidden;transition:transform .35s cubic-bezier(.2,.8,.2,1),box-shadow .35s,color .35s;
  z-index:0;white-space:nowrap;
}
.btn svg{width:18px;height:18px}
.btn-primary{background:var(--mustard);color:var(--green-900)}
.btn-primary::after{content:"";position:absolute;inset:0;background:var(--green-700);transform:translateY(101%);transition:transform .4s cubic-bezier(.2,.8,.2,1);z-index:-1}
.btn-primary:hover{color:var(--cream);transform:translateY(-3px);box-shadow:0 16px 30px -14px rgba(16,26,20,.6)}
.btn-primary:hover::after{transform:translateY(0)}
.btn-ghost{background:transparent;border-color:currentColor}
.btn-ghost::after{content:"";position:absolute;inset:0;background:var(--mustard);transform:translateY(101%);transition:transform .4s cubic-bezier(.2,.8,.2,1);z-index:-1}
.btn-ghost:hover{color:var(--green-900);transform:translateY(-3px);border-color:var(--mustard)}
.btn-ghost:hover::after{transform:translateY(0)}
.back-top{
  position:fixed;right:clamp(16px,3vw,28px);bottom:clamp(16px,3vw,28px);z-index:90;
  width:46px;height:46px;border:1px solid rgba(203,162,63,.55);border-radius:50%;
  display:grid;place-items:center;background:var(--green-800);color:var(--mustard-300);
  box-shadow:0 18px 38px -22px rgba(16,26,20,.85);cursor:pointer;
  opacity:0;pointer-events:none;transform:translateY(12px);
  transition:opacity .25s,transform .25s,background .25s,color .25s;
}
.back-top.show{opacity:1;pointer-events:auto;transform:translateY(0)}
.back-top:hover{background:var(--mustard);color:var(--green-900)}
.back-top svg{width:20px;height:20px}
.cookie-consent{
  position:fixed;
  left:clamp(14px,3vw,28px);
  right:clamp(14px,3vw,28px);
  bottom:clamp(14px,3vw,28px);
  z-index:160;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  max-width:860px;
  margin-inline:auto;
  padding:1rem 1.1rem;
  color:var(--cream);
  background:rgba(16,26,20,.96);
  border:1px solid rgba(203,162,63,.42);
  border-radius:18px;
  box-shadow:0 24px 60px -28px rgba(0,0,0,.85);
  opacity:0;
  pointer-events:none;
  transform:translateY(16px);
  transition:opacity .25s,transform .25s;
}
.cookie-consent.show{opacity:1;pointer-events:auto;transform:translateY(0)}
.cookie-consent p{max-width:56ch;font-size:.92rem;color:rgba(245,239,224,.78)}
.cookie-consent strong{display:block;color:var(--mustard-300);font-family:var(--serif);font-size:1.08rem}
.cookie-actions{display:flex;gap:.6rem;flex:none}
.cookie-actions button{
  border:1px solid rgba(245,239,224,.22);
  border-radius:999px;
  padding:.72rem 1rem;
  color:var(--cream);
  background:transparent;
  font:inherit;
  font-weight:800;
  cursor:pointer;
}
.cookie-actions .cookie-accept{border-color:var(--mustard);background:var(--mustard);color:var(--green-900)}
.cookie-actions button:hover{transform:translateY(-1px)}

/* ---------- top bar ---------- */
.topbar{
  background:var(--green-900);color:var(--cream-200);font-size:.82rem;font-weight:500;
  position:relative;z-index:60;letter-spacing:.02em;
}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:.55rem 0;flex-wrap:wrap}
.topbar a{display:inline-flex;align-items:center;gap:.45rem;transition:color .3s}
.topbar a:hover{color:var(--mustard-300)}
.topbar svg{width:14px;height:14px;color:var(--mustard)}
.topbar .dot{opacity:.4}

/* ---------- header ---------- */
header{
  position:sticky;top:0;z-index:50;transition:background .4s,box-shadow .4s,padding .4s;
  background:rgba(245,239,224,.0);padding:.6rem 0;
}
header.scrolled{background:rgba(244,238,222,.92);backdrop-filter:blur(10px);box-shadow:0 10px 30px -22px rgba(16,26,20,.6);padding:.2rem 0}
/* menu page sits on cream, so the header needs a solid base from the start */
header.solid{background:rgba(244,238,222,.92);backdrop-filter:blur(10px);box-shadow:0 10px 30px -22px rgba(16,26,20,.6)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:1.5rem}
.brand{display:flex;align-items:center;gap:.85rem;cursor:pointer}
.brand .badge{width:54px;height:54px;flex:none;transition:transform .5s cubic-bezier(.2,.8,.2,1)}
.brand:hover .badge{transform:rotate(-8deg) scale(1.05)}
.brand-text small{display:block;font-family:var(--sans);font-weight:700;font-size:.62rem;letter-spacing:.34em;text-transform:uppercase;color:var(--mustard-600)}
.brand-text strong{font-family:var(--serif);font-weight:900;font-size:1.32rem;color:var(--green-700);letter-spacing:-.02em;line-height:1}
.navlinks{display:flex;align-items:center;gap:2rem;list-style:none}
.navlinks a{font-weight:600;font-size:.94rem;color:var(--green-700);position:relative;padding:.2rem 0}
.navlinks a::after{content:"";position:absolute;left:0;bottom:-2px;height:2px;width:0;background:var(--mustard);transition:width .35s cubic-bezier(.2,.8,.2,1)}
.navlinks a:hover::after,.navlinks a.active::after{width:100%}
.nav-cta{display:flex;align-items:center;gap:1rem}
.burger{display:none;width:46px;height:46px;border:1.5px solid var(--green-600);border-radius:12px;background:transparent;cursor:pointer;position:relative;z-index:120}
.burger span{position:absolute;left:11px;right:11px;height:2px;background:var(--green-700);border-radius:2px;transition:.4s cubic-bezier(.2,.8,.2,1)}
.burger span:nth-child(1){top:15px}
.burger span:nth-child(2){top:22px}
.burger span:nth-child(3){top:29px}
body.menu-open .burger span:nth-child(1){top:22px;transform:rotate(45deg)}
body.menu-open .burger span:nth-child(2){opacity:0}
body.menu-open .burger span:nth-child(3){top:22px;transform:rotate(-45deg)}

/* mobile menu panel */
.mobile-menu{
  position:fixed;inset:0;z-index:110;background:var(--green-800);
  display:flex;flex-direction:column;justify-content:center;padding:2rem 9%;
  clip-path:circle(0 at calc(100% - 46px) 46px);transition:clip-path .6s cubic-bezier(.76,0,.24,1);
}
body.menu-open .mobile-menu{clip-path:circle(150% at calc(100% - 46px) 46px)}
.mobile-menu a{
  font-family:var(--serif);font-weight:900;font-size:clamp(2rem,9vw,3rem);color:var(--cream);
  padding:.35rem 0;border-bottom:1px solid rgba(245,239,224,.12);opacity:0;transform:translateY(18px);
  transition:opacity .5s,transform .5s,color .3s;display:flex;align-items:center;justify-content:space-between;
}
.mobile-menu a:hover{color:var(--mustard-300)}
.mobile-menu a span{font-family:var(--sans);font-size:.85rem;font-weight:700;color:var(--mustard);opacity:.6}
body.menu-open .mobile-menu a{opacity:1;transform:translateY(0)}
body.menu-open .mobile-menu a:nth-child(1){transition-delay:.18s}
body.menu-open .mobile-menu a:nth-child(2){transition-delay:.24s}
body.menu-open .mobile-menu a:nth-child(3){transition-delay:.3s}
body.menu-open .mobile-menu a:nth-child(4){transition-delay:.36s}
body.menu-open .mobile-menu a:nth-child(5){transition-delay:.42s}
body.menu-open .mobile-menu a:nth-child(6){transition-delay:.48s}
.mobile-foot{margin-top:2.2rem;color:var(--cream-200);font-size:.9rem;opacity:0;transition:opacity .5s .55s}
body.menu-open .mobile-foot{opacity:.8}
.mobile-foot a{color:var(--mustard-300);font-weight:700}

/* ---------- hero ---------- */
.hero{
  background:radial-gradient(120% 90% at 80% 0%,var(--green-600) 0%,var(--green-800) 55%,var(--green-900) 100%);
  color:var(--cream);position:relative;overflow:hidden;padding:clamp(3rem,7vw,6rem) 0 clamp(4rem,8vw,7rem);
}
.hero::after{content:"";position:absolute;inset:0;background-image:radial-gradient(rgba(203,162,63,.14) 1px,transparent 1px);background-size:26px 26px;opacity:.5;pointer-events:none}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2rem,5vw,4rem);align-items:center;position:relative;z-index:3}
.hero h1{font-size:clamp(2.7rem,6.4vw,5rem);color:var(--cream);margin:1.3rem 0 1.2rem}
.hero h1 em{font-style:italic;font-weight:500;color:var(--mustard-300)}
.hero p.lead{font-size:1.12rem;color:rgba(245,239,224,.82);max-width:34ch;margin-bottom:2rem}
.hero-cta{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:2.3rem}
.rating{display:flex;align-items:center;gap:.9rem;flex-wrap:wrap}
.rating b{font-family:var(--serif);font-size:1.25rem;color:var(--cream)}
.rating span{font-size:.88rem;color:rgba(245,239,224,.7)}

.hero-visual{position:relative;display:flex;justify-content:center}
.arch{
  width:min(420px,85%);aspect-ratio:3/4;border-radius:50% 50% 14px 14px/64% 64% 14px 14px;
  overflow:hidden;border:8px solid var(--mustard);box-shadow:var(--shadow);position:relative;
  background:var(--green-700);
}
.arch img{width:100%;height:100%;object-fit:cover;transition:transform 8s ease}
.hero:hover .arch img{transform:scale(1.08)}
.arch::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(16,26,20,.45));}
.float-badge{
  position:absolute;background:var(--cream);color:var(--green-700);border-radius:18px;padding:.85rem 1.1rem;
  box-shadow:var(--shadow);font-weight:700;display:flex;align-items:center;gap:.7rem;font-size:.9rem;z-index:4;
}
.float-badge svg{width:30px;height:30px;color:var(--mustard-600)}
.fb-1{bottom:6%;left:-4%;animation:floaty 5s ease-in-out infinite}
.fb-2{top:8%;right:-3%;animation:floaty 6s ease-in-out infinite reverse}
.fb-1 .num{font-family:var(--serif);font-size:1.4rem;color:var(--green-700);line-height:1}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
.leaf{position:absolute;color:var(--olive);opacity:.5;z-index:2}
.leaf.l1{top:-30px;left:-30px;width:150px;transform:rotate(-20deg)}
.leaf.l2{bottom:-40px;right:-30px;width:160px;transform:rotate(150deg)}

/* ---------- star rating (fractional, reusable) ---------- */
/* Built by JS from <span class="stars" data-rating="4.4"></span>.
   A dim "base" row of 5 stars sits behind a clipped golden "fill" row. */
.stars{position:relative;display:inline-flex;width:max-content;line-height:0;vertical-align:middle}
.stars .layer{display:inline-flex;gap:2px;pointer-events:none}
.stars .layer svg{width:19px;height:19px;flex:none}
.stars .base{color:rgba(203,162,63,.26)}
.stars .fill{position:absolute;top:0;left:0;overflow:hidden;white-space:nowrap;color:var(--mustard)}

/* ---------- marquee ---------- */
.marquee{background:var(--mustard);color:var(--green-900);padding:.95rem 0;overflow:hidden;position:relative;z-index:3;border-top:3px solid var(--green-900);border-bottom:3px solid var(--green-900)}
.marquee-track{display:flex;width:max-content;animation:scroll 28s linear infinite;gap:0}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee-track span{font-family:var(--serif);font-weight:900;font-size:1.15rem;font-style:italic;display:inline-flex;align-items:center;gap:1.6rem;padding-right:1.6rem;text-transform:uppercase;letter-spacing:.02em}
.marquee-track span::after{content:"\2726";font-style:normal;font-size:.8rem}
@keyframes scroll{to{transform:translateX(-50%)}}

/* ---------- generic section heading ---------- */
.sec-head{text-align:center;max-width:640px;margin:0 auto clamp(2.5rem,5vw,3.6rem)}
.sec-head h2{font-size:clamp(2.1rem,4.6vw,3.3rem);margin:1rem 0 .8rem;color:var(--green-700)}
.sec-head h1{font-size:clamp(2.4rem,6vw,4.2rem);margin:1rem 0 .8rem;color:var(--green-700)}
.sec-head p{color:rgba(25,35,27,.72);font-size:1.05rem}
.on-dark .sec-head h2{color:var(--cream)}
.on-dark .sec-head p{color:rgba(245,239,224,.78)}

/* ---------- about ---------- */
.about{padding:clamp(4rem,8vw,7rem) 0;background:var(--cream)}
.about-grid{display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.about-img{position:relative}
.about-img .frame{border-radius:18px;overflow:hidden;box-shadow:var(--shadow);aspect-ratio:4/5}
.about-img .frame img{width:100%;height:100%;object-fit:cover;transition:transform .9s ease}
.about-img:hover .frame img{transform:scale(1.06)}
.about-img .tag{position:absolute;bottom:-22px;right:-14px;background:var(--green-700);color:var(--cream);padding:1.1rem 1.5rem;border-radius:16px;box-shadow:var(--shadow);font-family:var(--serif);font-style:italic;font-size:1.05rem;max-width:200px;line-height:1.2}
.about-text h2{font-size:clamp(2rem,4.4vw,3.1rem);color:var(--green-700);margin:1rem 0 1.3rem}
.about-text p{color:rgba(25,35,27,.8);margin-bottom:1.1rem;font-size:1.04rem}
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:2rem;border-top:1px solid var(--line);padding-top:1.8rem}
.stat b{font-family:var(--serif);font-size:clamp(1.8rem,4vw,2.6rem);color:var(--mustard-600);display:block;line-height:1}
.stat span{font-size:.82rem;font-weight:600;text-transform:uppercase;letter-spacing:.12em;color:rgba(25,35,27,.6)}

/* ---------- subpages ---------- */
.subpage-hero{
  padding:clamp(4rem,8vw,7rem) 0;
  color:var(--cream);
  background:
    radial-gradient(circle at 82% 8%,rgba(203,162,63,.16),transparent 30%),
    linear-gradient(145deg,var(--green-700),var(--green-900));
  overflow:hidden;
}
.subpage-hero .wrap{max-width:900px}
.subpage-hero h1{
  color:var(--cream);
  font-size:clamp(2.6rem,6vw,4.8rem);
  margin:1rem 0;
}
.subpage-hero p{
  max-width:64ch;
  color:rgba(245,239,224,.78);
  font-size:1.08rem;
}
.page-cards{padding:clamp(4rem,8vw,6rem) 0;background:var(--cream-200)}
.card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.1rem}
.soft-card{
  display:block;
  padding:1.5rem;
  background:rgba(255,252,245,.78);
  border:1px solid var(--line);
  border-radius:18px;
  box-shadow:0 18px 45px -38px rgba(16,26,20,.75);
}
.soft-card h3{font-size:1.25rem;color:var(--green-700);margin-bottom:.5rem}
.soft-card p{color:rgba(25,35,27,.68)}
.source-card{transition:transform .3s,border-color .3s,box-shadow .3s}
.source-card:hover{
  transform:translateY(-4px);
  border-color:rgba(168,132,44,.45);
  box-shadow:0 22px 50px -34px rgba(16,26,20,.85);
}

/* ---------- menu / specialties (teaser on home) ---------- */
.menu{padding:clamp(4rem,8vw,7rem) 0;background:linear-gradient(180deg,var(--green-700),var(--green-800));color:var(--cream);position:relative;overflow:hidden}
.menu::before{content:"";position:absolute;inset:0;background-image:radial-gradient(rgba(203,162,63,.1) 1px,transparent 1px);background-size:30px 30px;opacity:.45}
.menu-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.4rem;position:relative;z-index:2}
.dish{
  background:rgba(245,239,224,.05);border:1px solid rgba(245,239,224,.12);border-radius:18px;padding:1.8rem;
  transition:transform .45s cubic-bezier(.2,.8,.2,1),background .45s,border-color .45s;position:relative;overflow:hidden;
}
.dish::before{content:"";position:absolute;top:0;left:0;width:100%;height:3px;background:var(--mustard);transform:scaleX(0);transform-origin:left;transition:transform .5s}
.dish:hover{transform:translateY(-8px);background:rgba(245,239,224,.09);border-color:rgba(203,162,63,.4)}
.dish:hover::before{transform:scaleX(1)}
.dish .ic{width:46px;height:46px;border-radius:12px;background:rgba(203,162,63,.16);display:grid;place-items:center;color:var(--mustard-300);margin-bottom:1.1rem}
.dish .ic svg{width:24px;height:24px}
.dish h3{font-size:1.4rem;color:var(--cream);margin-bottom:.2rem}
.dish .kind{font-size:.72rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--mustard)}
.dish p{color:rgba(245,239,224,.74);font-size:.96rem;margin-top:.7rem}
.menu-cta{text-align:center;margin-top:2.8rem;position:relative;z-index:2}
.menu-note{text-align:center;margin-top:1.4rem;position:relative;z-index:2;color:rgba(245,239,224,.7);font-size:.95rem}
.menu-note a{color:var(--mustard-300);font-weight:700;border-bottom:1px solid currentColor}

/* ---------- gallery ---------- */
.gallery{padding:clamp(4rem,8vw,7rem) 0;background:var(--cream-200)}
.gallery-page{min-height:70vh}
.gal-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:220px;gap:1rem}
.gallery-full-grid{grid-auto-rows:240px}
.gal-item{position:relative;overflow:hidden;border-radius:14px;cursor:pointer;box-shadow:0 12px 30px -20px rgba(16,26,20,.5)}
.gal-item img{width:100%;height:100%;object-fit:cover;transition:transform .7s cubic-bezier(.2,.8,.2,1)}
.gal-item:hover img{transform:scale(1.1)}
.gal-item::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(16,26,20,.75));opacity:0;transition:opacity .4s}
.gal-item:hover::after{opacity:1}
.gal-cap{position:absolute;left:1.1rem;bottom:1rem;color:var(--cream);font-family:var(--serif);font-style:italic;font-size:1.1rem;z-index:2;transform:translateY(12px);opacity:0;transition:.45s}
.gal-item:hover .gal-cap{transform:translateY(0);opacity:1}
.gal-item.big{grid-column:span 2;grid-row:span 2}
.gal-item.tall{grid-row:span 2}
.gallery-more{text-align:center;margin-top:2rem}
.gallery-empty,.menu-empty{
  padding:1.2rem;
  color:rgba(25,35,27,.72);
  background:rgba(255,252,245,.72);
  border:1px solid var(--line);
  border-radius:14px;
  text-align:center;
}
.menu-empty{color:var(--cream);background:rgba(245,239,224,.08);border-color:rgba(245,239,224,.16)}
.menu-empty a{color:var(--mustard-300);font-weight:800}

/* lightbox */
.lightbox{position:fixed;inset:0;z-index:200;background:rgba(16,26,20,.92);display:none;align-items:center;justify-content:center;padding:4%;cursor:zoom-out}
.lightbox.open{display:flex;animation:fade .3s}
.lightbox img{max-width:90%;max-height:88vh;border-radius:12px;border:6px solid var(--mustard);box-shadow:var(--shadow)}
.lightbox .x{position:absolute;top:24px;right:28px;color:var(--cream);font-size:2.4rem;line-height:1;cursor:pointer;font-family:var(--serif)}
@keyframes fade{from{opacity:0}to{opacity:1}}

/* ---------- reviews ---------- */
.reviews{
  padding:clamp(4rem,8vw,7rem) 0;
  color:var(--cream);
  background:
    radial-gradient(circle at 12% 20%,rgba(203,162,63,.15),transparent 28%),
    linear-gradient(145deg,var(--green-700),var(--green-900));
  position:relative;
  overflow:hidden;
}
.reviews::before{
  content:"";
  position:absolute;
  inset:0;
  opacity:.32;
  background-image:radial-gradient(rgba(224,192,116,.17) 1px,transparent 1px);
  background-size:30px 30px;
}
.reviews-layout{
  display:grid;
  grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr);
  gap:clamp(2rem,6vw,5rem);
  align-items:center;
  position:relative;
  z-index:2;
}
.review-score{
  padding:clamp(1.5rem,4vw,2.8rem);
  background:rgba(245,239,224,.055);
  border:1px solid rgba(245,239,224,.14);
  border-radius:24px;
  box-shadow:0 28px 70px -42px rgba(0,0,0,.8);
}
.score-row{display:flex;align-items:center;gap:1.25rem;margin:1.5rem 0}
.score-row>strong{
  color:var(--mustard-300);
  font-family:var(--serif);
  font-size:clamp(4rem,9vw,6.4rem);
  font-weight:900;
  letter-spacing:-.06em;
  line-height:.78;
}
.score-row .stars{margin-bottom:.45rem}
.score-row p{
  color:rgba(245,239,224,.58);
  font-size:.78rem;
  font-weight:700;
  letter-spacing:.04em;
}
.review-score h1,
.review-score h2{
  max-width:12ch;
  color:var(--cream);
  font-size:clamp(2rem,4.5vw,3.35rem);
  line-height:1.02;
}
.score-copy{
  max-width:46ch;
  margin:1.2rem 0 1.6rem;
  color:rgba(245,239,224,.72);
  font-size:.98rem;
}
.review-link{
  display:inline-flex;
  align-items:center;
  gap:.6rem;
  color:var(--mustard-300);
  border-bottom:1px solid rgba(224,192,116,.5);
  font-size:.9rem;
  font-weight:800;
  transition:color .25s,border-color .25s;
}
.review-link:hover{color:var(--cream);border-color:var(--cream)}
.review-link svg{width:17px;height:17px}
.review-themes{display:grid}
.review-theme{
  display:grid;
  grid-template-columns:auto minmax(0,1fr);
  gap:1.25rem;
  padding:clamp(1.3rem,3vw,1.8rem) 0;
  border-bottom:1px solid rgba(245,239,224,.15);
}
.review-theme:first-child{border-top:1px solid rgba(245,239,224,.15)}
.theme-number{
  color:var(--mustard);
  font-family:var(--serif);
  font-size:.82rem;
  font-weight:900;
  letter-spacing:.08em;
}
.review-theme h3{
  color:var(--cream);
  font-size:clamp(1.25rem,2.7vw,1.7rem);
  line-height:1.15;
}
.review-theme p{
  max-width:54ch;
  margin-top:.55rem;
  color:rgba(245,239,224,.65);
  font-size:.93rem;
}

/* ---------- contact ---------- */
.contact{padding:clamp(4rem,8vw,7rem) 0;background:var(--cream)}
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(2rem,4vw,3.5rem);align-items:stretch}
.info-card{background:var(--green-700);color:var(--cream);border-radius:22px;padding:clamp(1.8rem,3.5vw,2.8rem);box-shadow:var(--shadow)}
.info-card h2{color:var(--cream);font-size:clamp(1.9rem,4vw,2.6rem);margin:.8rem 0 1.6rem}
.info-row{display:flex;gap:1rem;align-items:flex-start;padding:1.05rem 0;border-bottom:1px solid rgba(245,239,224,.13)}
.info-row:last-of-type{border-bottom:none}
.info-row .ic{width:42px;height:42px;flex:none;border-radius:11px;background:rgba(203,162,63,.18);display:grid;place-items:center;color:var(--mustard-300)}
.info-row .ic svg{width:21px;height:21px}
.info-row h4{font-family:var(--sans);font-weight:700;font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--mustard);margin-bottom:.25rem}
.info-row p,.info-row a{font-size:1.02rem;color:rgba(245,239,224,.9)}
.info-row a:hover{color:var(--mustard-300)}
.hours-list{list-style:none;font-size:.98rem;width:100%}
.hours-list li{display:flex;justify-content:space-between;gap:1rem;padding:.28rem 0;color:rgba(245,239,224,.88)}
.hours-list li.today{color:var(--mustard-300);font-weight:700}
.hours-list li.closed span:last-child{color:rgba(245,239,224,.45)}
.info-card .btn{margin-top:1.8rem}
.map-card{border-radius:22px;overflow:hidden;box-shadow:var(--shadow);min-height:420px;position:relative;border:4px solid var(--green-700)}
.map-card iframe{width:100%;height:100%;border:0;position:absolute;inset:0;filter:saturate(.9)}

/* ---------- footer ---------- */
footer{background:var(--green-900);color:rgba(245,239,224,.75);padding:clamp(3.5rem,6vw,5rem) 0 2rem;position:relative;z-index:2;overflow:hidden}
footer::before{content:"";position:absolute;inset:0;background-image:radial-gradient(rgba(203,162,63,.08) 1px,transparent 1px);background-size:32px 32px;opacity:.5}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:2.5rem;position:relative;z-index:2;padding-bottom:3rem;border-bottom:1px solid rgba(245,239,224,.12)}
.foot-brand .badge{width:64px;height:64px;margin-bottom:1.1rem}
.foot-brand strong{font-family:var(--serif);font-weight:900;font-size:1.5rem;color:var(--cream);display:block}
.foot-brand p{margin-top:.9rem;max-width:32ch;font-size:.96rem}
.foot-col h5{font-family:var(--serif);font-size:1.15rem;color:var(--mustard-300);margin-bottom:1.1rem;font-weight:900}
.foot-col ul{list-style:none}
.foot-col li{padding:.32rem 0;font-size:.96rem}
.foot-col a{transition:color .3s;display:inline-flex;align-items:center;gap:.5rem}
.foot-col a:hover{color:var(--mustard-300)}
.foot-col svg{width:15px;height:15px;color:var(--mustard);flex:none}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;padding-top:1.6rem;position:relative;z-index:2;font-size:.85rem}
.foot-bottom .heart{color:var(--mustard-300)}
.socials{display:flex;gap:.7rem}
.socials a{width:38px;height:38px;border:1px solid rgba(245,239,224,.2);border-radius:50%;display:grid;place-items:center;transition:.35s}
.socials a:hover{background:var(--mustard);color:var(--green-900);border-color:var(--mustard);transform:translateY(-3px)}
.socials svg{width:17px;height:17px}

/* ---------- reveal animations ---------- */
.reveal{opacity:0;transform:translateY(34px);transition:opacity .8s cubic-bezier(.2,.8,.2,1),transform .8s cubic-bezier(.2,.8,.2,1);transition-delay:var(--d,0s)}
.reveal.show{opacity:1;transform:none}
.hero .reveal{transition-duration:.9s}

/* ---------- responsive ---------- */
@media(max-width:900px){
  .navlinks{display:none}
  .nav-cta .btn{display:none}
  .burger{display:block}
  .hero-grid{grid-template-columns:1fr;text-align:center}
  .hero p.lead{margin-inline:auto}
  .hero-cta,.rating{justify-content:center}
  .hero-visual{margin-top:1rem;order:-1}
  .arch{width:min(330px,80%)}
  .about-grid{grid-template-columns:1fr;gap:3rem}
  .about-img{max-width:440px;margin-inline:auto;width:100%}
  .contact-grid{grid-template-columns:1fr}
  .reviews-layout{grid-template-columns:1fr}
  .review-score h2{max-width:18ch}
  .map-card{min-height:340px}
  .foot-grid{grid-template-columns:1fr 1fr;gap:2rem}
  .gal-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:170px}
  .gal-item.big{grid-column:span 2;grid-row:span 1}
}
@media(max-width:560px){
  .topbar .wrap{justify-content:center}
  .topbar .hide-sm{display:none}
  .subpage-hero{text-align:center}
  .subpage-hero .eyebrow{justify-content:center}
  .card-grid{grid-template-columns:1fr}
  .cookie-consent{display:block;text-align:left}
  .cookie-actions{margin-top:.9rem}
  .cookie-actions button{flex:1}
  .stats{grid-template-columns:1fr 1fr;gap:1.4rem}
  .foot-grid{grid-template-columns:1fr}
  .gal-grid{grid-template-columns:1fr;grid-auto-rows:200px}
  .gal-item.big,.gal-item.tall{grid-column:auto;grid-row:auto}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition-duration:.01ms!important}
  .reveal{opacity:1;transform:none}
}
