/* ===== Raquel Oliveira · Fonoaudióloga — landing ===== */
:root{
  /* paleta principal LARANJA + dourado (arquétipo da Raquel).
     As variáveis ainda se chamam --sage por histórico, mas agora são tons quentes. */
  --sage:#E07A3E;        /* laranja principal */
  --sage-deep:#B5571F;   /* terracota p/ títulos e textos de destaque */
  --sage-soft:#F8D8BD;   /* pêssego suave (chips, blobs) */
  --sage-mist:#FCEBDD;   /* pêssego claríssimo (fundos, ícones) */
  --cream:#F7F3EB;
  --cream-deep:#F0E9DB;
  --gold:#C2A063;
  --gold-soft:#E4D2AE;
  --orange:#E8894B;
  --orange-soft:#F7D3B0;
  --orange-mist:#FBE7D5;
  --ink:#3B3A36;
  --ink-soft:#6B6A63;
  --white:#fff;
  --wa:#25D366;
  --wa-deep:#128C7E;
  --radius:26px;
  --radius-sm:16px;
  --shadow:0 18px 50px -22px rgba(125,68,30,.42);
  --shadow-sm:0 10px 30px -16px rgba(125,68,30,.38);
  --maxw:1140px;
  --font-display:"Fraunces",Georgia,serif;
  --font-body:"Nunito",system-ui,sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--cream);
  line-height:1.65;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3{font-family:var(--font-display);font-weight:600;line-height:1.12;letter-spacing:-.01em}
em{font-style:italic;color:var(--sage-deep)}
section{position:relative}

/* ---- decor background ---- */
.bg-decor{position:fixed;inset:0;z-index:-1;pointer-events:none;overflow:hidden}
.blob{position:absolute;border-radius:50%;filter:blur(8px);opacity:.5}
.blob-1{width:420px;height:420px;background:var(--sage-soft);top:-120px;right:-120px}
.blob-2{width:340px;height:340px;background:var(--gold-soft);bottom:8%;left:-140px;opacity:.35}
.blob-3{width:260px;height:260px;background:var(--orange-soft);top:46%;right:-90px;opacity:.32}

/* ---- buttons ---- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  font-family:var(--font-body);font-weight:800;font-size:1rem;
  padding:.85rem 1.5rem;border-radius:999px;cursor:pointer;border:none;
  transition:transform .2s ease,box-shadow .2s ease,background .2s ease;
  white-space:nowrap;
}
.btn:hover{transform:translateY(-2px)}
.btn-lg{padding:1.05rem 2rem;font-size:1.08rem}
.btn-wa{background:var(--wa);color:#fff;box-shadow:0 12px 28px -12px rgba(37,211,102,.8)}
.btn-wa:hover{background:#1ebe5a}
.btn-white{background:#fff;color:var(--wa-deep)}
.btn-white:hover{background:#f3fff8}
.btn-ghost{background:var(--sage-soft);color:var(--sage-deep)}
.btn-ghost:hover{background:var(--sage-mist)}
.btn-outline{background:transparent;border:2px solid var(--sage);color:var(--sage-deep);padding:.7rem 1.3rem}
.btn-outline:hover{background:var(--sage);color:#fff}
.ico-wa{width:20px;height:20px;fill:currentColor;flex:none}

.eyebrow{
  display:inline-block;font-weight:800;font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--gold);margin-bottom:.85rem;
}
.center{text-align:center}

/* ---- header ---- */
.site-header{
  position:sticky;top:0;z-index:50;
  display:flex;align-items:center;gap:1.5rem;
  padding:.8rem clamp(1rem,4vw,2.4rem);
  background:rgba(247,243,235,.82);backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(206,142,86,.15);
}
.brand{display:flex;align-items:center;gap:.7rem;margin-right:auto}
.brand-mark{
  width:44px;height:44px;border-radius:50%;flex:none;
  background:linear-gradient(140deg,var(--sage),var(--sage-deep));
  color:#fff;font-family:var(--font-display);font-weight:600;font-size:1.4rem;
  display:grid;place-items:center;box-shadow:var(--shadow-sm);
}
.brand-text{display:flex;flex-direction:column;line-height:1.1}
.brand-text strong{font-family:var(--font-display);font-size:1.18rem;font-weight:600}
.brand-text small{font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;color:var(--sage-deep);font-weight:700}
.nav-links{display:flex;gap:1.6rem;font-weight:700;font-size:.95rem;color:var(--ink-soft)}
.nav-links a{position:relative;padding:.2rem 0}
.nav-links a:hover{color:var(--sage-deep)}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-3px;width:0;height:2px;background:var(--gold);transition:width .25s}
.nav-links a:hover::after{width:100%}
.header-cta{padding:.6rem 1.2rem}

