:root{
  --sage:#ABBBA0;
  --sage-2:#C2CCB9;
  --cream:#FBFCFA;
  --ink:#0B0B0B;
  --muted:#4C564B;
  --card:#FFFFFF;
  --shadow: 0 18px 45px rgba(0,0,0,.12);
  --radius: 22px;
  --radius-sm: 16px;
  --max: 1120px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color:var(--ink);
  background:linear-gradient(180deg, var(--cream), #F1F3EE);
}

img{max-width:100%;display:block}
a{color:inherit}
.container{width:min(var(--max), calc(100% - 2rem)); margin-inline:auto}
.muted{color:var(--muted)}
.small{font-size:.92rem}
.skip{
  position:absolute; left:-999px; top:auto; width:1px; height:1px; overflow:hidden;
}
.skip:focus{left:1rem; top:1rem; width:auto; height:auto; z-index:999; background:#fff; padding:.75rem 1rem; border-radius:12px; box-shadow:var(--shadow)}

.badge{
  display:inline-flex; align-items:center; gap:.5rem;
  padding:.35rem .7rem;
  border-radius:999px;
  background:rgba(171,187,160,.25);
  border:1px solid rgba(171,187,160,.45);
  font-size:.9rem;
}

.topbar{
  background:rgba(255,255,255,.75);
  backdrop-filter: blur(10px);
  border-bottom:1px solid rgba(0,0,0,.06);
}
.topbar__inner{
  display:flex; align-items:center; justify-content:space-between;
  padding:.55rem 0;
  gap:1rem;
}
.topbar__sep{opacity:.5}
.link{display:inline-flex; align-items:center; gap:.5rem; text-decoration:none}
.icon{filter:saturate(.8)}

.header{
  position:sticky; top:0; z-index:50;
  background:rgba(251,252,250,.78);
  backdrop-filter: blur(10px);
  border-bottom:1px solid rgba(0,0,0,.06);
}
.header__inner{
  display:flex; align-items:center; justify-content:space-between;
  padding:.65rem 0;
  gap:1rem;
}
.brand{display:flex; align-items:center; text-decoration:none}
.brand__logo{height:54px; width:auto}
.nav__toggle{
  display:none;
  background:none; border:0; padding:.35rem; border-radius:12px;
}
.nav__toggle span{
  display:block; width:26px; height:2px; background:var(--ink); margin:6px 0; border-radius:2px;
}
.nav__menu{
  display:flex; align-items:center; gap:1rem;
}
.nav__menu a{
  text-decoration:none;
  padding:.55rem .6rem;
  border-radius:12px;
  color:rgba(11,11,11,.86);
}
.nav__menu a:hover{background:rgba(171,187,160,.18)}
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  gap:.5rem;
  padding:.9rem 1.05rem;
  border-radius:999px;
  border:1px solid rgba(0,0,0,.1);
  background:linear-gradient(180deg, var(--sage), #9FB08E);
  color:#0b0b0b;
  text-decoration:none;
  font-weight:700;
  box-shadow: 0 12px 28px rgba(0,0,0,.12);
  transition: transform .2s ease, box-shadow .2s ease;
}
.btn:hover{transform: translateY(-1px); box-shadow: 0 16px 34px rgba(0,0,0,.14)}
.btn--ghost{
  background:rgba(255,255,255,.65);
  box-shadow:none;
}
.btn--small{padding:.6rem .85rem; font-weight:700; font-size:.95rem}

.hero{position:relative; min-height: 78vh; display:grid; place-items:center; overflow:hidden}
.hero__bg{
  position:absolute; inset:0;
  width:100%; height:100%;
  object-fit:cover;
  object-position:center;
  transform:scale(1.05);
  filter:saturate(1.05) contrast(1.03);
}
.hero__overlay{
  position:absolute; inset:0;
  background: radial-gradient(900px 500px at 22% 45%, rgba(251,252,250,.90), rgba(251,252,250,.45) 55%, rgba(251,252,250,.22) 75%, rgba(251,252,250,.12));
}
.hero__content{position:relative; padding: 4rem 0}
.hero__card{
  width:min(610px, 100%);
  background:rgba(255,255,255,.74);
  border:1px solid rgba(0,0,0,.08);
  box-shadow:var(--shadow);
  border-radius: var(--radius);
  padding: 1.6rem 1.6rem 1.2rem;
  backdrop-filter: blur(10px);
}
.hero h1{
  margin:.1rem 0 .2rem;
  font-family:"Playfair Display", serif;
  font-size: clamp(2.1rem, 4vw, 3.3rem);
  letter-spacing:.2px;
}
.subtitle{
  margin:0 0 .9rem;
  font-size:1.05rem;
  font-weight:700;
  color:rgba(11,11,11,.65);
}
.lead{margin:0 0 1.2rem; font-size:1.08rem; line-height:1.55; color:rgba(11,11,11,.78)}
.hero__cta{display:flex; gap:.75rem; flex-wrap:wrap}
.hero__meta{
  display:grid; grid-template-columns: repeat(2, minmax(0,1fr));
  gap:.8rem;
  margin-top: 1.1rem;
}
.meta{
  background:rgba(171,187,160,.16);
  border:1px solid rgba(171,187,160,.35);
  border-radius: 16px;
  padding:.8rem .9rem;
}
.meta__k{display:block; font-size:.82rem; color:rgba(11,11,11,.55); font-weight:700; text-transform:uppercase; letter-spacing:.12em}
.meta__v{display:block; margin-top:.18rem; font-weight:700; color:rgba(11,11,11,.78)}

.section{padding: 4rem 0}
.section--soft{background: linear-gradient(180deg, rgba(171,187,160,.18), rgba(251,252,250,.35))}
.section__head{margin-bottom:1.4rem}
.section__head h2{
  margin:0 0 .35rem;
  font-family:"Playfair Display", serif;
  font-size: clamp(1.6rem, 3vw, 2.2rem);
}
.grid{
  display:grid;
  gap:1rem;
}
.grid--4{grid-template-columns: repeat(4, minmax(0, 1fr))}
.card{
  background:var(--card);
  border:1px solid rgba(0,0,0,.07);
  border-radius: var(--radius);
  padding: 1.25rem 1.25rem 1.1rem;
  box-shadow: 0 10px 26px rgba(0,0,0,.06);
}
.card h3{margin:.1rem 0 .5rem; font-size:1.05rem}

.menu-feature{
  margin-top: 1.2rem;
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap:1.1rem;
  align-items:stretch;
}
.menu-feature__img img{
  height:100%;
  object-fit:cover;
  border-radius: var(--radius);
  border:1px solid rgba(0,0,0,.07);
}
.pills{display:flex; gap:.55rem; flex-wrap:wrap; margin:.75rem 0 1rem}
.pill{
  display:inline-flex;
  padding:.4rem .75rem;
  border-radius:999px;
  background:rgba(171,187,160,.22);
  border:1px solid rgba(171,187,160,.35);
  font-weight:700;
  font-size:.92rem;
}
.menu-feature__actions{display:flex; gap:.65rem; flex-wrap:wrap}

.gallery{
  display:grid;
  grid-template-columns: repeat(4, minmax(0,1fr));
  gap:.9rem;
}
.gallery__item{
  border:0;
  padding:0;
  background:none;
  border-radius: 18px;
  overflow:hidden;
  cursor:pointer;
  border:1px solid rgba(0,0,0,.07);
  box-shadow: 0 10px 26px rgba(0,0,0,.06);
  transition: transform .18s ease;
}
.gallery__item:hover{transform: translateY(-2px)}
.gallery__item img{width:100%; height: 190px; object-fit:cover}

.video-card{border-radius: var(--radius); overflow:hidden; border:1px solid rgba(0,0,0,.07); box-shadow: var(--shadow)}
.ratio{position:relative; padding-top:56.25%}
.ratio iframe{position:absolute; inset:0; width:100%; height:100%}

.social-grid{
  display:grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap:1rem;
}
.card__head{
  display:flex; align-items:center; justify-content:space-between; gap:1rem;
  margin-bottom:.75rem;
}
.embed{
  border-radius: 18px;
  overflow:hidden;
  background: rgba(171,187,160,.12);
  border:1px solid rgba(171,187,160,.25);
  min-height: 420px;
}
.embed iframe{width:100%; height:520px}
.embed--ig{padding:1rem; min-height: 420px}
.embed--ig blockquote{width:100%}

.contact-grid{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap:1rem;
  align-items:stretch;
}
.form{display:grid; gap:.85rem}
label{display:grid; gap:.35rem; font-weight:700; color:rgba(11,11,11,.8)}
input, textarea{
  width:100%;
  padding:.85rem .95rem;
  border-radius: 16px;
  border:1px solid rgba(0,0,0,.14);
  background: rgba(255,255,255,.9);
  font-family: inherit;
  font-size:1rem;
  outline:none;
}
input:focus, textarea:focus{
  border-color: rgba(159,176,142,.9);
  box-shadow: 0 0 0 4px rgba(171,187,160,.25);
}
.form__actions{display:flex; gap:.75rem; flex-wrap:wrap; margin-top:.25rem}
.map{border-radius:18px; overflow:hidden; border:1px solid rgba(0,0,0,.07); margin-top:.65rem}
.map iframe{width:100%; height:320px; border:0}
.contact-actions{display:flex; gap:.65rem; flex-wrap:wrap; margin-top:.85rem}

.footer{
  background:rgba(255,255,255,.7);
  border-top:1px solid rgba(0,0,0,.06);
}
.footer__inner{
  padding: 1.6rem 0;
  display:flex; align-items:flex-start; justify-content:space-between;
  gap:1rem;
}
.footer__right p{margin:0}
.footer__left{line-height:1.5}

.fab{
  position:fixed;
  right: 18px;
  bottom: 18px;
  width: 56px;
  height: 56px;
  border-radius: 999px;
  display:grid;
  place-items:center;
  background: linear-gradient(180deg, var(--sage), #9FB08E);
  border:1px solid rgba(0,0,0,.1);
  box-shadow: 0 16px 40px rgba(0,0,0,.18);
  text-decoration:none;
  z-index:60;
  transition: transform .2s ease;
}
.fab:hover{transform: translateY(-2px)}
.fab span{font-size: 22px}

.lightbox{
  position:fixed;
  inset:0;
  background: rgba(0,0,0,.72);
  display:none;
  align-items:center;
  justify-content:center;
  padding: 1.2rem;
  z-index:80;
}
.lightbox.is-open{display:flex}
.lightbox__img{
  max-width:min(100%, 980px);
  max-height:min(86vh, 980px);
  border-radius: 18px;
  box-shadow: 0 24px 60px rgba(0,0,0,.35);
}
.lightbox__close{
  position:absolute;
  top: 14px;
  right: 14px;
  width: 46px;
  height: 46px;
  border-radius: 999px;
  border:1px solid rgba(255,255,255,.35);
  background: rgba(255,255,255,.12);
  color:#fff;
  font-size: 28px;
  cursor:pointer;
}

.reveal{opacity:0; transform: translateY(14px); transition: opacity .6s ease, transform .6s ease}
.reveal.is-in{opacity:1; transform: translateY(0)}

@media (max-width: 980px){
  .grid--4{grid-template-columns: repeat(2, minmax(0, 1fr))}
  .menu-feature{grid-template-columns: 1fr}
  .gallery{grid-template-columns: repeat(2, minmax(0, 1fr))}
  .social-grid{grid-template-columns: 1fr}
  .contact-grid{grid-template-columns: 1fr}
  .brand__logo{height:50px}
}
@media (max-width: 720px){
  .topbar__left{display:none}
  .nav__toggle{display:inline-flex}
  .nav__menu{
    position: absolute;
    right: 1rem;
    top: 64px;
    background: rgba(251,252,250,.98);
    border:1px solid rgba(0,0,0,.08);
    border-radius: 18px;
    box-shadow: var(--shadow);
    padding: .55rem;
    display:none;
    flex-direction:column;
    align-items:stretch;
    min-width: 220px;
  }
  .nav__menu a{padding:.75rem .85rem}
  .nav__menu.is-open{display:flex}
  .hero__meta{grid-template-columns: 1fr}
  .footer__inner{flex-direction:column}
}
