*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#F5F0EA;--bg2:#EDE7DF;--stone:#C8BAA8;--mist:#8E9E95;
  --forest:#3D5A47;--ink:#1E1E1E;--muted:#7A7265;--white:#FDFAF7;
}
html{scroll-behavior:smooth}
body{font-family:'Jost',sans-serif;background:var(--bg);color:var(--ink);font-weight:300}

nav{
  position:fixed;top:1.2rem;left:50%;transform:translateX(-50%);
  z-index:100;display:flex;align-items:center;gap:3rem;
  padding:.7rem 1.6rem .7rem 1.8rem;border-radius:100px;
  white-space:nowrap;
  background:rgba(245,240,234,.55);
  backdrop-filter:blur(24px) saturate(200%);
  -webkit-backdrop-filter:blur(24px) saturate(200%);
  border:1px solid rgba(255,255,255,.55);
  box-shadow:0 4px 24px rgba(0,0,0,.07),inset 0 1px 0 rgba(255,255,255,.65),inset 0 -1px 0 rgba(0,0,0,.03);
}
.nav-logo{font-family:'Playfair Display',serif;font-size:.95rem;color:var(--ink);text-decoration:none;letter-spacing:.01em}
.nav-links{display:flex;gap:1.8rem;list-style:none}
.nav-links a{text-decoration:none;font-size:.75rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);transition:color .2s;font-weight:400}
.nav-links a:hover{color:var(--forest)}
.btn-glass{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.55rem 1.3rem;border-radius:100px;
  font-size:.75rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase;
  text-decoration:none;color:var(--forest);
  background:rgba(61,90,71,.1);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  border:1px solid rgba(61,90,71,.25);
  box-shadow:0 2px 8px rgba(61,90,71,.1),inset 0 1px 0 rgba(255,255,255,.5);
  transition:all .3s;
}
.btn-glass:hover{background:rgba(61,90,71,.16);box-shadow:0 6px 20px rgba(61,90,71,.18),inset 0 1px 0 rgba(255,255,255,.6);transform:translateY(-1px)}

/* HERO */
#hero{
  display:flex;flex-direction:column;
  justify-content:center;padding:0 6vw;
  position:relative;overflow:hidden;
}
.hero-orb{position:absolute;border-radius:50%;pointer-events:none;filter:blur(80px)}
.orb1{width:55vw;height:55vw;background:radial-gradient(circle,rgba(142,158,149,.28),transparent 65%);top:-10vw;right:-8vw;animation:drift 18s ease-in-out infinite}
.orb2{width:35vw;height:35vw;background:radial-gradient(circle,rgba(200,186,168,.3),transparent 65%);bottom:5vh;left:-5vw;animation:drift 24s ease-in-out infinite reverse}
@keyframes drift{0%,100%{transform:translate(0,0)}50%{transform:translate(2vw,-3vh)}}

.hero-layout{
  position:relative;z-index:2;
  display:grid;grid-template-columns:1fr 1fr;
  gap:4vw;align-items:center;
  min-height:100vh;padding:7rem 0 5rem;
}
.hero-content{max-width:580px}
.hero-tag{display:inline-flex;align-items:center;gap:.6rem;font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--mist);margin-bottom:2rem;opacity:0;animation:up .7s .1s forwards}
.hero-tag::before{content:'';width:28px;height:1px;background:var(--stone);display:block}
h1{font-family:'Playfair Display',serif;font-size:clamp(2.8rem,5.5vw,5.8rem);font-weight:400;line-height:1.06;letter-spacing:-.01em;margin-bottom:2rem;opacity:0;animation:up .9s .25s forwards}
h1 em{font-style:italic;color:var(--forest)}
.hero-sub{font-size:1rem;line-height:1.85;color:var(--muted);max-width:420px;margin-bottom:3rem;opacity:0;animation:up .8s .4s forwards}
.hero-ctas{display:flex;gap:1rem;align-items:center;opacity:0;animation:up .8s .55s forwards}