/* ---- hero ---- */
.hero{
  max-width:var(--maxw);margin:0 auto;
  padding:clamp(2.5rem,6vw,5rem) clamp(1.1rem,4vw,2rem);
  display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2rem,5vw,4rem);align-items:center;
}
.hero h1{font-size:clamp(2.1rem,5vw,3.5rem);margin-bottom:1.1rem}
.lead{font-size:clamp(1.05rem,2vw,1.22rem);color:var(--ink-soft);max-width:34ch;margin-bottom:1.8rem}
.hero-actions{display:flex;flex-wrap:wrap;gap:.9rem;margin-bottom:1.8rem}
.hero-badges{list-style:none;display:flex;flex-wrap:wrap;gap:1.4rem}
.hero-badges li{display:flex;align-items:center;gap:.5rem;font-weight:700;color:var(--sage-deep);font-size:.98rem}
.hero-badges span{font-size:1.15rem}

.hero-photo{position:relative}
.photo-frame{
  position:relative;border-radius:48% 48% 46% 46%/40% 40% 40% 40%;overflow:hidden;
  box-shadow:var(--shadow);border:8px solid #fff;
  aspect-ratio:4/5;
}
.photo-frame img{width:100%;height:100%;object-fit:cover}
.frame-soft{border-radius:var(--radius)}
.float-tag{
  position:absolute;background:#fff;border-radius:999px;padding:.55rem 1rem .55rem .85rem;
  font-weight:800;font-size:.85rem;color:var(--sage-deep);box-shadow:var(--shadow-sm);
  display:flex;align-items:center;gap:.35rem;border-left:4px solid var(--orange);
}
.tag-1{top:8%;left:-6%;animation:float 6s ease-in-out infinite}
.tag-2{bottom:10%;right:-6%;animation:float 6s ease-in-out infinite .8s}
.sparkle{position:absolute;color:var(--orange);font-size:1.6rem;animation:twinkle 3s ease-in-out infinite}
.sparkle-1{top:-4%;right:14%}
.sparkle-2{bottom:2%;left:6%;animation-delay:1s}
.sparkle-3{top:6%;right:-4%;font-size:1.8rem}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
@keyframes twinkle{0%,100%{opacity:.4;transform:scale(.85)}50%{opacity:1;transform:scale(1.15)}}

/* ---- trust ---- */
.trust{
  max-width:var(--maxw);margin:0 auto;padding:1rem clamp(1.1rem,4vw,2rem) 2rem;
  display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;
}
.trust-item{
  background:#fff;border-radius:var(--radius-sm);padding:1.3rem 1.5rem;text-align:center;
  box-shadow:var(--shadow-sm);border:1px solid rgba(206,142,86,.12);
}
.trust-item strong{display:block;font-family:var(--font-display);font-size:1.2rem;color:var(--sage-deep);margin-bottom:.3rem}
.trust-item span{font-size:.92rem;color:var(--ink-soft)}

/* ---- sobre ---- */
.sobre{
  max-width:var(--maxw);margin:0 auto;
  padding:clamp(3rem,6vw,5rem) clamp(1.1rem,4vw,2rem);
  display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(2rem,5vw,4rem);align-items:center;
}
.sobre-photo{position:relative}
.sobre-text h2{font-size:clamp(1.8rem,3.6vw,2.6rem);margin-bottom:1.1rem}
.sobre-text p{color:var(--ink-soft);margin-bottom:1rem;font-size:1.05rem}
.sobre-text .btn{margin-top:.6rem}

/* ---- section head ---- */
.section-head{text-align:center;max-width:640px;margin:0 auto 2.6rem}
.section-head h2{font-size:clamp(1.9rem,4vw,2.8rem);margin-bottom:.7rem}
.section-head h2::after{content:"";display:block;width:66px;height:4px;margin:.9rem auto 0;border-radius:3px;background:linear-gradient(90deg,var(--gold),var(--orange))}
.section-head p{color:var(--ink-soft);font-size:1.05rem}

