/* ============================================
   RESTAURANT & CAFE TEMPLATE v3.0
   Williamson Automation — $10K quality
   Warm. Alive. Atmospheric. Not AI slop.
   ============================================ */

/* ---------- RESET ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --brand:#B87333;
  --brand-light:#D49050;
  --brand-dark:#8F5A28;
  --brand-glow:rgba(184,115,51,.1);
  --gold:#D4A574;
  --gold-dim:rgba(212,165,116,.08);
  --bg:#FAF6F0;
  --bg-alt:#F0EBE3;
  --bg-dark:#1C1410;
  --bg-darker:#120E0A;
  --card:#fff;
  --text:#2D2622;
  --text-m:#7A6E63;
  --text-dim:#A69E94;
  --border:rgba(139,37,0,.1);
  --border-s:rgba(139,37,0,.06);
  --hf:'Cormorant Garamond',Georgia,serif;
  --bf:'Montserrat',system-ui,sans-serif;
  --ease:cubic-bezier(.22,1,.36,1);
  --ease2:cubic-bezier(.77,0,.175,1);
}

html{-webkit-text-size-adjust:100%}
body{
  font-family:var(--bf);
  font-size:clamp(.95rem,.9rem + .25vw,1.0625rem);
  line-height:1.7;color:var(--text);
  background:var(--bg);
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
::selection{background:var(--brand);color:#FAF6F0}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:none;background:none}

/* ---------- LAYOUT ---------- */
.container{width:min(90%,1160px);margin-inline:auto}
.template-hidden{display:none}

/* ---------- SHARED TYPOGRAPHY ---------- */
.label{
  font-family:var(--bf);font-size:clamp(.65rem,.6rem + .2vw,.72rem);
  font-weight:600;letter-spacing:.2em;text-transform:uppercase;
  color:var(--brand);display:flex;align-items:center;gap:.75rem;margin-bottom:1.25rem;
}
.label::before{content:'';width:28px;height:1px;background:var(--brand);opacity:.5}
.label--light{color:var(--gold)}
.label--light::before{background:var(--gold)}

