/* style.css
   Developer comments included.
   Theme: Dark luxury (navy/black/gold)
   Pure CSS, responsive, with animations
*/

/* ---------- Base & Fonts ---------- */
:root{
  --bg:#e2e6f3;            /* deep near-black */
  --panel:#a4bfdd;         /* dark navy panel */
  --muted:#9aa0a6;
  --gold:#d4af37;          /* gold accent */
  --accent:#0b3b52;        /* navy accent */
  --glass: rgba(213, 174, 174, 0.03);
  --rounded: 12px;
  --container: 1150px;
}

* {box-sizing: border-box;}
html,body{height:100%;}
body{
  margin:0;
  font-family: "Montserrat", system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial;
  background: linear-gradient(180deg,var(--bg),#050611 60%);
  color: #e6eef6;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  line-height:1.55;
  letter-spacing:0.2px;
}

/* Utility container */
.container{max-width:var(--container);margin:0 auto;padding:1rem 1.25rem;}

/* ---------- Header / Nav ---------- */
.site-header{
  position:sticky;
  top:0;
  z-index:60;
  background:linear-gradient(180deg, rgba(2,6,10,0.6), rgba(2,6,10,0.25));
  backdrop-filter: blur(6px);
  border-bottom:1px solid rgba(255,255,255,0.03);
}
.header-inner{
  display:flex;
  align-items:center;
  gap:1rem;
  padding:0.6rem 0;
}
.brand .logo{height:46px;display:block;}
.site-header.small .brand .logo{height:40px;}
.nav{margin-left:auto;}
.nav ul{list-style:none;margin:0;padding:0;display:flex;gap:1.25rem;align-items:center;}
.nav a{
  color:var(--muted);
  text-decoration:none;
  font-weight:600;
  padding:0.45rem 0.6rem;
  border-radius:8px;
  transition:all 180ms ease;
}
.nav a:hover{color:white;background:rgba(255,255,255,0.03);transform:translateY(-2px);}
.nav a.active{color:var(--gold);text-shadow:0 1px 0 rgba(0,0,0,0.6);}

.cta-group{display:flex;align-items:center;gap:0.75rem;margin-left:1rem;}
.btn{
  display:inline-block;
  padding:0.55rem 0.9rem;
  border-radius:10px;
  text-decoration:none;
  font-weight:700;
  font-size:0.92rem;
  letter-spacing:0.6px;
}
.btn-outline{border:1px solid rgba(255,255,255,0.06);color:var(--muted);background:transparent;}
.btn-primary{background:linear-gradient(90deg,var(--accent),#123445);color:white;box-shadow:0 6px 22px rgba(2,10,18,0.45);border:1px solid rgba(255,255,255,0.03);}
.btn-gold{background:linear-gradient(90deg,var(--gold),#b88f2a);color:#071018;border:1px solid rgba(255,255,255,0.04);}

/* mobile toggle */
.mobile-toggle{display:none;background:transparent;border:0;color:var(--muted);font-size:1.15rem;padding:0.25rem 0.5rem;}

/* ---------- HERO ---------- */
.hero{
  position:relative;
  min-height:70vh;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  overflow:hidden;
  padding:3rem 0;
}
.hero-video{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  opacity:0.14;
  filter:grayscale(10%) contrast(0.9);
  z-index:0;
}
.hero-overlay{
  position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(5,6,10,0.6), rgba(2,6,11,0.6));
  z-index:1;
}
.hero-content{position:relative;z-index:2;max-width:900px;margin:0 auto;padding:2rem;}
.hero-logo{height:96px;margin-bottom:0.6rem;filter:drop-shadow(0 8px 22px rgba(0,0,0,0.6));}
.hero-title{
  font-family:"Playfair Display", serif;
  font-weight:700;
  font-size:2.25rem;
  margin:0.25rem 0 0.5rem;
  color: #f5f6f7;
  letter-spacing:0.6px;
}
.hero-sub{color:var(--muted);margin-bottom:1.25rem;}
.hero-ctas{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-top:0.8rem;}
.hero-info{list-style:none;padding:0;margin-top:1.25rem;display:flex;gap:1.5rem;justify-content:center;color:var(--muted);font-size:0.95rem;}

/* ---------- Highlights ---------- */
.highlights{padding:2.25rem 0;}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;}
.highlight-card{background:linear-gradient(180deg, rgba(255,255,255,0.015), rgba(255,255,255,0.02));padding:1.25rem;border-radius:14px;border:1px solid rgba(255,255,255,0.02);transition:transform 220ms ease, box-shadow 220ms ease;}
.highlight-card:hover{transform:translateY(-8px);box-shadow:0 20px 50px rgba(3,8,12,0.7);}

/* ---------- About / content ---------- */
.about-hero{padding:3rem 0;}
.about-grid{display:grid;grid-template-columns:1fr 420px;gap:2rem;align-items:center;}
.about-text .lead{font-size:1.05rem;color:var(--muted);line-height:1.68;margin-bottom:1rem;}
.values{display:flex;gap:1rem;margin-top:1.25rem;}
.values h4{font-family:"Playfair Display";margin:0 0 0.4rem 0;color:var(--gold);}
.img-stack img{width:100%;border-radius:12px;box-shadow:0 18px 48px rgba(0,0,0,0.6);}

/* ---------- Menu ---------- */
.menu-page{padding:2.5rem 0;}
.section-title{font-family:"Playfair Display";font-size:1.6rem;margin-bottom:0.25rem;color:#fff;}
.section-sub{color:var(--muted);margin-bottom:1rem;}
.menu-section{margin-top:1.25rem;padding:1rem 0;border-top:1px dashed rgba(255,255,255,0.03);}
.menu-grid{display:flex;flex-direction:column;gap:0.5rem;margin-top:0.75rem;}
.menu-item{display:flex;justify-content:space-between;align-items:center;padding:0.8rem 1rem;border-radius:10px;background:var(--glass);border:1px solid rgba(255,255,255,0.02);transition:transform 160ms ease;}
.menu-item:hover{transform:translateY(-6px)}
.menu-item h4{margin:0;font-size:1rem}
.mi-left .muted{color:var(--muted);font-size:0.92rem}
.menu-grid.smaller{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:0.5rem}
.flavour{padding:0.6rem;border-radius:10px;background:linear-gradient(180deg, rgba(255,255,255,0.02), rgba(255,255,255,0.01));text-align:center;font-weight:600;}

/* ---------- Gallery ---------- */
.gallery-page{padding:2.25rem 0;}
.insta-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:10px;}
.insta-item{overflow:hidden;border-radius:10px;display:block;border:1px solid rgba(255,255,255,0.02);}
.insta-item img{display:block;width:100%;height:100%;object-fit:cover;transition:transform 350ms ease;}
.insta-item:hover img{transform:scale(1.08) rotate(-0.6deg)}

/* ---------- Contact ---------- */
.contact-page{padding:2.25rem 0;}
.contact-grid{display:grid;grid-template-columns:1fr 460px;gap:2rem;align-items:start;}
.contact-info p{color:var(--muted)}
.map-wrap{height:260px;border-radius:12px;overflow:hidden;border:1px solid rgba(255,255,255,0.03);margin-top:1rem;}
.map-wrap iframe{width:100%;height:100%;border:0}

/* form */
.contact-form form{background:linear-gradient(180deg, rgba(255,255,255,0.02), rgba(255,255,255,0.01));padding:1.25rem;border-radius:12px;border:1px solid rgba(255,255,255,0.02);}
.contact-form label{display:block;margin:0.6rem 0 0.25rem;color:var(--muted);font-size:0.9rem;}
.contact-form input, .contact-form textarea, .contact-form select{
  width:100%;padding:0.72rem;border-radius:10px;border:1px solid rgba(255,255,255,0.04);background:transparent;color:inherit;font-size:0.95rem;
}
.form-row{display:flex;gap:0.75rem;}
.form-row > div{flex:1}

/* ---------- Footer ---------- */
.site-footer{border-top:1px solid rgba(255,255,255,0.03);padding:1.25rem 0;margin-top:2rem;background:linear-gradient(180deg, rgba(2,4,6,0.2), transparent)}
.footer-inner{display:flex;gap:1rem;align-items:center;justify-content:space-between;flex-wrap:wrap;}
.footer-logo{height:44px}
.footer-links a{display:inline-block;margin-right:0.5rem;color:var(--muted);text-decoration:none}
.footer-contact .small{color:var(--muted);font-size:0.9rem}

/* ---------- Responsive ---------- */
@media (max-width:1024px){
  .about-grid{grid-template-columns:1fr;}
  .contact-grid{grid-template-columns:1fr;}
  .grid-3{grid-template-columns:repeat(2,1fr)}
}

@media (max-width:780px){
  .nav{position:fixed;top:68px;right:12px;background:rgba(5,7,10,0.96);padding:1rem;border-radius:12px;border:1px solid rgba(255,255,255,0.03);display:none;box-shadow:0 20px 60px rgba(1,5,8,0.7)}
  .nav.open{display:block}
  .nav ul{flex-direction:column}
  .mobile-toggle{display:inline-block}
  .cta-group .btn{display:none}
  .header-inner{gap:0.5rem}
  .hero-title{font-size:1.6rem}
  .grid-3{grid-template-columns:1fr}
}

/* ---------- Small helpers ---------- */
.muted{color:var(--muted)}
.small{font-size:0.85rem;color:var(--muted)}
.centered{text-align:center}
.lead{font-size:1rem;color:var(--muted)}
.fade{animation:fadeIn 900ms ease both}
@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
