/*
  Designed and developed by Wave Agency - waveagency.com
  Version 1-4-0
*/

/* ============================================================
   ENOLOGY WINE BAR & BISTRO
   Design system: espresso and cream, a pour of burgundy.
   Display: Cormorant Garamond. Labels: Montserrat. Body: Inter.
   ============================================================ */

/* ---------- Fonts (self-hosted, latin) ---------- */
@font-face{font-family:"Cormorant Garamond";src:url("../../fonts/cormorant-garamond-400.woff2") format("woff2");font-weight:400;font-style:normal;font-display:swap;}
@font-face{font-family:"Cormorant Garamond";src:url("../../fonts/cormorant-garamond-400-italic.woff2") format("woff2");font-weight:400;font-style:italic;font-display:swap;}
@font-face{font-family:"Cormorant Garamond";src:url("../../fonts/cormorant-garamond-500.woff2") format("woff2");font-weight:500;font-style:normal;font-display:swap;}
@font-face{font-family:"Cormorant Garamond";src:url("../../fonts/cormorant-garamond-500-italic.woff2") format("woff2");font-weight:500;font-style:italic;font-display:swap;}
@font-face{font-family:"Cormorant Garamond";src:url("../../fonts/cormorant-garamond-600.woff2") format("woff2");font-weight:600;font-style:normal;font-display:swap;}
@font-face{font-family:"Montserrat";src:url("../../fonts/montserrat-600.woff2") format("woff2");font-weight:600;font-style:normal;font-display:swap;}
@font-face{font-family:"Inter";src:url("../../fonts/inter-400.woff2") format("woff2");font-weight:400;font-style:normal;font-display:swap;}
@font-face{font-family:"Inter";src:url("../../fonts/inter-500.woff2") format("woff2");font-weight:500;font-style:normal;font-display:swap;}

/* ---------- Tokens ---------- */
:root{
  /* Core palette (brand kit) */
  --espresso:#1F1A17;
  --cream:#F4EDE1;
  --burgundy:#6B1F2E;
  --brass:#B08D57;
  --stone:#CDBBA4;
  --parchment:#FBF7EF;

  /* Derived tints */
  --espresso-90:rgba(31,26,23,.90);
  --espresso-70:rgba(31,26,23,.70);
  --espresso-08:rgba(31,26,23,.08);
  --cream-70:rgba(244,237,225,.70);
  --cream-55:rgba(244,237,225,.55);
  --line:rgba(31,26,23,.14);
  --line-dark:rgba(244,237,225,.16);

  /* Type families */
  --display:"Cormorant Garamond",Georgia,"Times New Roman",serif;
  --label:"Montserrat",-apple-system,BlinkMacSystemFont,sans-serif;
  --body:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;

  /* Type scale (fluid) */
  --fs-hero:clamp(3.2rem,9vw,7rem);
  --fs-display:clamp(2.6rem,6vw,4.6rem);
  --fs-h2:clamp(2rem,4.2vw,3.1rem);
  --fs-h3:clamp(1.45rem,2.4vw,2rem);
  --fs-lead:clamp(1.1rem,1.6vw,1.32rem);
  --fs-body:1.0625rem;
  --fs-eyebrow:.72rem;
  --fs-small:.85rem;

  /* Layout */
  --maxw:1180px;
  --maxw-narrow:760px;
  --gutter:clamp(1.25rem,5vw,4rem);
  --radius:3px;

  --ease:cubic-bezier(.22,.61,.36,1);
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box;}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto;}}
body{margin:0;background:var(--cream);color:var(--espresso);
  font-family:var(--body);font-size:var(--fs-body);line-height:1.75;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
button{font-family:inherit;cursor:pointer;}
h1,h2,h3,h4{margin:0;font-weight:500;line-height:1.08;font-family:var(--display);}
p{margin:0 0 1.15em;}
ul{margin:0;padding:0;list-style:none;}
:focus-visible{outline:2px solid var(--burgundy);outline-offset:3px;}
::selection{background:var(--burgundy);color:var(--cream);}

/* ---------- Utilities ---------- */
.container{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gutter);}
.narrow{max-width:var(--maxw-narrow);}
.skip-link{position:absolute;left:-999px;top:0;background:var(--espresso);color:var(--cream);
  padding:.75rem 1.25rem;z-index:200;font-family:var(--label);font-size:var(--fs-small);}
.skip-link:focus{left:0;}

.eyebrow{font-family:var(--label);font-weight:600;text-transform:uppercase;
  font-size:var(--fs-eyebrow);letter-spacing:.3em;color:var(--burgundy);
  margin:0 0 1.1rem;display:block;}
.eyebrow.on-dark{color:var(--brass);}

.lead{font-size:var(--fs-lead);line-height:1.7;color:var(--espresso-70);}

.italic{font-style:italic;}

