/* ========== ELDO CHOPHOUSE — GLOBAL STYLES ========== */
:root {
  --black: #0A0A0A;
  --black-soft: #0E0E0E;
  --black-card: #141414;
  --gold: #C8A96E;
  --gold-hover: #D4B87A;
  --gold-dim: rgba(200,169,110,0.15);
  --cream: #F5F0EB;
  --cream-dim: #9E978E;
  --cream-mid: #C4BCB2;
  --serif: 'Cormorant Garamond', Georgia, serif;
  --sans: 'Jost', sans-serif;
  --radius: 6px;
  --radius-lg: 12px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:80px;overflow-x:hidden;width:100%}
body{background:var(--black);color:var(--cream);font-family:var(--sans);font-weight:300;overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;width:100%;position:relative}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}

/* ========== NAVIGATION ========== */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:22px 40px;transition:all 0.4s}
.nav::before{content:'';position:absolute;inset:0;background:linear-gradient(to bottom,rgba(10,10,10,0.85) 0%,transparent 100%);pointer-events:none;transition:opacity 0.4s}
.nav.scrolled::before{opacity:0}
.nav.scrolled{background:rgba(10,10,10,0.95);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);padding:12px 40px}
.nav>*{position:relative;z-index:1}
.nav-hamburger{cursor:pointer;display:flex;flex-direction:column;gap:6px;width:28px;padding:4px 0;background:none;border:none}
.nav-hamburger span{display:block;height:1px;background:var(--cream);transition:all 0.35s cubic-bezier(0.4,0,0.2,1);transform-origin:center}
.nav-hamburger.open span:first-child{transform:rotate(45deg) translate(5px,5px)}
.nav-hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.nav-hamburger.open span:last-child{transform:rotate(-45deg) translate(5px,-5px)}
.nav-logo{position:absolute;left:50%;transform:translateX(-50%);transition:opacity 0.3s}
.nav-logo img{height:52px;width:auto;filter:brightness(0) invert(1);transition:height 0.4s}
.nav.scrolled .nav-logo img{height:42px}
.has-hero .nav-logo{opacity:0;pointer-events:none}
.has-hero .nav.scrolled .nav-logo{opacity:1;pointer-events:all}
.nav-cta{font-family:var(--sans);font-size:11px;font-weight:500;letter-spacing:2.5px;text-transform:uppercase;padding:10px 26px;border:1px solid rgba(245,240,235,0.3);color:var(--cream);transition:all 0.3s;border-radius:var(--radius)}
.nav-cta:hover{background:var(--cream);color:var(--black)}
.nav-cta .cta-full{display:inline}
.nav-cta .cta-short{display:none}

/* ========== FULL SCREEN OVERLAY ========== */
.overlay{position:fixed;inset:0;z-index:99;display:flex;flex-direction:column;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity 0.45s ease}
.overlay.open{opacity:1;pointer-events:all}
.overlay-bg{position:absolute;inset:0;background-size:cover;background-position:center}
.overlay-bg::after{content:'';position:absolute;inset:0;background:rgba(10,10,10,0.82)}
.overlay-inner{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;gap:6px}
.overlay-inner a{font-family:var(--serif);font-size:clamp(28px,4.2vw,52px);font-weight:400;color:var(--cream);text-transform:uppercase;letter-spacing:4px;padding:6px 0;opacity:0;transform:translateY(18px);transition:color 0.3s,opacity 0.45s,transform 0.45s}
.overlay.open .overlay-inner a{opacity:1;transform:translateY(0)}
.overlay-inner a:nth-child(1){transition-delay:0.06s}
.overlay-inner a:nth-child(2){transition-delay:0.10s}
.overlay-inner a:nth-child(3){transition-delay:0.14s}
.overlay-inner a:nth-child(4){transition-delay:0.18s}
.overlay-inner a:nth-child(5){transition-delay:0.22s}
.overlay-inner a:nth-child(6){transition-delay:0.26s}
.overlay-inner a:nth-child(7){transition-delay:0.30s}
.overlay-inner a:hover{color:var(--gold)}
.overlay .sub-links{position:absolute;bottom:40px;display:flex;gap:32px;flex-wrap:wrap;justify-content:center;z-index:2}
.overlay .sub-links a{font-family:var(--sans);font-size:11px;font-weight:500;letter-spacing:2.5px;text-transform:uppercase;color:var(--cream-dim);transition:color 0.3s}
.overlay .sub-links a:hover{color:var(--cream)}

