/* ===========================================================
   Dra. Luísa Sabadini Prata — Landing Page
   Identidade Visual oficial
   Paleta: #B89089 nude · #F8D6D0 blush · #F1F1F1 fundo
           #D9D9D9 cinza · #BCCFDD azul claro · #8BA0B0 azul
           #3D576B ardósia (texto)
   Fontes: Manison (títulos) → Cormorant Garamond
           Balgin (legendas) → Montserrat
   =========================================================== */

:root{
  --nude:    #B89089;
  --blush:   #F8D6D0;
  --bg:      #F1F1F1;
  --gray:    #D9D9D9;
  --blue-1:  #BCCFDD;
  --blue-3:  #8BA0B0;
  --slate:   #3D576B;
  --slate-soft:#5C7184;
  --white:   #ffffff;
  --wpp:     #25D366;
  --wpp-deep:#1da851;

  --maxw: 1140px;
  --radius: 30px;       /* cantos arredondados (motivo da marca) */
  --shadow: 0 18px 46px rgba(61,87,107,.16);
  --serif: "Cormorant Garamond", Georgia, serif;
  --sans:  "Montserrat", -apple-system, BlinkMacSystemFont, sans-serif;
}

*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; }
body{
  font-family:var(--sans);
  color:var(--slate);
  background:var(--bg);
  line-height:1.7;
  font-weight:300;
  -webkit-font-smoothing:antialiased;
}
.container{ width:90%; max-width:var(--maxw); margin:0 auto; }

h1,h2,h3{ font-family:var(--serif); font-weight:500; line-height:1.1; color:var(--slate); }
em{ font-style:italic; color:var(--nude); }
.center{ text-align:center; }

.eyebrow{
  text-transform:uppercase;
  letter-spacing:.3em;
  font-size:.7rem;
  font-weight:500;
  color:var(--nude);
  margin-bottom:1rem;
}
.eyebrow.center{ text-align:center; }
.eyebrow.light{ color:rgba(255,255,255,.85); }