/* Diamond hairline divider, the recurring motif from Enology's print menus */
.divider{display:flex;align-items:center;justify-content:center;gap:0;margin:0 auto;width:min(260px,60%);}
.divider::before,.divider::after{content:"";height:1px;flex:1;background:var(--stone);}
.divider span{width:7px;height:7px;background:var(--brass);transform:rotate(45deg);margin:0 12px;flex:none;}
.divider.on-dark::before,.divider.on-dark::after{background:var(--line-dark);}
.divider.start{margin:0;justify-content:flex-start;width:200px;}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:.6em;font-family:var(--label);
  font-weight:600;text-transform:uppercase;letter-spacing:.16em;font-size:.74rem;
  padding:1.05em 1.9em;border:1px solid var(--espresso);background:var(--espresso);
  color:var(--cream);border-radius:var(--radius);transition:background .35s var(--ease),color .35s var(--ease),border-color .35s var(--ease),transform .35s var(--ease);}
.btn:hover{background:var(--burgundy);border-color:var(--burgundy);color:var(--cream);}
.btn .arrow{transition:transform .35s var(--ease);}
.btn:hover .arrow{transform:translateX(4px);}
.btn--ghost{background:transparent;color:var(--espresso);border-color:var(--espresso);}
.btn--ghost:hover{background:var(--espresso);color:var(--cream);}
.btn--on-dark{background:var(--cream);border-color:var(--cream);color:var(--espresso);}
.btn--on-dark:hover{background:var(--brass);border-color:var(--brass);color:var(--espresso);}
.btn--ghost-dark{background:transparent;color:var(--cream);border-color:var(--cream-55);}
.btn--ghost-dark:hover{background:var(--cream);color:var(--espresso);border-color:var(--cream);}

/* Text link with drawn underline */
.tlink{font-family:var(--label);font-weight:600;text-transform:uppercase;letter-spacing:.16em;
  font-size:.74rem;color:var(--burgundy);display:inline-flex;align-items:center;gap:.5em;
  padding-bottom:3px;background-image:linear-gradient(var(--burgundy),var(--burgundy));
  background-size:0% 1px;background-position:0 100%;background-repeat:no-repeat;
  transition:background-size .4s var(--ease);}
.tlink:hover{background-size:100% 1px;}
.tlink .arrow{transition:transform .35s var(--ease);}
.tlink:hover .arrow{transform:translateX(4px);}
.tlink.on-dark{color:var(--brass);background-image:linear-gradient(var(--brass),var(--brass));}

/* ============================================================
   HEADER / NAV
   ============================================================ */
.site-header{position:sticky;top:0;z-index:100;background:var(--cream);
  border-bottom:1px solid var(--line);transition:transform .4s var(--ease),background .4s var(--ease);}
.site-header.is-hidden{transform:translateY(-100%);}
.site-header.on-hero{position:fixed;left:0;right:0;background:transparent;border-bottom-color:transparent;}
.site-header.on-hero .nav-link,.site-header.on-hero .nav-toggle-line{color:var(--cream);}
.site-header.on-hero .nav-toggle-line{background:var(--cream);}
.site-header.on-hero .logo-dark{opacity:0;}
.site-header.on-hero .logo-light{opacity:1;}
.nav{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;
  height:84px;}
.brand{display:block;flex:none;position:relative;width:212px;height:54px;}
.brand img{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;object-position:left center;transition:opacity .4s var(--ease);image-rendering:-webkit-optimize-contrast;}
.logo-light{opacity:0;}
.logo-dark{opacity:1;}
.nav-menu{display:flex;align-items:center;gap:clamp(1rem,2.4vw,2.2rem);}
.nav-link{font-family:var(--label);font-weight:600;text-transform:uppercase;
  font-size:.72rem;letter-spacing:.18em;color:var(--espresso);position:relative;padding:.4rem 0;
  transition:color .3s var(--ease);}
.nav-link::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:1px;
  background:currentColor;transition:width .35s var(--ease);}
.nav-link:hover::after,.nav-link[aria-current="page"]::after{width:100%;}
.nav-cta{margin-left:.4rem;background:var(--brass);border-color:var(--brass);color:var(--espresso);
  box-shadow:0 2px 18px rgba(176,141,87,.28);}
.nav-cta:hover{background:var(--espresso);border-color:var(--espresso);color:var(--cream);}
.site-header.on-hero .nav-cta{background:var(--brass);border-color:var(--brass);color:var(--espresso);}
.site-header.on-hero .nav-cta:hover{background:var(--cream);border-color:var(--cream);color:var(--espresso);}
.nav-actions{display:flex;align-items:center;gap:1.25rem;}
.nav-menu__logo{display:none;}

/* Mobile toggle */
.nav-toggle{display:none;flex-direction:column;gap:5px;width:30px;height:30px;
  justify-content:center;background:none;border:0;padding:0;}
.nav-toggle-line{display:block;width:26px;height:2px;background:var(--espresso);
  transition:transform .35s var(--ease),opacity .25s var(--ease);}