/* ========== HERO ========== */
.hero{position:relative;height:100vh;min-height:640px;display:flex;align-items:center;justify-content:center;overflow:hidden}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center 40%;animation:heroZoom 22s ease-in-out infinite alternate}
.hero-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(to bottom,rgba(10,10,10,0.35) 0%,rgba(10,10,10,0.15) 30%,rgba(10,10,10,0.6) 70%,var(--black) 100%)}
.hero-bg::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at center,transparent 0%,rgba(10,10,10,0.5) 100%);z-index:1}
@keyframes heroZoom{0%{transform:scale(1)}100%{transform:scale(1.06)}}
.hero-content{position:relative;z-index:2;text-align:center;max-width:720px;padding:0 20px}
.hero-content>*{animation:fadeUp 1s ease-out both}
@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
.hero-mark-large{margin:0 auto 32px;animation-delay:0.15s;display:flex;justify-content:center}
.hero-mark-large img{height:clamp(160px,18vw,240px);width:auto;filter:brightness(0) invert(1) drop-shadow(0 2px 20px rgba(0,0,0,0.4));opacity:0.95}
.hero h1{font-family:var(--serif);font-weight:300;font-size:clamp(38px,5.5vw,74px);letter-spacing:2px;line-height:1.12;animation-delay:0.25s;text-shadow:0 2px 30px rgba(0,0,0,0.5)}
.hero-sub{font-weight:300;font-size:clamp(14px,1.4vw,17px);color:var(--cream-mid);letter-spacing:0.5px;line-height:1.75;margin-top:20px;animation-delay:0.4s;text-shadow:0 1px 20px rgba(0,0,0,0.5)}
.hero-ctas{display:flex;gap:14px;justify-content:center;margin-top:34px;animation-delay:0.55s}
.hero-scroll{position:absolute;bottom:28px;left:0;right:0;display:flex;flex-direction:column;align-items:center;gap:8px;animation:fadeUp 1s ease-out 0.9s both}
.hero-scroll span{font-size:9px;letter-spacing:2.5px;text-transform:uppercase;color:var(--cream-dim)}
.scroll-line{width:1px;height:36px;background:linear-gradient(to bottom,var(--cream-dim),transparent);animation:scrollPulse 2.2s ease-in-out infinite}
@keyframes scrollPulse{0%,100%{opacity:0.2}50%{opacity:0.9}}

/* ========== PAGE BANNER (subpages) ========== */
.page-banner{position:relative;height:55vh;min-height:380px;display:flex;align-items:flex-end;justify-content:center;overflow:hidden;padding-bottom:60px}
.page-banner .hero-bg{animation:none}
.page-banner .hero-bg::after{background:linear-gradient(to bottom,rgba(10,10,10,0.3) 0%,rgba(10,10,10,0.75) 70%,rgba(10,10,10,0.95) 100%)}
.page-banner .hero-bg::before{background:radial-gradient(ellipse at center,rgba(10,10,10,0.15) 0%,rgba(10,10,10,0.5) 100%);z-index:1}
.page-banner-content{position:relative;z-index:2;text-align:center;max-width:700px;padding:0 20px}
.page-banner-content .label{margin-bottom:12px}
.page-banner-content h1{font-family:var(--serif);font-weight:300;font-size:clamp(36px,5vw,64px);letter-spacing:2px;line-height:1.1;text-shadow:0 2px 30px rgba(0,0,0,0.5)}
.page-banner-content p{font-weight:300;font-size:clamp(14px,1.4vw,16px);color:var(--cream-mid);line-height:1.75;margin-top:16px;text-shadow:0 1px 15px rgba(0,0,0,0.4)}

/* ========== BUTTONS ========== */
.btn-gold{font-family:var(--sans);font-size:11.5px;font-weight:500;letter-spacing:2.5px;text-transform:uppercase;padding:14px 36px;background:var(--gold);color:var(--black);border:none;cursor:pointer;transition:all 0.3s;display:inline-block;border-radius:var(--radius)}
.btn-gold:hover{background:var(--gold-hover);transform:translateY(-1px);box-shadow:0 4px 20px rgba(200,169,110,0.25)}
.btn-ghost{font-family:var(--sans);font-size:11.5px;font-weight:500;letter-spacing:2.5px;text-transform:uppercase;padding:14px 36px;background:transparent;color:var(--cream);border:1px solid rgba(245,240,235,0.28);cursor:pointer;transition:all 0.3s;display:inline-block;border-radius:var(--radius)}
.btn-ghost:hover{border-color:var(--cream);background:rgba(245,240,235,0.05)}

