@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,600;0,700;1,400&family=Inter:wght@300;400;500;600&display=swap');

:root {
  --dark:        #1a1a1a;
  --dark2:       #2c2c2c;
  --gold:        #ed6e22;
  --gold-light:  #f08845;
  --cream:       #faf9f7;
  --white:       #ffffff;
  --text:        #2c2c2c;
  --text-light:  #666666;
  --text-muted:  #999999;
  --border:      #e8e2d9;
}

* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { font-family: 'Inter', sans-serif; color: var(--text); background: var(--cream); line-height: 1.7; }
img { display: block; max-width: 100%; }
a { text-decoration: none; }
h1,h2,h3,h4 { font-family: 'Playfair Display', serif; line-height: 1.2; }

/* ── NAV ── */
nav {
  position: fixed; top: 0; width: 100%; z-index: 1000;
  background: rgba(26,26,26,0.97); backdrop-filter: blur(10px);
  height: 72px; padding: 0 48px;
  display: flex; align-items: center; justify-content: space-between;
  border-bottom: 1px solid rgba(237,110,34,0.2);
}
.nav-logo { display: flex; flex-direction: column; align-items: center; }
.nav-logo .name { font-family:'Playfair Display',serif; font-size:17px; font-weight:700; color:#fff; letter-spacing:5px; }
.nav-logo .sub  { font-size:8px; color:var(--gold); letter-spacing:3px; text-transform:uppercase; margin-top:3px; }
.nav-links { display:flex; gap:28px; list-style:none; align-items:center; }
.nav-links a { color:rgba(255,255,255,0.7); font-size:11px; font-weight:500; letter-spacing:1.5px; text-transform:uppercase; transition:color .2s; }
.nav-links a:hover, .nav-links a.active { color:var(--gold); }
.nav-links .reserve a { background:var(--gold); color:var(--dark); padding:9px 20px; border-radius:2px; font-weight:600; }
.nav-links .reserve a:hover { background:var(--gold-light); color:var(--dark); }
.hamburger { display:none; flex-direction:column; gap:5px; cursor:pointer; background:none; border:none; padding:4px; }
.hamburger span { display:block; width:24px; height:2px; background:#fff; transition:all .3s; }
.mobile-menu { display:none; position:fixed; top:72px; left:0; width:100%; background:var(--dark); z-index:999; padding:16px 24px 24px; border-top:1px solid rgba(255,255,255,0.08); }
.mobile-menu.open { display:block; }
.mobile-menu a { display:block; color:rgba(255,255,255,0.7); font-size:13px; letter-spacing:1.5px; text-transform:uppercase; padding:13px 0; border-bottom:1px solid rgba(255,255,255,0.06); transition:color .2s; }
.mobile-menu a:last-child { border-bottom:none; }
.mobile-menu a:hover { color:var(--gold); }

/* ── HERO ── */
.hero {
  height: 100vh; min-height: 640px; position:relative;
  display:flex; align-items:center; justify-content:center; text-align:center;
  overflow:hidden;
}
.hero img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; object-position:center; }
.hero-overlay { position:absolute; inset:0; background:linear-gradient(to bottom, rgba(0,0,0,0.35) 0%, rgba(0,0,0,0.55) 100%); }
.hero-content { position:relative; z-index:1; padding:0 24px; }
.hero-eyebrow { font-size:11px; font-weight:600; letter-spacing:4px; text-transform:uppercase; color:var(--gold); margin-bottom:20px; }
.hero h1 { font-size:72px; color:#fff; font-weight:700; margin-bottom:16px; text-shadow:0 2px 20px rgba(0,0,0,0.4); }
.hero h1 em { font-style:italic; color:var(--gold); }
.hero p { font-size:16px; color:rgba(255,255,255,0.8); font-weight:300; letter-spacing:1px; margin-bottom:36px; }
.hero-ctas { display:flex; gap:16px; justify-content:center; flex-wrap:wrap; }

/* ── PAGE BANNER ── */
.page-banner { height:340px; position:relative; display:flex; align-items:flex-end; padding:48px; margin-top:72px; overflow:hidden; }
.page-banner img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.page-banner .overlay { position:absolute; inset:0; background:linear-gradient(to top, rgba(26,26,26,0.88) 0%, rgba(26,26,26,0.25) 100%); }
.page-banner .banner-text { position:relative; z-index:1; }
.page-banner h1 { font-size:44px; color:#fff; }
.page-banner .eyebrow { font-size:11px; font-weight:600; letter-spacing:3px; text-transform:uppercase; color:var(--gold); margin-bottom:10px; }

/* ── BUTTONS ── */
.btn { display:inline-block; padding:14px 32px; font-size:11px; font-weight:600; letter-spacing:2px; text-transform:uppercase; border-radius:2px; transition:all .2s; cursor:pointer; border:none; }
.btn-gold { background:var(--gold); color:var(--dark); }
.btn-gold:hover { background:var(--gold-light); transform:translateY(-1px); }
.btn-outline { background:transparent; color:#fff; border:1px solid rgba(255,255,255,0.4); }
.btn-outline:hover { border-color:var(--gold); color:var(--gold); }
.btn-outline-dark { background:transparent; color:var(--dark); border:1px solid var(--dark); }
.btn-outline-dark:hover { background:var(--dark); color:#fff; }

/* ── LAYOUT HELPERS ── */
.container { max-width:1140px; margin:0 auto; padding:0 48px; }
.section    { padding:88px 0; }
.section-sm { padding:60px 0; }
.label { font-size:11px; font-weight:600; letter-spacing:3px; text-transform:uppercase; color:var(--gold); margin-bottom:12px; }
.title { font-size:38px; color:var(--dark); margin-bottom:14px; }
.title-light { color:#fff; }
.divider { width:48px; height:2px; background:var(--gold); margin:18px 0; }
.subtitle { font-size:15px; color:var(--text-light); line-height:1.85; max-width:580px; }
.subtitle-light { color:rgba(255,255,255,0.65); }
.dark-bg  { background:var(--dark); }
.cream-bg { background:var(--cream); }

/* ── HOME: STATS STRIP ── */
.stats-strip { background:var(--dark); padding:36px 0; }
.stats-inner { display:flex; justify-content:center; gap:0; }
.stat-item { flex:1; max-width:260px; text-align:center; padding:20px 32px; border-right:1px solid rgba(255,255,255,0.08); }
.stat-item:last-child { border-right:none; }
.stat-num { font-family:'Playfair Display',serif; font-size:36px; font-weight:700; color:var(--gold); line-height:1; margin-bottom:6px; }
.stat-label { font-size:11px; color:rgba(255,255,255,0.5); letter-spacing:1.5px; text-transform:uppercase; }

/* ── HOME: ABOUT SPLIT ── */
.split { display:grid; grid-template-columns:1fr 1fr; }
.split-text { padding:80px 60px; display:flex; flex-direction:column; justify-content:center; }
.split-img { position:relative; overflow:hidden; min-height:520px; }
.split-img img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }

/* ── HOME: DISH CARDS ── */
.dishes-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:2px; }
.dish-card { position:relative; overflow:hidden; aspect-ratio:4/3; }
.dish-card img { width:100%; height:100%; object-fit:cover; transition:transform .5s; }
.dish-card:hover img { transform:scale(1.05); }
.dish-card .dish-label { position:absolute; bottom:0; left:0; right:0; padding:20px; background:linear-gradient(to top,rgba(0,0,0,0.75),transparent); color:#fff; font-family:'Playfair Display',serif; font-size:16px; }
.dish-card .dish-sub { font-family:'Inter',sans-serif; font-size:11px; color:var(--gold); letter-spacing:1px; text-transform:uppercase; margin-bottom:4px; }

/* ── HOME: FULL PHOTO SECTION ── */
.full-photo { position:relative; height:500px; overflow:hidden; }
.full-photo img { width:100%; height:100%; object-fit:cover; object-position:center 60%; }
.full-photo .overlay { position:absolute; inset:0; background:rgba(0,0,0,0.45); display:flex; align-items:center; justify-content:center; }
.full-photo .overlay-content { text-align:center; padding:24px; }
.full-photo .overlay-content h2 { font-size:48px; color:#fff; margin-bottom:12px; }
.full-photo .overlay-content p { font-size:15px; color:rgba(255,255,255,0.75); font-weight:300; margin-bottom:28px; max-width:520px; margin-left:auto; margin-right:auto; }

/* ── HOME: EVENTS TEASER ── */
.events-teaser { display:grid; grid-template-columns:1fr 1fr; min-height:480px; }
.events-photo { position:relative; overflow:hidden; }
.events-photo img { width:100%; height:100%; object-fit:cover; }
.events-body { background:var(--dark); display:flex; flex-direction:column; justify-content:center; padding:64px 60px; }

/* ── HOME: COCKTAIL STRIP ── */
.cocktail-strip { display:grid; grid-template-columns:1fr 1fr; min-height:440px; }
.cocktail-photo { position:relative; overflow:hidden; order:2; }
.cocktail-photo img { width:100%; height:100%; object-fit:cover; }
.cocktail-body { background:var(--cream); display:flex; flex-direction:column; justify-content:center; padding:64px 60px; order:1; }

/* ── HOME: FIND US ── */
.find-us { background:var(--dark2); padding:72px 0; text-align:center; }
.find-us h2 { font-size:36px; color:#fff; margin-bottom:8px; }
.find-us p { font-size:14px; color:rgba(255,255,255,0.5); margin-bottom:4px; }
.find-us .hours-grid { display:flex; justify-content:center; gap:48px; margin:32px 0; flex-wrap:wrap; }
.hours-block { text-align:center; }
.hours-block .h-label { font-size:10px; font-weight:600; letter-spacing:2px; text-transform:uppercase; color:var(--gold); margin-bottom:6px; }
.hours-block .h-time { font-size:15px; color:#fff; }

/* ── ABOUT PAGE ── */
.about-intro { display:grid; grid-template-columns:1fr 1fr; gap:0; }
.about-intro-text { padding:80px 60px; background:#fff; }
.about-intro-img { position:relative; min-height:480px; overflow:hidden; }
.about-intro-img img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.founders-strip { background:var(--dark); padding:64px 0; text-align:center; }
.founders-strip h2 { font-size:34px; color:#fff; margin-bottom:16px; }
.founders-strip p { font-size:15px; color:rgba(255,255,255,0.6); max-width:600px; margin:0 auto; line-height:1.85; }
.about-features { display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--border); margin-top:1px; }
.feature-box { background:#fff; padding:48px 40px; }
.feature-box .f-icon { font-size:28px; margin-bottom:16px; }
.feature-box h3 { font-size:18px; margin-bottom:10px; color:var(--dark); }
.feature-box p { font-size:14px; color:var(--text-light); line-height:1.8; }

/* ── MENU PAGE ── */
.menu-nav { background:#fff; border-bottom:1px solid var(--border); position:sticky; top:72px; z-index:10; }
.menu-nav-inner { display:flex; gap:0; overflow-x:auto; max-width:1140px; margin:0 auto; padding:0 48px; }
.menu-nav-inner::-webkit-scrollbar { display:none; }
.menu-tab { padding:18px 24px; font-size:12px; font-weight:600; letter-spacing:1.5px; text-transform:uppercase; color:var(--text-muted); border-bottom:2px solid transparent; cursor:pointer; white-space:nowrap; transition:all .2s; text-decoration:none; display:block; }
.menu-tab:hover, .menu-tab.active { color:var(--gold); border-bottom-color:var(--gold); }
.menu-category { padding:64px 0; border-bottom:1px solid var(--border); }
.menu-category:last-child { border-bottom:none; }
.menu-category h2 { font-size:30px; margin-bottom:8px; color:var(--dark); }
.menu-category .cat-note { font-size:13px; color:var(--text-muted); margin-bottom:40px; font-style:italic; }
.menu-items { display:grid; grid-template-columns:repeat(2,1fr); gap:0; }
.menu-item { padding:22px 0; border-bottom:1px solid var(--border); display:flex; justify-content:space-between; align-items:start; gap:16px; }
.menu-item:nth-child(odd) { padding-right:40px; }
.menu-item:nth-child(even) { padding-left:40px; border-left:1px solid var(--border); }
.item-info h4 { font-family:'Playfair Display',serif; font-size:16px; color:var(--dark); margin-bottom:4px; }
.item-info p { font-size:13px; color:var(--text-light); line-height:1.6; }
.item-info .tag { display:inline-block; font-size:10px; font-weight:600; letter-spacing:1px; text-transform:uppercase; color:var(--gold); margin-top:6px; }
.item-price { font-family:'Playfair Display',serif; font-size:15px; color:var(--gold); font-weight:600; white-space:nowrap; flex-shrink:0; }
.menu-note-box { background:#fff; border:1px solid var(--border); border-left:3px solid var(--gold); padding:20px 24px; margin-top:48px; border-radius:2px; font-size:13px; color:var(--text-light); }

/* ── GALLERY PAGE ── */
.gallery-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:4px; }
.gallery-item { position:relative; overflow:hidden; cursor:pointer; }
.gallery-item img { width:100%; height:100%; object-fit:cover; transition:transform .5s; display:block; }
.gallery-item:hover img { transform:scale(1.04); }
.gallery-item.tall { grid-row:span 2; }
.gallery-item.wide { grid-column:span 2; }

/* ── EVENTS PAGE ── */
.events-hero-strip { background:var(--dark); padding:72px 0; }
.events-season { display:grid; grid-template-columns:1fr 1fr; gap:2px; margin-bottom:2px; }
.events-season-img { position:relative; overflow:hidden; min-height:460px; }
.events-season-img img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.events-season-text { background:#fff; padding:64px 56px; display:flex; flex-direction:column; justify-content:center; }
.events-gallery { display:grid; grid-template-columns:repeat(5,1fr); gap:2px; }
.event-thumb { aspect-ratio:4/3; overflow:hidden; position:relative; }
.event-thumb img { width:100%; height:100%; object-fit:cover; transition:transform .4s; }
.event-thumb:hover img { transform:scale(1.05); }
.next-season { background:var(--dark); padding:72px 0; text-align:center; }
.next-season h2 { font-size:36px; color:#fff; margin-bottom:16px; }
.next-season p { font-size:15px; color:rgba(255,255,255,0.55); max-width:500px; margin:0 auto 32px; }
.season-badge { display:inline-block; border:1px solid var(--gold); color:var(--gold); font-size:12px; font-weight:600; letter-spacing:2px; text-transform:uppercase; padding:10px 24px; border-radius:2px; margin-bottom:32px; }

/* ── RESERVATIONS PAGE ── */
.res-grid { display:grid; grid-template-columns:1.1fr 0.9fr; gap:48px; align-items:start; }
.res-card { background:#fff; border:1px solid var(--border); border-radius:4px; padding:40px; }
.res-card h3 { font-size:22px; color:var(--dark); margin-bottom:24px; padding-bottom:16px; border-bottom:1px solid var(--border); }
.contact-method { display:flex; gap:16px; align-items:center; padding:18px 0; border-bottom:1px solid var(--border); }
.contact-method:last-child { border-bottom:none; }
.contact-method .cm-icon { width:44px; height:44px; background:var(--dark); border-radius:50%; display:flex; align-items:center; justify-content:center; flex-shrink:0; font-size:18px; }
.contact-method .cm-label { font-size:11px; font-weight:600; letter-spacing:1.5px; text-transform:uppercase; color:var(--text-muted); margin-bottom:3px; }
.contact-method .cm-value { font-size:14px; font-weight:500; color:var(--dark); }
.contact-method a { color:var(--gold); }
.hours-table { width:100%; }
.hours-table tr { border-bottom:1px solid var(--border); }
.hours-table tr:last-child { border-bottom:none; }
.hours-table td { padding:12px 0; font-size:14px; }
.hours-table td:first-child { color:var(--text-muted); }
.hours-table td:last-child { color:var(--dark); font-weight:500; text-align:right; }
.hours-note { font-size:12px; color:var(--gold); margin-top:12px; }

/* ── CONTACT PAGE ── */
.contact-grid { display:grid; grid-template-columns:1fr 1fr; gap:2px; }
.contact-info-col { background:#fff; padding:64px 56px; }
.contact-map-col { min-height:500px; position:relative; }
.contact-map-col iframe { position:absolute; inset:0; width:100%; height:100%; border:0; }
.contact-detail { display:flex; gap:16px; margin-bottom:28px; align-items:flex-start; }
.contact-detail .cd-label { font-size:10px; font-weight:700; letter-spacing:2px; text-transform:uppercase; color:var(--gold); margin-bottom:4px; }
.contact-detail .cd-value { font-size:14px; color:var(--dark); line-height:1.7; }
.contact-detail a { color:var(--dark); }
.contact-detail a:hover { color:var(--gold); }
.social-links { display:flex; gap:12px; margin-top:32px; flex-wrap:wrap; }
.social-link { display:inline-flex; align-items:center; gap:8px; padding:10px 18px; border:1px solid var(--border); border-radius:2px; font-size:12px; font-weight:600; letter-spacing:1px; text-transform:uppercase; color:var(--dark); transition:all .2s; }
.social-link:hover { border-color:var(--gold); color:var(--gold); }

/* ── FOOTER ── */
footer { background:#111; padding:56px 0 32px; }
.footer-grid { display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:48px; padding-bottom:40px; border-bottom:1px solid rgba(255,255,255,0.07); margin-bottom:28px; }
.footer-brand .name { font-family:'Playfair Display',serif; font-size:18px; font-weight:700; color:#fff; letter-spacing:5px; }
.footer-brand .sub  { font-size:8px; color:var(--gold); letter-spacing:3px; text-transform:uppercase; margin-top:4px; margin-bottom:16px; }
.footer-brand p { font-size:13px; color:rgba(255,255,255,0.35); line-height:1.8; }
.footer-col h4 { font-family:'Inter',sans-serif; font-size:10px; font-weight:700; letter-spacing:2.5px; text-transform:uppercase; color:var(--gold); margin-bottom:16px; }
.footer-col ul { list-style:none; }
.footer-col ul li { margin-bottom:9px; }
.footer-col ul li a { font-size:13px; color:rgba(255,255,255,0.4); transition:color .2s; }
.footer-col ul li a:hover { color:var(--gold); }
.footer-col p { font-size:13px; color:rgba(255,255,255,0.4); margin-bottom:7px; }
.footer-bottom { display:flex; justify-content:space-between; align-items:center; font-size:12px; color:rgba(255,255,255,0.25); }
.footer-social { display:flex; gap:20px; }
.footer-social a { font-size:12px; color:rgba(255,255,255,0.35); letter-spacing:1px; text-transform:uppercase; transition:color .2s; }
.footer-social a:hover { color:var(--gold); }

/* ── RESPONSIVE ── */
@media (max-width:960px) {
  nav { padding:0 24px; }
  .nav-links { display:none; }
  .hamburger { display:flex; }
  .hero h1 { font-size:48px; }
  .container { padding:0 24px; }
  .split, .about-intro, .events-teaser, .cocktail-strip, .events-season, .contact-grid, .res-grid { grid-template-columns:1fr; }
  .split-img, .about-intro-img, .events-season-img { min-height:320px; }
  .events-photo { min-height:300px; position:relative; }
  .events-photo img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
  .cocktail-photo { order:1; min-height:280px; position:relative; }
  .cocktail-photo img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
  .cocktail-body { order:2; }
  .split-text, .events-body, .cocktail-body, .about-intro-text, .events-season-text, .contact-info-col { padding:48px 24px; }
  .contact-map-col { min-height:320px; }
  .dishes-grid, .gallery-grid { grid-template-columns:repeat(2,1fr); }
  .gallery-item.wide { grid-column:span 1; }
  .about-features { grid-template-columns:1fr; }
  .menu-items { grid-template-columns:1fr; }
  .menu-item:nth-child(odd), .menu-item:nth-child(even) { padding:18px 0; border-left:none; }
  .footer-grid { grid-template-columns:1fr 1fr; gap:32px; }
  footer { padding:40px 0 24px; }
  .page-banner { padding:32px 24px; }
  .page-banner h1 { font-size:34px; }
  .menu-nav-inner { padding:0 24px; }
  .stats-inner { flex-wrap:wrap; }
  .stat-item { border-right:none; border-bottom:1px solid rgba(255,255,255,0.08); width:50%; }
}
@media (max-width:600px) {
  .hero h1 { font-size:36px; }
  .full-photo .overlay-content h2 { font-size:32px; }
  .dishes-grid, .gallery-grid { grid-template-columns:1fr; }
  .events-gallery { grid-template-columns:repeat(2,1fr); }
  .gallery-item.tall { grid-row:span 1; }
  .footer-grid { grid-template-columns:1fr; }
  .footer-bottom { flex-direction:column; gap:12px; text-align:center; }
  .stats-inner { flex-direction:column; align-items:center; }
  .stat-item { width:100%; border-right:none; }
  .hours-grid { flex-direction:column; gap:24px; }
}

/* ── SIGNATURE DISHES & DRINKS ── */
.signatures-section { background:var(--dark); padding:80px 0; }
.signatures-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:2px; margin-top:48px; }
.sig-item { position:relative; aspect-ratio:4/5; overflow:hidden; }
.sig-item img { width:100%; height:100%; object-fit:cover; transition:transform .5s; }
.sig-item:hover img { transform:scale(1.06); }
.sig-overlay { position:absolute; inset:0; background:linear-gradient(to bottom, rgba(0,0,0,0.1) 0%, rgba(0,0,0,0.75) 100%); display:flex; flex-direction:column; justify-content:flex-end; padding:24px; }
.sig-category { font-size:10px; letter-spacing:0.14em; text-transform:uppercase; color:var(--gold); font-weight:600; margin-bottom:8px; }
.sig-name { font-family:'Playfair Display',serif; font-size:20px; color:#fff; margin-bottom:6px; }
.sig-desc { font-size:12px; color:rgba(255,255,255,0.7); line-height:1.6; }

/* ── EVENT RESERVATION BLOCK ── */
.event-res-block { background:var(--cream); padding:72px 0; text-align:center; }
.event-res-block h2 { font-family:'Playfair Display',serif; font-size:36px; color:var(--dark); margin-bottom:16px; }
.event-res-block p { font-size:15px; color:var(--text); max-width:560px; margin:0 auto 32px; line-height:1.8; }