@media (max-width:920px){
  .nav-menu{position:fixed;inset:0;width:100vw;height:100dvh;
    background:var(--espresso);flex-direction:column;align-items:center;justify-content:center;
    gap:.3rem;padding:6rem var(--gutter) 3rem;transform:translateX(100%);
    transition:transform .5s var(--ease);z-index:120;overflow-y:auto;}
  .nav-menu.is-open{transform:translateX(0);}
  .nav-menu__logo{display:block;position:absolute;top:24px;left:50%;transform:translateX(-50%);
    width:190px;height:auto;}
  .nav-menu .nav-link{color:var(--cream);font-family:var(--display);text-transform:none;
    font-size:2.1rem;line-height:1.25;letter-spacing:0;font-weight:500;padding:.3rem 0;}
  .nav-menu .nav-link::after{display:none;}
  .nav-menu .nav-link:hover,.nav-menu .nav-link[aria-current="page"]{color:var(--brass);}
  .nav-menu .nav-cta{margin:1.7rem 0 0;font-size:.86rem;padding:1.3em 3.2em;
    box-shadow:0 4px 26px rgba(176,141,87,.4);}
  .nav-toggle{display:flex;z-index:130;position:relative;}
  .nav-open .nav-toggle-line:nth-child(1){transform:translateY(7px) rotate(45deg);background:var(--cream);}
  .nav-open .nav-toggle-line:nth-child(2){opacity:0;}
  .nav-open .nav-toggle-line:nth-child(3){transform:translateY(-7px) rotate(-45deg);background:var(--cream);}
  .nav-backdrop{display:none;}
  .site-header.on-hero .nav-menu .nav-link{color:var(--cream);}
}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;
  color:var(--cream);overflow:hidden;background:var(--espresso);}
.hero__media{position:absolute;inset:0;z-index:0;}
.hero__media img{width:100%;height:100%;object-fit:cover;
  opacity:.82;transform:scale(1.06);transition:transform 8s var(--ease);}
.hero.is-ready .hero__media img{transform:scale(1);}
.hero__media::after{content:"";position:absolute;inset:0;
  background:linear-gradient(90deg,rgba(31,26,23,.44) 0%,rgba(31,26,23,.14) 52%,rgba(31,26,23,.02) 100%),linear-gradient(180deg,rgba(31,26,23,.12) 0%,rgba(31,26,23,.02) 45%,rgba(31,26,23,.36) 100%);}
.hero__inner{position:relative;z-index:1;padding-block:9rem 5rem;width:100%;}
.hero__eyebrow{color:var(--brass);}
.hero__title{font-size:var(--fs-hero);font-weight:500;letter-spacing:-.01em;margin:0 0 1.4rem;max-width:14ch;}
.hero__title em{font-style:italic;font-weight:500;color:var(--brass);
  text-shadow:none;}
.hero__sub{font-family:var(--display);font-style:italic;font-size:var(--fs-lead);
  color:var(--cream-70);margin:0 0 .4rem;}
.hero__addr{font-family:var(--label);text-transform:uppercase;letter-spacing:.24em;
  font-size:.72rem;color:var(--cream-55);margin:0 0 2.4rem;}
.hero__cta{display:flex;flex-wrap:wrap;gap:1rem;}
.hero__scroll{position:absolute;left:50%;bottom:2rem;transform:translateX(-50%);z-index:1;
  font-family:var(--label);text-transform:uppercase;letter-spacing:.24em;font-size:.62rem;
  color:var(--cream-55);display:flex;flex-direction:column;align-items:center;gap:.6rem;}
.hero__scroll span{display:block;width:1px;height:42px;background:linear-gradient(var(--brass),transparent);
  animation:scrollpulse 2.4s var(--ease) infinite;}
@keyframes scrollpulse{0%{transform:scaleY(.3);transform-origin:top;opacity:.3;}50%{transform:scaleY(1);opacity:1;}100%{transform:scaleY(.3);transform-origin:bottom;opacity:.3;}}

/* Reveal-on-load for hero children (only hidden when JS is active) */
.js .reveal-up{opacity:0;transform:translateY(22px);}
.hero.is-ready .reveal-up{opacity:1;transform:none;transition:opacity 1s var(--ease),transform 1s var(--ease);}
.hero.is-ready .reveal-up:nth-child(1){transition-delay:.15s;}
.hero.is-ready .reveal-up:nth-child(2){transition-delay:.3s;}
.hero.is-ready .reveal-up:nth-child(3){transition-delay:.42s;}
.hero.is-ready .reveal-up:nth-child(4){transition-delay:.54s;}
.hero.is-ready .reveal-up:nth-child(5){transition-delay:.66s;}

/* ============================================================
   SECTIONS
   ============================================================ */