/* ========== SECTIONS ========== */
.sec{padding:100px 40px;max-width:1320px;margin:0 auto}
.sec-dark{max-width:100%;background:var(--black-soft)}
.sec-dark>.sec-header,.sec-dark>.cards-3,.sec-dark>.cta-center,.sec-dark>.split,.sec-dark>.happenings-scroll-wrap,.sec-dark>.feature-grid,.sec-dark>.stagger-grid{max-width:1240px;margin-left:auto;margin-right:auto}
.label{font-family:var(--sans);font-size:11px;font-weight:500;letter-spacing:3px;text-transform:uppercase;color:var(--gold);margin-bottom:14px}
.sec-h2{font-family:var(--serif);font-weight:300;font-size:clamp(30px,3.8vw,52px);line-height:1.18}
.sec-sub{font-weight:300;font-size:15px;color:var(--cream-dim);line-height:1.75;max-width:540px;margin:16px auto 0}
.sec-header{text-align:center;margin-bottom:8px}
.body-text{font-size:15px;color:var(--cream-dim);line-height:1.75}
.pull-quote{font-family:var(--serif);font-size:clamp(18px,1.8vw,22px);font-style:italic;color:var(--cream);line-height:1.6;margin:24px 0;padding-left:20px;border-left:2px solid var(--gold)}
.link-arrow{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:500;letter-spacing:2px;text-transform:uppercase;color:var(--gold);margin-top:24px;transition:gap 0.3s}
.link-arrow:hover{gap:14px}
.cta-center{text-align:center;margin-top:48px}
.diet{font-size:12px;color:var(--cream-dim);font-family:var(--sans);font-weight:300}

/* ========== OVERLAPPING SPLIT — Toca Madera inspired ========== */
.split{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.split-img{overflow:hidden;border-radius:var(--radius-lg);box-shadow:0 20px 60px rgba(0,0,0,0.5)}
.split-img img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/5;transition:transform 0.6s ease}
.split-img:hover img{transform:scale(1.025)}

/* Overlap variant: image bleeds into text area */
.split-overlap{position:relative;display:grid;grid-template-columns:1.15fr 1fr;gap:0;align-items:center;padding:80px 0}
.split-overlap .split-img{position:relative;z-index:2;margin-right:-60px;border-radius:var(--radius-lg);box-shadow:0 24px 80px rgba(0,0,0,0.6)}
.split-overlap .split-text{position:relative;z-index:1;background:var(--black-card);border-radius:var(--radius-lg);padding:56px 56px 56px 100px;box-shadow:0 12px 40px rgba(0,0,0,0.3)}
.split-overlap.reverse{grid-template-columns:1fr 1.15fr}
.split-overlap.reverse .split-img{order:2;margin-right:0;margin-left:-60px}
.split-overlap.reverse .split-text{order:1;padding:56px 100px 56px 56px}

/* ========== FEATURE GRID — Asymmetric cards with images ========== */
.feature-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:48px}
.feature-card{position:relative;border-radius:var(--radius-lg);overflow:hidden;background:var(--black-card);min-height:400px;display:flex;flex-direction:column;justify-content:flex-end;transition:transform 0.4s;cursor:pointer}
.feature-card:hover{transform:translateY(-4px)}
.feature-card.tall{grid-row:span 2;min-height:100%}
.feature-card-img{position:absolute;inset:0}
.feature-card-img img{width:100%;height:100%;object-fit:cover;transition:transform 0.6s ease}
.feature-card:hover .feature-card-img img{transform:scale(1.04)}
.feature-card-img::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(10,10,10,0.92) 0%,rgba(10,10,10,0.3) 50%,rgba(10,10,10,0.05) 100%)}
.feature-card-body{position:relative;z-index:2;padding:36px}
.feature-card-body .label{margin-bottom:8px}
.feature-card-body h3{font-family:var(--serif);font-size:clamp(24px,2.6vw,36px);font-weight:400;line-height:1.2;margin-bottom:10px}
.feature-card-body p{font-size:14px;color:var(--cream-dim);line-height:1.65;max-width:400px}
.feature-card-body .link-arrow{margin-top:16px;font-size:11px}

