/* ========== Base ========== */
:root{
  --bg:#0e0e0f; --card:#141416; --text:#e9e7e4; --muted:#bdb7b0;
  --accent:#c0392b; --accent-2:#f4d19e; --border:#262629;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color:var(--text); background:linear-gradient(180deg,#0b0b0c, #141416 40%, #0b0b0c);
  line-height:1.6;
}
img{max-width:100%;height:auto;display:block;border-radius:12px}
.container{max-width:1120px;margin:0 auto;padding:0 20px}
.section{padding:72px 0}
.section.alt{background:linear-gradient(180deg, #131315, #0f0f11);}
.section-head{margin-bottom:28px}
h1,h2,h3{font-family:"Playfair Display", serif;margin:0 0 12px}
h1{font-size:clamp(2rem, 3vw + 1rem, 3rem);letter-spacing:0.2px}
h2{font-size:clamp(1.6rem, 2vw + 1rem, 2.2rem)}
.lead{font-size:1.125rem;color:var(--muted)}
.tiny{font-size:.85rem;color:var(--muted)}
.mt-8{margin-top:8px}

.accent{color:var(--accent-2)}
.btn{
  display:inline-block;padding:12px 18px;border-radius:999px;border:1px solid var(--border);
  color:var(--text); text-decoration:none; font-weight:600;
  transition:.2s background, .2s border-color, .2s transform;
  will-change:transform;
}
.btn:hover{transform:translateY(-1px)}
.btn-primary{background:var(--accent); border-color:transparent}
.btn-primary:hover{filter:brightness(1.08)}
.btn-outline{background:transparent}
.btn:focus{outline:2px solid var(--accent-2); outline-offset:2px}

/* Header & Nav */
.site-header{position:relative;padding-bottom:24px}
.nav{display:flex;align-items:center;justify-content:space-between;padding:16px 0}
.brand{display:flex;gap:10px;align-items:center;color:var(--text);text-decoration:none;font-weight:700;letter-spacing:.5px}
.brand img{filter:drop-shadow(0 0 8px rgba(255,255,255,.1))}
.nav-list{display:flex;gap:18px;list-style:none;margin:0;padding:0;align-items:center}
.nav-list a{color:var(--text);text-decoration:none}
.nav-toggle{display:none;background:#1b1b1f;color:var(--text);border:1px solid var(--border);padding:8px 10px;border-radius:8px}

/* Hero */
.hero{display:grid;grid-template-columns:1.2fr .8fr; gap:28px; align-items:center; padding:24px 0 0}
.hero-img{height:420px;object-fit:cover;border:1px solid var(--border);}
.hero-cta{display:flex;gap:12px;margin:18px 0 8px}

/* Menu grid */
.menu-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.menu-card{background:var(--card);padding:18px;border:1px solid var(--border);border-radius:14px}
.menu-card h3{margin:0 0 6px}
.menu-card p{margin:0;color:var(--muted)}
.price{margin-top:8px;font-weight:600}

/* Drinks */
.drinks{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.drinks article{background:var(--card);padding:18px;border:1px solid var(--border);border-radius:14px}

/* Gallery */
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.gallery-grid img{aspect-ratio: 4 / 3; object-fit:cover}

/* Contact */
.contact-wrap{display:grid;grid-template-columns:1.1fr .9fr;gap:20px}
.contact-list{list-style:none;padding:0;margin:0 0 12px}
.res-form{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.res-form label{display:grid;gap:6px;font-size:.95rem}
.res-form input,.res-form textarea{
  background:#1a1a1e;color:var(--text);border:1px solid var(--border);
  padding:10px;border-radius:10px;
}
.res-form textarea{grid-column:1/-1}
.res-form button{grid-column:1/-1;justify-self:start}
.map-wrap iframe{width:100%;height:100%;min-height:360px;border:0;border-radius:12px;border:1px solid var(--border)}

/* Footer */
.site-footer{border-top:1px solid var(--border);padding:28px 0 46px;background:#0e0e0f}
.footer-grid{display:flex;justify-content:space-between;gap:18px;align-items:flex-start}
.brand-foot span{font-weight:800}

/* Accessibility */
.skip-link{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}
.skip-link:focus{left:8px;top:8px;width:auto;height:auto;background:#000;color:#fff;padding:8px;border-radius:8px}

/* Responsive */
@media (max-width: 900px){
  .hero{grid-template-columns:1fr}
  .menu-grid{grid-template-columns:1fr 1fr}
  .drinks,.contact-wrap{grid-template-columns:1fr}
  .gallery-grid{grid-template-columns:1fr 1fr}
  .nav-toggle{display:block}
  .nav-list{display:none;position:absolute;right:20px;top:64px;background:#111214;border:1px solid var(--border);padding:10px 14px;border-radius:12px}
  .nav-list.open{display:flex;flex-direction:column;align-items:flex-start}
}
@media (max-width: 520px){
  .menu-grid{grid-template-columns:1fr}
  .gallery-grid{grid-template-columns:1fr}
  .hero-img{height:260px}
}