.section{padding-block:clamp(4rem,9vw,8rem);}
.section--tight{padding-block:clamp(3rem,6vw,5rem);}
.section--dark{background:var(--espresso);color:var(--cream);}
.section--parchment{background:var(--parchment);}
.section-head{text-align:center;max-width:62ch;margin:0 auto clamp(2.5rem,5vw,4rem);}
.section-head .divider{margin-bottom:1.6rem;}
.section-head h2{font-size:var(--fs-h2);margin:0 0 1rem;}
.section-head .lead{margin:0 auto;}
.section--dark .section-head h2,.section--dark .lead{color:var(--cream);}
.section--dark .lead{color:var(--cream-70);}

/* Alternating feature rows */
.feature{display:grid;grid-template-columns:1fr 1fr;align-items:center;gap:clamp(2rem,6vw,5rem);}
.feature + .feature{margin-top:clamp(4rem,8vw,7rem);}
.feature__media{position:relative;}
.feature__media img{width:100%;aspect-ratio:1/1;object-fit:cover;border-radius:var(--radius);}
.feature__media::before{content:"";position:absolute;inset:14px -14px -14px 14px;border:1px solid var(--brass);
  border-radius:var(--radius);z-index:-1;opacity:.55;}
.feature--rev .feature__media::before{inset:14px 14px -14px -14px;}
.feature--rev .feature__text{order:-1;}
.feature__text h3{font-size:var(--fs-display);margin:0 0 .4rem;line-height:1.04;}
.feature__sub{font-family:var(--display);font-style:italic;font-size:var(--fs-lead);
  color:var(--burgundy);margin:0 0 1.4rem;}
.feature__text .btn,.feature__text .tlink{margin-top:.5rem;}
@media (max-width:780px){
  .feature{grid-template-columns:1fr;gap:1.8rem;}
  .feature--rev .feature__text{order:0;}
  .feature__media::before{display:none;}
}

/* Pillar cards with iconography */
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.2rem,2.4vw,1.8rem);}
.pillar{position:relative;text-align:center;padding:clamp(2rem,3vw,2.8rem) clamp(1.4rem,2vw,2rem);
  border:1px solid var(--line-dark);border-radius:var(--radius);background:rgba(244,237,225,.025);
  transition:transform .5s var(--ease),border-color .5s var(--ease),background .5s var(--ease),box-shadow .5s var(--ease);}
.pillar:hover{transform:translateY(-8px);border-color:rgba(176,141,87,.6);
  background:rgba(176,141,87,.06);box-shadow:0 22px 50px -28px rgba(0,0,0,.6);}
.pillar__icon{width:48px;height:48px;margin:0 auto 1.3rem;display:grid;place-items:center;}
.pillar__icon svg{width:100%;height:100%;stroke:var(--brass);fill:none;
  transition:transform .5s var(--ease);}
.pillar:hover .pillar__icon svg{transform:scale(1.08) rotate(-2deg);}
.pillar h3{font-size:var(--fs-h3);margin:0 0 .5rem;color:var(--cream);}
.pillar p{color:var(--cream-70);font-size:.96rem;margin:0;}
.pillar .num{font-family:var(--label);font-size:.68rem;letter-spacing:.28em;color:var(--brass);
  display:block;margin-bottom:.7rem;text-transform:uppercase;}
@media (max-width:720px){.pillars{grid-template-columns:1fr;gap:1.1rem;}}

/* ============================================================
   CARDS (events, blog)
   ============================================================ */
.card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.4rem,3vw,2.2rem);}
.card-grid--2{grid-template-columns:repeat(2,1fr);}
@media (max-width:880px){.card-grid,.card-grid--2{grid-template-columns:1fr;}}
.card{background:var(--parchment);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);}
.section--dark .card{background:#2a2420;border-color:var(--line-dark);}
.card:hover{transform:translateY(-5px);box-shadow:0 22px 44px rgba(31,26,23,.13);}
.card__media{aspect-ratio:1/1;overflow:hidden;}
.card__media img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease);}
.card:hover .card__media img{transform:scale(1.05);}
.card__body{padding:1.7rem 1.7rem 1.9rem;display:flex;flex-direction:column;flex:1;}
.card__tag{font-family:var(--label);text-transform:uppercase;letter-spacing:.22em;
  font-size:.64rem;color:var(--burgundy);margin-bottom:.85rem;}
.section--dark .card__tag{color:var(--brass);}
.card__title{font-size:var(--fs-h3);margin:0 0 .7rem;line-height:1.1;}
.card__body p{font-size:.96rem;color:var(--espresso-70);margin:0 0 1.3rem;}
.section--dark .card__body p{color:var(--cream-70);}
.card__body p:last-child{margin-bottom:0;}
.card__body .tlink{margin-top:auto;color:var(--burgundy);}
.resv-welcome{max-width:60ch;margin:1.8rem auto 0;text-align:center;
  font-size:1.02rem;line-height:1.7;color:var(--espresso-90);}