.section-title{
  font-family:var(--hf);font-weight:300;letter-spacing:-.02em;line-height:1.08;
  font-size:clamp(2.2rem,1.6rem + 2.5vw,4rem);color:var(--text);
}
.section-title em{font-style:italic;font-weight:400}
.section-title--light{color:#FAF6F0}
.section-title--light em{color:var(--gold)}

.ornament{width:90px;height:16px;display:block;margin-top:1.25rem}
.ornament line{stroke:var(--border);stroke-width:1}
.ornament circle{fill:none;stroke:var(--brand);stroke-width:1;opacity:.35}

/* ---------- GRAIN TEXTURE (lightweight CSS pattern) ---------- */
.hero__grain,.reviews__grain,.cta__grain,.foot__grain{
  position:absolute;inset:0;pointer-events:none;z-index:1;opacity:.03;
  background-image:
    radial-gradient(circle at 20% 80%, rgba(255,255,255,.08) 0%, transparent 1%),
    radial-gradient(circle at 80% 20%, rgba(255,255,255,.06) 0%, transparent 1%),
    radial-gradient(circle at 50% 50%, rgba(255,255,255,.04) 0%, transparent 1%);
  background-size:3px 3px, 5px 5px, 7px 7px;
}

/* ---------- SCROLL REVEAL SYSTEM ---------- */
[data-reveal]{opacity:0;transition:opacity .9s var(--ease),transform .9s var(--ease)}
[data-reveal="up"]{transform:translateY(40px)}
[data-reveal="left"]{transform:translateX(-40px)}
[data-reveal="right"]{transform:translateX(40px)}
[data-reveal="fade"]{transform:none}
[data-reveal="clip"]{clip-path:inset(0 100% 0 0);transform:none;transition:clip-path 1.2s var(--ease2),opacity .9s var(--ease)}
[data-reveal].is-visible{opacity:1;transform:none;clip-path:inset(0 0 0 0)}

/* ---------- BUTTONS ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.5rem;
  font-family:var(--bf);font-size:.82rem;font-weight:600;
  padding:.85rem 1.8rem;border-radius:3px;letter-spacing:.03em;
  transition:transform .3s var(--ease),background .4s,border-color .4s,box-shadow .4s;
}
.btn:hover{transform:translateY(-2px)}
.btn--fill{background:var(--brand);color:#fff;box-shadow:0 4px 20px rgba(139,37,0,.25)}
.btn--fill:hover{background:var(--brand-light);box-shadow:0 8px 30px rgba(139,37,0,.35)}
.btn--outline{border:1px solid rgba(250,246,240,.2);color:rgba(250,246,240,.8)}
.btn--outline:hover{border-color:rgba(250,246,240,.5);background:rgba(250,246,240,.05)}

/* ==============================================
   NAV
   ============================================== */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  padding:clamp(1rem,.8rem + .5vw,1.4rem) 0;
  transition:background .5s,backdrop-filter .5s,padding .4s,box-shadow .4s;
}
.nav.scrolled{
  background:rgba(250,246,240,.88);
  backdrop-filter:blur(24px) saturate(1.3);
  -webkit-backdrop-filter:blur(24px) saturate(1.3);
  box-shadow:0 1px 0 var(--border-s);padding:.7rem 0;
}
.nav__inner{display:flex;align-items:center;justify-content:space-between}
.nav__brand{
  font-family:var(--hf);font-size:clamp(1.3rem,1.1rem + .7vw,1.75rem);
  font-weight:500;letter-spacing:-.015em;line-height:1.1;
  transition:color .4s;
}
.nav:not(.scrolled) .nav__brand{color:#fff}
.nav.scrolled .nav__brand{color:var(--text)}

.nav__links{display:none;align-items:center;gap:clamp(1.5rem,1rem + 1.5vw,2.5rem)}
@media(min-width:769px){.nav__links{display:flex}}
.nav__link{
  font-size:.75rem;font-weight:500;text-transform:uppercase;letter-spacing:.12em;
  opacity:.65;transition:opacity .3s;position:relative;
}
.nav__link::after{
  content:'';position:absolute;bottom:-3px;left:0;width:100%;height:1px;
  background:currentColor;transform:scaleX(0);transform-origin:right;
  transition:transform .4s var(--ease2);
}
.nav__link:hover{opacity:1}
.nav__link:hover::after{transform:scaleX(1);transform-origin:left}
.nav:not(.scrolled) .nav__link{color:#fff}
.nav.scrolled .nav__link{color:var(--text)}

.nav__cta{
  display:none;align-items:center;gap:.4rem;
  font-size:.78rem;font-weight:600;color:#fff;
  background:var(--brand);padding:.5rem 1.1rem;border-radius:3px;
  transition:background .3s,transform .2s,box-shadow .3s;
  box-shadow:0 2px 12px rgba(139,37,0,.2);
}
.nav__cta:hover{background:var(--brand-light);transform:translateY(-1px);box-shadow:0 4px 16px rgba(139,37,0,.3)}
@media(min-width:769px){.nav__cta{display:inline-flex}}

/* Hamburger */
.nav__hamburger{display:none;flex-direction:column;gap:5px;padding:8px;z-index:110}
.nav__hamburger span{display:block;width:22px;height:1.5px;background:var(--text);border-radius:2px;transition:transform .3s,opacity .3s}
.nav:not(.scrolled) .nav__hamburger span{background:#fff}
.nav__hamburger.active span:nth-child(1){transform:rotate(45deg) translate(4.5px,4.5px)}
.nav__hamburger.active span:nth-child(2){opacity:0}
.nav__hamburger.active span:nth-child(3){transform:rotate(-45deg) translate(4.5px,-4.5px)}
@media(max-width:768px){.nav__hamburger{display:flex}.nav__cta{display:none}}

/* Mobile drawer */
.nav__drawer{
  position:fixed;inset:0;background:var(--bg);z-index:105;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2.5rem;
  opacity:0;pointer-events:none;transition:opacity .4s;
}
.nav__drawer.open{opacity:1;pointer-events:auto}
.nav__drawer a{
  font-family:var(--hf);font-size:clamp(1.5rem,1.2rem + 1vw,2.2rem);
  font-weight:500;color:var(--text);transition:color .2s;
}
.nav__drawer a:hover{color:var(--brand)}
.nav__drawer-phone{
  font-family:var(--bf) !important;font-size:1rem !important;font-weight:600 !important;
  color:var(--brand) !important;margin-top:1rem;
}

/* ==============================================
   HERO — Cinematic, atmospheric
   ============================================== */
.hero{
  position:relative;min-height:100vh;min-height:100svh;
  display:flex;align-items:flex-end;overflow:hidden;
  padding-bottom:clamp(4rem,3rem + 4vw,8rem);
}
.hero__bg{position:absolute;inset:0}
.hero__img{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  transform:scale(1.08);transition:transform 1.6s var(--ease);
}
.hero.is-loaded .hero__img{transform:scale(1)}

/* Fallback when image token hasn't been replaced */
.hero__img[src*="{{"]{opacity:0}
.hero:has(.hero__img[src*="{{"])>.hero__bg{
  background:linear-gradient(165deg,#3D2418,#2D1810 40%,#1C1410);
}

.hero__overlay{
  position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg,
    rgba(28,20,16,.3) 0%,rgba(28,20,16,.05) 30%,
    rgba(28,20,16,.4) 65%,rgba(28,20,16,.82) 100%);
}

/* Floating ambient glow orbs — soft radial gradients, no blur filter */
.hero__glow{
  position:absolute;border-radius:50%;z-index:0;
  pointer-events:none;
}
.hero__glow--1{
  width:min(60vw,700px);height:min(60vw,700px);
  background:radial-gradient(circle,rgba(212,165,116,.1) 0%,rgba(212,165,116,.03) 40%,transparent 70%);
  top:-15%;left:-12%;
  animation:glowDrift1 12s ease-in-out infinite alternate;
}
.hero__glow--2{
  width:min(50vw,600px);height:min(50vw,600px);
  background:radial-gradient(circle,rgba(139,37,0,.08) 0%,rgba(139,37,0,.02) 40%,transparent 70%);
  bottom:-5%;right:-8%;
  animation:glowDrift2 14s ease-in-out infinite alternate;
}
@keyframes glowDrift1{to{transform:translate(4vw,-3vw)}}
@keyframes glowDrift2{to{transform:translate(-3vw,2vw)}}

.hero__content{position:relative;z-index:3;max-width:800px}

/* Hero entrance — JS-controlled via .hero-show class */
.hero__est,.hero__title,.hero__sub,.hero__btn{
  opacity:0;transform:translateY(24px);
  transition:opacity .8s var(--ease),transform .8s var(--ease);
}
.hero__est.hero-show{opacity:1;transform:none;transition-delay:.15s}
.hero__title.hero-show{opacity:1;transform:none;transition-delay:.3s}
.hero__sub.hero-show{opacity:1;transform:none;transition-delay:.5s}
.hero__btn.hero-show{opacity:1;transform:none;transition-delay:.7s}

.hero__est{
  display:flex;align-items:center;gap:.75rem;
  font-family:var(--bf);font-size:.68rem;font-weight:500;
  text-transform:uppercase;letter-spacing:.22em;
  color:rgba(255,255,255,.55);margin-bottom:clamp(1rem,.5rem + 1vw,1.5rem);
}
.hero__est-line{width:32px;height:1px;background:rgba(255,255,255,.25)}

.hero__title{
  font-family:var(--hf);font-weight:300;
  font-size:clamp(2.8rem,1.5rem + 5.5vw,7rem);
  line-height:.98;letter-spacing:-.03em;color:#fff;
  margin-bottom:clamp(.6rem,.4rem + .5vw,1rem);
}

.hero__sub{
  font-family:var(--hf);font-size:clamp(1rem,.85rem + .5vw,1.35rem);
  font-weight:300;font-style:italic;color:rgba(255,255,255,.6);
  margin-bottom:clamp(1.5rem,1rem + 1vw,2.5rem);max-width:38ch;
}

.hero__btn{
  display:inline-flex;align-items:center;gap:.6rem;
  font-family:var(--bf);font-size:.78rem;font-weight:600;
  text-transform:uppercase;letter-spacing:.14em;color:#fff;
  border:1px solid rgba(255,255,255,.25);padding:.9rem 2rem;
  border-radius:2px;transition:background .4s,border-color .4s,transform .3s;
}
.hero__btn:hover{
  background:rgba(255,255,255,.07);border-color:rgba(255,255,255,.5);
  transform:translateY(-2px);
}

/* Scroll indicator */
.hero__scroll{
  position:absolute;bottom:clamp(1rem,.5rem + 1vw,2rem);
  left:50%;transform:translateX(-50%);z-index:3;
  display:flex;flex-direction:column;align-items:center;gap:.6rem;
}
.hero__scroll span{
  font-size:.58rem;font-weight:500;text-transform:uppercase;
  letter-spacing:.25em;color:rgba(255,255,255,.3);
}
.hero__scroll-bar{
  width:1px;height:40px;background:rgba(255,255,255,.12);
  position:relative;overflow:hidden;
}
.hero__scroll-bar::after{
  content:'';position:absolute;top:-100%;width:100%;height:100%;
  background:rgba(255,255,255,.5);animation:scrollPulse 2.2s ease-in-out infinite;
}
@keyframes scrollPulse{0%{top:-100%}50%{top:100%}100%{top:100%}}

/* ==============================================
   TICKER — Infinite horizontal scroll
   ============================================== */
.ticker{
  background:var(--bg-dark);padding:clamp(1rem,.8rem + .4vw,1.4rem) 0;
  overflow:hidden;position:relative;
}
.ticker__track{
  display:flex;width:max-content;
  /* JS calculates --group-w at runtime; fallback scrolls by estimated amount */
  animation:tickerScroll var(--ticker-dur, 25s) linear infinite;
}
.ticker:hover .ticker__track{animation-play-state:paused}
.ticker__group{display:flex;align-items:center;flex-shrink:0}
.ticker__item{
  font-family:var(--hf);font-size:clamp(.95rem,.8rem + .5vw,1.2rem);
  font-weight:400;color:rgba(250,246,240,.75);white-space:nowrap;
  display:inline-flex;align-items:center;gap:.4rem;
}
.ticker__item svg{fill:var(--gold);flex-shrink:0}
.ticker__item--em{font-style:italic;font-weight:300;color:rgba(250,246,240,.45)}
.ticker__dot{
  width:4px;height:4px;border-radius:50%;
  background:rgba(250,246,240,.15);
  margin:0 clamp(1.2rem,.8rem + .8vw,2rem);flex-shrink:0;
}
@keyframes tickerScroll{to{transform:translateX(calc(var(--group-w, -50%) * -1))}}

/* ==============================================
   MENU — Framed editorial
   ============================================== */
.menu{
  padding:clamp(5rem,4rem + 3vw,9rem) 0 clamp(4rem,3rem + 3vw,7rem);
  background:var(--bg);position:relative;overflow:hidden;
}

/* Ambient warm glow */
.menu__glow{
  position:absolute;top:20%;left:-15%;
  width:min(60vw,600px);height:min(60vw,600px);
  background:radial-gradient(circle,rgba(212,165,116,.06) 0%,rgba(212,165,116,.02) 40%,transparent 70%);
  border-radius:50%;pointer-events:none;
  animation:glowDrift1 16s ease-in-out infinite alternate;
}

.menu__head{text-align:center;margin-bottom:clamp(2.5rem,2rem + 2vw,4.5rem)}
.menu__head .label{justify-content:center}
.menu__head .label::after{content:'';width:28px;height:1px;background:var(--brand);opacity:.5}

/* Decorative frame */
.menu__frame{
  max-width:920px;margin:0 auto;position:relative;
  padding:clamp(2rem,1.5rem + 1.5vw,3.5rem) clamp(1.5rem,1rem + 1.5vw,3rem);
  border:1px solid var(--border);
  display:flex;flex-direction:column;gap:0;
  overflow:hidden;
}
.menu__frame::before,.menu__frame::after{
  content:'';position:absolute;width:24px;height:24px;border-color:var(--brand);opacity:.2;
  z-index:2;
}
.menu__frame::before{top:-1px;left:-1px;border-top:2px solid;border-left:2px solid}
.menu__frame::after{bottom:-1px;right:-1px;border-bottom:2px solid;border-right:2px solid}

@media(min-width:700px){.menu__frame{flex-direction:row}}

.menu__col{flex:1;min-width:0}
.menu__divider{display:none}
@media(min-width:700px){
  .menu__divider{
    display:block;width:1px;align-self:stretch;
    background:var(--border);margin:0 clamp(1.5rem,1rem + 1vw,2.5rem);
  }
}

.menu__item{
  padding:clamp(1rem,.75rem + .5vw,1.35rem) 0;
  border-bottom:1px solid var(--border-s);position:relative;
}
.menu__item:last-child{border-bottom:none}
/* Hover underline animation */
.menu__item::after{
  content:'';position:absolute;bottom:0;left:0;width:100%;height:1px;
  background:var(--brand);transform:scaleX(0);transform-origin:right;
  transition:transform .5s var(--ease2);
}
.menu__item:hover::after{transform:scaleX(1);transform-origin:left}

.menu__row{display:flex;align-items:baseline;gap:.5rem;margin-bottom:.25rem}
.menu__name{
  font-family:var(--hf);font-size:clamp(1.1rem,.95rem + .4vw,1.3rem);
  font-weight:600;color:var(--text);white-space:nowrap;
}
.menu__dots{
  flex:1;border-bottom:1px dotted var(--text-m);margin-bottom:.3em;
  opacity:.25;min-width:16px;
}
.menu__price{
  font-family:var(--bf);font-size:.88rem;font-weight:600;color:var(--brand);
  white-space:nowrap;
}
.menu__desc{font-size:.8rem;color:var(--text-m);line-height:1.5;max-width:42ch}

/* ==============================================
   REVIEWS — Dark section, atmospheric
   ============================================== */
.reviews{
  padding:clamp(5rem,4rem + 3vw,9rem) 0;
  background:var(--bg-dark);position:relative;overflow:hidden;
  /* Subtle animated gradient background */
  background:linear-gradient(-45deg,#1C1410,#231812,#1A120E,#1C1410);
  background-size:300% 300%;
  animation:bgShift 20s ease infinite;
}
@keyframes bgShift{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}

.reviews__head{margin-bottom:clamp(2.5rem,2rem + 2vw,4.5rem)}

.reviews__grid{
  display:grid;grid-template-columns:1fr;
  gap:clamp(1.25rem,1rem + .5vw,1.75rem);
}
@media(min-width:700px){
  .reviews__grid{grid-template-columns:1.2fr .8fr;grid-template-rows:auto auto}
  .review--big{grid-row:1/3}
}

.review{
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.05);
  border-radius:3px;padding:clamp(1.5rem,1.25rem + .5vw,2.25rem);
  transition:transform .5s var(--ease),box-shadow .5s var(--ease),border-color .4s;
}
.review:hover{
  transform:translateY(-4px);
  box-shadow:0 20px 60px rgba(0,0,0,.2);
  border-color:rgba(212,165,116,.12);
}

.review--big{
  padding:clamp(2.5rem,2rem + 1.5vw,4rem);
  background:linear-gradient(135deg,rgba(212,165,116,.04),transparent 60%),rgba(255,255,255,.02);
  position:relative;display:flex;flex-direction:column;justify-content:center;
}
.review__mark{
  font-family:var(--hf);font-size:clamp(5rem,4rem + 3vw,8rem);
  color:var(--gold);opacity:.08;line-height:.5;display:block;
  position:absolute;top:clamp(1rem,.5rem + 1vw,2rem);left:clamp(1.5rem,1rem + 1vw,2.5rem);
}
.review--big .review__text{
  font-family:var(--hf);font-size:clamp(1.15rem,1rem + .5vw,1.5rem);
  font-style:italic;font-weight:400;line-height:1.5;
  color:rgba(250,246,240,.85);margin-bottom:1.5rem;position:relative;z-index:1;
}
.review__foot{display:flex;align-items:center;gap:1rem;position:relative;z-index:1}

.review__stars{display:flex;gap:2px;margin-bottom:.75rem}
.review__stars svg{width:15px;height:15px;fill:var(--gold)}
.review--big .review__foot .review__stars{margin-bottom:0}

.review__text{
  font-size:clamp(.88rem,.84rem + .15vw,.95rem);line-height:1.65;
  color:rgba(250,246,240,.7);margin-bottom:.75rem;
}
.review cite,.review__foot cite{
  font-size:.78rem;font-weight:600;font-style:normal;
  color:rgba(250,246,240,.4);letter-spacing:.03em;
}

/* ==============================================
   ABOUT — Asymmetric, overlapping
   ============================================== */
.about{
  padding:clamp(5rem,4rem + 4vw,10rem) 0;
  background:var(--bg-alt);position:relative;overflow:hidden;
}
.about__glow{
  position:absolute;top:30%;right:-10%;
  width:min(55vw,600px);height:min(55vw,600px);
  background:radial-gradient(circle,rgba(212,165,116,.06) 0%,rgba(212,165,116,.02) 40%,transparent 70%);
  border-radius:50%;pointer-events:none;
  animation:glowDrift2 18s ease-in-out infinite alternate;
}

.about__grid{
  display:grid;grid-template-columns:1fr;
  gap:clamp(2.5rem,2rem + 2vw,4rem);align-items:center;
}
@media(min-width:768px){
  .about__grid{grid-template-columns:.9fr 1.1fr;gap:clamp(3rem,2rem + 3vw,6rem)}
}

.about__photo{
  position:relative;aspect-ratio:3/4;overflow:visible;
  background:
    radial-gradient(ellipse at 30% 40%,rgba(212,165,116,.12),transparent 60%),
    radial-gradient(ellipse at 70% 70%,rgba(139,37,0,.08),transparent 50%),
    linear-gradient(160deg,#2D2016 0%,#3D2C20 40%,#2D2016 100%);
  border-radius:2px;
}
.about__photo img{
  width:100%;height:100%;object-fit:cover;border-radius:2px;
  position:relative;z-index:2;
}
/* Hide broken image icon when token hasn't been replaced */
.about__photo img[src*="{{"]{opacity:0}
.about__photo-frame{
  position:absolute;top:16px;left:16px;right:-16px;bottom:-16px;
  border:1px solid var(--brand);border-radius:2px;opacity:.12;z-index:1;
}

.about__text{max-width:50ch}
.about__quote{
  font-family:var(--hf);font-size:clamp(4rem,3rem + 2vw,6rem);
  color:var(--brand);opacity:.1;line-height:.5;display:block;margin-bottom:.5rem;
}
.about__wave{width:70px;height:12px;margin:1.25rem 0 1.5rem}
.about__wave path{stroke:var(--brand);stroke-width:1.5;fill:none;opacity:.3}
.about__body{
  font-size:clamp(.88rem,.84rem + .15vw,.95rem);line-height:1.75;
  color:var(--text-m);margin-bottom:0;
}
.about__meta{
  display:flex;align-items:center;gap:1.25rem;
  margin-top:2rem;padding-top:1.75rem;border-top:1px solid var(--border-s);
}
.about__year{
  font-family:var(--hf);font-size:clamp(2.5rem,2rem + 1.5vw,3.5rem);
  font-weight:300;color:var(--brand);opacity:.18;line-height:1;
}
.about__meta-line{width:1px;height:32px;background:var(--border)}
.about__owner{
  font-family:var(--hf);font-size:1.05rem;font-weight:500;
  display:block;line-height:1.2;color:var(--text);
}
.about__meta small{
  font-size:.7rem;font-weight:500;text-transform:uppercase;
  letter-spacing:.1em;color:var(--text-m);
}

/* ==============================================
   GALLERY (hidden by default)
   ============================================== */
.gallery{padding:clamp(5rem,3.5rem + 3vw,8rem) 0;background:var(--bg)}
.gallery__head{text-align:center;margin-bottom:clamp(2.5rem,2rem + 1.5vw,4rem)}
.gallery__head .label{justify-content:center}
.gallery__head .label::after{content:'';width:28px;height:1px;background:var(--brand);opacity:.5}
.gallery__grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:clamp(.5rem,.25rem + .5vw,1rem);
}
@media(min-width:700px){
  .gallery__grid{grid-template-columns:1.3fr .7fr 1fr;grid-template-rows:260px 220px}
  .gallery__item--tall{grid-row:1/3}
}
.gallery__item{
  border-radius:3px;overflow:hidden;
  background:linear-gradient(135deg,#2D2016,#3D2C20);
}
.gallery__item img[src*="{{"]{opacity:0}
.gallery__item img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .6s var(--ease);
}
.gallery__item:hover img{transform:scale(1.04)}

/* ==============================================
   LOCATION
   ============================================== */
.loc{
  padding:clamp(5rem,4rem + 3vw,9rem) 0;
  background:
    radial-gradient(ellipse at 70% 30%,rgba(139,37,0,.04),transparent 55%),
    var(--bg-alt);
  position:relative;
}
.loc__head{text-align:center;margin-bottom:clamp(2.5rem,2rem + 2vw,4.5rem)}
.loc__head .label{justify-content:center}
.loc__head .label::after{content:'';width:28px;height:1px;background:var(--brand);opacity:.5}

.loc__grid{
  display:grid;grid-template-columns:1fr;
  gap:clamp(1.5rem,1rem + 1vw,2.5rem);
}
@media(min-width:768px){.loc__grid{grid-template-columns:.85fr 1.15fr;align-items:stretch}}

/* Info card — styled container, not bare text */
.loc__info{
  background:var(--card);border:1px solid var(--border);
  border-radius:4px;padding:clamp(1.5rem,1.25rem + 1vw,2.5rem);
  box-shadow:0 4px 24px rgba(45,32,22,.04);
}

.loc__hours{width:100%;border-collapse:collapse;margin-bottom:1.75rem}
.loc__hours td{
  padding:.6rem 0;border-bottom:1px solid var(--border-s);font-size:.88rem;
}
.loc__hours td:first-child{font-weight:500;color:var(--text)}
.loc__hours td:last-child{text-align:right;color:var(--text-m)}

.loc__contact{
  display:flex;flex-direction:column;gap:.75rem;
  padding-top:1.5rem;border-top:1px solid var(--border-s);
}
.loc__link{
  display:flex;align-items:center;gap:.6rem;font-size:.9rem;color:var(--text);
  transition:color .3s;
}
.loc__link svg{flex-shrink:0;stroke:var(--brand);opacity:.5}
.loc__link:hover{color:var(--brand)}
.loc__link--phone{
  font-weight:600;font-size:1.05rem;color:#fff;
  background:var(--brand);padding:.7rem 1.25rem;border-radius:3px;
  justify-content:center;margin-top:.5rem;
  box-shadow:0 4px 16px rgba(139,37,0,.2);
  transition:background .3s,transform .2s,box-shadow .3s;
}
.loc__link--phone svg{stroke:#fff;opacity:.8}
.loc__link--phone:hover{
  background:var(--brand-light);color:#fff;opacity:1;
  transform:translateY(-1px);box-shadow:0 6px 20px rgba(139,37,0,.3);
}

.loc__map{
  border-radius:4px;overflow:hidden;aspect-ratio:4/3;
  background:
    radial-gradient(ellipse at 50% 50%,rgba(212,165,116,.08),transparent 60%),
    var(--bg-alt);
  box-shadow:0 4px 24px rgba(45,32,22,.06);
  border:1px solid var(--border);
}
.loc__map iframe{width:100%;height:100%;border:0}

/* ==============================================
   CTA — Atmospheric dark
   ============================================== */
.cta{
  position:relative;text-align:center;overflow:hidden;
  padding:clamp(6rem,5rem + 5vw,12rem) 0;
}
.cta__bg{
  position:absolute;inset:0;
  background:linear-gradient(-45deg,#1C1410,#231812,#1A120E,#1C1410);
  background-size:300% 300%;
  animation:bgShift 25s ease infinite;
}
.cta__glow{
  position:absolute;border-radius:50%;pointer-events:none;
}
.cta__glow--1{
  width:min(60vw,650px);height:min(60vw,650px);
  background:radial-gradient(circle,rgba(139,37,0,.1) 0%,rgba(139,37,0,.03) 40%,transparent 70%);
  top:-15%;left:-8%;animation:glowDrift1 14s ease-in-out infinite alternate;
}
.cta__glow--2{
  width:min(50vw,550px);height:min(50vw,550px);
  background:radial-gradient(circle,rgba(212,165,116,.06) 0%,rgba(212,165,116,.02) 40%,transparent 70%);
  bottom:-10%;right:-5%;animation:glowDrift2 16s ease-in-out infinite alternate;
}
.cta__inner{position:relative;z-index:3}
.cta__label{
  font-family:var(--bf);font-size:clamp(.65rem,.6rem + .15vw,.72rem);
  font-weight:600;text-transform:uppercase;letter-spacing:.22em;
  color:var(--gold);margin-bottom:1.5rem;
}
.cta__title{
  font-family:var(--hf);font-size:clamp(2.4rem,1.6rem + 3.5vw,5.5rem);
  font-weight:300;color:#FAF6F0;line-height:1.05;letter-spacing:-.02em;
  margin-bottom:1.25rem;
}
.cta__title em{font-style:italic;font-weight:400;color:var(--gold)}
.cta__sub{
  font-size:clamp(.88rem,.84rem + .15vw,.95rem);
  color:rgba(250,246,240,.4);margin-bottom:2.5rem;
  max-width:50ch;margin-inline:auto;
}
.cta__btns{display:flex;flex-wrap:wrap;justify-content:center;gap:1rem}

/* ==============================================
   FOOTER
   ============================================== */
.foot{
  position:relative;overflow:hidden;
  padding:clamp(3.5rem,3rem + 2vw,6rem) 0 clamp(1.5rem,1rem + .5vw,2rem);
  background:var(--bg-darker);color:rgba(250,246,240,.55);
}
.foot__inner{position:relative;z-index:2}
.foot__grid{
  display:grid;grid-template-columns:1fr;gap:2.5rem;
  margin-bottom:clamp(2.5rem,2rem + 1vw,4rem);
}
@media(min-width:600px){.foot__grid{grid-template-columns:1.4fr 1fr 1fr}}

.foot__brand{
  font-family:var(--hf);font-size:clamp(1.3rem,1.1rem + .6vw,1.7rem);
  font-weight:500;color:#FAF6F0;margin-bottom:.75rem;
}
.foot__tagline{
  font-family:var(--hf);font-size:.9rem;font-style:italic;font-weight:300;
  color:rgba(250,246,240,.3);max-width:26ch;
}
.foot__heading{
  font-size:.68rem;font-weight:600;text-transform:uppercase;
  letter-spacing:.15em;color:rgba(250,246,240,.25);margin-bottom:1.25rem;
}
.foot__link{
  display:flex;align-items:center;gap:.5rem;
  font-size:.82rem;margin-bottom:.6rem;
  color:rgba(250,246,240,.55);transition:color .3s;
}
.foot__link:hover{color:#FAF6F0}
.foot__link svg{flex-shrink:0;opacity:.3}
.foot__hours{font-size:.8rem;line-height:1.8;color:rgba(250,246,240,.35)}
.foot__bar{
  border-top:1px solid rgba(250,246,240,.05);
  padding-top:clamp(1rem,.75rem + .5vw,1.5rem);
  font-size:.72rem;color:rgba(250,246,240,.2);
}
.foot__bar a{color:rgba(250,246,240,.35);transition:color .3s}
.foot__bar a:hover{color:rgba(250,246,240,.6)}

/* ==============================================
   MOBILE (480px and below)
   ============================================== */
@media(max-width:480px){
  .menu__frame{padding:1rem .75rem;border:none}
  .menu__frame::before,.menu__frame::after{display:none}
  .hero__glow{display:none}
  .about__photo-frame{display:none}
  .review--big{padding:1.75rem 1.25rem}
  .cta__glow{display:none}
  .hero__est-line{width:20px}
  .hero__title{font-size:clamp(2.5rem,2rem + 4vw,3.5rem)}
}

/* Tablet adjustments */
@media(min-width:481px) and (max-width:768px){
  .hero__title{font-size:clamp(3rem,2rem + 4vw,4.5rem)}
  .reviews__grid{grid-template-columns:1fr}
  .about__grid{grid-template-columns:1fr}
  .about__photo{max-width:400px}
  .loc__grid{grid-template-columns:1fr}
}