/* ========== HAPPENINGS HORIZONTAL SCROLL ========== */
.happenings-scroll-wrap{position:relative;margin-top:48px}
.happenings-scroll{display:flex;gap:20px;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;padding-bottom:20px;scrollbar-width:none}
.happenings-scroll::-webkit-scrollbar{display:none}
.hap-card{flex:0 0 340px;scroll-snap-align:start;position:relative;border-radius:var(--radius-lg);overflow:hidden;background:var(--black-card);height:480px;transition:transform 0.35s}
.hap-card:hover{transform:translateY(-4px)}
.hap-card-img{position:absolute;inset:0}
.hap-card-img img{width:100%;height:100%;object-fit:cover;transition:transform 0.55s}
.hap-card:hover .hap-card-img img{transform:scale(1.05)}
.hap-card-img::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(10,10,10,0.95) 0%,rgba(10,10,10,0.15) 55%)}
.hap-card-body{position:absolute;bottom:0;left:0;right:0;padding:32px;z-index:2}
.hap-card-body .card-tag{display:inline-block;font-family:var(--sans);font-size:10px;font-weight:500;letter-spacing:2px;text-transform:uppercase;color:var(--gold);background:var(--gold-dim);padding:5px 12px;border-radius:20px;margin-bottom:10px}
.hap-card-body h3{font-family:var(--serif);font-size:24px;font-weight:400;line-height:1.25;margin-bottom:8px}
.hap-card-body p{font-size:13px;color:var(--cream-dim);line-height:1.6;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.hap-card-body .hap-meta{display:flex;gap:16px;margin-top:12px;font-size:12px;color:var(--cream-mid)}
.hap-card-body .hap-meta span{display:flex;align-items:center;gap:4px}
/* Scroll arrows */
.scroll-arrows{display:flex;gap:8px;justify-content:flex-end;margin-top:16px}
.scroll-arrow{width:44px;height:44px;border:1px solid rgba(255,255,255,0.12);border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;background:rgba(20,20,20,0.8);color:var(--cream-dim);font-size:18px;transition:all 0.3s;user-select:none}
.scroll-arrow:hover{border-color:var(--gold);color:var(--gold)}

/* ========== STAGGER GALLERY — Masonry-like ========== */
.stagger-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:12px;margin-top:48px}
.stagger-grid .sg-item{border-radius:var(--radius);overflow:hidden;position:relative}
.stagger-grid .sg-item img{width:100%;height:100%;object-fit:cover;filter:brightness(0.8);transition:transform 0.5s,filter 0.5s}
.stagger-grid .sg-item:hover img{transform:scale(1.06);filter:brightness(1)}
.stagger-grid .sg-tall{grid-row:span 2}
.stagger-grid .sg-wide{grid-column:span 2}

/* ========== MENU CARD ========== */
.menu-card-section{display:grid;grid-template-columns:1fr 1.2fr;gap:0;align-items:stretch;min-height:600px;border-radius:var(--radius-lg);overflow:hidden;background:var(--black-card);box-shadow:0 20px 60px rgba(0,0,0,0.4);margin-top:48px}
.menu-card-img{position:relative;overflow:hidden}
.menu-card-img img{width:100%;height:100%;object-fit:cover;min-height:600px}
.menu-card-content{padding:56px 48px;display:flex;flex-direction:column}
.menu-card-content .menu-tabs{justify-content:flex-start;margin:24px 0 0}
.menu-card-content .menu-wrap{margin:0;max-width:100%}

/* ========== CARDS (original 3-up) ========== */
.cards-3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:48px}
.card{position:relative;display:block;overflow:hidden;border-radius:var(--radius-lg);aspect-ratio:3/4;background:var(--black-card)}
.card-img{position:absolute;inset:0}
.card-img img{width:100%;height:100%;object-fit:cover;transition:transform 0.55s ease,filter 0.55s ease}
.card:hover .card-img img{transform:scale(1.05);filter:brightness(0.65)}
.card-overlay{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;padding:32px;background:linear-gradient(to top,rgba(10,10,10,0.85) 0%,rgba(10,10,10,0.05) 55%);transition:background 0.4s}
.card:hover .card-overlay{background:linear-gradient(to top,rgba(10,10,10,0.92) 0%,rgba(10,10,10,0.15) 60%)}
.card-tag{font-family:var(--sans);font-size:10px;font-weight:500;letter-spacing:2px;text-transform:uppercase;color:var(--gold);margin-bottom:6px}
.card h3{font-family:var(--serif);font-size:clamp(22px,2.2vw,32px);font-weight:400;line-height:1.2}
.card p{font-size:13px;font-weight:300;color:var(--cream-dim);line-height:1.6;max-height:0;overflow:hidden;opacity:0;transition:all 0.4s ease;margin-top:0}
.card:hover p{max-height:80px;opacity:1;margin-top:8px}
.card-cta{font-size:11px;font-weight:500;letter-spacing:2px;text-transform:uppercase;color:var(--gold);margin-top:14px;display:inline-flex;align-items:center;gap:6px;opacity:0;transform:translateY(6px);transition:opacity 0.3s 0.1s,transform 0.3s 0.1s}
.card:hover .card-cta{opacity:1;transform:translateY(0)}

