:root{
  --bg:#111111;
  --bg-soft:#181818;
  --panel:rgba(255,255,255,0.04);
  --text:#f6f0e8;
  --muted:rgba(246,240,232,0.72);
  --line:rgba(255,255,255,0.10);
  --accent:#d4af7a;
  --shadow:0 20px 40px rgba(0,0,0,0.25);
  --radius-xl:32px;
  --radius-lg:24px;
  --radius-md:16px;
  --container:min(1200px, calc(100% - 40px));
}
*{box-sizing:border-box}
html,body{margin:0;min-height:100%;scroll-behavior:smooth}
body{
  background:var(--bg);
  color:var(--text);
  font-family:Georgia,"Times New Roman",serif;
}
a{text-decoration:none;color:inherit}
img{display:block;width:100%}
input,textarea,button{font:inherit}
.site-shell{min-height:100vh;display:flex;flex-direction:column}
main{flex:1}
.container{width:var(--container);margin:0 auto}

.topbar{
  position:sticky;top:0;z-index:50;
  border-bottom:1px solid var(--line);
  background:rgba(17,17,17,0.92);
  backdrop-filter:blur(12px);
}
.topbar-inner{
  display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:20px;padding:18px 0;
}
.brand{
  white-space:nowrap;font-size:1.2rem;font-weight:700;text-transform:uppercase;letter-spacing:.35em;
}
.nav{
  display:flex;flex-wrap:wrap;justify-content:center;gap:24px;font-size:.78rem;text-transform:uppercase;letter-spacing:.2em;
  align-items:center;
}
.nav > a,.menu-trigger{transition:.25s ease}
.nav > a:hover,.nav > a.active,.menu-trigger:hover,.menu-trigger.active{color:var(--accent)}

.menu-dropdown{position:relative}
.menu-trigger{display:inline-block}
.dropdown-panel{
  position:absolute;left:50%;top:calc(100% - 2px);transform:translateX(-50%);
  min-width:180px;display:none;flex-direction:column;
  background:#1a1a1a;border:1px solid rgba(255,255,255,.1);
  border-radius:16px;padding:8px 0;text-align:center;
  box-shadow:0 20px 40px rgba(0,0,0,.3);
}
.menu-dropdown:hover .dropdown-panel,
.menu-dropdown:focus-within .dropdown-panel{display:flex}
.dropdown-panel a{
  padding:12px 16px;font-size:.75rem;letter-spacing:.18em;text-transform:uppercase;
  color:rgba(255,255,255,.8);transition:.2s ease;
  white-space:nowrap;
}
.dropdown-panel a:hover,.dropdown-panel a.active{
  background:var(--accent);color:#111111;
}

