:root{
  --green-deep:#0f2218;
  --green-dark:#1a3320;
  --green-mid:#2d5a2d;
  --green-accent:#4a8c4a;
  --green-light:#a8c990;
  --green-pale:#e8f4e0;
  --cream:#f7f3ed;
  --cream-warm:#ede8e0;
  --gold:#c9a06a;
  --gold-light:#e8c88a;
  --white:#ffffff;
  --text-dark:#0f1a0f;
  --text-mid:#3a5a3a;
  --text-muted:#6a8a6a;
  --ff-display:"Cormorant Garamond",serif;
  --ff-body:"DM Sans",sans-serif;
  --transition:cubic-bezier(.4,0,.2,1);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--ff-body);background:var(--cream);color:var(--text-dark);overflow-x:hidden}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}

/* ─── SCROLLBAR ─── */
::-webkit-scrollbar{width:4px}
::-webkit-scrollbar-track{background:var(--cream)}
::-webkit-scrollbar-thumb{background:var(--green-accent)}

/* ─── NAV ─── */
#navbar{position:fixed;top:0;left:0;right:0;z-index:1000;padding:20px 5vw;display:flex;align-items:center;justify-content:space-between;transition:all .4s var(--transition)}
#navbar.scrolled{background:rgba(15,34,24,.95);backdrop-filter:blur(12px);padding:14px 5vw}
.nav-logo{height:44px;transition:opacity .3s}
.nav-logo:hover{opacity:.8}
.nav-links{display:flex;align-items:center;gap:32px}
.nav-links a{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.85);font-weight:500;transition:color .2s;position:relative}
.nav-links a::after{content:'';position:absolute;bottom:-3px;left:0;width:0;height:1px;background:var(--gold);transition:width .3s}
.nav-links a:hover{color:var(--gold-light)}
.nav-links a:hover::after{width:100%}
.nav-cta{background:var(--gold);color:var(--green-deep)!important;padding:10px 22px!important;border-radius:2px;letter-spacing:.1em!important}
.nav-cta:hover{background:var(--gold-light)!important}
.nav-cta::after{display:none!important}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:4px}
.hamburger span{display:block;width:24px;height:1.5px;background:#fff;transition:all .3s}
#mobile-menu{display:none;position:fixed;inset:0;background:var(--green-deep);z-index:999;flex-direction:column;align-items:center;justify-content:center;gap:32px}
#mobile-menu.open{display:flex}
#mobile-menu a{font-family:var(--ff-display);font-size:2rem;color:var(--cream);font-weight:300;letter-spacing:.04em}
#mobile-menu a:hover{color:var(--gold)}
.mob-close{position:absolute;top:24px;right:5vw;font-size:28px;color:var(--cream);cursor:pointer;background:none;border:none}

/* ─── HERO ─── */
#hero{height:100vh;min-height:600px;background:var(--green-deep);position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden}
.hero-bg{position:absolute;inset:0;background:
  radial-gradient(ellipse 70% 60% at 30% 40%,rgba(74,140,74,.18) 0%,transparent 60%),
  radial-gradient(ellipse 50% 80% at 80% 70%,rgba(201,160,106,.08) 0%,transparent 50%),
  linear-gradient(160deg,#0a1a10 0%,#1a3320 50%,#0f2218 100%);
}
.hero-pattern{position:absolute;inset:0;opacity:.04;background-image:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' stroke='%23a8c990' stroke-width='.5'%3E%3Ccircle cx='30' cy='30' r='20'/%3E%3Ccircle cx='30' cy='30' r='10'/%3E%3Cline x1='10' y1='30' x2='50' y2='30'/%3E%3Cline x1='30' y1='10' x2='30' y2='50'/%3E%3C/g%3E%3C/svg%3E");background-size:60px 60px}
.hero-inner{position:relative;text-align:center;padding:0 5vw;max-width:900px}
.hero-tag{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin-bottom:28px;opacity:0;animation:fadeUp .8s .3s var(--transition) forwards}
.hero-logo{height:90px;margin:0 auto 32px;opacity:0;animation:fadeUp .8s .5s var(--transition) forwards;filter:drop-shadow(0 0 40px rgba(168,201,144,.15))}
.hero-h1{font-family:var(--ff-display);font-size:clamp(3.2rem,8vw,6.5rem);font-weight:300;color:var(--cream);line-height:1.05;letter-spacing:-.01em;opacity:0;animation:fadeUp .9s .7s var(--transition) forwards}
.hero-h1 em{font-style:italic;color:var(--green-light)}
.hero-sub{font-size:14px;color:rgba(247,243,237,.6);letter-spacing:.12em;text-transform:uppercase;margin-top:20px;opacity:0;animation:fadeUp .8s .9s var(--transition) forwards;font-weight:300}
.hero-btns{display:flex;gap:16px;justify-content:center;margin-top:40px;opacity:0;animation:fadeUp .8s 1.1s var(--transition) forwards;flex-wrap:wrap}
.btn-primary{background:var(--gold);color:var(--green-deep);padding:15px 36px;font-size:12px;letter-spacing:.14em;text-transform:uppercase;font-weight:600;border-radius:2px;transition:all .25s;font-family:var(--ff-body)}
.btn-primary:hover{background:var(--gold-light);transform:translateY(-2px)}
.btn-outline{border:1px solid rgba(247,243,237,.4);color:var(--cream);padding:15px 36px;font-size:12px;letter-spacing:.14em;text-transform:uppercase;font-weight:400;border-radius:2px;transition:all .25s;font-family:var(--ff-body)}
.btn-outline:hover{border-color:var(--gold);color:var(--gold);transform:translateY(-2px)}
.hero-scroll{position:absolute;bottom:36px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;opacity:0;animation:fadeIn 1s 1.6s forwards}
.hero-scroll span{font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:rgba(247,243,237,.4)}
.scroll-line{width:1px;height:48px;background:linear-gradient(to bottom,var(--gold),transparent);animation:scrollPulse 2s infinite}
@keyframes scrollPulse{0%,100%{opacity:.4;transform:scaleY(1)}50%{opacity:1;transform:scaleY(1.1)}}

/* ─── STORY BAND ─── */
#story{padding:80px 5vw;background:var(--cream)}
.story-inner{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.story-label{font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--green-accent);margin-bottom:16px;font-weight:600}
.story-h2{font-family:var(--ff-display);font-size:clamp(2.2rem,4vw,3.4rem);color:var(--green-deep);font-weight:300;line-height:1.2;margin-bottom:24px}
.story-h2 em{font-style:italic;color:var(--green-mid)}
.story-p{font-size:15px;color:var(--text-mid);line-height:1.8;font-weight:300;margin-bottom:16px}
.story-stats{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:40px}
.stat{border-left:2px solid var(--green-light);padding-left:16px}
.stat-num{font-family:var(--ff-display);font-size:2.4rem;color:var(--green-dark);font-weight:300;line-height:1}
.stat-lbl{font-size:11px;color:var(--text-muted);letter-spacing:.08em;margin-top:4px}
.story-visual{position:relative}
.story-card{background:var(--green-dark);border-radius:4px;padding:48px 40px;position:relative;overflow:hidden}
.story-card::before{content:'';position:absolute;top:-40px;right:-40px;width:200px;height:200px;border-radius:50%;background:rgba(168,201,144,.08)}
.story-card-quote{font-family:var(--ff-display);font-size:1.6rem;font-style:italic;color:var(--cream);line-height:1.5;font-weight:300;position:relative;z-index:1}
.story-card-quote::before{content:'"';font-size:5rem;color:var(--green-light);opacity:.3;position:absolute;top:-20px;left:-10px;font-family:var(--ff-display);line-height:1}
.story-card-attr{font-size:11px;letter-spacing:.12em;color:var(--green-light);margin-top:20px;text-transform:uppercase;position:relative;z-index:1}
.house-rules{margin-top:32px;background:var(--green-pale);border-radius:4px;padding:24px}
.rules-title{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--green-accent);margin-bottom:12px;font-weight:600}
.rules-list{list-style:none;display:flex;flex-direction:column;gap:8px}
.rules-list li{font-size:12.5px;color:var(--text-mid);display:flex;align-items:flex-start;gap:8px;line-height:1.5}
.rules-list li::before{content:'—';color:var(--green-accent);flex-shrink:0;margin-top:1px}

/* ─── MENU SECTION ─── */
#menu{background:var(--green-deep);padding:0 0 80px}
.menu-hero{height:220px;background:linear-gradient(160deg,var(--green-deep) 0%,var(--green-mid) 100%);display:flex;align-items:flex-end;padding:0 5vw 40px;position:relative;overflow:hidden}
.menu-hero::after{content:'MENU';position:absolute;right:-2vw;bottom:-20px;font-family:var(--ff-display);font-size:clamp(6rem,14vw,12rem);color:rgba(255,255,255,.03);font-weight:300;letter-spacing:-.02em;pointer-events:none}
.menu-hero-inner{max-width:1100px;width:100%}
.menu-label{font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin-bottom:8px;font-weight:600}
.menu-h2{font-family:var(--ff-display);font-size:clamp(2.4rem,5vw,4rem);color:var(--cream);font-weight:300;line-height:1.1}
.menu-h2 em{font-style:italic;color:var(--green-light)}

/* TABS */
.menu-tabs-wrap{background:rgba(255,255,255,.04);border-bottom:1px solid rgba(255,255,255,.08);position:sticky;top:72px;z-index:50;backdrop-filter:blur(8px)}
.menu-tabs{display:flex;overflow-x:auto;max-width:1100px;margin:0 auto;padding:0 5vw;scrollbar-width:none;gap:0}
.menu-tabs::-webkit-scrollbar{display:none}
.tab-btn{background:none;border:none;font-family:var(--ff-body);font-size:11.5px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:rgba(247,243,237,.45);padding:18px 20px;cursor:pointer;white-space:nowrap;border-bottom:2px solid transparent;transition:all .25s;position:relative}
.tab-btn.active{color:var(--gold);border-bottom-color:var(--gold)}
.tab-btn:hover:not(.active){color:rgba(247,243,237,.8)}

/* MENU CONTENT */
.menu-content{max-width:1100px;margin:0 auto;padding:48px 5vw 0}
.menu-pane{display:none}
.menu-pane.active{display:block}
.menu-section-title{font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:24px;padding-bottom:8px;border-bottom:1px solid rgba(255,255,255,.08);font-weight:600}

/* MENU GRID */
.menu-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1px;background:rgba(255,255,255,.06);border-radius:4px;overflow:hidden;margin-bottom:40px}
.menu-item{background:rgba(255,255,255,.02);padding:20px 24px;cursor:pointer;transition:background .2s;display:flex;justify-content:space-between;align-items:flex-start;gap:16px}
.menu-item:hover{background:rgba(168,201,144,.08)}
.menu-item-left{flex:1;min-width:0}
.item-badges{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:6px}
.badge{font-size:9px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;padding:2px 8px;border-radius:2px}
.badge-best{background:rgba(201,160,106,.2);color:var(--gold)}
.badge-chef{background:rgba(74,140,74,.2);color:var(--green-light)}
.badge-sig{background:rgba(168,201,144,.15);color:var(--green-light)}
.badge-new{background:rgba(255,255,255,.1);color:rgba(247,243,237,.8)}
.badge-spicy{background:rgba(180,50,30,.2);color:#f08070}
.item-name{font-family:var(--ff-display);font-size:16.5px;color:var(--cream);font-weight:400;line-height:1.3}
.item-desc{font-size:11.5px;color:rgba(247,243,237,.45);margin-top:4px;line-height:1.6;font-weight:300}
.item-tags{display:flex;gap:6px;margin-top:8px;flex-wrap:wrap}
.temp-tag{font-size:9px;padding:2px 7px;border-radius:2px;font-weight:500;letter-spacing:.06em}
.tag-hot{background:rgba(180,100,30,.2);color:#e8a87a}
.tag-ice{background:rgba(30,100,180,.2);color:#7aaae8}
.item-right{text-align:right;flex-shrink:0}
.item-price{font-family:var(--ff-display);font-size:18px;color:var(--cream);font-weight:300;white-space:nowrap}
.item-price small{font-size:11px;font-family:var(--ff-body);color:rgba(247,243,237,.4);display:block;margin-top:2px;letter-spacing:.04em}

/* STEAK BUILDER */
.steak-card{background:rgba(255,255,255,.03);border:1px solid rgba(201,160,106,.2);border-radius:4px;padding:32px;margin-bottom:40px}
.steak-header{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:16px;margin-bottom:28px;padding-bottom:20px;border-bottom:1px solid rgba(255,255,255,.08)}
.steak-name{font-family:var(--ff-display);font-size:1.8rem;color:var(--cream);font-weight:300}
.steak-price{font-family:var(--ff-display);font-size:2rem;color:var(--gold);font-weight:300}
.steak-desc{font-size:13px;color:rgba(247,243,237,.5);line-height:1.7;margin-bottom:24px}
.builder-row{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:20px}
.builder-label{font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-bottom:12px;font-weight:600}
.builder-opts{display:flex;flex-wrap:wrap;gap:8px}
.opt{font-size:11px;padding:6px 14px;border:1px solid rgba(255,255,255,.15);border-radius:2px;color:rgba(247,243,237,.7);cursor:pointer;transition:all .2s}
.opt:hover,.opt.selected{border-color:var(--gold);color:var(--gold);background:rgba(201,160,106,.08)}

/* MODAL */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(5,15,8,.85);z-index:2000;align-items:flex-end;justify-content:center;backdrop-filter:blur(4px)}
.modal-overlay.open{display:flex;animation:fadeIn .2s}
.modal-box{background:var(--green-dark);width:100%;max-width:540px;border-radius:12px 12px 0 0;padding:32px 28px 40px;position:relative;animation:slideUp .35s var(--transition)}
.modal-handle{width:40px;height:3px;background:rgba(255,255,255,.2);border-radius:2px;margin:0 auto 24px}
.modal-cat{font-size:9.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-bottom:6px;font-weight:600}
.modal-name{font-family:var(--ff-display);font-size:1.8rem;color:var(--cream);font-weight:300;margin-bottom:12px;line-height:1.2}
.modal-desc{font-size:13.5px;color:rgba(247,243,237,.65);line-height:1.7;margin-bottom:20px}
.modal-price-row{display:flex;align-items:center;justify-content:space-between;padding-top:16px;border-top:1px solid rgba(255,255,255,.08)}
.modal-price{font-family:var(--ff-display);font-size:1.6rem;color:var(--cream);font-weight:300}
.modal-note{font-size:10px;color:rgba(247,243,237,.4);margin-top:4px}
.modal-close-btn{position:absolute;top:20px;right:20px;background:rgba(255,255,255,.08);border:none;color:var(--cream);width:32px;height:32px;border-radius:50%;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;transition:background .2s}
.modal-close-btn:hover{background:rgba(255,255,255,.15)}
@keyframes slideUp{from{transform:translateY(60px);opacity:0}to{transform:translateY(0);opacity:1}}

/* ─── HOURS / INFO STRIP ─── */
#info{background:var(--cream-warm);padding:64px 5vw}
.info-inner{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:48px;align-items:start}
.info-block{}
.info-icon{width:36px;height:36px;background:var(--green-pale);border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:14px;font-size:16px}
.info-title{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--green-accent);margin-bottom:8px;font-weight:600}
.info-val{font-family:var(--ff-display);font-size:1.2rem;color:var(--green-dark);font-weight:400;line-height:1.4}
.info-sub{font-size:12.5px;color:var(--text-muted);margin-top:6px;line-height:1.6;font-weight:300}
.open-dot{display:inline-block;width:7px;height:7px;background:#4caf50;border-radius:50%;margin-right:6px;animation:blink 2s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}

/* ─── FOOTER ─── */
footer{background:var(--green-deep);padding:48px 5vw 28px;border-top:1px solid rgba(255,255,255,.06)}
.footer-inner{max-width:1100px;margin:0 auto}
.footer-top{display:flex;justify-content:space-between;align-items:flex-start;gap:40px;flex-wrap:wrap;padding-bottom:32px;border-bottom:1px solid rgba(255,255,255,.06);margin-bottom:24px}
.footer-logo{height:36px;opacity:.8}
.footer-links{display:flex;gap:28px;flex-wrap:wrap}
.footer-links a{font-size:11.5px;color:rgba(247,243,237,.45);letter-spacing:.1em;text-transform:uppercase;transition:color .2s}
.footer-links a:hover{color:var(--gold)}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}
.footer-copy{font-size:11px;color:rgba(247,243,237,.3)}
.footer-note{font-size:10px;color:rgba(247,243,237,.25)}

/* ─── ANIMATIONS ─── */
@keyframes fadeUp{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.reveal{opacity:0;transform:translateY(30px);transition:opacity .7s var(--transition),transform .7s var(--transition)}
.reveal.visible{opacity:1;transform:translateY(0)}

/* ─── RESPONSIVE ─── */
@media(max-width:900px){
  .story-inner{grid-template-columns:1fr;gap:40px}
  .info-inner{grid-template-columns:1fr 1fr}
  .builder-row{grid-template-columns:1fr}
}
@media(max-width:680px){
  .nav-links{display:none}
  .hamburger{display:flex}
  .menu-grid{grid-template-columns:1fr}
  .info-inner{grid-template-columns:1fr}
  .story-stats{grid-template-columns:1fr 1fr}
  .hero-btns{flex-direction:column;align-items:center}
  .btn-primary,.btn-outline{width:100%;max-width:280px;text-align:center}
  .footer-top{flex-direction:column}
  .footer-bottom{flex-direction:column;text-align:center}
}


/* ─── EVENTS HOME SECTION ─── */
#events-home{background:var(--green-deep);padding:84px 5vw;border-top:1px solid rgba(255,255,255,.05)}
.events-home-inner{max-width:1100px;margin:0 auto}
.events-home-head{display:flex;justify-content:space-between;align-items:end;gap:24px;flex-wrap:wrap;margin-bottom:28px}
.events-home-copy{max-width:640px}
.events-home-label{font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin-bottom:10px;font-weight:600}
.events-home-title{font-family:var(--ff-display);font-size:clamp(2.2rem,4.5vw,3.8rem);color:var(--cream);font-weight:300;line-height:1.1}
.events-home-title em{font-style:italic;color:var(--green-light)}
.events-home-sub{font-size:14px;color:rgba(247,243,237,.58);line-height:1.7;margin-top:12px;max-width:560px}
.events-home-actions{display:flex;gap:12px;flex-wrap:wrap}
.evhome-filter{display:flex;overflow-x:auto;gap:0;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06);border-radius:4px;scrollbar-width:none}
.evhome-filter::-webkit-scrollbar{display:none}
.evhome-filter-btn{background:none;border:none;font-family:var(--ff-body);font-size:11px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:rgba(247,243,237,.45);padding:15px 18px;cursor:pointer;white-space:nowrap;border-bottom:2px solid transparent;transition:all .25s}
.evhome-filter-btn.active{color:var(--gold);border-bottom-color:var(--gold)}
.evhome-filter-btn:hover:not(.active){color:rgba(247,243,237,.8)}
.evhome-meta{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;margin:18px 0 22px}
.evhome-count{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:rgba(247,243,237,.5);font-weight:600}
.evhome-note{font-size:12px;color:rgba(247,243,237,.35)}
.evhome-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(270px,1fr));gap:18px}
.evhome-card{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);border-radius:6px;overflow:hidden;display:flex;flex-direction:column;transition:transform .25s,background .25s,border-color .25s}
.evhome-card:hover{transform:translateY(-4px);background:rgba(255,255,255,.05);border-color:rgba(201,160,106,.28)}
.evhome-art{position:relative;aspect-ratio:16/10;background:linear-gradient(145deg,var(--green-mid),var(--green-dark));display:flex;align-items:center;justify-content:center;overflow:hidden}
.evhome-art-emoji{font-size:4rem;filter:drop-shadow(0 8px 20px rgba(0,0,0,.18))}
.evhome-art::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(15,34,24,.9) 5%,transparent 55%)}
.evhome-date{position:absolute;top:14px;left:14px;background:var(--gold);color:var(--green-deep);padding:6px 11px;border-radius:3px;text-align:center;line-height:1.05;z-index:1}
.evhome-date-day{display:block;font-family:var(--ff-display);font-size:1.55rem;font-weight:300}
.evhome-date-mon{display:block;font-size:8.5px;font-weight:700;letter-spacing:.12em;text-transform:uppercase}
.evhome-body{padding:18px 20px 20px;display:flex;flex-direction:column;flex:1}
.evhome-tag{font-size:9px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);margin-bottom:8px}
.evhome-name{font-family:var(--ff-display);font-size:1.45rem;color:var(--cream);font-weight:400;line-height:1.2;margin-bottom:12px}
.evhome-detail{display:flex;flex-direction:column;gap:6px;margin-bottom:18px}
.evhome-row{font-size:12px;color:rgba(247,243,237,.45);display:flex;align-items:center;gap:8px;line-height:1.6}
.evhome-row svg{flex-shrink:0}
.evhome-actions-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:auto}
.evhome-btn{display:inline-flex;align-items:center;justify-content:center;padding:11px 15px;border-radius:2px;font-size:10px;letter-spacing:.12em;text-transform:uppercase;font-weight:700;border:none;cursor:pointer;transition:all .22s}
.evhome-btn.primary{background:var(--gold);color:var(--green-deep)}
.evhome-btn.primary:hover{background:var(--gold-light);transform:translateY(-1px)}
.evhome-btn.ghost{background:transparent;border:1px solid rgba(255,255,255,.2);color:rgba(247,243,237,.78)}
.evhome-btn.ghost:hover{border-color:var(--gold);color:var(--gold)}
.evhome-empty{grid-column:1/-1;text-align:center;padding:44px 24px;background:rgba(255,255,255,.02);border:1px dashed rgba(255,255,255,.1);border-radius:6px;color:rgba(247,243,237,.45);font-size:14px}