/* ========== MENU ========== */
.menu-wrap{max-width:800px;margin:0 auto}
.menu-tabs{display:flex;justify-content:center;gap:32px;margin:32px 0 8px}
.mtab{font-family:var(--sans);font-size:12px;font-weight:500;letter-spacing:2.5px;text-transform:uppercase;color:var(--cream-dim);cursor:pointer;padding-bottom:8px;border:none;border-bottom:1.5px solid transparent;background:none;transition:all 0.3s}
.mtab.active,.mtab:hover{color:var(--cream);border-bottom-color:var(--gold)}
.menu-cat{font-family:var(--sans);font-size:11px;font-weight:500;letter-spacing:3px;text-transform:uppercase;color:var(--gold);margin-top:36px;margin-bottom:6px;padding-top:10px}
.mi{display:flex;justify-content:space-between;align-items:baseline;padding:14px 0;border-bottom:1px solid rgba(255,255,255,0.05)}
.mi-name{font-family:var(--serif);font-size:19px;font-weight:400}
.mi-desc{font-size:13px;font-weight:300;color:var(--cream-dim);margin-top:3px}
.mi-price{font-size:14px;font-weight:400;color:var(--gold);white-space:nowrap;margin-left:24px}

/* ========== GALLERY ========== */
.gallery{display:grid;grid-template-columns:repeat(5,1fr);gap:3px}
.gallery div{aspect-ratio:1;overflow:hidden}
.gallery img{width:100%;height:100%;object-fit:cover;filter:brightness(0.75);transition:transform 0.45s,filter 0.45s}
.gallery div:hover img{transform:scale(1.05);filter:brightness(1)}

/* ========== CONTACT & FORMS ========== */
.contact-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:48px;margin-top:48px;max-width:1100px;margin-left:auto;margin-right:auto}
.ci-block{margin-bottom:24px}
.ci-label{font-family:var(--sans);font-size:10px;font-weight:500;letter-spacing:2px;text-transform:uppercase;color:var(--gold);margin-bottom:6px}
.ci-block a,.ci-block p{font-size:15px;color:var(--cream-dim);line-height:1.7;transition:color 0.3s}
.ci-block a:hover{color:var(--cream)}
.ci-block strong{color:var(--cream);font-weight:400}

.eldo-form{display:flex;flex-direction:column;gap:20px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.form-group{display:flex;flex-direction:column;gap:6px}
.form-group label{font-family:var(--sans);font-size:10px;font-weight:500;letter-spacing:2px;text-transform:uppercase;color:var(--gold)}
.form-group input,.form-group select,.form-group textarea{background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.1);color:var(--cream);font-family:var(--sans);font-size:14px;font-weight:300;padding:14px 16px;border-radius:var(--radius);outline:none;transition:border-color 0.3s}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--gold)}
.form-group textarea{min-height:120px;resize:vertical}
.form-group select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%239E978E'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center}
.form-group select option{background:var(--black);color:var(--cream)}
.form-submit{margin-top:8px}
.form-success{text-align:center;padding:48px 0}
.form-success h3{font-family:var(--serif);font-size:32px;font-weight:300;margin-bottom:12px;color:var(--gold)}
.form-success p{color:var(--cream-dim);font-size:15px}