.btn,.btn-outline,.btn-light{
  display:inline-flex;align-items:center;justify-content:center;border-radius:999px;
  padding:14px 26px;text-transform:uppercase;letter-spacing:.18em;font-size:.78rem;transition:.25s ease;
}
.btn{background:var(--accent);color:#111;border:1px solid var(--accent)}
.btn:hover{transform:translateY(-1px)}
.btn-outline{border:1px solid var(--accent);color:var(--accent);background:transparent}
.btn-outline:hover{background:var(--accent);color:#111}
.btn-light{border:1px solid rgba(255,255,255,.3);color:var(--text)}
.btn-light:hover{background:#fff;color:#111;border-color:#fff}

.hero,.page-hero{
  position:relative;display:grid;place-items:center;overflow:hidden;text-align:center;
}
.hero{min-height:92vh}
.page-hero{min-height:62vh}
.hero::before,.page-hero::before{
  content:"";position:absolute;inset:0;background-position:center;background-size:cover;background-repeat:no-repeat;
}
.hero.home::before{
  background-image:linear-gradient(rgba(0,0,0,.58), rgba(0,0,0,.58)), url("https://images.unsplash.com/photo-1514933651103-005eec06c04b?auto=format&fit=crop&w=1800&q=80");
}
.page-hero.our-place::before{
  background-image:linear-gradient(rgba(0,0,0,.58), rgba(0,0,0,.58)), url("https://images.unsplash.com/photo-1555396273-367ea4eb4db5?auto=format&fit=crop&w=1800&q=80");
}
.page-hero.menu::before,.page-hero.lunch::before,.page-hero.dinner::before{
  background-image:linear-gradient(rgba(0,0,0,.58), rgba(0,0,0,.58)), url("https://images.unsplash.com/photo-1544025162-d76694265947?auto=format&fit=crop&w=1800&q=80");
}
.page-hero.experiences::before{
  background-image:linear-gradient(rgba(0,0,0,.58), rgba(0,0,0,.58)), url("https://images.unsplash.com/photo-1552566626-52f8b828add9?auto=format&fit=crop&w=1800&q=80");
}
.page-hero.order::before{
  background-image:linear-gradient(rgba(0,0,0,.58), rgba(0,0,0,.58)), url("https://images.unsplash.com/photo-1414235077428-338989a2e8c0?auto=format&fit=crop&w=1800&q=80");
}
.page-hero.reservations::before{
  background-image:linear-gradient(rgba(0,0,0,.58), rgba(0,0,0,.58)), url("https://images.unsplash.com/photo-1514933651103-005eec06c04b?auto=format&fit=crop&w=1800&q=80");
}
.page-hero.contact::before{
  background-image:linear-gradient(rgba(0,0,0,.58), rgba(0,0,0,.58)), url("https://images.unsplash.com/photo-1558030006-450675393462?auto=format&fit=crop&w=1800&q=80");
}
.hero-inner{
  position:relative;z-index:1;width:min(900px, calc(100% - 40px));padding:80px 0;
}
.eyebrow{
  margin:0 0 18px;color:var(--accent);font-size:.82rem;text-transform:uppercase;letter-spacing:.42em;
}
h1,h2,h3{margin:0;text-transform:uppercase;line-height:1.1}
h1{font-size:clamp(3rem,8vw,7rem);letter-spacing:.28em}
.page-hero h1{font-size:clamp(3rem,8vw,6rem);letter-spacing:.24em}
h2{font-size:clamp(2rem,4vw,3.4rem);letter-spacing:.18em}
h3{font-size:1.2rem;letter-spacing:.18em}
.lead{max-width:760px;margin:24px auto 0;color:rgba(255,255,255,.85);font-size:1.06rem}
.hero-actions{margin-top:34px;display:flex;flex-wrap:wrap;justify-content:center;gap:16px}
.section{padding:96px 0}

.section-heading{
  display:flex;align-items:end;justify-content:space-between;gap:30px;margin-bottom:48px;
}
.section-heading p:last-child{max-width:460px;text-align:right;color:var(--muted);margin:0}

.grid-2,.grid-3,.grid-4,.contact-grid{
  display:grid;gap:24px;
}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
.contact-grid{grid-template-columns:1.1fr .9fr}

.card,.panel,.form-card,.menu-card{
  border:1px solid var(--line);background:var(--panel);border-radius:var(--radius-xl);
  box-shadow:var(--shadow);padding:32px;
}
.card-number{margin-bottom:18px;color:var(--accent);font-size:.8rem;letter-spacing:.35em}
.muted{color:var(--muted)}

.split-image{overflow:hidden;border-radius:var(--radius-lg);min-height:460px}
.split-image.small{min-height:360px}
.split-image img{height:100%;object-fit:cover}

.split-copy{
  min-height:460px;display:flex;align-items:center;border-radius:var(--radius-lg);
  background:var(--bg-soft);padding:48px;
}

.menu-grid{
  display:grid;
  grid-template-columns:repeat(4, minmax(0,1fr));
  gap:40px;
}
.menu-entry{
  border-bottom:1px solid rgba(255,255,255,.1);
  padding-bottom:24px;
}
.menu-entry-top{
  display:flex;align-items:flex-start;justify-content:space-between;gap:16px;
}
.menu-price{color:var(--accent);white-space:nowrap;letter-spacing:.1em}
.menu-desc{
  margin-top:12px;
  max-width:420px;
  font-size:.92rem;
  line-height:1.6;
  color:rgba(246,240,232,.7);
}

.gallery-item{overflow:hidden;border-radius:var(--radius-lg)}
.gallery-item.large{grid-column:span 2;grid-row:span 2}
.gallery-item img{
  min-height:220px;height:100%;object-fit:cover;transition:transform .45s ease;
}
.gallery-item:hover img{transform:scale(1.05)}

.footer{
  border-top:1px solid var(--line);text-align:center;padding:26px 20px 34px;
  color:rgba(255,255,255,.4);font-size:.78rem;text-transform:uppercase;letter-spacing:.2em;
}
.footer-stack{display:flex;flex-direction:column;align-items:center;gap:16px}
.insta-link{
  display:flex;align-items:center;gap:10px;color:var(--accent);transition:.2s ease;
}
.insta-link:hover{opacity:.8}

form{display:grid;gap:16px}
.row-2{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
input,textarea{
  width:100%;border-radius:var(--radius-md);border:1px solid var(--line);
  background:rgba(0,0,0,.3);color:var(--text);padding:14px 16px;outline:none;
}
input::placeholder,textarea::placeholder{color:rgba(255,255,255,.35)}
textarea{min-height:130px;resize:vertical}

@media (max-width:820px){
  .topbar-inner,.section-heading{flex-direction:column;align-items:flex-start}
  .section-heading p:last-child{text-align:left}
  .grid-2,.grid-3,.contact-grid,.row-2{grid-template-columns:1fr}
  .gallery-item.large{grid-column:span 1;grid-row:span 1}
  .split-copy,.card,.panel,.form-card,.menu-card{padding:26px}
  .nav{justify-content:flex-start}
}
@media (max-width:560px){
  :root{--container:min(1200px, calc(100% - 24px))}
  .hero-inner{width:min(900px, calc(100% - 24px))}
  .section{padding:72px 0}
  .btn,.btn-outline,.btn-light{width:100%}
}


/* Mobile-friendly refinements: desktop styles above stay unchanged */
@media (max-width: 900px){
  :root{
    --container:min(1200px, calc(100% - 28px));
    --radius-xl:24px;
    --radius-lg:20px;
  }

  body{
    overflow-x:hidden;
  }

  .topbar{
    position:sticky;
  }

  .topbar-inner{
    display:grid;
    grid-template-columns:1fr auto;
    align-items:center;
    gap:14px;
    padding:14px 0;
  }

  .brand{
    font-size:1rem;
    letter-spacing:.28em;
  }

  .topbar-inner > .btn-outline{
    grid-column:2;
    grid-row:1;
    width:auto;
    padding:10px 14px;
    font-size:.68rem;
    letter-spacing:.12em;
  }

  .nav{
    grid-column:1 / -1;
    width:100%;
    display:flex;
    flex-wrap:nowrap;
    justify-content:flex-start;
    gap:10px;
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
    padding:4px 2px 8px;
    scrollbar-width:none;
  }

  .nav::-webkit-scrollbar{
    display:none;
  }

  .nav > a,
  .menu-trigger,
  .dropdown-panel a{
    flex:0 0 auto;
    border:1px solid rgba(255,255,255,.12);
    border-radius:999px;
    padding:10px 13px;
    background:rgba(255,255,255,.035);
    letter-spacing:.12em;
    font-size:.68rem;
    line-height:1;
    white-space:nowrap;
  }

  .nav > a.active,
  .menu-trigger.active{
    border-color:var(--accent);
    color:var(--accent);
  }

  .menu-dropdown{
    display:flex;
    flex:0 0 auto;
    gap:8px;
    align-items:center;
  }

  .dropdown-panel{
    position:static;
    transform:none;
    min-width:0;
    display:flex;
    flex-direction:row;
    gap:8px;
    padding:0;
    border:0;
    background:transparent;
    box-shadow:none;
  }

  .dropdown-panel a{
    color:rgba(255,255,255,.8);
    text-align:center;
  }

  .dropdown-panel a:hover,
  .dropdown-panel a.active{
    background:var(--accent);
    color:#111;
  }

  .hero{min-height:72vh;}
  .page-hero{min-height:50vh;}
  .hero-inner{padding:58px 0;}

  h1{
    font-size:clamp(2.6rem, 14vw, 5rem);
    letter-spacing:.16em;
  }

  .page-hero h1{
    font-size:clamp(2.2rem, 11vw, 4.5rem);
    letter-spacing:.12em;
  }

  h2{
    font-size:clamp(1.85rem, 8vw, 3rem);
    letter-spacing:.12em;
  }

  h3{
    letter-spacing:.12em;
  }

  .eyebrow{
    letter-spacing:.26em;
    font-size:.74rem;
  }

  .lead{
    font-size:1rem;
    line-height:1.7;
  }

  .section{
    padding:70px 0;
  }

  .section-heading{
    gap:18px;
    margin-bottom:30px;
  }

  .grid-4{
    grid-template-columns:repeat(2, minmax(0,1fr));
  }

  .menu-grid{
    grid-template-columns:repeat(2, minmax(0,1fr));
    gap:28px 22px;
  }

  .split-image,
  .split-copy{
    min-height:320px;
  }

  .split-copy{
    padding:32px;
  }
}

@media (max-width: 560px){
  :root{
    --container:min(1200px, calc(100% - 22px));
  }

  .topbar-inner{
    gap:12px;
  }

  .topbar-inner > .btn-outline{
    padding:9px 12px;
    font-size:.62rem;
    letter-spacing:.1em;
  }

  .brand{
    font-size:.95rem;
    letter-spacing:.22em;
  }

  .nav{
    gap:8px;
    padding-bottom:10px;
  }

  .nav > a,
  .menu-trigger,
  .dropdown-panel a{
    padding:9px 11px;
    font-size:.62rem;
    letter-spacing:.1em;
  }

  .hero{min-height:66vh;}
  .page-hero{min-height:44vh;}
  .hero-inner{
    width:min(900px, calc(100% - 24px));
    padding:48px 0;
  }

  h1{
    font-size:clamp(2.55rem, 18vw, 4rem);
    letter-spacing:.12em;
    text-indent:.12em;
  }

  .page-hero h1{
    font-size:clamp(2rem, 13vw, 3.5rem);
    letter-spacing:.08em;
    text-indent:.08em;
  }

  .eyebrow{
    letter-spacing:.18em;
  }

  .hero-actions{
    width:100%;
    gap:12px;
  }

  .btn,.btn-outline,.btn-light{
    width:100%;
    min-height:48px;
    padding:13px 18px;
    letter-spacing:.14em;
  }

  .grid-4,
  .menu-grid{
    grid-template-columns:1fr;
  }

  .menu-entry-top{
    gap:12px;
  }

  .menu-entry-top h3{
    font-size:1rem;
  }

  .grid-2,
  .grid-3,
  .contact-grid,
  .row-2{
    grid-template-columns:1fr;
  }

  .card,.panel,.form-card,.menu-card{
    padding:22px;
    border-radius:22px;
  }

  .split-image,
  .split-image.small,
  .split-copy{
    min-height:260px;
  }

  .footer{
    padding:24px 14px 30px;
    font-size:.68rem;
    letter-spacing:.12em;
    line-height:1.7;
  }
}

@media (max-width: 380px){
  .brand{
    font-size:.84rem;
    letter-spacing:.18em;
  }

  .topbar-inner > .btn-outline{
    padding:8px 10px;
    font-size:.58rem;
  }

  .nav > a,
  .menu-trigger,
  .dropdown-panel a{
    font-size:.58rem;
    padding:8px 10px;
  }
}