/* Hero photo */
.hero-photo-wrap{
  position:relative;display:flex;justify-content:center;align-items:flex-end;
  opacity:0;animation:up .9s .3s forwards;
}
.hero-photo-frame{
  width:100%;max-width:440px;
  aspect-ratio:3/4;
  border-radius:40px 40px 120px 40px;
  overflow:hidden;
  box-shadow:0 32px 80px rgba(0,0,0,.13),0 8px 24px rgba(0,0,0,.07);
  position:relative;
}
.hero-photo-frame::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(to bottom,transparent 55%,rgba(61,90,71,.12) 100%);
  pointer-events:none;
}
.hero-photo-img{
  width:100%;height:100%;object-fit:cover;object-position:top center;
  display:block;transition:transform .6s ease;
}
.hero-photo-frame:hover .hero-photo-img{transform:scale(1.03)}
.hero-photo-chip{
  position:absolute;bottom:1.5rem;left:50%;transform:translateX(-50%);
  padding:.6rem 1.1rem;border-radius:12px;
  background:rgba(245,240,234,.78);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border:1px solid rgba(255,255,255,.65);
  box-shadow:0 8px 28px rgba(0,0,0,.1),inset 0 1px 0 rgba(255,255,255,.7);
  font-size:.72rem;color:var(--forest);font-weight:500;white-space:nowrap;z-index:3;
}
.btn-wa{
  display:inline-flex;align-items:center;gap:.65rem;
  padding:.85rem 2rem;border-radius:100px;
  font-size:.88rem;font-weight:500;letter-spacing:.04em;text-decoration:none;color:#fff;
  background:rgba(61,90,71,.82);
  backdrop-filter:blur(16px) saturate(180%);-webkit-backdrop-filter:blur(16px) saturate(180%);
  border:1px solid rgba(255,255,255,.18);
  box-shadow:0 8px 32px rgba(61,90,71,.3),inset 0 1px 0 rgba(255,255,255,.22),inset 0 -1px 0 rgba(0,0,0,.12);
  transition:all .35s;
}
.btn-wa:hover{background:rgba(61,90,71,.92);transform:translateY(-2px);box-shadow:0 16px 48px rgba(61,90,71,.38),inset 0 1px 0 rgba(255,255,255,.28)}
.btn-wa svg{width:18px;height:18px;fill:#fff;flex-shrink:0}
.btn-text{font-size:.8rem;color:var(--muted);text-decoration:none;border-bottom:1px solid var(--stone);padding-bottom:1px;transition:color .2s}
.btn-text:hover{color:var(--forest)}

/* SHARED */
section{padding:8vw 6vw}
.s-tag{font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--mist);display:block;margin-bottom:1.4rem}
h2{font-family:'Playfair Display',serif;font-size:clamp(2rem,3.5vw,3rem);font-weight:400;line-height:1.2;margin-bottom:1.4rem;letter-spacing:-.01em}
h2 em{font-style:italic;color:var(--forest)}
.body-text{font-size:.96rem;line-height:1.9;color:var(--muted);max-width:520px}

/* APRESENTAÇÃO */
#apresentacao{background:var(--white);display:grid;grid-template-columns:1fr 1fr;gap:6vw;align-items:center}
.apres-photos{display:grid;grid-template-columns:1fr 1fr;gap:1rem;position:relative}
.apres-photo{border-radius:28px;overflow:hidden;aspect-ratio:3/4;position:relative}
.apres-photo img{width:100%;height:100%;object-fit:cover;object-position:top center;display:block;transition:transform .5s ease}
.apres-photo:hover img{transform:scale(1.04)}
.apres-photo.tall{margin-top:2.5rem}
.apres-chip{
  position:absolute;bottom:-1rem;left:50%;transform:translateX(-50%);
  padding:.7rem 1.2rem;border-radius:14px;
  background:rgba(245,240,234,.75);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border:1px solid rgba(255,255,255,.65);
  box-shadow:0 8px 28px rgba(0,0,0,.1),inset 0 1px 0 rgba(255,255,255,.7);
  font-size:.75rem;color:var(--forest);font-weight:500;white-space:nowrap;z-index:3;
}
.apres-text p{font-size:.96rem;line-height:1.9;color:var(--muted);margin-bottom:1rem}
.apres-text strong{color:var(--ink);font-weight:500}
.tag-list{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1.6rem}
.tag{
  font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;
  padding:.4rem .9rem;border-radius:100px;
  background:rgba(61,90,71,.07);border:1px solid rgba(61,90,71,.15);
  color:var(--forest);font-weight:400;
}

/* ÁREAS */
#areas{background:var(--bg)}
.areas-inner{display:grid;grid-template-columns:1fr 1fr;gap:6vw;align-items:start}
.areas-list{list-style:none;margin-top:.5rem}
.areas-list li{
  font-family:'Playfair Display',serif;
  font-size:clamp(1.1rem,2vw,1.5rem);
  font-weight:400;color:var(--ink);
  padding:.7rem 0;
  border-bottom:1px solid rgba(200,186,168,.35);
  letter-spacing:-.01em;
  transition:color .2s,padding-left .25s;cursor:default;
}
.areas-list li:first-child{border-top:1px solid rgba(200,186,168,.35)}
.areas-list li:hover{color:var(--forest);padding-left:.4rem}

/* TCC */
#tcc{background:var(--forest);display:grid;grid-template-columns:1fr 1fr;gap:6vw;align-items:center;position:relative;overflow:hidden}
#tcc::before{content:'TCC';position:absolute;right:-2vw;top:50%;transform:translateY(-50%);font-family:'Playfair Display',serif;font-size:22vw;color:rgba(255,255,255,.04);pointer-events:none;line-height:1;letter-spacing:-.05em}
#tcc .s-tag{color:rgba(255,255,255,.4)}
#tcc h2{color:#fff}
#tcc h2 em{color:rgba(200,186,168,.9)}
.tcc-intro{font-size:.96rem;line-height:1.9;color:rgba(255,255,255,.6);margin-bottom:2.5rem;max-width:460px}
.tcc-pillars{display:flex;flex-direction:column;gap:.75rem}
.tcc-pillar{
  padding:1.1rem 1.4rem;border-radius:14px;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.09);
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);transition:background .3s;
}
.tcc-pillar:hover{background:rgba(255,255,255,.1)}
.tcc-pillar strong{display:block;font-size:.88rem;font-weight:500;color:rgba(255,255,255,.88);margin-bottom:.25rem}
.tcc-pillar span{font-size:.8rem;color:rgba(255,255,255,.5);line-height:1.65}

