:root{
  --bg:#faf7f3;
  --bg-soft:#f1e9e1;
  --ink:#2e2a26;
  --muted:#7a716a;
  --gold:#c9a36a;
  --gold-d:#b08a4f;
  --line:#e6dcd1;
  --white:#fff;
  --shadow:0 18px 50px rgba(80,60,40,.12);
  --serif:'Cormorant Garamond',Georgia,serif;
  --sans:'Montserrat',-apple-system,Segoe UI,Roboto,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--sans);color:var(--ink);background:var(--bg);line-height:1.65;font-weight:300}
.container{width:min(1140px,92%);margin:0 auto}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3{font-family:var(--serif);font-weight:500;line-height:1.1}
.eyebrow{display:inline-block;font-size:.74rem;letter-spacing:.28em;text-transform:uppercase;color:var(--gold-d);margin-bottom:.6rem}

/* buttons */
.btn{display:inline-block;background:var(--gold);color:#fff;padding:.85rem 1.7rem;border-radius:40px;font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;font-weight:500;transition:.25s;border:1px solid var(--gold)}
.btn:hover{background:var(--gold-d);border-color:var(--gold-d);transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line)}
.btn-ghost:hover{background:#fff;color:var(--gold-d);border-color:var(--gold)}
.btn-sm{padding:.55rem 1.2rem}

/* header */
.site-header{position:sticky;top:0;z-index:50;background:rgba(250,247,243,.92);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.nav-wrap{display:flex;align-items:center;justify-content:space-between;padding:.9rem 0}
.brand{display:flex;align-items:center;line-height:1}
.logo{height:48px;width:auto;display:block}
.brand-mark{font-family:var(--serif);font-size:1.7rem;font-weight:600;letter-spacing:.02em}
.brand-sub{font-size:.62rem;letter-spacing:.34em;text-transform:uppercase;color:var(--muted)}
.nav{display:flex;align-items:center;gap:1.9rem}
.nav a{font-size:.82rem;letter-spacing:.08em;color:var(--ink);transition:.2s}
.nav a:hover{color:var(--gold-d)}
.nav .btn{color:#fff}
.nav-toggle{display:none;background:none;border:0;font-size:1.5rem;color:var(--ink);cursor:pointer}

/* hero */
.hero{position:relative;min-height:88vh;display:flex;align-items:center;text-align:center;color:#fff;
  background:url('img/young-attractive-woman-having-massage-relaxing-spa-salon-scaled.jpg') center/cover fixed}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(46,42,38,.45),rgba(46,42,38,.62))}
.hero-inner{position:relative;width:min(820px,92%)}
.hero-quote{font-family:var(--serif);font-style:italic;font-size:1.5rem;opacity:.95;margin-bottom:1rem}
.hero h1{font-size:clamp(2.6rem,6vw,4.6rem);font-weight:600;letter-spacing:.01em}
.hero-tag{margin:1rem 0 1.8rem;font-size:1rem;letter-spacing:.04em;opacity:.92}
.hero-cta{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-top:1.8rem}
.hero-cta .btn-ghost{color:#fff;border-color:rgba(255,255,255,.6)}
.hero-cta .btn-ghost:hover{background:#fff;color:var(--gold-d)}
.hero-hours{margin-top:1.8rem;font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;opacity:.85}

/* sections */
.section{padding:5.5rem 0}
.section-head{text-align:center;margin-bottom:3rem}
.section-head h2,.about-text h2,.contatti-info h2{font-size:clamp(2rem,4vw,2.9rem)}
.about{background:var(--white)}

.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:3.5rem;align-items:center}
.about-img img{border-radius:6px;box-shadow:var(--shadow);height:100%;object-fit:cover}
.about-text p{color:var(--muted);margin-top:1rem}
.about-text .lead{color:var(--ink);font-size:1.08rem}
.about-text .lead strong{color:var(--gold-d);font-weight:500}

/* servizi cards */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}
.card{background:#fff;border-radius:8px;overflow:hidden;box-shadow:var(--shadow);transition:.3s}
.card:hover{transform:translateY(-6px)}
.card-img{height:230px;background-size:cover;background-position:center}
.card-body{padding:1.6rem}
.card-body h3{font-size:1.6rem;margin-bottom:.5rem}
.card-body p{color:var(--muted);font-size:.95rem}

/* trattamenti */
.trattamenti{background:var(--bg-soft)}
.tratt-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem;max-width:880px;margin:0 auto}
.tratt-col{background:#fff;border-radius:8px;padding:2.2rem 2.4rem;box-shadow:var(--shadow)}
.tratt-col h3{font-size:1.8rem;color:var(--gold-d);margin-bottom:1rem;border-bottom:1px solid var(--line);padding-bottom:.6rem}
.tratt-col ul{list-style:none}
.tratt-col li{padding:.55rem 0;border-bottom:1px dashed var(--line);font-size:.95rem;letter-spacing:.02em}
.tratt-col li:last-child{border-bottom:0}

/* contatti */
.contatti{background:var(--white)}
.contatti-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center}
.info-list{list-style:none;margin:1.4rem 0 2rem}
.info-list li{display:flex;flex-direction:column;padding:.9rem 0;border-bottom:1px solid var(--line)}
.info-list strong{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-d);margin-bottom:.3rem;font-weight:600}
.info-list a{color:var(--ink)}
.info-list a:hover{color:var(--gold-d)}
.contatti-cta{display:flex;gap:.8rem;flex-wrap:wrap}
.contatti-map iframe{width:100%;height:380px;border:0;border-radius:8px;box-shadow:var(--shadow)}

/* closing band */
.closing{background:var(--gold);color:#fff;text-align:center;padding:3.6rem 0}
.closing p{font-family:var(--serif);font-style:italic;font-size:clamp(1.5rem,3vw,2.3rem);letter-spacing:.01em}

/* footer */
.site-footer{background:var(--ink);color:#cfc6bd;text-align:center;padding:3rem 0}
.site-footer .areas{font-size:.78rem;color:#9b938b;margin:.2rem 0 .6rem;letter-spacing:.04em}
.footer-inner .brand-mark{color:#fff;display:block;margin-bottom:.6rem}
.logo-footer{height:54px;margin:0 auto 1rem;filter:brightness(0) invert(1);opacity:.92}
.site-footer p{font-size:.82rem}
.site-footer .credit{color:var(--gold);margin-top:.4rem;font-size:.75rem;letter-spacing:.1em}
.site-footer .credit a{color:var(--gold);text-decoration:underline}
.site-footer .credit a:hover{color:#fff}

/* whatsapp float */
.wa-float{position:fixed;right:20px;bottom:20px;width:56px;height:56px;border-radius:50%;background:#25d366;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 24px rgba(37,211,102,.45);z-index:60;transition:.25s}
.wa-float:hover{transform:scale(1.08)}

/* responsive */
@media(max-width:860px){
  .nav{position:absolute;top:100%;left:0;right:0;flex-direction:column;gap:0;background:var(--bg);border-bottom:1px solid var(--line);max-height:0;overflow:hidden;transition:max-height .3s}
  .nav.open{max-height:380px;padding:.5rem 0}
  .nav a{padding:.8rem 6%;width:100%}
  .nav-toggle{display:block}
  .hero{background-attachment:scroll;align-items:stretch;padding:16vh 0 8vh}
  .hero-inner{display:flex;flex-direction:column;justify-content:space-between;flex:1;width:88%}
  .about-grid,.cards,.tratt-grid,.contatti-grid{grid-template-columns:1fr}
  .section{padding:4rem 0}
  .about-img{order:-1}
}
