/* Light Mediterranean theme */
:root{--cream:#F7F4ED;--linen:#EFE7DA;--sand:#F2EDE4;--olive:#8A9771;--terracotta:#C27A53;--espresso:#4E3D31;--marble:#F5F3EE;--gold:#D4B07D;--card:#ffffff;--max:1200px;--radius:18px}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--cream);color:var(--espresso);font-family:Inter,system-ui,Segoe UI,Roboto,Arial,sans-serif;line-height:1.85;letter-spacing:0.014em}
img{max-width:100%;display:block;border-radius:14px}
.container{max-width:var(--max);margin-inline:auto;padding:32px 32px 32px 32px}
.container,
.page,
section,
.about-home,
.menu-section,
.gallery-section,
.contact-section{padding-left:24px;padding-right:24px}
@media (min-width:768px){
.container,
.page,
section,
.about-home,
.menu-section,
.gallery-section,
.contact-section{padding-left:48px;padding-right:48px}
}
@media (min-width:1200px){
.container,
.page,
section,
.about-home,
.menu-section,
.gallery-section,
.contact-section{padding-left:72px;padding-right:72px}
}
a{color:var(--terracotta);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3{font-family:'Cormorant Garamond','Libre Bodoni',Georgia,serif;color:var(--espresso);letter-spacing:0.32px}
h1{letter-spacing:.2px;font-weight:700}
h2{letter-spacing:.15px}
h3{letter-spacing:.1px}
.eyebrow{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:#6d5c4d;font-family:Inter,system-ui,sans-serif}
.btn{display:inline-block;padding:12px 18px;border-radius:14px;border:1px solid var(--olive);font-weight:600;background:var(--sand);color:var(--espresso);transition:transform .18s ease, box-shadow .18s ease;box-shadow:0 8px 24px rgba(142,151,113,.12)}
.btn.primary{background:var(--olive);color:#fff;border-color:var(--olive)}
.btn.ghost{background:transparent;color:var(--espresso);border-color:var(--olive)}
.btn:hover{transform:translateY(-2px);text-decoration:none;box-shadow:0 12px 26px rgba(142,151,113,.18)}
.site-header{position:fixed;top:0;left:0;right:0;z-index:80;backdrop-filter:blur(10px);border-bottom:1px solid #e3d8c6;padding-top:max(4px,env(safe-area-inset-top));background:#fdfdfc;opacity:1;pointer-events:auto;transform:none;box-shadow:0 2px 8px rgba(0,0,0,0.08)}
.site-header .inner{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 20px}
.brand{display:flex;align-items:center;gap:10px;text-decoration:none}
.brand-logo{height:64px;max-height:72px;width:auto;display:block}
nav.primary{display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.nav-left,.nav-right,nav.primary{display:flex;align-items:center;gap:14px}
.nav-left a,.nav-right a,nav.primary a{color:#333 !important;text-decoration:none;font-weight:500;letter-spacing:0.08em;font-family:'Cormorant Garamond','Libre Bodoni',Georgia,serif;position:relative;padding-bottom:4px;text-shadow:0 1px 3px rgba(0,0,0,.15)}
.nav-left a::after,.nav-right a::after,nav.primary a::after{content:"";position:absolute;left:0;right:0;bottom:0;height:1px;background:linear-gradient(90deg,transparent,var(--gold),transparent);transform:scaleX(0);transform-origin:center;transition:transform .2s ease}
.nav-left a:hover::after,.nav-right a:hover::after,nav.primary a:hover::after{transform:scaleX(1)}
.nav-left .cta,.nav-right .cta,nav.primary .cta{background:var(--olive);color:#fff;padding:10px 14px;border-radius:14px;font-family:Inter,sans-serif;letter-spacing:0.04em;text-shadow:0 1px 3px rgba(0,0,0,.35)}
.site-header nav a:visited,.site-header nav a:active,.site-header nav a:focus,.site-header nav a:hover{color:#111 !important;text-shadow:0 1px 3px rgba(0,0,0,.2)}
.primary a,.nav-left a,.nav-right a{transition:color .2s ease;text-shadow:0 1px 6px rgba(255,255,255,.5)}
.nav-left{justify-content:flex-end}
.nav-right{justify-content:flex-start}
.nav-logo{display:flex;justify-content:center;align-items:center}
.nav-logo-img{height:34px;width:auto;display:block;transition:all .35s ease}
@media(max-width:768px){.brand-logo{height:56px;max-height:64px}nav.primary{gap:14px}nav.primary .cta{padding:10px 12px}}
@media(max-width:420px){.brand-logo{height:44px;max-height:52px}nav.primary{gap:10px}nav.primary a{font-size:15px;color:#fff !important;text-shadow:0 1px 3px rgba(0,0,0,.35)}.site-header .inner{padding:10px 14px}}
.site-footer{background:var(--sand);color:var(--espresso);margin-top:100px;padding:48px 0;border-top:1px solid #e6dfd2}
.site-footer a{color:var(--terracotta)}
.foot{display:flex;flex-direction:column;align-items:center;gap:16px;text-align:center}
.footer-logo{height:180px;width:auto;display:block;margin:0 auto 14px}
.tiny{font-size:13px;color:#7a6b5c;padding:8px 0 12px}
.page{padding:96px 0 80px}
.menu-page,.gallery-page,.contact-page{background:var(--marble);padding-top:96px;padding-bottom:86px}
.menu-page .page-head h1,.gallery-page .page-head h1,.contact-page .page-head h1{letter-spacing:.32px;font-size:44px}
.page-head .eyebrow{margin-bottom:6px}
.page-head h1{margin:0 0 8px;font-size:42px}
.page-head p{margin:0;color:#6d5c4d;font-size:17px}
.page .container{padding-inline:32px}
.container,.about-wrap,.preview-grid,.insta-grid,.map-card,.content-wrap{padding-left:32px;padding-right:32px}
@media(min-width:768px){.container,.about-wrap,.content-wrap{padding-left:48px;padding-right:48px}}
.about-home{background:var(--linen);padding:86px 0;border-top:1px solid #e3d8c6;border-bottom:1px solid #e3d8c6;position:relative}
.about-home:before{content:"";position:absolute;top:32px;left:32px;width:46px;height:120px;background:linear-gradient(180deg,var(--olive),transparent);opacity:.15}
.about-home .about-wrap{display:grid;grid-template-columns:1fr 1fr;grid-template-areas:"text media" "doodle media";align-items:flex-start;position:relative;gap:42px}
.about-home .about-wrap:after{content:"";position:absolute;left:50%;top:12%;bottom:12%;width:1px;background:linear-gradient(180deg,transparent,var(--olive),transparent);opacity:.4;transform:translateX(-50%)}
.about-text{position:relative;margin-bottom:32px;padding-bottom:10px;transform:translateY(-50px);grid-area:text}
.about-text h2{margin:0 0 12px;font-size:42px;letter-spacing:0.28px}
.about-text p{margin:0 0 16px;color:#5f4c40;font-family:'Cormorant Garamond','Libre Bodoni',Georgia,serif;font-size:19px;line-height:1.9}
.about-text p.dropcap::first-letter{float:left;font-size:46px;line-height:0.85;padding-right:8px;color:var(--terracotta);font-family:'Libre Bodoni','Cormorant Garamond',serif}
.heritage-highlight .heritage-copy::first-letter{float:none;font-size:inherit;line-height:inherit;padding-right:0;color:inherit}
.heritage-highlight{max-width:600px;margin:24px auto;text-align:center;color:var(--terracotta);font-family:'Cormorant Garamond','Libre Bodoni',Georgia,serif;display:flex;flex-direction:column;align-items:center;gap:12px}
.heritage-highlight .heritage-rule{display:block;width:190px;height:1px;background:linear-gradient(90deg,var(--terracotta),rgba(183,112,87,0));opacity:.8}
.heritage-highlight .heritage-icon svg{width:22px;height:22px;color:var(--terracotta)}
.heritage-highlight .heritage-copy{margin:0;font-size:19px;line-height:1.9;font-weight:400;letter-spacing:0}
.about-doodle{margin-top:-20px;display:flex;justify-content:center;align-items:flex-end;grid-area:doodle}
.about-doodle img{width:380px;max-width:80%;height:auto}
.about-home .about-media{display:flex;align-items:flex-end;grid-area:media}
.about-home .about-media img{width:100%;height:auto;object-fit:cover;border-radius:12px}
@media(max-width:900px){.about-home .about-wrap{grid-template-columns:1fr;grid-template-areas:"text" "doodle" "media"}.about-home .about-wrap:after{display:none}.about-home{padding:58px 0}.about-text{transform:translateY(-30px);margin-bottom:24px}.about-doodle{margin-top:10px}.about-doodle img{width:280px;max-width:85%}}

@media(max-width:600px){
  .page,.container,section,.about-home,.menu-section,.gallery-section,.contact-section{padding-left:20px;padding-right:20px}
  .page-head{padding-left:6px;padding-right:6px;margin-top:14px;margin-bottom:18px}
  .menu-section{padding:24px;margin-top:24px}
  .menu-grid{column-count:1;column-gap:0}
  .filters{justify-content:center}
  .menu-list,.menu-item,.filters{padding-left:10px;padding-right:10px}
  .heritage-highlight{gap:10px;font-size:17px}
  .heritage-highlight .heritage-copy{font-size:17px;line-height:1.85;letter-spacing:0}
  .heritage-highlight .heritage-icon svg{width:18px;height:18px}
  .heritage-highlight .heritage-rule{width:160px}
}

.menu-preview{background:var(--marble);padding:90px 0;border-top:1px solid #e3d8c6;border-bottom:1px solid #e3d8c6}
.menu-preview h2{margin:6px 0 18px;font-size:40px;letter-spacing:.32px}
.preview-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.preview-card{padding:18px;border:1px solid #e6dccd;border-radius:14px;background:linear-gradient(180deg,#fff,#f8f5ee);box-shadow:0 10px 22px rgba(78,61,49,.06)}
.preview-title{font-family:'Cormorant Garamond','Libre Bodoni',serif;font-size:22px;letter-spacing:.2px;color:var(--espresso);margin-bottom:8px}
.preview-copy{margin:0;color:#6a5b4b;line-height:1.7;font-size:16px}
.preview-cta{margin-top:22px;text-align:center}
@media(max-width:900px){.preview-grid{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.preview-grid{grid-template-columns:1fr}}
.instagram{background:var(--sand);border-top:1px solid #e3d8c6;border-bottom:1px solid #e3d8c6;padding:70px 0}
.instagram h2{font-family:'Cormorant Garamond',Georgia,serif;color:var(--espresso);margin:0 0 12px;text-align:center}
.insta-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.insta-card{position:relative;border-radius:12px;overflow:hidden;border:1px solid #e9dfd0;box-shadow:0 12px 26px rgba(78,61,49,.06)}
.insta-img{width:100%;height:100%;display:block;object-fit:cover;transition:transform .25s ease}
.insta-overlay{position:absolute;inset:0;background:rgba(255,255,255,.18);opacity:0;display:flex;align-items:center;justify-content:center;transition:opacity .25s ease}
.insta-card:hover .insta-img{transform:scale(1.04)}
.insta-card:hover .insta-overlay{opacity:1}
.insta-logo{width:32px;height:32px;opacity:.95}
.insta-actions{display:flex;justify-content:center;margin-top:18px}
@media(max-width:900px){.insta-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.insta-grid{grid-template-columns:1fr}}

.find-us{background:var(--sand);color:var(--espresso);border-top:1px solid #e3d8c6;border-bottom:1px solid #e3d8c6;margin-top:80px;padding:72px 0}
.find-wrap{display:grid;grid-template-columns:1fr;gap:22px}
.find-head h2{font-size:36px;font-weight:700;margin:0 0 8px;text-align:center}
.find-head p{text-align:center;color:#6d5c4d;margin:0 0 12px}
.map-card{border-radius:18px;overflow:hidden;border:1px solid #e3d8c6;box-shadow:0 12px 28px rgba(78,61,49,.08);background:var(--card);padding:10px}
.map-card img{width:100%;display:block;border-radius:12px}
.map-card .map-embed{width:100%;height:420px;border:0;display:block;border-radius:12px}
.map-actions{display:flex;justify-content:center;margin-top:12px}
.reserve{display:grid;grid-template-columns:1.3fr .7fr;gap:22px;align-items:start;margin:12px 0 20px}
.reserve-card{background:linear-gradient(180deg,#fff,#f7f2e9);border:1px solid #e6dccd;box-shadow:0 10px 24px rgba(78,61,49,.06)}
.reserve-card h2{margin-top:0;font-size:30px;letter-spacing:.24px}
.hours h3{margin-top:0;font-size:22px}
.hours ul{list-style:none;padding:0;margin:0;color:#6d5c4d}
.map-wrap{margin-top:22px;border-radius:18px;overflow:hidden;border:1px solid #e3d8c6;box-shadow:0 12px 28px rgba(78,61,49,.08)}
.map-wrap iframe{width:100%;height:420px;border:0;display:block}
@media(max-width:900px){.reserve{grid-template-columns:1fr}}

/* TripAdvisor section */
.tripadvisor{background:var(--linen);color:var(--espresso);border-top:1px solid #e3d8c6;border-bottom:1px solid #e3d8c6;padding:70px 0}
.trip-card{display:flex;align-items:center;justify-content:center;gap:16px;padding:26px;border:1px solid #e6dccd;border-radius:16px;background:linear-gradient(180deg,#fff,#f9f5ee);box-shadow:0 10px 22px rgba(78,61,49,.06);transition:transform .18s ease, box-shadow .18s ease, opacity .18s ease}
.trip-card:hover{transform:translateY(-2px);box-shadow:0 14px 28px rgba(78,61,49,.1);opacity:.98}
.trip-logo{width:120px;height:auto;display:block}
.trip-text{text-align:center;color:#5f4c40}
.trip-rating{font-family:'Cormorant Garamond',Georgia,serif;font-size:28px;letter-spacing:.2px}
.trip-rating .stars{font-weight:700;margin-right:6px}
#hero{scroll-margin-top:80px}
.hero{position:relative;width:100%;height:100vh;display:flex;align-items:center;justify-content:center;overflow:hidden;background:var(--cream);margin-top:0}
#hero video,
#hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1}
#hero-video{filter:brightness(0.82)}
.hero-fallback{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;opacity:0;transition:opacity .3s ease;z-index:0}
.hero-overlay{position:absolute;inset:0;background:rgba(0,0,0,0.35);pointer-events:none;z-index:2}
.hero-text{position:relative;z-index:3;color:#ffffff;text-align:center;width:100%;padding:0 20px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;animation:fadeUp 1s ease forwards}
.hero-eyebrow{color:#ffffff !important;font-size:0.9rem;letter-spacing:0.15em;opacity:0.9;text-transform:uppercase;margin:0;font-family:Inter,sans-serif;text-shadow:0 2px 6px rgba(0,0,0,0.45)}
.hero-title{color:#ffffff !important;font-size:60px;line-height:1.08;margin:0;text-shadow:0 2px 6px rgba(0,0,0,0.45);letter-spacing:0.32px;font-family:'Cormorant Garamond','Libre Bodoni',Georgia,serif;font-weight:600}
@media (prefers-reduced-data: reduce){#hero-video{display:none}.hero-fallback{opacity:1}}
.hero video:not([src]) + .hero-fallback{opacity:1}
.hero video:empty + .hero-fallback{opacity:1}
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:16px}
.card{background:var(--card);backdrop-filter: blur(3px);padding:20px;border-radius:var(--radius);border:1px solid #e3d8c6;box-shadow:0 12px 26px rgba(78,61,49,.08)}
.split .split-wrap{display:grid;grid-template-columns:1fr 1fr;gap:28px;align-items:center}
.menu-divider img{width:100%;height:auto;border-radius:16px;margin:16px 0}
.filters{display:flex;gap:12px;flex-wrap:wrap;margin:20px 0 16px;justify-content:center}
.menu-section{padding:30px;border:1px solid #e6dccd;border-radius:18px;background:linear-gradient(180deg,#fff,#f8f4ec);box-shadow:0 10px 22px rgba(78,61,49,.08);margin-top:32px}
.menu-section{max-width:1100px;margin-left:auto;margin-right:auto}
.filters button{appearance:none;border:1px solid var(--olive);background:var(--cream);color:var(--espresso);padding:10px 14px;border-radius:999px;font-weight:600;letter-spacing:.2px;box-shadow:0 10px 24px rgba(78,61,49,.06);transition:transform .15s ease, box-shadow .15s ease}
.filters button.active{background:var(--terracotta);color:#fff;border-color:var(--terracotta);box-shadow:0 12px 26px rgba(194,122,83,.16)}
.filters button:hover{transform:translateY(-1px)}
.category-divider{height:1px;background:linear-gradient(90deg,transparent,var(--terracotta),transparent);margin:10px 0 20px;border-radius:1px}
.menu-grid{display:block;column-count:2;column-gap:26px}
.menu-list,.menu-item,.filters{padding-left:12px;padding-right:12px}
.menu-category{column-span:all;break-inside:avoid;margin:0 0 10px}
.menu-item{display:grid;grid-template-columns:1fr auto;column-gap:14px;row-gap:8px;break-inside:avoid;margin:0 0 22px;padding:0 0 18px;border-bottom:1px solid #e5dbcc;background:transparent;line-height:1.65}
.menu-item .name{font-family:'Cormorant Garamond','Libre Bodoni',Georgia,serif;font-size:22px;letter-spacing:.18px;color:var(--espresso)}
.menu-item .name .veg-icon{width:16px;height:16px;vertical-align:-2px;color:var(--olive);margin-right:6px}
.menu-item .price{font-family:"SFMono-Regular",Consolas,Monaco,"Andale Mono","Ubuntu Mono",monospace;font-size:16px;color:var(--olive);white-space:nowrap}
.menu-item .desc{grid-column:1/3;font-size:15px;color:#6a5b4b;margin:6px 0 0;line-height:1.65}
.menu-category-title{font-family:'Cormorant Garamond','Libre Bodoni',Georgia,serif;font-weight:700;text-align:center;color:var(--espresso);margin:40px 0 6px;letter-spacing:.32px;font-size:36px;position:relative;padding-bottom:8px}
.menu-category-rule{height:1px;background:linear-gradient(90deg,transparent,var(--terracotta),transparent);width:120px;margin:0 auto 16px;border-radius:1px}
.gallery-grid{column-count:3;column-gap:18px;padding:12px 0}
.gallery-item{display:block;border:1px solid #e7dece;border-radius:10px;overflow:hidden;margin:0 0 18px;box-shadow:0 10px 24px rgba(78,61,49,.06);transition:transform .28s ease, box-shadow .28s ease;break-inside:avoid}
.gallery-item img{display:block;width:auto;max-width:100%;height:auto;margin:0 auto}
.gallery-item:hover{transform:scale(1.04);box-shadow:0 16px 30px rgba(78,61,49,.1)}
.lightbox{position:fixed;inset:0;background:rgba(245,243,238,.94);display:flex;align-items:center;justify-content:center;padding:34px;backdrop-filter:blur(8px);transition:opacity .18s ease;opacity:0;pointer-events:none}
.lightbox.open{opacity:1;pointer-events:auto}
.lightbox-img{max-width:90vw;max-height:80vh;border-radius:12px;border:8px solid #fff;box-shadow:0 16px 38px rgba(78,61,49,.16)}
.lightbox-close{position:absolute;top:18px;right:18px;color:var(--espresso);background:rgba(255,255,255,.8);border:1px solid #e3d8c6;border-radius:50%;width:40px;height:40px;font-size:30px;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 10px 24px rgba(78,61,49,.12)}
@media(max-width:900px){.hero-title{font-size:46px}.menu-grid{column-count:1}.gallery-grid{column-count:2}.menu-item{padding:16px;border-radius:14px}.menu-item .name{font-size:22px}.menu-item .price{font-size:18px}.menu-item .desc{font-size:14px}.menu-section{padding:12px 0 24px}}
@media(max-width:600px){.gallery-grid{column-count:1}.hero{min-height:68vh;margin-top:60px}}
@media(max-width:480px){.hero-title{font-size:34px;line-height:1.1}.hero-text{padding:110px 20px 54px}}
@media(max-width:420px){nav.primary a{font-size:15px}.container{padding:22px}}
.menu-controls{display:flex;align-items:center;gap:10px;margin:12px 0 14px;justify-content:flex-end}
.currency{font-size:14px;color:#6d5c4d;letter-spacing:.08em;text-transform:uppercase}
.currency-select{appearance:none;padding:10px 14px;border:1px solid var(--olive);border-radius:999px;background:var(--cream);color:var(--espresso);font:inherit;box-shadow:0 8px 20px rgba(78,61,49,.04)}
@media(max-width:900px){.menu-controls{justify-content:center;margin-top:12px}}

/* Animations */
[data-animate]{opacity:0;transform:translateY(14px);animation:fadeUp .6s ease forwards}
@keyframes fadeUp{to{opacity:1;transform:translateY(0)}}


/* UNIVERSAL GUTTERS */
.page,
.page > .container,
section,
.menu-page,
.gallery-page,
.contact-page,
.menu-section,
.gallery-section,
.contact-section {
  padding-left: 28px !important;
  padding-right: 28px !important;
}

.menu-title-serif {
  font-family: 'Cormorant Garamond','Libre Bodoni',Georgia,serif;
  font-size: 54px;
  letter-spacing: 0.25px;
  text-align: center;
  margin: 40px 0 32px;
  color: var(--espresso);
  text-transform: uppercase;
}

@media (min-width: 768px) {
  .page,
  .page > .container,
  section,
  .menu-page,
  .gallery-page,
  .contact-page,
  .menu-section,
  .gallery-section,
  .contact-section {
    padding-left: 48px !important;
    padding-right: 48px !important;
  }
}

@media (min-width: 1200px) {
  .page,
  .page > .container,
  section,
  .menu-page,
  .gallery-page,
  .contact-page,
  .menu-section,
  .gallery-section,
  .contact-section {
    padding-left: 72px !important;
    padding-right: 72px !important;
  }
}

/* Center grids and cards */
.menu-grid,
.gallery-grid,
.reserve,
.map-wrap,
.preview-grid,
.insta-grid {
  margin-left: auto;
  margin-right: auto;
  max-width: 1100px;
}

/* Prevent page headings from touching the edge */
.page-head,
.page-head h1,
.page-head p {
  padding-left: 12px !important;
  padding-right: 12px !important;
}

/* === Global Magazine Gutters & Breathing Room === */
:root {
  --gutter-desktop: 24px;
  --gutter-mobile: 28px;
}

/* Base gutters (desktop-first) */
.page,
.page > .container,
.container,
section,
.about-home,
.menu-section,
.gallery-section,
.contact-section,
.menu-grid,
.gallery-grid,
.reserve,
.map-wrap,
.preview-grid,
.insta-grid,
.menu-list,
.menu-item,
.filters,
.page-head,
.page-head h1,
.page-head p {
  padding-left: var(--gutter-desktop) !important;
  padding-right: var(--gutter-desktop) !important;
}

/* Center grids and cards */
.menu-grid,
.gallery-grid,
.preview-grid,
.insta-grid,
.reserve,
.map-wrap {
  margin-left: auto !important;
  margin-right: auto !important;
  max-width: 1100px;
}

/* Extra inner comfort for menu items/filters */
.menu-item,
.menu-list,
.filters {
  padding-left: 12px !important;
  padding-right: 12px !important;
  box-sizing: border-box;
}

/* Responsive overrides */
@media (max-width: 900px) {
  .page,
  .page > .container,
  .container,
  section,
  .about-home,
  .menu-section,
  .gallery-section,
  .contact-section,
  .menu-grid,
  .gallery-grid,
  .reserve,
  .map-wrap,
  .preview-grid,
  .insta-grid,
  .menu-list,
  .menu-item,
  .filters,
  .page-head,
  .page-head h1,
  .page-head p {
    padding-left: var(--gutter-mobile) !important;
    padding-right: var(--gutter-mobile) !important;
  }
}

@media (max-width: 640px) {
  .page,
  .page > .container,
  .container,
  section,
  .about-home,
  .menu-section,
  .gallery-section,
  .contact-section,
  .menu-grid,
  .gallery-grid,
  .reserve,
  .map-wrap,
  .preview-grid,
  .insta-grid,
  .menu-list,
  .menu-item,
  .filters,
  .page-head,
  .page-head h1,
  .page-head p {
    padding-left: var(--gutter-mobile) !important;
    padding-right: var(--gutter-mobile) !important;
  }
}

/* === Social Follow Section === */
.social-follow {
  background: var(--sand);
  border-top: 1px solid #e3d8c6;
  border-bottom: 1px solid #e3d8c6;
  padding: 70px 0;
  text-align: center;
}

.social-follow-title {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-size: 36px;
  margin: 0 0 12px;
  color: var(--espresso);
}

.social-follow-sub {
  color: #6d5c4d;
  margin: 0 0 24px;
  font-size: 18px;
}

.social-buttons {
  display: flex;
  justify-content: center;
  gap: 20px;
  flex-wrap: wrap;
  margin-top: 10px;
}

.social-btn {
  padding: 14px 22px;
  font-size: 17px;
  border-radius: 14px;
  font-weight: 600;
  letter-spacing: 0.03em;
  text-shadow: none;
}

.insta-btn {
  background: #E1306C;
  border: 1px solid #E1306C;
  color: #fff;
}

.insta-btn:hover {
  background: #c82a60;
  transform: translateY(-2px);
}

.fb-btn {
  background: #1877F2;
  border: 1px solid #1877F2;
  color: #fff;
}

.fb-btn:hover {
  background: #0f63cc;
  transform: translateY(-2px);
}

@media (max-width: 600px) {
  .social-follow-title {
    font-size: 30px;
  }
  .social-buttons {
    flex-direction: column;
  }
}

/* === Stay Connected Section === */
.stay-connected {
  background: var(--marble);
  border-top: 1px solid #e6dfd2;
  border-bottom: 1px solid #e6dfd2;
  padding: 70px 0;
  margin-top: 60px;
}

.stay-wrap {
  text-align: center;
  max-width: 700px;
  margin: 0 auto;
}

.stay-title {
  font-size: 38px;
  margin: 8px 0 16px;
  color: var(--espresso);
  font-family: 'Cormorant Garamond', serif;
}

.stay-copy {
  margin: 0 auto 28px;
  font-size: 18px;
  color: #6d5c4d;
  max-width: 540px;
  line-height: 1.8;
}

.stay-actions {
  display: flex;
  justify-content: center;
  gap: 16px;
  flex-wrap: wrap;
}

.stay-actions .btn {
  padding: 12px 22px;
  font-size: 16px;
  border-radius: 14px;
}

@media (max-width: 600px) {
  .stay-title {
    font-size: 30px;
  }
  .stay-copy {
    font-size: 17px;
  }
  .stay-actions {
    flex-direction: column;
    gap: 14px;
  }
}

/* Google Reviews section */
.reviews {
  background: var(--marble);
  border-top: 1px solid #e3d8c6;
  border-bottom: 1px solid #e3d8c6;
  padding: 72px 0;
}

.reviews-top {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 24px;
}

.reviews-top h2 {
  margin: 0;
  font-size: 32px;
}

.reviews-link {
  font-size: 14px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--terracotta);
}

.reviews-shell {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: stretch;
  gap: 12px;
}

.reviews-shell.reviews-disabled button {
  opacity: 0.4;
  pointer-events: none;
}

.reviews-prev,
.reviews-next {
  border: none;
  background: #fff8;
  width: 40px;
  height: 40px;
  border-radius: 999px;
  font-size: 22px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 10px 24px rgba(78, 61, 49, 0.12);
}

.reviews-carousel {
  overflow: hidden;
  position: relative;
  min-height: 220px;
}

.review-card {
  display: none;
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 1.4fr);
  gap: 18px;
  padding: 22px;
  border-radius: 18px;
  border: 1px solid #e6dccd;
  background: linear-gradient(180deg, #ffffff, #f9f5ee);
  box-shadow: 0 10px 24px rgba(78, 61, 49, 0.08);
}

.review-card.active {
  display: grid;
}

.review-image-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 14px;
}

.review-body {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.review-rating {
  font-size: 20px;
  color: var(--terracotta);
}

.review-text {
  margin: 0;
  color: #5f4c40;
  font-size: 16px;
}

.review-author {
  margin: 4px 0 0;
  font-size: 14px;
  color: #7a6b5c;
}

.review-fallback {
  padding: 26px;
  border-radius: 18px;
  border: 1px solid #e6dccd;
  background: linear-gradient(180deg, #ffffff, #f9f5ee);
  box-shadow: 0 10px 24px rgba(78, 61, 49, 0.08);
}

.review-fallback-main {
  margin: 0 0 4px;
  font-weight: 600;
}

.review-fallback-sub {
  margin: 0;
  color: #7a6b5c;
  font-size: 14px;
}

@media (max-width: 768px) {
  .reviews-shell {
    grid-template-columns: 1fr;
    gap: 12px;
  }

  .reviews-prev,
  .reviews-next {
    order: 2;
    margin-inline: auto;
  }

  .review-card {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  nav.primary a {
    color: #4E3D31 !important;   /* solid espresso */
    text-shadow: none !important;
    opacity: 1 !important;
  }

  .site-header {
    background: #fdfdfc !important; /* solid background */
    backdrop-filter: none !important;
  }

  .site-header .inner {
    padding: 12px 20px !important;
  }
}

/* === Carousel Section === */
.carousel-section {
  background: var(--marble);
  padding: 60px 0;
  border-top: 1px solid #e3d8c6;
  border-bottom: 1px solid #e3d8c6;
  text-align: center;
}

.carousel-title {
  font-family: 'Cormorant Garamond', serif;
  font-size: 36px;
  margin-bottom: 6px;
}

.carousel-sub {
  margin: 0 0 26px;
  color: #6d5c4d;
  font-size: 17px;
}

.carousel-container {
  overflow-x: auto;
  overflow-y: hidden;
  white-space: nowrap;
  scrollbar-width: none;
  -ms-overflow-style: none;
}

.carousel-container::-webkit-scrollbar {
  display: none;
}

.carousel-track {
  display: inline-flex;
  gap: 16px;
  padding: 0 24px;
}

.carousel-img {
  width: 280px;
  height: 180px;
  object-fit: cover;
  border-radius: 14px;
  flex-shrink: 0;
  border: 1px solid #e6dccd;
  box-shadow: 0 10px 20px rgba(78,61,49,.08);
  transition: transform .2s ease, box-shadow .2s ease;
}

.carousel-img:hover {
  transform: translateY(-4px);
  box-shadow: 0 20px 30px rgba(78,61,49,.12);
}

@media(max-width: 600px) {
  .carousel-img {
    width: 220px;
    height: 150px;
  }
}

/* placeholder removed */
.carousel-section {
  background: var(--marble);
  padding: 60px 0;
  border-top: 1px solid #e3d8c6;
  border-bottom: 1px solid #e3d8c6;
  text-align: center;
}

.carousel-title {
  font-family: 'Cormorant Garamond', serif;
  font-size: 36px;
  margin-bottom: 6px;
}

.carousel-sub {
  margin: 0 0 26px;
  color: #6d5c4d;
  font-size: 17px;
}

.carousel-container {
  overflow-x: auto;
  overflow-y: hidden;
  white-space: nowrap;
  scrollbar-width: none;
  -ms-overflow-style: none;
}

.carousel-container::-webkit-scrollbar {
  display: none;
}

.carousel-track {
  display: inline-flex;
  gap: 16px;
  padding: 0 24px;
}

.carousel-img {
  width: 280px;
  height: 180px;
  object-fit: cover;
  border-radius: 14px;
  flex-shrink: 0;
  border: 1px solid #e6dccd;
  box-shadow: 0 10px 20px rgba(78,61,49,.08);
  transition: transform .2s ease, box-shadow .2s ease;
}

.carousel-img:hover {
  transform: translateY(-4px);
  box-shadow: 0 20px 30px rgba(78,61,49,.12);
}

@media(max-width: 600px) {
  .carousel-img {
    width: 220px;
    height: 150px;
  }
}

/* Story carousel under About */

/* === Global Magazine Gutters & Breathing Room === */
:root {
  --gutter-desktop: 24px;
  --gutter-mobile: 28px;
}

/* Base gutters (desktop-first) */
.page,
.page > .container,
.container,
section,
.about-home,
.menu-section,
.gallery-section,
.contact-section,
.menu-grid,
.gallery-grid,
.reserve,
.map-wrap,
.preview-grid,
.insta-grid,
.menu-list,
.menu-item,
.filters,
.page-head,
.page-head h1,
.page-head p {
  padding-left: var(--gutter-desktop) !important;
  padding-right: var(--gutter-desktop) !important;
}

/* Center key grids/cards and avoid edge touch */
.menu-grid,
.gallery-grid,
.preview-grid,
.insta-grid,
.reserve,
.map-wrap {
  margin-left: auto !important;
  margin-right: auto !important;
  max-width: 1100px;
}

/* Extra inner comfort for menu items/filters */
.menu-item,
.menu-list,
.filters {
  padding-left: 12px !important;
  padding-right: 12px !important;
  box-sizing: border-box;
}

/* Responsive overrides */
@media (max-width: 900px) {
  .page,
  .page > .container,
  .container,
  section,
  .about-home,
  .menu-section,
  .gallery-section,
  .contact-section,
  .menu-grid,
  .gallery-grid,
  .reserve,
  .map-wrap,
  .preview-grid,
  .insta-grid,
  .menu-list,
  .menu-item,
  .filters,
  .page-head,
  .page-head h1,
  .page-head p {
    padding-left: var(--gutter-mobile) !important;
    padding-right: var(--gutter-mobile) !important;
  }
}

@media (max-width: 640px) {
  .page,
  .page > .container,
  .container,
  section,
  .about-home,
  .menu-section,
  .gallery-section,
  .contact-section,
  .menu-grid,
  .gallery-grid,
  .reserve,
  .map-wrap,
  .preview-grid,
  .insta-grid,
  .menu-list,
  .menu-item,
  .filters,
  .page-head,
  .page-head h1,
  .page-head p {
    padding-left: var(--gutter-mobile) !important;
    padding-right: var(--gutter-mobile) !important;
  }
}