/* ========== FOOTER ========== */
footer{background:var(--black);padding:80px 40px 40px;border-top:1px solid rgba(255,255,255,0.05)}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:48px;max-width:1200px;margin:0 auto}
.footer-logo{margin-bottom:16px}
.footer-addr{font-size:14px;line-height:1.75;color:var(--cream-dim)}
.footer-addr a{color:var(--cream-dim);transition:color 0.3s}
.footer-addr a:hover{color:var(--cream)}
footer h4{font-family:var(--sans);font-size:10px;font-weight:500;letter-spacing:2.5px;text-transform:uppercase;color:var(--gold);margin-bottom:18px}
.fh{font-size:14px;color:var(--cream-dim);line-height:1.6;margin-bottom:14px}
.fh strong{color:var(--cream);font-weight:400}
footer ul{list-style:none}
footer ul li{margin-bottom:10px}
footer ul a{font-size:14px;color:var(--cream-dim);transition:color 0.3s}
footer ul a:hover{color:var(--cream)}
.footer-bottom{max-width:1200px;margin:48px auto 0;padding-top:24px;border-top:1px solid rgba(255,255,255,0.05);display:flex;justify-content:space-between;align-items:center}
.footer-bottom span{font-size:12px;color:#666}
.footer-social{display:flex;gap:14px}
.footer-social a{width:34px;height:34px;display:flex;align-items:center;justify-content:center;border:1px solid rgba(255,255,255,0.1);border-radius:50%;color:var(--cream-dim);font-size:12px;font-weight:500;letter-spacing:1px;transition:all 0.3s}
.footer-social a:hover{border-color:var(--gold);color:var(--gold)}

/* ========== REVEAL ========== */
.reveal{opacity:0;transform:translateY(20px);transition:opacity 0.7s ease,transform 0.7s ease}
.reveal.visible{opacity:1;transform:translateY(0)}

/* ========== TIMELINE (Happenings detail) ========== */
.timeline{max-width:800px;margin:0 auto}
.tl-item{display:grid;grid-template-columns:120px 1fr;gap:32px;padding:40px 0;border-bottom:1px solid rgba(255,255,255,0.05)}
.tl-date{font-family:var(--sans);font-size:11px;font-weight:500;letter-spacing:2px;text-transform:uppercase;color:var(--gold);padding-top:6px}
.tl-body h3{font-family:var(--serif);font-size:26px;font-weight:400;margin-bottom:10px}
.tl-body p{font-size:14px;color:var(--cream-dim);line-height:1.7;margin-bottom:14px}
.tl-body .tag{display:inline-block;font-size:10px;letter-spacing:1.5px;text-transform:uppercase;padding:4px 12px;border:1px solid rgba(200,169,110,0.3);color:var(--gold);margin-right:8px;margin-bottom:8px}

/* ========== ABOUT PAGE ========== */
.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:40px;margin-top:48px}
.value-item{text-align:center;padding:40px 24px}
.value-icon{font-size:40px;margin-bottom:16px;filter:grayscale(0.3)}
.value-item h3{font-family:var(--serif);font-size:24px;font-weight:400;margin-bottom:12px}
.value-item p{font-size:14px;color:var(--cream-dim);line-height:1.7}

