/* =========================================================
   VITTALE ESTÉTICA — Design System (premium)
   ========================================================= */
:root{
  --cream:#f8f4ee;
  --cream-2:#f1e9df;
  --cream-3:#e9decf;
  --ink:#2a241f;
  --ink-soft:#5b5147;
  --terra:#bd7a5e;        /* cor de marca (logo) */
  --terra-deep:#a3624a;
  --terra-tint:#e7ccbd;
  --gold:#b89763;
  --sage:#9aa886;
  --white:#ffffff;
  --line:rgba(42,36,31,.12);
  --shadow:0 18px 50px -20px rgba(60,40,30,.35);
  --shadow-soft:0 10px 40px -22px rgba(60,40,30,.45);
  --r:18px;
  --maxw:1180px;
  --serif:"Marcellus",Georgia,serif;
  --sans:"DM Sans",-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(--cream);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
h1,h2,h3,h4{font-family:var(--serif);font-weight:400;line-height:1.12;color:var(--ink)}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.eyebrow{
  font-family:var(--sans);font-size:.74rem;letter-spacing:.32em;text-transform:uppercase;
  color:var(--terra-deep);font-weight:600;display:inline-flex;align-items:center;gap:.7em;
}
.eyebrow::before{content:"";width:34px;height:1px;background:var(--terra)}
.eyebrow.center::after{content:"";width:34px;height:1px;background:var(--terra)}
.eyebrow.center{justify-content:center}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;gap:.6em;cursor:pointer;border:none;
  font-family:var(--sans);font-weight:600;font-size:.92rem;letter-spacing:.02em;
  padding:16px 30px;border-radius:100px;transition:.35s cubic-bezier(.2,.7,.3,1);
  position:relative;
}
.btn-primary{background:var(--terra);color:#fff;box-shadow:0 12px 28px -12px rgba(163,98,74,.7)}
.btn-primary:hover{background:var(--terra-deep);transform:translateY(-2px);box-shadow:0 18px 34px -12px rgba(163,98,74,.85)}
.btn-ghost{background:transparent;color:var(--ink);border:1px solid var(--line)}
.btn-ghost:hover{border-color:var(--terra);color:var(--terra-deep)}
.btn-light{background:#fff;color:var(--ink)}
.btn-light:hover{transform:translateY(-2px)}

/* =========== Header =========== */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:100;
  padding:18px 0;transition:.4s;
}
.site-header.scrolled{background:rgba(248,244,238,.92);backdrop-filter:blur(12px);box-shadow:0 1px 0 var(--line);padding:12px 0}
.nav{display:flex;align-items:center;justify-content:space-between;gap:24px}
.nav__logo img{height:44px;width:auto}
.nav__menu{display:flex;align-items:center;gap:34px;list-style:none}
.nav__menu a{font-size:.92rem;font-weight:500;color:var(--ink);position:relative;padding:4px 0}
.nav__menu a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:1.5px;background:var(--terra);transition:.3s}
.nav__menu a:hover::after{width:100%}
.nav__cta{display:flex;align-items:center;gap:14px}
.nav__burger{display:none;background:none;border:none;cursor:pointer;flex-direction:column;gap:5px}
.nav__burger span{width:26px;height:2px;background:var(--ink);transition:.3s}

/* =========== Hero =========== */
.hero{position:relative;padding:170px 0 90px}
.hero__grid{display:grid;grid-template-columns:1.05fr .95fr;gap:60px;align-items:center}
.hero h1{font-size:clamp(2.6rem,5vw,4.3rem);letter-spacing:-.01em}
.hero h1 em{font-style:italic;color:var(--terra-deep)}
.hero__lead{margin:26px 0 34px;font-size:1.12rem;color:var(--ink-soft);max-width:30em}
.hero__actions{display:flex;gap:16px;flex-wrap:wrap;align-items:center}
.hero__stats{display:flex;gap:38px;margin-top:48px;padding-top:30px;border-top:1px solid var(--line)}
.hero__stats .n{font-family:var(--serif);font-size:2rem;color:var(--terra-deep);line-height:1}
.hero__stats .l{font-size:.82rem;color:var(--ink-soft);margin-top:6px}
.hero__media{position:relative}
.hero__media img{border-radius:240px 240px 24px 24px;box-shadow:var(--shadow);width:100%;object-fit:cover;aspect-ratio:5/6}
.hero__badge{
  position:absolute;left:-26px;bottom:38px;background:#fff;border-radius:16px;padding:18px 22px;
  box-shadow:var(--shadow-soft);display:flex;align-items:center;gap:14px;max-width:230px;
}
.hero__badge .ic{width:42px;height:42px;border-radius:50%;background:var(--cream-2);display:grid;place-items:center;color:var(--terra-deep);flex:none}
.hero__badge small{font-size:.78rem;color:var(--ink-soft);display:block}
.hero__badge b{font-family:var(--serif);font-size:1.05rem}
.hero__leaf{position:absolute;right:-30px;top:-20px;width:120px;opacity:.5;color:var(--sage)}

