:root{
  --bg: #0b0f0d;
  --paper: #0f1512;
  --card: rgba(255,255,255,.06);
  --text: rgba(255,255,255,.92);
  --muted: rgba(255,255,255,.70);
  --soft: rgba(255,255,255,.12);
  --brand: #67d39a;
  --brand2:#f7c66b;
  --shadow: 0 18px 40px rgba(0,0,0,.42);
  --radius: 18px;
  --radius2: 26px;
  --max: 1140px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  background:
    radial-gradient(1200px 600px at 15% 10%, rgba(103,211,154,.15), transparent 55%),
    radial-gradient(1000px 600px at 85% 15%, rgba(247,198,107,.10), transparent 55%),
    linear-gradient(180deg, #060807 0%, #0b0f0d 70%, #070a08 100%);
  color: var(--text);
  line-height:1.55;
}
a{color:inherit; text-decoration:none}
img{max-width:100%; display:block}

.container{max-width:var(--max); margin:0 auto; padding:0 20px}
.muted{color:var(--muted)}
.k{font-family:"Playfair Display", serif}
.accent{color:var(--brand)}

.nav{
  position:sticky; top:0; z-index:50;
  backdrop-filter: blur(12px);
  background: rgba(6,8,7,.55);
  border-bottom: 1px solid rgba(255,255,255,.08);
}
.nav-inner{display:flex; align-items:center; justify-content:space-between; padding:14px 0; gap:14px}

.brand{display:flex; align-items:center; gap:10px; font-weight:700; letter-spacing:.2px}
.logo{
  width:38px; height:38px; border-radius:12px;
  background:
    radial-gradient(circle at 30% 30%, rgba(103,211,154,.9), rgba(103,211,154,.2)),
    radial-gradient(circle at 70% 70%, rgba(247,198,107,.8), rgba(247,198,107,.18));
  box-shadow: 0 10px 20px rgba(0,0,0,.35);
  position:relative;
  border:1px solid rgba(255,255,255,.15);
}
.logo:after{
  content:"";
  position:absolute; inset:10px 11px 12px 10px;
  border-radius:10px;
  border:1px dashed rgba(255,255,255,.35);
  opacity:.7;
}
.brand-title{display:flex; flex-direction:column; line-height:1.1}
.brand-title b{font-family:"Playfair Display", serif; font-size:18px}
.brand-title span{font-size:12px; color:var(--muted)}

.nav-links{display:flex; gap:18px; align-items:center}
.nav-links a{
  font-size:14px; color:var(--muted);
  padding:8px 10px; border-radius:999px;
  border:1px solid transparent;
  transition: .2s ease;
}
.nav-links a:hover{color:var(--text); border-color: rgba(255,255,255,.10); background: rgba(255,255,255,.04)}

.nav-cta{display:flex; gap:10px; align-items:center}

.btn{
  display:inline-flex; align-items:center; justify-content:center;
  gap:10px;
  padding:10px 14px;
  border-radius:999px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  color: var(--text);
  font-weight:600;
  font-size:14px;
  transition: .2s ease;
  box-shadow: 0 10px 26px rgba(0,0,0,.18);
  cursor:pointer;
}
.btn:hover{transform: translateY(-1px); background: rgba(255,255,255,.09)}
.btn.primary{
  border-color: rgba(103,211,154,.40);
  background: linear-gradient(180deg, rgba(103,211,154,.24), rgba(103,211,154,.10));
}

.hamburger{display:none}
.mobile-wrap{padding:0 0 14px; display:flex; gap:10px; flex-wrap:wrap}

.hero{padding: 38px 0 26px}
.hero-grid{display:grid; grid-template-columns: 1.05fr .95fr; gap: 22px; align-items:stretch}

.hero-card{
  border-radius: var(--radius2);
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
  box-shadow: var(--shadow);
  overflow:hidden;
  position:relative;
  min-height: 520px;
}
.hero-media{
  position:absolute; inset:0;
  background-size: cover;
  background-position: center;
  filter: saturate(1.05) contrast(1.05);
  transform: scale(1.02);
  transition: opacity .28s ease;
}
.hero-overlay{
  position:absolute; inset:0;
  background:
    linear-gradient(115deg, rgba(5,7,6,.86) 18%, rgba(5,7,6,.40) 60%, rgba(5,7,6,.10) 100%),
    radial-gradient(900px 540px at 25% 20%, rgba(103,211,154,.20), transparent 55%),
    radial-gradient(800px 520px at 65% 30%, rgba(247,198,107,.12), transparent 55%);
}
.hero-content{
  position:relative;
  padding: 44px;
  height: 100%;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  gap: 20px;
}
.eyebrow{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding: 8px 12px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.06);
  color: var(--muted);
  width: fit-content;
  font-weight:600;
  font-size:13px;
}
.dot{
  width:8px; height:8px; border-radius:99px;
  background: var(--brand);
  box-shadow: 0 0 0 6px rgba(103,211,154,.12);
}
h1{
  margin: 14px 0 10px;
  font-family: "Playfair Display", serif;
  font-size: clamp(34px, 4vw, 54px);
  line-height: 1.05;
  letter-spacing: -.6px;
}
.hero p{margin:0; color:var(--muted); font-size:16px; max-width:54ch}
.hero-actions{display:flex; gap:12px; flex-wrap:wrap; margin-top:18px}

.stats{display:grid; grid-template-columns: repeat(3, 1fr); gap: 12px; margin-top: 18px}
.stat{
  padding: 14px;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.05);
}
.stat b{display:block; font-size:16px}
.stat span{color: var(--muted); font-size:12.5px}