/* ATENDIMENTO */
#atendimento{background:var(--white);display:grid;grid-template-columns:1fr 1fr;gap:8vw;align-items:center}
.steps-simple{display:flex;flex-direction:column}
.step-s{display:flex;gap:1.5rem;align-items:flex-start;padding:1.4rem 0;border-bottom:1px solid rgba(200,186,168,.3)}
.step-s:last-child{border-bottom:none}
.step-n{font-family:'Playfair Display',serif;font-size:1.4rem;color:var(--stone);font-style:italic;min-width:2rem;line-height:1.3}
.step-s h4{font-size:.88rem;font-weight:500;color:var(--ink);margin-bottom:.3rem}
.step-s p{font-size:.8rem;color:var(--muted);line-height:1.7}

/* CTA */
#cta{background:var(--bg);text-align:center;padding:10vw 6vw}
.cta-inner{max-width:560px;margin:0 auto}
#cta h2{font-size:clamp(2.2rem,4vw,3.4rem);margin-bottom:1rem}
#cta .body-text{margin:0 auto 3rem;text-align:center;max-width:400px}
.btn-wa-lg{
  display:inline-flex;align-items:center;gap:.75rem;
  padding:1rem 2.4rem;border-radius:100px;
  font-size:.95rem;font-weight:500;letter-spacing:.03em;text-decoration:none;color:#fff;
  background:rgba(61,90,71,.85);
  backdrop-filter:blur(20px) saturate(200%);-webkit-backdrop-filter:blur(20px) saturate(200%);
  border:1px solid rgba(255,255,255,.2);
  box-shadow:0 12px 40px rgba(61,90,71,.32),inset 0 1px 0 rgba(255,255,255,.25),inset 0 -1px 0 rgba(0,0,0,.1);
  transition:all .35s cubic-bezier(.2,.8,.2,1);
}
.btn-wa-lg:hover{background:rgba(61,90,71,.95);transform:translateY(-3px);box-shadow:0 20px 56px rgba(61,90,71,.38),inset 0 1px 0 rgba(255,255,255,.32)}
.btn-wa-lg svg{width:20px;height:20px;fill:white}
.cta-note{margin-top:1.4rem;font-size:.75rem;color:var(--stone);letter-spacing:.06em}

/* FOOTER */
footer{background:var(--ink);padding:2rem 6vw;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}
.footer-logo{font-family:'Playfair Display',serif;font-size:.95rem;color:rgba(255,255,255,.5);font-style:italic}
footer p{font-size:.72rem;color:rgba(255,255,255,.25)}

/* FLOAT WA */
.wa-fab{
  position:fixed;bottom:2rem;right:2rem;z-index:200;
  width:54px;height:54px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;text-decoration:none;
  background:rgba(37,211,102,.8);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border:1px solid rgba(255,255,255,.3);
  box-shadow:0 8px 28px rgba(37,211,102,.35),inset 0 1px 0 rgba(255,255,255,.3);
  transition:all .3s;animation:popIn .5s 1.5s backwards;
}
@keyframes popIn{from{transform:scale(0) rotate(-30deg);opacity:0}to{transform:scale(1) rotate(0);opacity:1}}
.wa-fab:hover{background:rgba(37,211,102,.92);transform:scale(1.08)}
.wa-fab svg{width:26px;height:26px;fill:white}

.r{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s ease}
.r.on{opacity:1;transform:none}
@keyframes up{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}

@media(max-width:768px){
  nav{gap:1rem;padding:.6rem 1rem .6rem 1.2rem}
  .nav-links{display:none}
  section{padding:14vw 5vw}
  #hero{padding:0 5vw}
  .hero-layout{
    grid-template-columns:1fr;
    grid-template-rows:auto auto;
    padding:6rem 0 4rem;
    gap:2.5rem;
  }
  .hero-photo-wrap{order:-1;justify-content:center}
  .hero-photo-frame{max-width:280px;border-radius:28px 28px 80px 28px}
  .hero-photo-chip{font-size:.68rem;padding:.5rem .9rem}
  #apresentacao,#atendimento,#tcc{grid-template-columns:1fr;gap:4rem}
  .areas-inner{grid-template-columns:1fr;gap:2rem}
  .apres-photos{grid-template-columns:1fr 1fr}
}

.foto_hero{
  display: flex;
  align-items: right;
}
