:root{
  --cream:#f4efe6;--cream2:#ebe3d6;--espresso:#241610;--espresso2:#3a261c;
  --terra:#c26d4a;--terra-dark:#9e5235;--sage:#7d8f72;--white:#fff;
  --muted:#6f6258;--muted2:#9a8d82;
  --font-display:"Fraunces",Georgia,serif;
  --font-body:"DM Sans",system-ui,sans-serif;
  --nav-h:4.25rem;--max:76rem;--radius:1.1rem;--radius-pill:999px;
  --shadow:0 24px 60px rgba(36,22,16,.14);
  --text-hero:clamp(2.5rem,1.2rem + 5.5vw,5.2rem);
  --text-xl:clamp(1.75rem,1rem + 2.2vw,3rem);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font-body);font-size:1rem;line-height:1.65;color:var(--espresso);background:var(--cream);overflow-x:hidden;-webkit-font-smoothing:antialiased}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;border:0;background:none;cursor:pointer}
address{font-style:normal}
.container{width:min(var(--max),calc(100% - 2rem));margin-inline:auto}
.eyebrow{font-size:.76rem;letter-spacing:.18em;text-transform:uppercase;color:var(--terra);font-weight:600;margin-bottom:.85rem}
h1,h2,h3{font-family:var(--font-display);font-weight:500;line-height:1.05;letter-spacing:-.02em}
h1{font-size:var(--text-hero)}
h2{font-size:var(--text-xl)}
h3{font-size:clamp(1.2rem,.95rem + .8vw,1.55rem)}
p{color:var(--muted);max-width:44ch}
.reveal{opacity:0;transform:translateY(28px);transition:opacity .8s cubic-bezier(.22,1,.36,1),transform .8s cubic-bezier(.22,1,.36,1)}
.reveal.is-visible{opacity:1;transform:none}
.reveal--delay{transition-delay:.12s}
.reveal--delay2{transition-delay:.22s}
/* NAV */
.site-nav{position:fixed;inset:0 0 auto;z-index:100;height:var(--nav-h);display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:0 1.25rem;transition:background .35s,box-shadow .35s,backdrop-filter .35s}
.site-nav.is-scrolled{background:rgba(244,239,230,.82);backdrop-filter:blur(14px);box-shadow:0 1px 0 rgba(36,22,16,.06)}
.nav-brand{font-family:var(--font-display);font-size:clamp(1.05rem,.9rem + .6vw,1.35rem);font-weight:500;color:var(--espresso)}
.nav-brand em{font-style:italic;color:var(--terra)}
.nav-links{display:flex;gap:1.35rem}
.nav-links a{font-size:.88rem;color:var(--muted);transition:color .2s}
.nav-links a:hover{color:var(--espresso)}
.nav-cta{padding:.62rem 1.1rem;border-radius:var(--radius-pill);background:var(--espresso);color:var(--cream);font-size:.84rem;font-weight:600;transition:transform .15s,background .2s}
.nav-cta:hover{background:var(--espresso2);transform:translateY(-1px)}
.nav-burger{display:none;width:2.6rem;height:2.6rem;border-radius:50%;border:1px solid rgba(36,22,16,.12);position:relative}
.nav-burger span{position:absolute;left:50%;top:50%;width:1rem;height:2px;background:var(--espresso);transform:translate(-50%,-50%);transition:transform .2s}
.nav-burger span:last-child{transform:translate(-50%,-50%) translateY(5px)}
.nav-burger span:first-child{transform:translate(-50%,-50%) translateY(-5px)}
.site-nav.is-open .nav-burger span:first-child{transform:translate(-50%,-50%) rotate(45deg)}
.site-nav.is-open .nav-burger span:last-child{transform:translate(-50%,-50%) rotate(-45deg)}
.nav-mobile{position:fixed;inset:var(--nav-h) 0 0;z-index:90;background:rgba(244,239,230,.97);padding:1.25rem;display:flex;flex-direction:column;gap:.35rem;backdrop-filter:blur(16px);transform:translateY(-8px);opacity:0;pointer-events:none;transition:opacity .25s,transform .25s}
.nav-mobile.is-open{transform:none;opacity:1;pointer-events:auto}
.nav-mobile a{padding:.85rem 0;border-bottom:1px solid rgba(36,22,16,.08);font-size:1.05rem}
.nav-mobile__cta{margin-top:.75rem;text-align:center;padding:.9rem;border-radius:var(--radius-pill);background:var(--espresso);color:var(--cream);font-weight:600}
@media(max-width:860px){
  .nav-links,.nav-cta{display:none}
  .nav-burger{display:grid;place-items:center}
}
/* BUTTONS */
.btn{display:inline-flex;align-items:center;justify-content:center;padding:.85rem 1.35rem;border-radius:var(--radius-pill);font-weight:600;font-size:.92rem;transition:transform .15s,box-shadow .2s,background .2s,color .2s}
.btn--fill{background:var(--espresso);color:var(--cream);box-shadow:0 10px 24px rgba(36,22,16,.18)}
.btn--fill:hover{transform:translateY(-2px);background:var(--espresso2)}
.btn--ghost{border:1px solid rgba(36,22,16,.18);color:var(--espresso);background:rgba(255,255,255,.35)}
.btn--ghost:hover{background:#fff}
/* HERO */
.hero{position:relative;min-height:100svh;padding:calc(var(--nav-h) + 1.5rem) 0 3rem;overflow:hidden}
.hero__media{position:absolute;inset:0;z-index:0}
.hero__media img{width:100%;height:100%;object-fit:cover;animation:heroZoom 18s ease-in-out infinite alternate}
.hero__grain{position:absolute;inset:0;background:linear-gradient(115deg,rgba(244,239,230,.88) 8%,rgba(244,239,230,.55) 42%,rgba(36,22,16,.35) 100%);mix-blend-mode:normal}
@keyframes heroZoom{from{transform:scale(1)}to{transform:scale(1.06)}}
.hero__layout{position:relative;z-index:2;width:min(var(--max),calc(100% - 2rem));margin-inline:auto;display:grid;grid-template-columns:1.1fr .72fr;gap:2rem;align-items:end;min-height:calc(100svh - var(--nav-h) - 4rem)}
.hero__copy h1{margin-bottom:1rem;max-width:11ch}
.hero__copy p{margin-bottom:1.5rem;font-size:clamp(.98rem,.9rem + .3vw,1.1rem)}
.hero__actions{display:flex;flex-wrap:wrap;gap:.7rem}
.hero__float{position:relative;margin-bottom:1rem;transform:translateY(12px)}
.hero__float img{border-radius:calc(var(--radius) * 1.4);box-shadow:var(--shadow);animation:floatY 6s ease-in-out infinite}
.hero__float figcaption{position:absolute;left:1rem;bottom:1rem;padding:.45rem .75rem;border-radius:var(--radius-pill);background:rgba(255,255,255,.82);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--espresso)}
@keyframes floatY{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
.hero__scroll{position:absolute;left:50%;bottom:1.25rem;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:.35rem;font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted2);z-index:2}
.hero__scroll i{display:block;width:1px;height:2.2rem;background:linear-gradient(var(--terra),transparent);animation:scrollLine 1.8s ease-in-out infinite}
@keyframes scrollLine{0%,100%{opacity:.35;transform:scaleY(.7)}50%{opacity:1;transform:scaleY(1)}}
@media(max-width:900px){
  .hero__layout{grid-template-columns:1fr;align-items:end}
  .hero__float{max-width:16rem;justify-self:end;margin-top:-1rem}
  .hero__copy h1{max-width:none}
}
@media(max-width:520px){
  .hero__float{max-width:12rem}
}
/* MARQUEE */
.marquee{padding:1rem 0;border-block:1px solid rgba(36,22,16,.08);background:var(--cream2);overflow:hidden}
.marquee__track{display:flex;gap:2.5rem;width:max-content;animation:marquee 28s linear infinite}
.marquee span{font-family:var(--font-display);font-size:clamp(1rem,.85rem + .8vw,1.45rem);font-style:italic;color:var(--espresso2);white-space:nowrap}
.marquee span::after{content:"·";margin-left:2.5rem;color:var(--terra);font-style:normal}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
/* ABOUT */
.about{padding:clamp(4rem,7vw,7rem) 0}
.about__grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,4vw,4rem);align-items:center}
.about__text h2{margin-bottom:1rem;max-width:14ch}
.about__text p{margin-bottom:1.75rem}
.about__stats{display:flex;gap:1.5rem;flex-wrap:wrap}
.about__stats li{display:flex;flex-direction:column;gap:.2rem;padding-right:1.5rem;border-right:1px solid rgba(36,22,16,.1)}
.about__stats li:last-child{border-right:0}
.about__stats strong{font-family:var(--font-display);font-size:clamp(1.6rem,1.2rem + 1.2vw,2.4rem);line-height:1;color:var(--espresso)}
.about__stats span{font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted2)}
.about__stack{position:relative;min-height:28rem}
.stack-card{position:absolute;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.stack-card img{width:100%;height:100%;object-fit:cover}
.stack-card--a{inset:8% 18% 18% 0;z-index:1}
.stack-card--b{inset:0 0 28% 34%;z-index:2;width:58%}
.stack-card--c{inset:auto 0 0 auto;width:42%;z-index:3;animation:floatY 7s ease-in-out infinite}
@media(max-width:900px){
  .about__grid{grid-template-columns:1fr}
  .about__stack{min-height:22rem;max-width:28rem;margin-inline:auto}
}
/* MENU */
.menu{padding:clamp(3rem,6vw,6rem) 0;background:var(--espresso);color:var(--cream)}
.menu .eyebrow{color:#e8b49a}
.menu h2,.menu h3{color:var(--cream)}
.menu p{color:rgba(244,239,230,.72)}
.menu__head{margin-bottom:2.5rem}
.menu__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem}
.menu-card{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:calc(var(--radius) * 1.2);overflow:hidden;transition:transform .35s,box-shadow .35s}
.menu-card:hover{transform:translateY(-6px);box-shadow:0 20px 40px rgba(0,0,0,.22)}
.menu-card__img{aspect-ratio:4/3;overflow:hidden}
.menu-card__img img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.menu-card:hover .menu-card__img img{transform:scale(1.06)}
.menu-card__body{padding:1.25rem 1.25rem 1.4rem}
.menu-card__body h3{margin-bottom:.85rem}
.menu-card ul{display:grid;gap:.55rem}
.menu-card li{display:flex;justify-content:space-between;gap:1rem;font-size:.92rem;color:rgba(244,239,230,.82)}
.menu-card em{font-style:normal;color:#e8b49a;font-weight:600}
@media(max-width:900px){.menu__grid{grid-template-columns:1fr}}
/* SPACE */
.space{padding:clamp(4rem,7vw,7rem) 0 0}
.space__intro{margin-bottom:2rem}
.space__intro h2{max-width:16ch}
.space__gallery{display:grid;grid-template-columns:repeat(12,1fr);gap:.85rem;padding-inline:max(1rem,calc((100% - var(--max))/2 + 1rem))}
.space__tile{position:relative;border-radius:var(--radius);overflow:hidden;min-height:14rem}
.space__tile img{width:100%;height:100%;object-fit:cover;min-height:14rem;transition:transform .7s cubic-bezier(.22,1,.36,1)}
.space__tile:hover img{transform:scale(1.05)}
.space__tile figcaption{position:absolute;left:.85rem;bottom:.85rem;padding:.35rem .7rem;border-radius:var(--radius-pill);background:rgba(36,22,16,.72);color:var(--cream);font-size:.75rem}
.space__tile--wide{grid-column:span 7}
.space__tile:not(.space__tile--wide){grid-column:span 5}
.space__gallery .space__tile:nth-child(3){grid-column:span 5}
.space__gallery .space__tile:nth-child(4){grid-column:span 7}
@media(max-width:768px){
  .space__gallery{grid-template-columns:1fr 1fr}
  .space__tile--wide,.space__tile,.space__gallery .space__tile:nth-child(3),.space__gallery .space__tile:nth-child(4){grid-column:span 1}
  .space__tile:first-child{grid-column:span 2}
}
/* CONTACT */
.contact{padding:clamp(4rem,7vw,7rem) 0}
.contact__grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem;align-items:center}
.contact__copy h2{margin-bottom:1rem;max-width:14ch}
.contact__copy p{margin-bottom:1.5rem}
.contact__copy a:hover{color:var(--terra)}
.contact__copy address p{margin-bottom:1rem;color:var(--espresso)}
.contact__hours{display:grid;gap:.45rem;margin-top:1.25rem}
.contact__hours p{display:flex;justify-content:space-between;gap:1rem;max-width:20rem;color:var(--espresso)}
.contact__hours span{color:var(--muted)}
.contact__visual{position:relative;border-radius:calc(var(--radius) * 1.3);overflow:hidden;box-shadow:var(--shadow)}
.contact__visual img{aspect-ratio:4/5;object-fit:cover;width:100%}
.btn--map{position:absolute;left:1rem;bottom:1rem}
@media(max-width:860px){.contact__grid{grid-template-columns:1fr}}
/* FOOTER */
.site-footer{padding:2rem 0 2.5rem;border-top:1px solid rgba(36,22,16,.08)}
.site-footer__inner{display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;font-size:.84rem;color:var(--muted2)}
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none!important;transition:none!important}
  .reveal{opacity:1;transform:none}
}
.menu-card__body{padding:1.5rem 1.25rem 1.55rem}
.space__gallery--duo .space__tile--wide{grid-column:span 8}
.space__gallery--duo .space__tile:last-child{grid-column:span 4}
.contact__map{aspect-ratio:4/5;min-height:18rem;background:linear-gradient(145deg,var(--espresso2),var(--terra-dark));display:flex;flex-direction:column;justify-content:flex-end;padding:1.5rem;color:var(--cream);position:relative;overflow:hidden}
.contact__map::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 30% 20%,rgba(255,255,255,.12),transparent 55%)}
.contact__map span{font-size:.75rem;letter-spacing:.14em;text-transform:uppercase;opacity:.75}
.contact__map strong{font-family:var(--font-display);font-size:clamp(1.6rem,1.2rem + 1.5vw,2.4rem);line-height:1.1;margin-top:.35rem}
@media(max-width:768px){.space__gallery--duo .space__tile--wide,.space__gallery--duo .space__tile:last-child{grid-column:span 2}}