.card__body .tlink{margin-top:auto;}

/* ============================================================
   MENU / CELLAR LIST
   ============================================================ */
.menu-nav{position:sticky;top:84px;z-index:40;background:var(--cream);
  border-bottom:1px solid var(--line);box-shadow:0 8px 22px -16px rgba(31,26,23,.4);}
.menu-nav ul{display:flex;justify-content:center;gap:1.9rem;overflow-x:auto;padding:.9rem var(--gutter);
  max-width:var(--maxw);margin-inline:auto;scrollbar-width:none;}
.menu-nav ul::-webkit-scrollbar{display:none;}
.menu-nav a{font-family:var(--label);text-transform:uppercase;letter-spacing:.18em;
  font-size:.68rem;color:var(--espresso-70);white-space:nowrap;flex:none;padding-bottom:2px;
  border-bottom:1px solid transparent;transition:color .3s,border-color .3s;}
.menu-nav a:hover{color:var(--burgundy);border-color:var(--burgundy);}
@media (max-width:760px){.menu-nav ul{justify-content:flex-start;}}

.menu-group{margin-bottom:clamp(3rem,6vw,5rem);scroll-margin-top:160px;}
.menu-group__head{text-align:center;margin-bottom:2.4rem;}
.menu-group__head .eyebrow{margin-bottom:1rem;}
.menu-group__head h2{font-size:var(--fs-h2);}
.menu-columns{columns:2;column-gap:clamp(2.5rem,6vw,5rem);}
@media (max-width:720px){.menu-columns{columns:1;}}
.menu-item{break-inside:avoid;text-align:center;margin-bottom:2rem;padding-bottom:0;}
.menu-item__name{font-family:var(--display);font-weight:600;font-size:1.45rem;line-height:1.2;margin:0 0 .25rem;}
.menu-item__desc{font-family:var(--display);font-style:italic;font-size:1.08rem;line-height:1.4;
  color:var(--espresso-70);margin:0 0 .4rem;}
.menu-item__allergen{font-family:var(--label);font-size:.6rem;letter-spacing:.18em;color:var(--brass);}
.menu-item__price{font-family:var(--label);font-weight:600;font-size:.82rem;letter-spacing:.08em;
  color:var(--espresso);margin-top:.35rem;}
.menu-item__price .sep{color:var(--stone);margin:0 .5em;}

.menu-note{text-align:center;font-size:.86rem;color:var(--espresso-70);font-style:italic;
  font-family:var(--display);max-width:60ch;margin:2rem auto 0;}
.allergen-key{text-align:center;font-family:var(--label);font-size:.66rem;letter-spacing:.12em;
  text-transform:uppercase;color:var(--espresso-70);margin-top:2.5rem;line-height:2;}

/* Two-column menu band split (food | drink quick switch) */
.menu-split{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(2rem,5vw,4rem);}
@media (max-width:720px){.menu-split{grid-template-columns:1fr;}}

/* Happy Hour */
.menu-group--hh{background:var(--parchment);border:1px solid var(--stone-40);
  border-radius:4px;padding:clamp(2rem,5vw,3.5rem);margin-top:1rem;}
.hh-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.6rem 3rem;
  max-width:820px;margin:0 auto;}
.hh-item{padding:1.4rem 0;border-top:1px solid var(--stone-40);}
.hh-item__name{font-family:var(--display);font-weight:600;font-size:1.5rem;
  color:var(--burgundy);line-height:1.15;}
.hh-item__desc{font-size:.92rem;color:var(--espresso-70);margin-top:.35rem;line-height:1.5;}
@media (max-width:680px){.hh-grid{grid-template-columns:1fr;gap:0;}}

/* Events */
.event-schedule{font-family:var(--label);text-transform:uppercase;letter-spacing:.18em;
  font-size:.74rem;color:var(--brass);margin-top:.4rem;}
.event-card__when{font-family:var(--label);text-transform:uppercase;letter-spacing:.14em;
  font-size:.66rem;color:var(--burgundy);margin:.2rem 0 .7rem;}
.card__title a{color:inherit;text-decoration:none;background-image:linear-gradient(var(--brass),var(--brass));
  background-size:0% 1px;background-position:0 100%;background-repeat:no-repeat;transition:background-size .35s var(--ease);}
.card__title a:hover{background-size:100% 1px;}

/* FAQ */
.faq{max-width:760px;margin:0 auto;}
.faq-item{border-top:1px solid var(--stone-40);}
.faq-item:last-child{border-bottom:1px solid var(--stone-40);}
.faq-item summary{cursor:pointer;list-style:none;padding:1.3rem 2.2rem 1.3rem 0;position:relative;
  font-family:var(--display);font-size:1.4rem;color:var(--espresso);line-height:1.3;}
.faq-item summary::-webkit-details-marker{display:none;}
.faq-item summary::after{content:"+";position:absolute;right:0;top:1.15rem;font-family:var(--display);
  font-size:1.6rem;color:var(--burgundy);transition:transform .3s var(--ease);}