/* ========== RESPONSIVE ========== */
@media(max-width:1024px){
  .split{grid-template-columns:1fr;gap:40px}
  .split[style*="row-reverse"]{direction:ltr}
  .split-img img{aspect-ratio:16/10}
  .split-overlap{grid-template-columns:1fr}
  .split-overlap .split-img{margin-right:0}
  .split-overlap .split-text{padding:40px 32px}
  .split-overlap.reverse .split-img{margin-left:0;order:0}
  .split-overlap.reverse .split-text{order:1;padding:40px 32px}
  .cards-3{grid-template-columns:1fr 1fr}
  .feature-grid{grid-template-columns:1fr}
  .feature-card.tall{grid-row:span 1}
  .menu-card-section{grid-template-columns:1fr}
  .menu-card-img{max-height:300px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
  .contact-grid{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .values-grid{grid-template-columns:1fr 1fr}
  .tl-item{grid-template-columns:1fr;gap:12px}
  .stagger-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:180px}
}
@media(max-width:768px){
  .sec{padding:48px 20px}
  .sec-h2{font-size:clamp(28px,7vw,40px)}
  /* NAV */
  .nav{padding:14px 20px!important}
  .nav.scrolled{padding:10px 20px!important}
  .nav-hamburger{width:24px;gap:5px;flex-shrink:0}
  .nav-logo{position:absolute!important;left:50%!important;transform:translateX(-50%)!important;flex:none}
  .nav-logo img{height:36px!important}
  .nav.scrolled .nav-logo img{height:36px!important}
  .has-hero .nav-logo{opacity:0;pointer-events:none;transition:opacity 0.3s}
  .has-hero .nav.scrolled .nav-logo{opacity:1;pointer-events:all}
  .nav-cta{font-size:10px!important;letter-spacing:2px!important;padding:10px 20px!important;white-space:nowrap;flex-shrink:0;margin-left:auto}
  .nav-cta .cta-full{display:none!important}
  .nav-cta .cta-short{display:inline!important}
  /* HERO */
  .hero{min-height:100svh}
  .hero-content{padding:0 24px}
  .hero-mark-large img{height:clamp(140px,36vw,200px)!important}
  .hero-content h1{font-size:clamp(36px,10vw,56px)!important}
  .hero-content .hero-sub{font-size:15px!important;max-width:320px;margin-left:auto;margin-right:auto}
  .hero-ctas{flex-direction:column;align-items:center;gap:12px}
  .hero-ctas .btn-gold,.hero-ctas .btn-ghost{width:260px;text-align:center}
  .hero-scroll{bottom:20px}
  .hero-scroll span{font-size:8px;letter-spacing:2px}
  /* GRID LAYOUTS */
  .cards-3{grid-template-columns:1fr}
  .gallery{grid-template-columns:repeat(2,1fr);gap:4px}
  .feature-grid{grid-template-columns:1fr}
  .stagger-grid{grid-template-columns:1fr 1fr;grid-auto-rows:160px}
  .footer-grid{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;gap:16px;text-align:center}
  /* OVERLAY */
  .overlay-inner a{font-size:clamp(22px,6vw,36px);letter-spacing:2px}
  .overlay .sub-links{gap:16px;padding:0 20px;bottom:24px}
  .overlay .sub-links a{font-size:10px;letter-spacing:1.5px}
  /* SUBPAGES */
  .values-grid{grid-template-columns:1fr}
  .page-banner{height:40vh;min-height:280px}
  .page-banner-content h1{font-size:clamp(28px,8vw,42px)}
  .page-banner-content p{font-size:14px;max-width:300px;margin-left:auto;margin-right:auto}
  /* MENU */
  .menu-tabs{gap:4px;flex-wrap:wrap;justify-content:center}
  .mtab{font-size:11px;padding:10px 16px;letter-spacing:1.5px}
  .mi{gap:8px}
  .mi-price{font-size:14px;white-space:nowrap}
  /* HAPPENINGS SCROLL */
  .hap-card{flex:0 0 85vw;height:420px}
  /* FORMS */
  .eldo-form{padding:32px 20px}
  /* CONTACT */
  .ci-block{margin-bottom:24px}
}

/* ========== OVERLAP SPLIT — Image + floating card ========== */
.overlap-split{display:grid;grid-template-columns:1.2fr 1fr;align-items:center;gap:0;position:relative;max-width:1280px;margin:0 auto}
.os-image{position:relative;z-index:1;border-radius:var(--radius-lg);overflow:hidden;box-shadow:0 24px 80px rgba(0,0,0,0.5)}
.os-image img{width:100%;display:block;aspect-ratio:4/5;object-fit:cover;transition:transform 0.6s}
.os-image:hover img{transform:scale(1.02)}
.os-card{position:relative;z-index:2;margin-left:-80px;background:var(--black-card);border-radius:var(--radius-lg);padding:52px 48px;box-shadow:0 16px 48px rgba(0,0,0,0.4)}
.overlap-split.reverse{grid-template-columns:1fr 1.2fr}
.overlap-split.reverse .os-image{order:2}
.overlap-split.reverse .os-card{order:1;margin-left:0;margin-right:-80px}

/* ========== CINEMATIC BREAK ========== */
.cinematic{position:relative;height:50vh;min-height:340px;overflow:hidden}
.cinematic-img{position:absolute;inset:-20%;background-size:cover;background-position:center;will-change:transform}
.cinematic::before{content:'';position:absolute;inset:0;z-index:1;background:linear-gradient(to bottom,var(--black) 0%,rgba(10,10,10,0.15) 22%,rgba(10,10,10,0.15) 78%,var(--black) 100%);pointer-events:none}
.cinematic-img::after{content:'';position:absolute;inset:0;background:linear-gradient(to bottom,var(--black) 0%,rgba(10,10,10,0.2) 20%,rgba(10,10,10,0.2) 80%,var(--black) 100%)}

/* ========== MENU CATEGORY CARDS ========== */
.menu-categories{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:48px}
.menu-cat-card{position:relative;border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:3/4;display:block;cursor:pointer}
.menu-cat-card img{width:100%;height:100%;object-fit:cover;transition:transform 0.6s}
.menu-cat-card:hover img{transform:scale(1.06)}
.mcc-overlay{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;padding:32px;background:linear-gradient(to top,rgba(10,10,10,0.9) 0%,rgba(10,10,10,0.1) 55%)}
.mcc-overlay h3{font-family:var(--serif);font-size:clamp(22px,2.4vw,32px);font-weight:400;line-height:1.2;margin-bottom:6px}
.mcc-overlay p{font-size:13px;color:var(--cream-dim);line-height:1.5}
.mcc-overlay .label{margin-bottom:6px}

/* ========== SHOWCASE GRID — Asymmetric masonry ========== */
.showcase-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:220px;gap:4px}
.showcase-item{overflow:hidden;position:relative}
.showcase-item img{width:100%;height:100%;object-fit:cover;filter:brightness(0.78);transition:transform 0.5s,filter 0.5s}
.showcase-item:hover img{transform:scale(1.05);filter:brightness(1)}
.showcase-item.sg-wide{grid-column:span 2}
.showcase-item.sg-tall{grid-row:span 2}
.showcase-item.sg-hero{grid-column:span 2;grid-row:span 2}
.showcase-item.sg-square{}
.showcase-item.sg-med{}

/* ========== HAPPENINGS SCROLL CONTAINER ========== */
.happenings-scroll{display:flex;gap:20px;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;padding:48px 0 20px;scrollbar-width:none}
.happenings-scroll::-webkit-scrollbar{display:none}