.event-modal-overlay,.event-reserve-overlay{display:none;position:fixed;inset:0;background:rgba(7,18,12,.82);backdrop-filter:blur(8px);z-index:2200;align-items:center;justify-content:center;padding:20px}
.event-modal-overlay.open,.event-reserve-overlay.open{display:flex}
.event-modal-box,.event-reserve-box{width:100%;max-width:760px;background:var(--green-dark);border-radius:12px;border:1px solid rgba(255,255,255,.07);box-shadow:0 30px 90px rgba(0,0,0,.35);position:relative;overflow:hidden}
.event-modal-grid{display:grid;grid-template-columns:minmax(220px,280px) 1fr}
.event-modal-visual{min-height:100%;background:linear-gradient(160deg,var(--green-mid),var(--green-deep));display:flex;align-items:center;justify-content:center;position:relative;padding:36px}
.event-modal-visual::after{content:'';position:absolute;inset:0;background:radial-gradient(circle at 30% 30%,rgba(168,201,144,.2),transparent 45%)}
.event-modal-emoji{font-size:6rem;position:relative;z-index:1}
.event-modal-content{padding:34px 32px 32px}
.event-modal-close,.event-reserve-close{position:absolute;top:16px;right:16px;width:34px;height:34px;border:none;border-radius:50%;background:rgba(255,255,255,.08);color:var(--cream);font-size:15px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s,transform .2s;z-index:2}
.event-modal-close:hover,.event-reserve-close:hover{background:rgba(255,255,255,.16);transform:rotate(90deg)}
.event-modal-pill{display:inline-block;font-size:9px;letter-spacing:.16em;text-transform:uppercase;color:var(--green-light);background:rgba(168,201,144,.1);padding:5px 12px;border-radius:2px;font-weight:700;margin-bottom:14px}
.event-modal-title{font-family:var(--ff-display);font-size:clamp(2rem,4vw,3rem);font-weight:300;color:var(--cream);line-height:1.08;margin-bottom:18px}
.event-modal-meta{display:grid;gap:12px;margin-bottom:20px}
.event-modal-meta-item{display:flex;gap:12px;align-items:flex-start}
.event-modal-meta-icon{width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.06);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:14px}
.event-modal-meta-label{font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:rgba(247,243,237,.35);font-weight:700;margin-bottom:2px}
.event-modal-meta-value{font-size:13.5px;color:var(--cream);line-height:1.5}
.event-modal-desc{font-size:13.5px;color:rgba(247,243,237,.62);line-height:1.8;margin-bottom:24px}
.event-modal-desc p{margin-bottom:12px}
.event-modal-desc p:last-child{margin-bottom:0}
.event-modal-actions{display:flex;gap:12px;flex-wrap:wrap}
.event-modal-actions .evhome-btn{padding:13px 18px}
.event-reserve-box{max-width:520px;padding:30px 28px 28px}
.event-reserve-title{font-family:var(--ff-display);font-size:2rem;color:var(--cream);font-weight:300;margin-bottom:8px;padding-right:42px}
.event-reserve-sub{font-size:13px;color:rgba(247,243,237,.5);line-height:1.6;margin-bottom:18px}
.event-reserve-note{background:rgba(201,160,106,.08);border:1px solid rgba(201,160,106,.16);border-radius:4px;padding:12px 14px;margin-bottom:18px;font-size:12px;color:rgba(247,243,237,.55);line-height:1.6}
.event-form-group{margin-bottom:14px}
.event-form-label{display:block;font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:rgba(247,243,237,.42);font-weight:700;margin-bottom:6px}
.event-form-input{width:100%;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);border-radius:3px;padding:12px 14px;font-size:13.5px;color:var(--cream);font-family:var(--ff-body);outline:none;transition:border-color .2s,background .2s}
.event-form-input:focus{border-color:var(--gold);background:rgba(255,255,255,.1)}
.event-form-input::placeholder{color:rgba(247,243,237,.26)}
select.event-form-input{appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L6 6L11 1' stroke='%23c9a06a' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center}
.event-form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.event-submit{width:100%;margin-top:4px}
@media(max-width:900px){.event-modal-grid{grid-template-columns:1fr}.event-modal-visual{min-height:220px}.event-modal-content{padding:28px 24px 26px}}
@media(max-width:680px){.events-home-head{align-items:flex-start}.event-form-row{grid-template-columns:1fr}.event-modal-actions{flex-direction:column}.event-modal-actions .evhome-btn{width:100%}.event-modal-title{font-size:2rem}}


/* ─── ELEGANT MOTION UPGRADE ─── */
:root{
  --ease-lux:cubic-bezier(.22,1,.36,1);
  --ease-soft:cubic-bezier(.25,.46,.45,.94);
  --shadow-lux:0 28px 80px rgba(0,0,0,.18);
  --shadow-float:0 18px 44px rgba(0,0,0,.16);
}
body{
  background:
    radial-gradient(1200px 700px at 50% -10%, rgba(168,201,144,.05), transparent 60%),
    var(--cream);
}
#hero,#menu,#events-home,#info,footer{position:relative;isolation:isolate}
#hero::after,
#events-home::after{
  content:'';
  position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(circle at 50% 20%, rgba(201,160,106,.08), transparent 42%);
  opacity:.9;
}
.hero-bg{
  transform:scale(1.08);
  transform-origin:center center;
  animation:heroBreath 18s ease-in-out infinite alternate;
  will-change:transform;
}
.hero-pattern{
  animation:patternDrift 24s ease-in-out infinite;
  will-change:transform,opacity;
}
.hero-inner{will-change:transform}
.story-card,.steak-card,.event-modal-box,.event-reserve-box,.modal-box{
  box-shadow:var(--shadow-lux);
}
.house-rules,.menu-grid,.evhome-card,.info-block{
  box-shadow:var(--shadow-float);
}
.btn-primary,.btn-outline,.nav-cta,.evhome-btn,.btn-submit{
  position:relative;
  overflow:hidden;
  isolation:isolate;
}
.btn-primary::after,.btn-outline::after,.nav-cta::after,.evhome-btn::after,.btn-submit::after{
  content:'';
  position:absolute;inset:-120% auto -120% -30%;
  width:32%;
  transform:translateX(-180%) skewX(-18deg);
  background:linear-gradient(90deg, transparent, rgba(255,255,255,.28), transparent);
  transition:transform .9s var(--ease-lux);
  pointer-events:none;
}
.btn-primary:hover::after,.btn-outline:hover::after,.nav-cta:hover::after,.evhome-btn:hover::after,.btn-submit:hover::after{
  transform:translateX(540%) skewX(-18deg);
}
.story-card,
.steak-card,
.evhome-card,
.info-block,
.menu-item,
.tab-btn,
.footer-links a{
  transition-timing-function:var(--ease-lux);
}
.menu-tabs-wrap{
  transition:background .45s var(--ease-lux), border-color .45s var(--ease-lux), box-shadow .45s var(--ease-lux);
}
.menu-tabs-wrap.nav-sync{
  box-shadow:0 16px 36px rgba(0,0,0,.18);
}
.story-card{
  transition:transform .55s var(--ease-lux), box-shadow .55s var(--ease-lux);
}
.story-card:hover{
  transform:translateY(-8px);
  box-shadow:0 34px 90px rgba(0,0,0,.22);
}
.house-rules{
  transition:transform .45s var(--ease-lux), border-color .45s var(--ease-lux), background .45s var(--ease-lux);
  border:1px solid rgba(74,140,74,.08);
}
.house-rules:hover{
  transform:translateY(-4px);
  background:#edf6e7;
}
.menu-item{
  position:relative;
  transition:transform .45s var(--ease-lux), background .45s var(--ease-lux), border-color .45s var(--ease-lux);
}
.menu-item::before,
.evhome-card::before{
  content:'';
  position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(120deg, transparent 0%, rgba(255,255,255,.07) 18%, transparent 40%);
  transform:translateX(-140%);
  transition:transform 1s var(--ease-lux);
}
.menu-item:hover,
.info-block:hover{
  transform:translateY(-4px);
}
.menu-item:hover::before,
.evhome-card:hover::before{
  transform:translateX(130%);
}
.info-block{
  border:1px solid rgba(74,140,74,.08);
  border-radius:10px;
  padding:22px;
  background:rgba(255,255,255,.28);
  backdrop-filter:blur(8px);
  transition:transform .45s var(--ease-lux), background .45s var(--ease-lux), border-color .45s var(--ease-lux), box-shadow .45s var(--ease-lux);
}
.info-block:hover{
  background:rgba(255,255,255,.46);
  border-color:rgba(201,160,106,.22);
  box-shadow:0 24px 54px rgba(0,0,0,.08);
}
.evhome-card{
  position:relative;
  transform-style:preserve-3d;
  perspective:1000px;
  transition:transform .55s var(--ease-lux), background .45s var(--ease-lux), border-color .45s var(--ease-lux), box-shadow .55s var(--ease-lux);
}
.evhome-card:hover{
  transform:translateY(-8px);
  box-shadow:0 28px 70px rgba(0,0,0,.24);
}
.evhome-art{
  overflow:hidden;
}
.evhome-art-emoji{
  transition:transform .8s var(--ease-lux), filter .8s var(--ease-lux);
}
.evhome-card:hover .evhome-art-emoji{
  transform:scale(1.08) translateY(-4px);
  filter:drop-shadow(0 16px 30px rgba(0,0,0,.26));
}
.events-home-title em,.story-h2 em,.menu-h2 em{
  position:relative;
}
.events-home-title em::after,.story-h2 em::after,.menu-h2 em::after{
  content:'';
  position:absolute;left:0;right:0;bottom:.06em;height:1px;
  background:linear-gradient(90deg, rgba(201,160,106,0), rgba(201,160,106,.75), rgba(201,160,106,0));
  opacity:.7;
}
.motion-reveal{
  opacity:0;
  transform:translate3d(0,40px,0) scale(.985);
  filter:blur(10px);
  transition:
    opacity .95s var(--ease-lux),
    transform 1.05s var(--ease-lux),
    filter .9s ease;
  transition-delay:var(--motion-delay,0ms);
  will-change:opacity,transform,filter;
}
.motion-reveal.in-view{
  opacity:1;
  transform:none;
  filter:blur(0);
}
.menu-pane.pane-enter{
  animation:paneFade .7s var(--ease-lux) both;
}
@keyframes paneFade{
  from{opacity:0;transform:translateY(18px) scale(.99)}
  to{opacity:1;transform:none}
}
@keyframes heroBreath{
  0%{transform:scale(1.05) translate3d(0,0,0)}
  100%{transform:scale(1.11) translate3d(0,-10px,0)}
}
@keyframes patternDrift{
  0%,100%{transform:translate3d(0,0,0);opacity:.04}
  50%{transform:translate3d(0,-14px,0);opacity:.065}
}
@media(max-width:680px){
  .info-block{padding:18px}
  .story-card:hover,.evhome-card:hover,.menu-item:hover,.info-block:hover{transform:none}
}
@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  .hero-bg,.hero-pattern{animation:none!important}
  .motion-reveal{opacity:1!important;transform:none!important;filter:none!important}
  .btn-primary::after,.btn-outline::after,.nav-cta::after,.evhome-btn::after,.btn-submit::after,
  .menu-item::before,.evhome-card::before{display:none!important}
}