.faq-item[open] summary::after{transform:rotate(45deg);}
.faq-answer{padding:0 0 1.4rem;}
.faq-answer p{font-size:.98rem;color:var(--espresso-70);line-height:1.7;max-width:64ch;}

/* ============================================================
   PAGE HERO (interior pages)
   ============================================================ */
.page-hero{background:var(--espresso);color:var(--cream);padding-block:clamp(7rem,12vw,9rem) clamp(3rem,6vw,4.5rem);
  text-align:center;position:relative;overflow:hidden;}
.page-hero__inner{position:relative;z-index:1;}
.page-hero .eyebrow{color:var(--brass);}
.page-hero h1{font-size:var(--fs-display);margin:0 0 1.2rem;}
.page-hero p{color:var(--cream-70);font-size:var(--fs-lead);max-width:58ch;margin-inline:auto;}
.page-hero .divider{margin-top:1.6rem;}

/* ============================================================
   RICH TEXT / PROSE
   ============================================================ */
.prose{max-width:68ch;margin-inline:auto;}
.prose h2{font-size:var(--fs-h3);margin:2.4rem 0 1rem;}
.prose p{color:var(--espresso-90);}
.prose .lead{color:var(--espresso-70);margin-bottom:1.6rem;}
.prose a:not(.btn):not(.tlink){color:var(--burgundy);text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1px;}

/* Info grid (contact, details) */
.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:2.5rem;}
.info-block .eyebrow{margin-bottom:.7rem;}
.info-block p{margin:0 0 .3rem;color:var(--espresso-90);}
.info-block a{color:var(--burgundy);}

.hours-list{font-family:var(--body);}
.hours-list li{display:flex;justify-content:space-between;gap:1.5rem;padding:.55rem 0;
  border-bottom:1px solid var(--line);font-size:.98rem;}
.hours-list li:last-child{border-bottom:0;}
.hours-list .day{font-family:var(--label);text-transform:uppercase;letter-spacing:.12em;font-size:.72rem;
  color:var(--espresso);align-self:center;}
.hours-list .time{color:var(--espresso-70);}
.hours-list .closed{color:var(--stone);font-style:italic;}
.special-days-head{font-family:var(--label);text-transform:uppercase;letter-spacing:.14em;
  font-size:.62rem;color:var(--stone);margin:1.8rem 0 .2rem;}
.special-days{font-family:var(--body);}
.special-days li{display:flex;justify-content:space-between;gap:1rem;padding:.55rem 0;
  font-size:.8rem;border-bottom:1px solid var(--stone-30,rgba(205,187,164,.3));}
.special-days li:last-child{border-bottom:0;}
.special-days .day{color:var(--espresso-70);font-weight:500;white-space:nowrap;}
.special-days .time{color:var(--stone);text-align:right;font-style:italic;}

/* OpenTable widgets */
.ot-widget{min-height:240px;display:flex;justify-content:center;}
.ot-widget iframe{width:100%!important;max-width:100%;}
.ot-comms{max-width:560px;margin:0 auto;background:var(--cream);border-radius:var(--radius);
  overflow:hidden;}
.ot-comms iframe{width:100%;border:0;display:block;min-height:480px;}

/* CTA band */
.cta-band{background:var(--espresso);color:var(--cream);text-align:center;
  padding-block:clamp(3.5rem,7vw,6rem);}
.cta-band h2{font-size:var(--fs-display);margin:0 0 1rem;color:var(--cream);}
.cta-band p{color:var(--cream-70);max-width:52ch;margin:0 auto 2rem;font-size:var(--fs-lead);}
.cta-band .divider span{background:var(--brass);}
.cta-band .divider::before,.cta-band .divider::after{background:var(--line-dark);}
.cta-band .btn{background:var(--brass);border-color:var(--brass);color:var(--espresso);}
.cta-band .btn:hover{background:var(--cream);border-color:var(--cream);color:var(--espresso);}

/* Happy Hour promo band */
.hh-promo{background:var(--espresso);color:var(--cream);padding-block:clamp(2.6rem,5vw,3.8rem);}
.hh-promo__inner{display:flex;align-items:center;justify-content:space-between;gap:2rem;flex-wrap:wrap;}
.hh-promo .eyebrow{color:var(--brass);}
.hh-promo h2{font-size:var(--fs-h2);color:var(--cream);margin:.4rem 0 .6rem;}
.hh-promo p{color:var(--cream-70);max-width:50ch;margin:0;}
.hh-promo .btn{flex:none;background:var(--brass);border-color:var(--brass);color:var(--espresso);
  box-shadow:0 2px 18px rgba(176,141,87,.28);}
.hh-promo .btn:hover{background:var(--cream);border-color:var(--cream);color:var(--espresso);}
@media (max-width:680px){.hh-promo__inner{flex-direction:column;align-items:flex-start;gap:1.4rem;}}