/* ---------- Botões ---------- */
.btn{
  display:inline-flex; align-items:center; gap:.55rem;
  padding:.95rem 1.9rem;
  border-radius:50px;
  font-family:var(--sans);
  font-weight:500;
  font-size:.9rem;
  letter-spacing:.02em;
  text-decoration:none;
  cursor:pointer;
  transition:transform .2s ease, box-shadow .2s ease, background .2s ease, color .2s ease;
}
/* Primário = AGENDAMENTO (evidência) */
.btn-agendar{ background:var(--slate); color:#fff; box-shadow:0 12px 26px rgba(61,87,107,.28); }
.btn-agendar:hover{ background:#32485a; transform:translateY(-2px); }
/* WhatsApp = secundário, sempre presente */
.btn-wpp{ background:var(--wpp); color:#fff; box-shadow:0 10px 24px rgba(37,211,102,.3); }
.btn-wpp:hover{ background:var(--wpp-deep); transform:translateY(-2px); }
.btn-outline{ background:transparent; color:var(--slate); border:1.6px solid var(--slate); }
.btn-outline:hover{ background:var(--slate); color:#fff; }
.btn-sm{ padding:.62rem 1.4rem; font-size:.82rem; }
.btn-lg{ padding:1.15rem 2.5rem; font-size:1rem; }

/* ---------- Motivo: quadro de cantos arredondados ---------- */
.frame{
  border:1.6px solid var(--blue-3);
  border-radius:var(--radius);
  padding:2.2rem 2.4rem;
}

/* ---------- Header ---------- */
.site-header{
  position:sticky; top:0; z-index:50;
  background:rgba(241,241,241,.88);
  backdrop-filter:blur(10px);
  border-bottom:1px solid #e3e3e3;
}
.header-inner{ display:flex; align-items:center; justify-content:space-between; padding:.7rem 0; }
.brand{ display:flex; align-items:center; gap:.7rem; text-decoration:none; color:var(--slate); }
.brand-logo{ height:46px; width:auto; display:block; }
.brand-name{ font-family:var(--serif); font-size:1.25rem; font-weight:500; letter-spacing:.01em; }
.nav{ display:flex; gap:2rem; }
.nav a{ text-decoration:none; color:var(--slate-soft); font-size:.85rem; transition:color .2s; }
.nav a:hover{ color:var(--nude); }

/* ---------- Hero ---------- */
.hero{ background:var(--bg); padding:4.5rem 0 5rem; overflow:hidden; }
.hero-inner{ display:grid; grid-template-columns:1.05fr .95fr; gap:3.5rem; align-items:center; }
.hero h1{ font-size:clamp(2.5rem,5.2vw,3.9rem); margin-bottom:1.4rem; font-weight:500; }
.hero h1 .big{ display:block; font-size:1.18em; line-height:1; margin-top:.1em; }
.lead{ font-size:1.05rem; color:var(--slate-soft); max-width:34rem; margin-bottom:2rem; font-weight:400; }
.hero-ctas{ display:flex; gap:1rem; flex-wrap:wrap; }
.hero-days{ margin-top:1.1rem; font-size:.82rem; color:var(--slate-soft); }
.hero-days strong{ color:var(--slate); font-weight:600; }

/* Foto recortada + motivo do quadrado cinza e blush */
.hero-photo{ position:relative; display:flex; align-items:flex-end; justify-content:center; min-height:500px; }
.sq{ position:absolute; border-radius:42px; z-index:0; }
.sq-gray{ width:78%; aspect-ratio:1/1; background:var(--gray); right:6%; top:8%; }
.sq-blush{ width:46%; aspect-ratio:1/1; background:var(--blush); left:4%; bottom:6%; }
.cutout{
  position:relative; z-index:1;
  width:100%; max-width:440px; height:auto;
  filter:drop-shadow(0 20px 26px rgba(61,87,107,.22));
  /* esfumaça SÓ a borda de baixo (joelho e insulinas ficam nítidos) */
  -webkit-mask-image:linear-gradient(to bottom, #000 94%, rgba(0,0,0,.5) 98%, transparent 100%);
          mask-image:linear-gradient(to bottom, #000 94%, rgba(0,0,0,.5) 98%, transparent 100%);
}
/* sombra de chão sob a foto */
.hero-photo::after{
  content:""; position:absolute; z-index:0; bottom:3%; left:50%; transform:translateX(-50%);
  width:60%; height:34px;
  background:radial-gradient(ellipse at center, rgba(61,87,107,.30), transparent 72%);
  filter:blur(7px);
}

/* ---------- Faixa promessa ---------- */
.promessa{ background:var(--nude); color:#fff; padding:3.2rem 0; }
.promessa p{ font-family:var(--serif); font-size:clamp(1.4rem,3vw,2rem); font-style:italic; text-align:center; max-width:50rem; margin:0 auto; line-height:1.4; color:#fff; }
.promessa strong{ color:var(--bg); font-weight:600; }

/* ---------- Sobre ---------- */
.sobre{ padding:5.5rem 0; }
.sobre-inner{ display:grid; grid-template-columns:.9fr 1.1fr; gap:3.5rem; align-items:center; }
.sobre h2{ font-size:clamp(1.9rem,4vw,2.7rem); margin-bottom:1.4rem; }
.sobre p{ color:var(--slate-soft); margin-bottom:1rem; max-width:36rem; font-weight:400; }
.sobre .assinatura{ color:var(--slate); font-family:var(--serif); font-size:1.25rem; font-style:italic; border-left:3px solid var(--nude); padding-left:1.2rem; margin:1.6rem 0; }
.credencial{ font-size:.78rem !important; letter-spacing:.12em; text-transform:uppercase; color:var(--blue-3) !important; }

/* Foto da seção sobre — moldura cantos arredondados */
.sobre-photo{ position:relative; }
.photo-frame{
  position:relative;
  aspect-ratio:4/5;
  border-radius:var(--radius);
  background-size:cover; background-position:center top;
  box-shadow:var(--shadow);
  overflow:hidden;
}
.photo-frame.tall{ aspect-ratio:3/4; }
.sobre-photo::after{
  content:""; position:absolute; z-index:-1;
  width:70%; aspect-ratio:1/1; background:var(--blue-1);
  border-radius:42px; right:-6%; top:-6%;
}

/* ---------- Áreas de atuação ---------- */
.atuacao{ padding:5rem 0; }
.atuacao h2{ font-size:clamp(1.9rem,4vw,2.6rem); margin-bottom:3rem; }
.cards{ display:grid; grid-template-columns:repeat(4,1fr); gap:1.4rem; }
.card{
  background:#fff; border-radius:24px; padding:2rem 1.6rem;
  box-shadow:0 8px 24px rgba(61,87,107,.07);
  border-top:3px solid var(--nude);
  transition:transform .25s ease, box-shadow .25s ease;
}
.card:hover{ transform:translateY(-6px); box-shadow:var(--shadow); }
.card h3{ font-size:1.35rem; margin-bottom:.7rem; color:var(--slate); }
.card p{ font-size:.9rem; color:var(--slate-soft); font-weight:400; }

/* ---------- Diferencial ---------- */
.diferencial{ padding:5.5rem 0; background:var(--slate); color:#fff; }
.diferencial h2{ font-size:clamp(1.9rem,4vw,2.6rem); margin-bottom:3rem; color:#fff; }
.light{ color:#fff; }
.diff-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:2.2rem; }
.diff-num{ font-family:var(--serif); font-size:2.6rem; color:var(--blue-1); display:block; margin-bottom:.5rem; }
.diff-item h3{ font-size:1.3rem; margin-bottom:.6rem; color:#fff; }
.diff-item p{ color:rgba(255,255,255,.82); font-size:.95rem; font-weight:400; }

/* ---------- Método ---------- */
.metodo{ padding:5.5rem 0; }
.metodo h2{ font-size:clamp(1.9rem,4vw,2.6rem); margin-bottom:3rem; }
.steps{ display:grid; grid-template-columns:repeat(3,1fr); gap:2rem; }
.step{ text-align:center; padding:2rem 1.4rem; background:#fff; border-radius:24px; box-shadow:0 8px 24px rgba(61,87,107,.06); }
.step-num{
  display:grid; place-items:center; width:56px; height:56px; margin:0 auto 1.2rem;
  border-radius:50%; background:var(--nude); color:#fff;
  font-family:var(--serif); font-size:1.5rem; font-weight:600;
}
.step h3{ font-size:1.3rem; margin-bottom:.6rem; }
.step p{ color:var(--slate-soft); font-size:.92rem; font-weight:400; }

/* ---------- CTA ---------- */
.cta{ padding:5.5rem 0; }
.cta-card{
  background:var(--nude); color:#fff; border-radius:40px;
  padding:4rem 2rem; text-align:center;
  box-shadow:var(--shadow);
}
.cta h2{ font-size:clamp(2rem,4.5vw,3rem); margin-bottom:1rem; color:#fff; }
.cta-sub{ color:rgba(255,255,255,.92); font-size:1.08rem; margin-bottom:2.2rem; }
.cta-ctas{ display:flex; gap:1rem; justify-content:center; flex-wrap:wrap; }
.cta-card .btn-agendar{ background:#fff; color:var(--slate); }
.cta-card .btn-agendar:hover{ background:var(--bg); }
.cta-card .btn-outline{ border-color:#fff; color:#fff; }
.cta-card .btn-outline:hover{ background:#fff; color:var(--nude); }
.cta-local{ margin-top:1.8rem; font-size:.88rem; color:rgba(255,255,255,.9); }

/* ---------- Footer ---------- */
.site-footer{ background:var(--slate); color:rgba(255,255,255,.8); padding:3rem 0 1.5rem; }
.footer-inner{ display:flex; justify-content:space-between; align-items:center; gap:2rem; flex-wrap:wrap; padding-bottom:1.8rem; border-bottom:1px solid rgba(255,255,255,.14); }
.footer-brand{ display:flex; align-items:center; gap:1rem; }
.footer-logo{ height:54px; width:auto; filter:brightness(0) invert(1); opacity:.92; }
.footer-brand strong{ display:block; font-family:var(--serif); font-size:1.2rem; color:#fff; }
.footer-brand span{ font-size:.8rem; }
.footer-links{ display:flex; gap:1.8rem; align-items:center; flex-wrap:wrap; }
.footer-links a{ color:rgba(255,255,255,.85); text-decoration:none; font-size:.88rem; }
.footer-links a:hover{ color:var(--nude); }
.disclaimer{ font-size:.72rem; color:rgba(255,255,255,.45); margin-top:1.5rem; line-height:1.6; text-align:center; }

/* ---------- WhatsApp flutuante ---------- */
.wpp-float{
  position:fixed; right:22px; bottom:22px; z-index:80;
  width:58px; height:58px; border-radius:50%;
  background:var(--wpp); color:#fff;
  display:grid; place-items:center;
  box-shadow:0 10px 30px rgba(37,211,102,.5);
  transition:transform .2s ease;
  animation:pulse 2.4s infinite;
}
.wpp-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 16px rgba(37,211,102,0);} 100%{box-shadow:0 0 0 0 rgba(37,211,102,0);} }

/* ===========================================================
   RESPONSIVO
   =========================================================== */
@media (max-width:900px){
  .nav{ display:none; }
  .hero-inner,.sobre-inner{ grid-template-columns:1fr; gap:2.5rem; }
  .hero-photo{ order:-1; max-width:400px; margin:0 auto; min-height:420px; }
  .cards{ grid-template-columns:repeat(2,1fr); }
  .diff-grid,.steps{ grid-template-columns:1fr; gap:1.4rem; }
  .footer-inner{ flex-direction:column; align-items:flex-start; }
}
@media (max-width:540px){
  .cards{ grid-template-columns:1fr; }
  .hero{ padding:3rem 0 3.5rem; }
  .btn{ width:100%; justify-content:center; }
  .hero-ctas,.cta-ctas{ flex-direction:column; }
  .cta-card{ padding:3rem 1.3rem; border-radius:28px; }
}
