:root{
  --bg:#fbf6f2;
  --bg-alt:#f3e9e2;
  --ink:#3a2e2a;
  --muted:#9a7b6b;
  --rose:#c98b86;
  --rose-deep:#b06a64;
  --gold:#c9a24b;
  --card:#ffffff;
  --radius:18px;
  --shadow:0 14px 40px rgba(140,90,70,.10);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:'Jost',system-ui,sans-serif;
  color:var(--ink);
  background:var(--bg);
  line-height:1.6;
}
h1,h2,h3{font-family:'Cormorant Garamond',Georgia,serif;font-weight:600;line-height:1.1;margin:0}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

/* ── Nav ── */
.nav{
  position:sticky;top:0;z-index:20;
  display:flex;justify-content:space-between;align-items:center;
  padding:1rem clamp(1rem,5vw,3.5rem);
  background:rgba(251,246,242,.85);
  backdrop-filter:blur(10px);
  border-bottom:1px solid rgba(180,140,120,.15);
}
.nav__brand{font-family:'Cormorant Garamond',serif;font-size:1.5rem;font-weight:600;letter-spacing:.5px}
.nav__links{display:flex;gap:1.6rem;align-items:center;font-size:.95rem}
.nav__links a{color:var(--muted);transition:color .2s}
.nav__links a:hover{color:var(--rose-deep)}
.nav__cta{
  background:var(--rose-deep);color:#fff !important;
  padding:.5rem 1.1rem;border-radius:30px;
}
.nav__cta:hover{background:var(--ink)}

/* ── Hero ── */
.hero{
  position:relative;
  padding:clamp(3rem,9vw,7rem) clamp(1rem,5vw,3.5rem) clamp(3rem,7vw,5rem);
  background:
    radial-gradient(900px 500px at 80% -10%, rgba(201,139,134,.25), transparent 60%),
    radial-gradient(700px 500px at 0% 100%, rgba(201,162,75,.14), transparent 55%),
    var(--bg);
  overflow:hidden;
}
.hero__inner{max-width:760px}
.hero__eyebrow{
  text-transform:uppercase;letter-spacing:.32em;font-size:.78rem;
  color:var(--rose-deep);margin:0 0 1rem;
  animation:fade .8s both;
}
.hero__title{
  font-size:clamp(2.6rem,6.5vw,4.6rem);
  margin-bottom:1.4rem;
  animation:fade .8s .1s both;
}
.hero__sub{
  color:var(--muted);font-size:1.08rem;max-width:600px;margin:0 0 2rem;
  animation:fade .8s .2s both;
}
.hero__actions{display:flex;gap:1rem;flex-wrap:wrap;animation:fade .8s .3s both}
.hero__hours{margin-top:1.6rem;color:var(--muted);font-size:.92rem;animation:fade .8s .4s both}

.btn{
  display:inline-block;padding:.85rem 1.8rem;border-radius:32px;
  font-size:1rem;font-weight:500;cursor:pointer;border:none;
  transition:transform .15s, box-shadow .25s, background .2s;
}
.btn--primary{background:var(--rose-deep);color:#fff;box-shadow:0 10px 24px rgba(176,106,100,.35)}
.btn--primary:hover{transform:translateY(-2px);box-shadow:0 16px 30px rgba(176,106,100,.45)}
.btn--ghost{background:transparent;border:1.5px solid var(--rose);color:var(--rose-deep)}
.btn--ghost:hover{background:var(--rose);color:#fff}
.btn--wide{width:100%;text-align:center}

/* ── Sections ── */
.section{padding:clamp(3rem,7vw,5.5rem) clamp(1rem,5vw,3.5rem);max-width:1140px;margin:0 auto}
.section--alt{background:var(--bg-alt);max-width:none}
.section--alt > *{max-width:1140px;margin-left:auto;margin-right:auto}
.section__head{margin-bottom:2.5rem;text-align:center}
.section__kicker{
  display:inline-block;text-transform:uppercase;letter-spacing:.28em;
  font-size:.74rem;color:var(--gold);margin-bottom:.6rem;
}
.section__head h2{font-size:clamp(2rem,4.5vw,3rem)}

/* ── Services ── */
.services{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.3rem}
.service{
  background:var(--card);border-radius:var(--radius);padding:1.6rem;
  box-shadow:var(--shadow);border:1px solid rgba(180,140,120,.1);
  transition:transform .2s, box-shadow .2s;
}
.service:hover{transform:translateY(-4px);box-shadow:0 20px 50px rgba(140,90,70,.16)}
.service__top{display:flex;justify-content:space-between;align-items:baseline;gap:1rem;margin-bottom:.6rem}
.service__top h3{font-size:1.35rem}
.service__price{color:var(--rose-deep);font-weight:600;white-space:nowrap}
.service__desc{color:var(--muted);font-size:.95rem;margin:0 0 .8rem}
.service__dur{font-size:.85rem;color:var(--gold)}

/* ── Gallery ── */
.gallery{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem}
.gallery__item{
  border-radius:14px;overflow:hidden;aspect-ratio:1;
  box-shadow:var(--shadow);animation:fade .7s var(--d,0ms) both;
}
.gallery__item img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.gallery__item:hover img{transform:scale(1.07)}

/* ── About ── */
.about{display:flex;justify-content:center}
.about__text{max-width:680px;text-align:center}
.about__text h2{font-size:clamp(2.2rem,5vw,3.2rem);margin:.4rem 0 1rem}
.about__text p{color:var(--muted)}
.about__perks{
  list-style:none;padding:0;margin:1.6rem 0 0;
  display:flex;flex-wrap:wrap;gap:.6rem;justify-content:center;
}
.about__perks li{
  background:#fff;border:1px solid rgba(180,140,120,.18);
  padding:.5rem 1rem;border-radius:30px;font-size:.9rem;color:var(--ink);
}

/* ── Form ── */
.form{max-width:680px;margin:0 auto;background:var(--card);
  padding:2rem;border-radius:var(--radius);box-shadow:var(--shadow)}
.form__row{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:1rem}
.form__row > label{flex:1;min-width:150px}
.form label{display:block;font-size:.9rem;color:var(--muted);margin-bottom:1rem}
.form input,.form select,.form textarea{
  width:100%;margin-top:.35rem;padding:.7rem .9rem;
  border:1.5px solid #e6d8cf;border-radius:12px;
  font-family:inherit;font-size:1rem;color:var(--ink);background:#fff;
  transition:border .2s;
}
.form input:focus,.form select:focus,.form textarea:focus{outline:none;border-color:var(--rose)}
.form__note{font-size:.8rem;color:var(--muted);text-align:center;margin:.8rem 0 0}

.banner{padding:1rem 1.2rem;border-radius:12px;margin-bottom:1.4rem;text-align:center;font-weight:500}
.banner--ok{background:#d8f5e3;color:#2f855a;border:1px solid #aee3c4}

/* ── Footer ── */
.footer{
  background:var(--ink);color:#e8ddd6;
  padding:3rem clamp(1rem,5vw,3.5rem);
  display:flex;flex-wrap:wrap;gap:2rem;justify-content:space-between;align-items:flex-start;
}
.footer__col{display:flex;flex-direction:column;gap:.4rem}
.footer__col strong{font-family:'Cormorant Garamond',serif;font-size:1.3rem;color:#fff}
.footer__col a{color:#d9b8b3}
.footer__col a:hover{color:#fff}
.footer__copy{width:100%;text-align:center;color:#a08d84;font-size:.85rem;margin:1.5rem 0 0}

@keyframes fade{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}

@media(max-width:640px){
  .nav__links a:not(.nav__cta){display:none}
}