/* Reviews embed */
.reviews-embed{margin-top:2.2rem;min-height:200px;}

/* Rewards page blocks */
.rw-block{max-width:60ch;margin:0 auto;text-align:center;}
.rw-block h2{font-size:var(--fs-h2);margin:.3rem 0 .4rem;}
.rw-block p:last-child{color:var(--espresso-70);font-size:1.02rem;line-height:1.8;margin:0;}
.rw-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;max-width:680px;
  margin:2.6rem auto 0;text-align:center;}
.rw-stat{padding:1.7rem 1rem;border:1px solid var(--line);border-radius:var(--radius);
  background:var(--cream);transition:transform .45s var(--ease),border-color .45s var(--ease),box-shadow .45s var(--ease);}
.rw-stat:hover{transform:translateY(-6px);border-color:var(--brass);box-shadow:0 18px 40px -24px rgba(31,26,23,.35);}
.rw-stat__num{display:block;font-family:var(--display);font-size:2.7rem;color:var(--brass);line-height:1;}
.rw-stat__label{display:block;margin-top:.55rem;font-family:var(--label);text-transform:uppercase;
  letter-spacing:.12em;font-size:.62rem;color:var(--espresso-70);}
@media (max-width:600px){.rw-stats{grid-template-columns:1fr;}}

/* Gallery grid (Stellina-inspired) */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:.85rem;}
.gallery figure{margin:0;overflow:hidden;border-radius:var(--radius);position:relative;background:var(--stone);}
.gallery img{width:100%;height:100%;object-fit:cover;display:block;aspect-ratio:1/1;
  transition:transform .8s var(--ease);}
.gallery figure:hover img{transform:scale(1.06);}
@media (max-width:760px){
  .gallery{grid-template-columns:repeat(2,1fr);gap:.6rem;}
}

/* Embed wrapper (reservations / forms) */
.embed-card{background:var(--parchment);border:1px solid var(--line);border-radius:var(--radius);
  padding:clamp(1.5rem,4vw,2.5rem);}
.embed-card iframe{width:100%;border:0;display:block;border-radius:var(--radius);}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{background:var(--espresso);color:var(--cream-70);
  padding-block:clamp(3.5rem,6vw,5rem) 2rem;}
.footer-top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.15fr;gap:clamp(1.6rem,3vw,2.6rem);
  padding-bottom:3rem;border-bottom:1px solid var(--line-dark);}
@media (max-width:880px){.footer-top{grid-template-columns:1fr 1fr;gap:2.5rem;}}
@media (max-width:520px){.footer-top{grid-template-columns:1fr;}}
.footer-brand img{width:200px;margin-bottom:1.4rem;}
.footer-brand p{font-size:.92rem;color:var(--cream-70);max-width:34ch;}
.footer-brand .tagline{font-family:var(--display);font-style:italic;font-size:1.25rem;color:var(--cream);margin-bottom:1rem;}
.footer-col h4{font-family:var(--label);font-weight:600;text-transform:uppercase;letter-spacing:.2em;
  font-size:.66rem;color:var(--brass);margin:0 0 1.2rem;}
.footer-col li{margin-bottom:.7rem;}
.footer-col a{font-size:.92rem;color:var(--cream-70);transition:color .3s var(--ease);}
.footer-col a:hover{color:var(--cream);}
.footer-social{display:flex;gap:1rem;margin-top:.3rem;flex-wrap:wrap;}
.footer-social a{display:grid;place-items:center;width:38px;height:38px;border:1px solid var(--line-dark);
  border-radius:50%;transition:background .3s var(--ease),border-color .3s var(--ease);}
.footer-social a:hover{background:var(--brass);border-color:var(--brass);}
.footer-social svg{width:16px;height:16px;fill:var(--cream-70);transition:fill .3s var(--ease);}
.footer-social a:hover svg{fill:var(--espresso);}
.footer-brand .footer-social{margin-top:1.3rem;}
.footer-hours{margin:0 0 .9rem;}
.footer-hours li{display:flex;justify-content:space-between;gap:.6rem;margin-bottom:.45rem;
  font-size:.82rem;color:var(--cream-70);}
.footer-hours .d{font-family:var(--label);text-transform:uppercase;letter-spacing:.08em;
  font-size:.66rem;color:var(--brass);white-space:nowrap;padding-top:.15rem;}
.footer-hours .t{text-align:right;}
.footer-meta{font-size:.8rem;color:var(--cream-70);margin-top:.5rem;line-height:1.5;}
.footer-meta a{color:var(--cream-70);transition:color .3s var(--ease);}
.footer-meta a:hover{color:var(--brass);}
.footer-bottom{display:flex;flex-wrap:wrap;justify-content:space-between;gap:1rem;
  padding-top:2rem;font-size:.78rem;color:var(--cream-55);align-items:center;}