.hero-footer{
  display:flex; gap:10px; flex-wrap:wrap; align-items:center; justify-content:space-between;
  border-top:1px solid rgba(255,255,255,.08);
  padding-top:16px;
  color:var(--muted);
  font-size:13px;
}
.hero-footer-actions{display:flex; gap:10px; flex-wrap:wrap}

.side{display:flex; flex-direction:column; gap: 16px}
.panel{
  border-radius: var(--radius2);
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
  box-shadow: var(--shadow);
  overflow:hidden;
}
.panel-inner{padding:18px 18px 16px}
.panel-title{display:flex; align-items:flex-start; justify-content:space-between; gap:12px}
.panel-title h3{margin:0; font-size:16px; letter-spacing:-.2px}
.badge{
  font-size:12px; font-weight:700;
  color: rgba(5,7,6,.90);
  background: linear-gradient(180deg, rgba(247,198,107,.95), rgba(247,198,107,.65));
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.20);
}
.badge-green{background: linear-gradient(180deg, rgba(103,211,154,.95), rgba(103,211,154,.65))}
.badge-white{background: linear-gradient(180deg, rgba(255,255,255,.95), rgba(255,255,255,.70))}
.panel p{margin:8px 0 0; color: var(--muted); font-size:13.5px}

.thumb{width:100%; height: 200px; object-fit: cover}

.section{padding:46px 0}
.section-head{display:flex; align-items:flex-end; justify-content:space-between; gap:14px; margin-bottom:18px}
.section-head h2{font-family:"Playfair Display", serif; margin:0; font-size:28px; letter-spacing:-.3px}
.section-head p{margin:0; color:var(--muted); max-width:62ch}

.grid{display:grid; grid-template-columns: repeat(12, 1fr); gap: 14px}
.card{
  border-radius: var(--radius);
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
  box-shadow: 0 16px 36px rgba(0,0,0,.32);
  overflow:hidden;
}
.menu-card{grid-column: span 6}
.menu-card .body{padding: 14px 14px 16px}
.menu-card h3{margin:0; font-size:16px}
.menu-card p{margin:6px 0 0; color:var(--muted); font-size:13.5px}
.meta{display:flex; gap:8px; flex-wrap:wrap; margin-top:10px}
.pill{
  font-size: 12px;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.05);
  color: var(--muted);
}
.pill.hot{border-color: rgba(255,101,101,.30); color: rgba(255,255,255,.82)}
.pill.fresh{border-color: rgba(103,211,154,.30); color: rgba(255,255,255,.82)}

.gallery{display:grid; grid-template-columns: repeat(12, 1fr); gap: 14px}
.g1{grid-column: span 7; min-height: 340px}
.g2{grid-column: span 5; min-height: 340px}
.g3{grid-column: span 6; min-height: 320px}
.g4{grid-column: span 6; min-height: 320px}
.gallery img{width:100%; height:100%; object-fit:cover; transform: scale(1.01)}
.cap{
  position:absolute; left:14px; bottom:14px;
  padding:10px 12px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(6,8,7,.55);
  backdrop-filter: blur(10px);
  max-width: calc(100% - 28px);
}
.gallery .card{position:relative; cursor:zoom-in}
.cap b{display:block; font-size:13px}
.cap span{display:block; font-size:12px; color: var(--muted)}

.reviews .review{grid-column: span 4; padding:16px}
.review p{margin:10px 0 0; color:var(--muted); font-size:13.5px}
.stars{color: var(--brand2); letter-spacing: 2px}

.visit{grid-column: span 7; padding:18px}
.visit h3{margin:0; font-size:16px}
.visit p{margin:8px 0 0; color:var(--muted); font-size:13.5px}

.info{grid-column: span 5; padding:18px; display:flex; flex-direction:column; gap:12px}
.info .row{display:flex; justify-content:space-between; gap:12px; padding:12px; border-radius: 16px; border:1px solid rgba(255,255,255,.10); background: rgba(255,255,255,.04)}
.info .row b{font-size:13px}
.info .row span{color:var(--muted); font-size:13px; text-align:right}

.divider{height:1px; background: rgba(255,255,255,.08); margin: 18px 0}

.footer{
  padding: 34px 0 26px;
  border-top: 1px solid rgba(255,255,255,.08);
  margin-top: 34px;
  color: var(--muted);
  font-size: 13px;
}
.footer-inner{display:flex; gap:12px; flex-wrap:wrap; align-items:center; justify-content:space-between}
.footnote{padding-bottom:18px; opacity:.75}

.lightbox{position:fixed; inset:0; z-index:80}
.lightbox-bg{position:absolute; inset:0; background:rgba(0,0,0,.78); backdrop-filter: blur(8px)}
.lightbox-inner{
  position:relative; height:100%;
  display:flex; flex-direction:column;
  align-items:center; justify-content:center;
  padding:18px;
  max-width:min(980px, 95vw);
  margin:0 auto;
}
.lightbox-bar{display:flex; justify-content:space-between; align-items:center; gap:10px; width:100%; margin-bottom:10px}
.lightbox-img{
  width:100%;
  max-height: 78vh;
  object-fit:contain;
  border-radius: 18px;
  border:1px solid rgba(255,255,255,.14);
  box-shadow: 0 30px 80px rgba(0,0,0,.55);
  background: rgba(255,255,255,.03);
}

/* Responsive */
@media (max-width: 980px){
  .hero-grid{grid-template-columns: 1fr;}
  .menu-card{grid-column: span 12}
  .reviews .review{grid-column: span 12}
  .visit{grid-column: span 12}
  .info{grid-column: span 12}
  .g1,.g2,.g3,.g4{grid-column: span 12; min-height: 260px}
}
@media (max-width: 760px){
  .nav-links{display:none}
  .hamburger{display:inline-flex}
  .hero-content{padding: 26px}
  .stats{grid-template-columns: 1fr;}
}