/* ---- atendo cards ---- */
.atendo{max-width:var(--maxw);margin:0 auto;padding:clamp(2rem,5vw,4rem) clamp(1.1rem,4vw,2rem)}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.card{
  background:#fff;border-radius:var(--radius);padding:2rem 1.7rem;
  box-shadow:var(--shadow-sm);border:1px solid rgba(206,142,86,.12);
  transition:transform .25s ease,box-shadow .25s ease;
}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.card-ico{
  width:62px;height:62px;border-radius:20px;display:grid;place-items:center;
  font-size:1.7rem;background:var(--sage-mist);margin-bottom:1.1rem;
}
/* alterna acentos quentes (laranja) com o verde p/ dar vida */
.cards .card:nth-child(2) .card-ico,
.cards .card:nth-child(4) .card-ico{background:var(--orange-mist)}
.card h3{font-size:1.3rem;margin-bottom:.55rem;color:var(--sage-deep)}
.card p{color:var(--ink-soft);font-size:.98rem}
.card-cta{background:linear-gradient(160deg,var(--sage),var(--sage-deep));color:#fff}
.card-cta h3,.card-cta p{color:#fff}
.card-cta .card-ico{background:rgba(255,255,255,.18)}
.card-cta .btn{margin-top:1.1rem}

/* ---- sinais ---- */
.sinais{padding:clamp(3rem,6vw,5rem) clamp(1.1rem,4vw,2rem);background:var(--sage-mist);margin-top:2rem}
.sinais-inner{max-width:var(--maxw);margin:0 auto}
.sinais-list{
  list-style:none;display:grid;grid-template-columns:repeat(2,1fr);gap:1.1rem;margin-bottom:1.8rem;
}
.sinais-list li{
  display:flex;gap:1rem;background:#fff;border-radius:var(--radius-sm);padding:1.3rem 1.4rem;
  box-shadow:var(--shadow-sm);
}
.sinais-list li span{font-size:1.7rem;flex:none}
.sinais-list strong{display:block;font-family:var(--font-display);font-size:1.12rem;color:var(--sage-deep);margin-bottom:.2rem}
.sinais-list p{color:var(--ink-soft);font-size:.94rem}
.sinais-note{text-align:center;max-width:680px;margin:0 auto 2rem;color:var(--ink);font-size:1.08rem;font-weight:600}

/* ---- atendimento ---- */
.atendimento{max-width:var(--maxw);margin:0 auto;padding:clamp(3rem,6vw,5rem) clamp(1.1rem,4vw,2rem)}
.atend-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:1.4rem;margin-bottom:2rem}
.atend-card{
  background:#fff;border-radius:var(--radius);padding:2.2rem 2rem;text-align:center;
  box-shadow:var(--shadow-sm);border:1px solid rgba(206,142,86,.12);
}
.atend-ico{font-size:2.4rem;margin-bottom:.7rem}
.atend-card h3{font-size:1.5rem;color:var(--sage-deep);margin-bottom:.6rem}
.atend-card p{color:var(--ink-soft);margin-bottom:1rem}
.link-map{font-weight:800;color:var(--gold);border-bottom:2px solid transparent;transition:border-color .2s}
.link-map:hover{border-color:var(--gold)}
.map-wrap{position:relative;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);border:6px solid #fff;height:360px}
.map-wrap iframe{width:100%;height:100%;border:0;display:block}
#map-facade{cursor:pointer;background:
  radial-gradient(circle at 30% 30%, var(--sage-soft), transparent 60%),
  radial-gradient(circle at 80% 80%, var(--gold-soft), transparent 55%),
  var(--sage-mist);
  outline:none;transition:filter .2s}