/* ========== HAP TAG ========== */
.hap-tag{position:absolute;top:16px;left:16px;z-index:3;display:inline-block;font-family:var(--sans);font-size:10px;font-weight:500;letter-spacing:2px;text-transform:uppercase;color:var(--gold);background:rgba(10,10,10,0.7);backdrop-filter:blur(8px);padding:5px 14px;border-radius:20px}

/* ========== HAP META (non-span version) ========== */
.hap-meta{margin-top:12px;font-size:12px;color:var(--cream-mid);letter-spacing:0.5px}

/* ========== REVEAL STAGGER ========== */
.reveal-stagger .reveal{opacity:0;transform:translateY(20px);transition:opacity 0.6s ease,transform 0.6s ease}
.reveal-stagger .reveal:nth-child(1){transition-delay:0.05s}
.reveal-stagger .reveal:nth-child(2){transition-delay:0.12s}
.reveal-stagger .reveal:nth-child(3){transition-delay:0.19s}
.reveal-stagger .reveal:nth-child(4){transition-delay:0.26s}
.reveal-stagger .reveal.visible{opacity:1;transform:translateY(0)}

/* ========== RESPONSIVE — New components ========== */
@media(max-width:1024px){
  .overlap-split{grid-template-columns:1fr!important;gap:0;max-width:100%!important}
  .os-image{border-radius:var(--radius-lg) var(--radius-lg) 0 0;box-shadow:none}
  .os-image img{aspect-ratio:16/10}
  .os-card{margin-left:0!important;margin-right:0!important;border-radius:0 0 var(--radius-lg) var(--radius-lg);box-shadow:none;background:var(--black-card)}
  .overlap-split.reverse .os-image{order:0}
  .overlap-split.reverse .os-card{order:1}
  .menu-categories{grid-template-columns:1fr 1fr}
  .showcase-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:180px}
  .showcase-item.sg-hero{grid-column:span 2;grid-row:span 1}
  .showcase-item.sg-wide{grid-column:span 2}
  .cinematic-img{/* parallax handled by JS */}
}
@media(max-width:768px){
  .overlap-split{border-radius:var(--radius-lg);overflow:hidden;margin:0!important}
  .os-image{border-radius:0}
  .os-image img{aspect-ratio:16/9}
  .os-card{padding:28px 24px;border-radius:0}
  .menu-categories{grid-template-columns:1fr;gap:16px}
  .menu-cat-card{aspect-ratio:16/9}
  .showcase-grid{grid-template-columns:1fr 1fr;grid-auto-rows:140px;gap:3px}
  .showcase-item.sg-hero{grid-column:span 2}
  .showcase-item.sg-wide{grid-column:span 2}
  .showcase-item.sg-tall{grid-row:span 1}
  .cinematic{height:35vh;min-height:200px}
}

/* ========== PAGE TRANSITIONS ========== */
.page-transition{position:fixed;inset:0;z-index:9999;pointer-events:none}
.page-transition .pt-overlay{position:absolute;inset:0;background:var(--black)}
.page-transition .pt-line{position:absolute;left:0;right:0;top:50%;height:1px;background:var(--gold)}
/* Default: overlay covers the page (prevents flash on load) */
.page-transition .pt-overlay{transform:scaleY(1)}
.page-transition .pt-line{transform:scaleX(1)}
/* Reveal: sweep overlay up and retract line */
.page-transition.leaving .pt-overlay{transform:scaleY(0);transform-origin:top;transition:transform 0.55s cubic-bezier(0.76,0,0.24,1) 0.08s}
.page-transition.leaving .pt-line{transform:scaleX(0);transform-origin:right;transition:transform 0.3s cubic-bezier(0.76,0,0.24,1) 0s}
/* Hidden: after reveal completes, overlay is display:none via JS */
/* Cover: when navigating away, sweep up from bottom */
.page-transition.entering .pt-overlay{transform:scaleY(1);transform-origin:bottom;transition:transform 0.45s cubic-bezier(0.76,0,0.24,1)}
.page-transition.entering .pt-line{transform:scaleX(1);transform-origin:left;transition:transform 0.3s cubic-bezier(0.76,0,0.24,1) 0.1s}
/* Page content fade on load */
body.pt-ready main,body.pt-ready>section,body.pt-ready>.hero,body.pt-ready>.sec,body.pt-ready>.sec-dark,body.pt-ready>.cinematic,body.pt-ready>footer{animation:ptFadeIn 0.6s ease 0.15s both}
@keyframes ptFadeIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