/* =========== Section base =========== */
.section{padding:100px 0}
.section--tint{background:var(--cream-2)}
.section--ink{background:#241f1b;color:#e9e1d7}
.section--ink h2,.section--ink h3{color:#fff}
.sec-head{max-width:620px;margin-bottom:54px}
.sec-head.center{margin:0 auto 60px;text-align:center}
.sec-head h2{font-size:clamp(2rem,3.6vw,2.9rem);margin-top:18px}
.sec-head p{margin-top:16px;color:var(--ink-soft);font-size:1.05rem}

/* =========== Tratamentos (3 cards) =========== */
.treat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.tcard{
  background:#fff;border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow-soft);
  transition:.4s;border:1px solid rgba(255,255,255,.6)
}
.tcard:hover{transform:translateY(-8px);box-shadow:var(--shadow)}
.tcard__img{height:230px;overflow:hidden;position:relative}
.tcard__img img{width:100%;height:100%;object-fit:cover;transition:.7s}
.tcard:hover .tcard__img img{transform:scale(1.06)}
.tcard__img span{position:absolute;top:16px;left:16px;background:rgba(255,255,255,.92);color:var(--terra-deep);font-size:.72rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;padding:7px 14px;border-radius:100px}
.tcard__body{padding:28px 26px 30px}
.tcard__body h3{font-size:1.5rem;margin-bottom:10px}
.tcard__body p{color:var(--ink-soft);font-size:.96rem}
.tcard__link{margin-top:18px;display:inline-flex;align-items:center;gap:.5em;color:var(--terra-deep);font-weight:600;font-size:.9rem}
.tcard__link svg{transition:.3s}
.tcard:hover .tcard__link svg{transform:translateX(4px)}

/* =========== Sobre =========== */
.about__grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:64px;align-items:center}
.about__media{position:relative}
.about__media img{border-radius:24px 200px 24px 24px;box-shadow:var(--shadow);aspect-ratio:4/5;object-fit:cover;width:100%}
.about__exp{position:absolute;right:-22px;bottom:-22px;background:var(--terra);color:#fff;border-radius:20px;padding:24px 26px;text-align:center;box-shadow:var(--shadow)}
.about__exp .n{font-family:var(--serif);font-size:2.6rem;line-height:1}
.about__exp .l{font-size:.78rem;letter-spacing:.06em;opacity:.92;margin-top:4px}
.about p.lead{font-size:1.08rem;color:var(--ink-soft);margin:20px 0 28px}
.about__feats{display:grid;gap:20px;margin-top:10px}
.feat{display:flex;gap:16px;align-items:flex-start}
.feat .ic{width:48px;height:48px;border-radius:14px;background:var(--cream-2);display:grid;place-items:center;color:var(--terra-deep);flex:none}
.feat h4{font-size:1.15rem;margin-bottom:4px}
.feat p{font-size:.94rem;color:var(--ink-soft)}

/* =========== Equipamentos =========== */
.equip-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:26px;margin-top:10px}
.ecard{position:relative;border-radius:var(--r);overflow:hidden;min-height:300px;display:flex;align-items:flex-end;box-shadow:var(--shadow-soft);transition:.4s}
.ecard:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.ecard img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;transition:.7s}
.ecard:hover img{transform:scale(1.05)}
.ecard::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(20,16,13,0) 30%,rgba(20,16,13,.85) 100%);z-index:1}
.ecard__body{position:relative;z-index:2;padding:30px;color:#fff}
.ecard__body h3{color:#fff;font-size:1.7rem}
.ecard__body p{font-size:.92rem;opacity:.88;margin-top:6px;max-width:34em}
.ecard__body .more{margin-top:14px;display:inline-flex;gap:.5em;align-items:center;font-size:.85rem;font-weight:600;letter-spacing:.04em;border-bottom:1px solid rgba(255,255,255,.4);padding-bottom:2px}

/* =========== Diferenciais (strip) =========== */
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.why{padding:30px 26px;border-radius:var(--r);background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08)}
.why .ic{color:var(--terra-tint);margin-bottom:16px}
.why h4{color:#fff;font-size:1.2rem;margin-bottom:8px}
.why p{font-size:.92rem;color:#c9bdb0}

/* =========== FAQ =========== */
.faq{max-width:820px;margin:0 auto}
.faq__item{border-bottom:1px solid var(--line)}
.faq__q{width:100%;text-align:left;background:none;border:none;cursor:pointer;padding:24px 0;display:flex;justify-content:space-between;align-items:center;gap:24px;font-family:var(--serif);font-size:1.22rem;color:var(--ink)}
.faq__q .pm{flex:none;width:34px;height:34px;border-radius:50%;border:1px solid var(--line);display:grid;place-items:center;transition:.3s;color:var(--terra-deep)}
.faq__item.open .faq__q .pm{background:var(--terra);color:#fff;border-color:var(--terra);transform:rotate(45deg)}
.faq__a{max-height:0;overflow:hidden;transition:max-height .4s ease;color:var(--ink-soft)}
.faq__a p{padding:0 0 24px}

/* =========== CTA band =========== */
.cta-band{position:relative;border-radius:28px;overflow:hidden;padding:70px 40px;text-align:center;background:linear-gradient(120deg,var(--terra) 0%,var(--terra-deep) 100%);color:#fff}
.cta-band h2{color:#fff;font-size:clamp(1.9rem,3.4vw,2.8rem);max-width:16em;margin:14px auto 0}
.cta-band p{max-width:30em;margin:16px auto 30px;opacity:.92}
.cta-band .eyebrow{color:#fff}
.cta-band .eyebrow::before,.cta-band .eyebrow.center::after{background:rgba(255,255,255,.7)}

/* =========== Footer =========== */
.footer{background:#211c18;color:#c9bdb0;padding:72px 0 30px}
.footer__grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.1fr;gap:40px}
.footer__logo{height:54px;margin-bottom:18px}
.footer p{font-size:.92rem;line-height:1.8}
.footer h5{color:#fff;font-family:var(--serif);font-weight:400;font-size:1.2rem;margin-bottom:18px}
.footer ul{list-style:none}
.footer ul li{margin-bottom:10px;font-size:.92rem}
.footer ul a:hover{color:var(--terra-tint)}
.footer__contact li{display:flex;gap:10px;margin-bottom:14px;align-items:flex-start}
.footer__contact .ic{color:var(--terra);flex:none;margin-top:2px}
.footer__social{display:flex;gap:12px;margin-top:18px}
.footer__social a{width:40px;height:40px;border-radius:50%;border:1px solid rgba(255,255,255,.16);display:grid;place-items:center;transition:.3s;color:#c9bdb0}
.footer__social a:hover{background:var(--terra);border-color:var(--terra);color:#fff}
.footer__bottom{margin-top:50px;padding-top:24px;border-top:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-size:.84rem;color:#8d8377}

/* =========== WhatsApp float =========== */
.wa-float{position:fixed;right:22px;bottom:22px;z-index:90;width:60px;height:60px;border-radius:50%;background:#25d366;display:grid;place-items:center;box-shadow:0 12px 30px -8px rgba(37,211,102,.7);transition:.3s;animation:pulse 2.6s infinite}
.wa-float:hover{transform:scale(1.08)}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(37,211,102,.5)}70%{box-shadow:0 0 0 18px rgba(37,211,102,0)}100%{box-shadow:0 0 0 0 rgba(37,211,102,0)}}

/* =========== Reveal animation =========== */
.reveal{opacity:0;transform:translateY(28px);transition:.8s cubic-bezier(.2,.7,.3,1)}
.reveal.in{opacity:1;transform:none}

/* =========== Responsive =========== */
@media(max-width:980px){
  .hero__grid,.about__grid{grid-template-columns:1fr;gap:44px}
  .hero__media{order:-1;max-width:440px;margin:0 auto}
  .treat-grid,.why-grid{grid-template-columns:repeat(2,1fr)}
  .footer__grid{grid-template-columns:1fr 1fr}
}
@media(max-width:680px){
  .nav__menu{position:fixed;inset:0 0 0 auto;width:78%;max-width:320px;background:var(--cream);flex-direction:column;align-items:flex-start;justify-content:center;padding:40px;gap:22px;transform:translateX(100%);transition:.4s;box-shadow:var(--shadow);z-index:120}
  .nav__menu.open{transform:none}
  .nav__burger{display:flex;z-index:130}
  .nav__cta .btn-ghost{display:none}
  .treat-grid,.equip-grid,.why-grid,.footer__grid{grid-template-columns:1fr}
  .section{padding:70px 0}
  .hero{padding:140px 0 70px}
  .hero__stats{gap:24px}
  .cta-band{padding:50px 24px}
  .about__exp{right:10px}
}

/* ============ INNER PAGES ============ */
.page-hero{position:relative;padding:170px 0 90px;overflow:hidden}
.page-hero::before{content:"";position:absolute;inset:0;background:var(--cream-2);z-index:-2}
.page-hero__img{position:absolute;inset:0;z-index:-1;opacity:.16}
.page-hero__img img{width:100%;height:100%;object-fit:cover}
.page-hero .crumb{font-size:.84rem;color:var(--ink-soft);margin-top:16px}
.page-hero .crumb a:hover{color:var(--terra-deep)}
.page-hero h1{font-size:clamp(2.3rem,4.6vw,3.6rem);margin-top:14px;max-width:16em}
.page-hero p.sub{font-size:1.18rem;color:var(--terra-deep);margin-top:14px;font-family:var(--serif);font-style:italic}

.prose{max-width:760px}
.prose p{margin-bottom:18px;color:var(--ink-soft);font-size:1.04rem}
.split{display:grid;grid-template-columns:1.15fr .85fr;gap:60px;align-items:center}
.split.rev{grid-template-columns:.85fr 1.15fr}
.split__media img{border-radius:24px 24px 200px 24px;box-shadow:var(--shadow);aspect-ratio:4/5;object-fit:cover;width:100%}
.split.rev .split__media img{border-radius:24px 24px 24px 200px}

.benefits{display:grid;grid-template-columns:repeat(2,1fr);gap:22px;margin-top:36px}
.benefit{display:flex;gap:16px;background:#fff;border-radius:16px;padding:22px 24px;box-shadow:var(--shadow-soft)}
.benefit .ic{width:44px;height:44px;border-radius:12px;background:var(--cream-2);display:grid;place-items:center;color:var(--terra-deep);flex:none}
.benefit h4{font-size:1.12rem;margin-bottom:4px}
.benefit p{font-size:.92rem;color:var(--ink-soft)}

.info-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:14px}
.info{background:#fff;border-radius:var(--r);padding:30px 28px;box-shadow:var(--shadow-soft)}
.info .num{font-family:var(--serif);font-size:1.6rem;color:var(--terra-tint)}
.info h4{font-size:1.25rem;margin:8px 0 8px}
.info p{font-size:.95rem;color:var(--ink-soft)}

.chips{display:flex;flex-wrap:wrap;gap:12px;margin-top:24px}
.chip{background:#fff;border:1px solid var(--line);border-radius:100px;padding:10px 18px;font-size:.9rem;color:var(--ink);display:flex;align-items:center;gap:.5em}
.chip svg{color:var(--terra-deep)}

/* contact */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:start}
.contact-card{background:#fff;border-radius:var(--r);padding:36px;box-shadow:var(--shadow-soft)}
.contact-list{list-style:none;margin-top:10px}
.contact-list li{display:flex;gap:14px;padding:16px 0;border-bottom:1px solid var(--line);align-items:flex-start}
.contact-list li:last-child{border:none}
.contact-list .ic{width:44px;height:44px;border-radius:12px;background:var(--cream-2);display:grid;place-items:center;color:var(--terra-deep);flex:none}
.contact-list b{display:block;font-family:var(--serif);font-size:1.05rem}
.contact-list span{font-size:.92rem;color:var(--ink-soft)}
.map{border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow-soft);min-height:340px;border:none;width:100%}
.ff{display:grid;gap:16px}
.ff input,.ff textarea{width:100%;padding:14px 16px;border:1px solid var(--line);border-radius:12px;font-family:var(--sans);font-size:.95rem;background:var(--cream);color:var(--ink)}
.ff input:focus,.ff textarea:focus{outline:none;border-color:var(--terra)}
.ff textarea{min-height:120px;resize:vertical}

@media(max-width:980px){.split,.split.rev,.contact-grid{grid-template-columns:1fr;gap:40px}.info-grid{grid-template-columns:1fr}.split__media{max-width:440px;margin:0 auto}}
@media(max-width:680px){.benefits{grid-template-columns:1fr}.page-hero{padding:140px 0 60px}}

.equip-banner{width:100%;border-radius:24px;box-shadow:var(--shadow);max-height:440px;object-fit:cover;object-position:center}
.split__media img{object-position:center}
.tcard__img img,.ecard img{object-position:center 35%}