#map-facade:hover,#map-facade:focus-visible{filter:brightness(.98)}
#map-facade.map-loaded{cursor:default;background:none}
.map-facade-inner{
  position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:.35rem;text-align:center;padding:1rem;color:var(--ink);
}
.map-facade-inner .map-pin{font-size:2.6rem;animation:float 5s ease-in-out infinite}
.map-facade-inner strong{font-family:var(--font-display);font-size:1.3rem;color:var(--sage-deep)}
.map-facade-inner>span{color:var(--ink-soft);font-weight:600}
.map-load-btn{
  margin-top:.7rem;background:var(--sage);color:#fff;font-weight:800;
  padding:.6rem 1.3rem;border-radius:999px;box-shadow:var(--shadow-sm);
}
#map-facade:hover .map-load-btn{background:var(--sage-deep)}

/* ---- quote ---- */
.quote{
  max-width:var(--maxw);margin:0 auto;
  padding:clamp(3rem,6vw,5rem) clamp(1.1rem,4vw,2rem);
  display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:center;
}
.quote-photo img{border-radius:var(--radius);box-shadow:var(--shadow);aspect-ratio:1/1;object-fit:cover;width:100%}
.quote-mark{font-family:var(--font-display);font-size:5rem;line-height:.4;color:var(--gold-soft);margin-bottom:.6rem}
.quote blockquote{font-family:var(--font-display);font-size:clamp(1.4rem,3vw,2rem);font-style:italic;line-height:1.35;color:var(--ink);margin-bottom:1.1rem}
.quote cite{font-weight:800;color:var(--sage-deep);font-style:normal}

/* ---- final cta ---- */
.final-cta{padding:clamp(3rem,7vw,6rem) clamp(1.1rem,4vw,2rem);
  background:linear-gradient(150deg,var(--sage),var(--sage-deep));color:#fff;text-align:center;margin-top:2rem}
.final-inner{max-width:680px;margin:0 auto}
.final-cta h2{font-size:clamp(1.9rem,4.5vw,3rem);margin-bottom:.9rem;color:#fff}
.final-cta p{font-size:1.15rem;opacity:.92;margin-bottom:1.8rem}

/* ---- footer ---- */
.site-footer{
  max-width:var(--maxw);margin:0 auto;padding:2.6rem clamp(1.1rem,4vw,2rem);
  display:flex;flex-wrap:wrap;align-items:center;gap:1.4rem;justify-content:space-between;
}
.foot-brand{display:flex;align-items:center;gap:.8rem}
.foot-brand strong{display:block;font-family:var(--font-display);font-size:1.15rem}
.foot-brand small{color:var(--ink-soft)}
.foot-links{display:flex;gap:1.6rem;font-weight:700;color:var(--sage-deep)}
.foot-links a:hover{color:var(--gold)}
.foot-copy{width:100%;text-align:center;color:var(--ink-soft);font-size:.9rem;border-top:1px solid rgba(206,142,86,.15);padding-top:1.4rem}

/* ---- whatsapp float ---- */
.wa-float{
  position:fixed;right:20px;bottom:20px;z-index:60;
  width:60px;height:60px;border-radius:50%;background:var(--wa);
  display:grid;place-items:center;box-shadow:0 14px 30px -8px rgba(37,211,102,.75);
  animation:pulse 2.6s infinite;transition:transform .2s}
.wa-float:hover{transform:scale(1.08)}
.wa-float svg{width:32px;height:32px;fill:#fff}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(37,211,102,.5)}70%{box-shadow:0 0 0 16px rgba(37,211,102,0)}100%{box-shadow:0 0 0 0 rgba(37,211,102,0)}}

/* ---- reveal ---- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}

/* ---- responsive ---- */
@media (max-width:880px){
  .nav-links{display:none}
  .hero,.sobre,.quote{grid-template-columns:1fr}
  .hero-photo{order:-1;max-width:380px;margin:0 auto}
  .sobre-photo{max-width:360px;margin:0 auto}
  .trust{grid-template-columns:1fr}
  .cards{grid-template-columns:1fr 1fr}
  .sinais-list{grid-template-columns:1fr}
  .atend-cards{grid-template-columns:1fr}
  .quote-photo{max-width:420px;margin:0 auto}
}
@media (max-width:560px){
  .cards{grid-template-columns:1fr}
  .header-cta span{display:none}
  .hero-actions .btn{width:100%}
  .float-tag{font-size:.75rem;padding:.4rem .7rem}
  .tag-1{left:-2%}.tag-2{right:-2%}
}
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;scroll-behavior:auto}
  .reveal{opacity:1;transform:none}
}