.footer-bottom a{color:var(--cream-55);text-decoration:underline;text-underline-offset:3px;}
.footer-bottom a:hover{color:var(--cream);}
.footer-legal{font-size:.74rem;color:var(--cream-55);max-width:60ch;margin-top:1rem;line-height:1.6;}

/* ============================================================
   SCROLL REVEAL
   ============================================================ */
.js .reveal{opacity:0;transform:translateY(28px);}
.reveal{transition:opacity .9s var(--ease),transform .9s var(--ease);}
.reveal.is-visible{opacity:1;transform:none;}
@media (prefers-reduced-motion:reduce){
  .reveal,.reveal-up{opacity:1!important;transform:none!important;transition:none!important;}
  .hero__media img{transform:none!important;}
  .hero__scroll span{animation:none;}
}

/* ============================================================
   FORMS (feedback / careers / newsletter)
   ============================================================ */
.field{margin-bottom:1.3rem;}
.field label{display:block;font-family:var(--label);text-transform:uppercase;letter-spacing:.14em;
  font-size:.66rem;color:var(--espresso);margin-bottom:.5rem;}
.field input,.field textarea,.field select{width:100%;padding:.85rem 1rem;border:1px solid var(--line);
  background:var(--cream);border-radius:var(--radius);font-family:var(--body);font-size:.98rem;color:var(--espresso);
  transition:border-color .3s var(--ease);}
.field input:focus,.field textarea:focus,.field select:focus{border-color:var(--burgundy);outline:none;}
.field textarea{min-height:140px;resize:vertical;}
.form-note{font-size:.78rem;color:var(--espresso-70);margin-top:1rem;}

/* Newsletter inline */
.newsletter{display:flex;gap:.8rem;flex-wrap:wrap;max-width:480px;margin-inline:auto;}
.newsletter input{flex:1;min-width:200px;}

/* ---------- Reservation bar (home + reservations, Stellina-style) ---------- */
.resv{background:var(--espresso);color:var(--cream);}
.resv__head{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:1.2rem 2rem;margin-bottom:1.8rem;}
.resv__head .eyebrow{color:var(--brass);}
.resv__head h2{font-size:var(--fs-display);margin:.4rem 0 0;line-height:1;}
.resv__note{max-width:34ch;color:var(--cream-70);font-size:.95rem;margin:0;line-height:1.6;}
.resv__note a{color:var(--brass);}
.resv-bar{display:grid;grid-template-columns:1.3fr 1fr 1fr auto;background:var(--cream);
  border:1px solid rgba(31,26,23,.14);border-radius:4px;overflow:hidden;align-items:stretch;
  box-shadow:0 18px 40px rgba(31,26,23,.18);}
.resv-field{display:flex;flex-direction:column;gap:.35rem;padding:1rem 1.25rem;
  border-right:1px solid rgba(31,26,23,.12);min-width:0;}
.resv-field label{font-family:var(--label);text-transform:uppercase;letter-spacing:.2em;
  font-size:.58rem;color:var(--espresso-70);}
.resv-field input,.resv-field select{border:0;background:transparent;font-family:var(--body);
  font-size:1rem;line-height:1.2;color:var(--espresso);padding:0;width:100%;
  -webkit-appearance:none;appearance:none;cursor:pointer;}
.resv-field input::-webkit-calendar-picker-indicator{opacity:.5;cursor:pointer;}
.resv-field input:focus,.resv-field select:focus{outline:none;}
.resv-submit{border:0;background:var(--espresso);color:var(--cream);font-family:var(--label);
  text-transform:uppercase;letter-spacing:.2em;font-size:.7rem;padding:1rem 2.2rem;cursor:pointer;
  white-space:nowrap;transition:background .3s var(--ease);}
.resv-submit:hover{background:var(--burgundy);}
@media (max-width:760px){
  .resv-bar{grid-template-columns:1fr;}
  .resv-field{border-right:0;border-bottom:1px solid rgba(31,26,23,.12);}
  .resv-submit{padding:1.15rem;}
}

/* ---------- Founder quote ---------- */
.founder__inner{max-width:62ch;margin-inline:auto;text-align:center;}
.founder__mark{font-family:var(--display);font-size:3.4rem;line-height:.6;color:var(--brass);
  margin:0 0 .8rem;}
.founder blockquote{font-family:var(--display);font-style:italic;
  font-size:clamp(1.5rem,3.2vw,2.2rem);line-height:1.4;color:var(--espresso);margin:0 0 1.6rem;}
.founder__cite{font-family:var(--label);text-transform:uppercase;letter-spacing:.18em;
  font-size:.68rem;color:var(--espresso-70);font-style:normal;line-height:1.7;}
.founder__cite strong{display:block;font-size:.78rem;letter-spacing:.16em;color:var(--espresso);}

/* ---------- Events calendar embed ---------- */
.events-embed{margin-top:1.6rem;min-height:300px;}
