/* ==========================================================
   STYLE.CSS — LP Dr. Rafael Avelar (DESKTOP ONLY, sem responsivo)
   BG degradê #191919 -> #B2B2B2 | Texto left | PNG do Dr. right
   ========================================================== */

/* --------- Variáveis --------- */
:root{
  --text:#EDEDED;
  --muted:#AFAFAF;
  --brand:#976C53;
  --brand-2:#7E5A46;
  --font: ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto,
          "Helvetica Neue", Arial, "Noto Sans", sans-serif;
}

/* --------- Base --------- */
*{ box-sizing:border-box; -webkit-tap-highlight-color:transparent; }
html, body{ height:100%; }
body{ margin:0; color:var(--text); background:#191919; font-family:var(--font); line-height:1.5; }
a{ color:inherit; text-decoration:none; }
img{ display:block; max-width:100%; }
.container{ width:1180px; margin:0 auto; }

/* --------- Botão --------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  gap:10px; padding:12px 18px; border-radius:12px; border:1px solid transparent;
  font-weight:700; font-size:16px; cursor:pointer; transition:.25s; white-space:nowrap;
  background:linear-gradient(180deg, var(--brand), var(--brand-2));
  color:#0B0B0B; box-shadow:0 8px 24px rgba(151,108,83,.28);
}
.btn:hover{ transform:translateY(-1px); box-shadow:0 14px 34px rgba(151,108,83,.38); }

/* ==========================================================
   HERO
   ========================================================== */
.hero{
  position:relative; isolation:isolate;
  height:100vh; overflow:hidden;
  display:flex; flex-direction:column; justify-content:flex-start;
  padding-top:40px;
  /* BG total com degradê: esquerda (#191919) -> direita (#B2B2B2) */
  background: linear-gradient(90deg, #191919 0%, #2B2B2B 40%, #5E5E5E 72%, #B2B2B2 100%);
}

/* Logo topo */
.hero__logo{ margin-left:40px; margin-bottom:40px; }

/* Bloco de texto (esquerda) */
.hero__grid{ max-width:640px; margin-left:40px; }
.eyebrow{ font-size:15px; color:var(--muted); margin-bottom:10px; }
.hero__title{ font-size:38px; line-height:1.2; font-weight:900; margin:0 0 12px; }
.hero__name{ font-size:18px; font-weight:600; color:#CFCFCF; margin:0 0 22px; }

.hero__bullets{ margin:0 0 26px; padding:0; list-style:none; }
.hero__bullets li{
  display:flex; align-items:flex-start; gap:10px;
  color:#DADADA; margin:10px 0;
}
.hero__bullets li::before{
  content:""; width:10px; height:10px; margin-top:7px; border-radius:50%;
  background:linear-gradient(180deg, var(--brand), var(--brand-2));
  box-shadow:0 0 0 4px rgba(151,108,83,.18);
}

.hero__cta{ margin-top:6px; }
.hero__badges{ display:flex; gap:10px; margin-top:20px; }
.badge{
  font-size:13px; color:#C9C9C9; border:1px solid #2B2B2B;
  padding:8px 12px; border-radius:999px; background:rgba(255,255,255,.02);
}

/* ==========================================================
   FOTO PNG (direita) — sem borda/sombra
   ========================================================== */
.hero__photo{
  position:absolute;
  right:60px; bottom:0; z-index:1;
  pointer-events:none;              /* não “pega” clique; foco fica no CTA */
}
.hero__photo img{
  height:95vh; width:auto; object-fit:contain;
  /* sem borda, sem sombra, sem filtros */
}

/* =========================
   VÍDEO DE VENDAS (DESKTOP)
   ========================= */
.sales-video{
  background: linear-gradient(180deg, #101010 0%, #0E0E0E 100%);
  padding: 90px 0 110px;
  position: relative;
  overflow: hidden;
}

/* Cabeçalho/narrativa */
.sales-head{
  width: 860px;      /* narrativa mais larga que o player para respirar */
  margin: 0 auto 36px;
  text-align: center;
}
.sales-eyebrow{
  display:inline-block;
  font-size:14px;
  color:#AFAFAF;
  letter-spacing:.08em;
  text-transform:uppercase;
  margin:0 0 10px;
}
.sales-title{
  font-size:30px;
  font-weight:900;
  letter-spacing:-.01em;
  margin:0 0 12px;
}
.sales-title span{
  color:#976C53;     /* acento elegante */
}
.sales-lead{
  margin:0 auto 18px;
  color:#D8D8D8;
  font-size:18px;
  line-height:1.55;
}

/* (mantive as regras de .sales-promises, mas sem usar no HTML) */

/* Moldura do vídeo */
.video-frame{
  display:flex; justify-content:center; margin: 26px 0 0;
}
.video-chrome{
  width:960px;             /* ↑ maior, igual ao iframe */
  height:auto;
  border-radius:18px;
  padding:14px;            /* cromado */
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.01));
  border:1px solid #1E1E1E;
  box-shadow: 0 30px 80px rgba(0,0,0,.55);
}
.video-chrome iframe{
  display:block;
  width:960px; height:540px;   /* ↑ 16:9 maior */
  border-radius:12px;
  overflow:hidden;
}

/* CTA com a MESMA largura do vídeo */
.video-cta{
  margin-top: 18px;
  display:flex; flex-direction:column; align-items:center; gap:12px;
}
.btn--wide{
  display:block;
  width:960px;                 /* ↑ exatamente a largura do vídeo */
  text-align:center;
}
.cta-note{
  font-size:14px; color:#AFAFAF; margin:0;
}

/* =========================
   COMO POSSO TE AJUDAR (DESKTOP)
   ========================= */
.care-areas{
  background: linear-gradient(180deg, #121212 0%, #0E0E0E 100%);
  padding: 100px 0 120px;
}

.care-head{
  width: 960px;
  margin: 0 auto 36px;
  text-align: center;
}
.care-eyebrow{
  display:inline-block;
  font-size:14px;
  color:#AFAFAF;
  letter-spacing:.08em;
  text-transform:uppercase;
  margin-bottom:10px;
}
.care-title{
  font-size:30px;
  font-weight:900;
  letter-spacing:-.01em;
  margin:0 0 12px;
}
.care-lead{
  font-size:18px;
  color:#D8D8D8;
  line-height:1.6;
  margin:0;
}

/* Grid 2×3 */
.care-grid{
  width:1180px;
  margin:34px auto 0;
  display:grid;
  grid-template-columns: 1fr 1fr;  /* desktop-only */
  gap:18px;
}

/* Card premium */
.care-card{
  position:relative;
  padding:22px 24px 24px 24px;
  border-radius:18px;
  background:
    radial-gradient(120% 120% at 0% 0%, rgba(255,255,255,.04), rgba(255,255,255,.01) 60%),
    linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,.00));
  border:1px solid #1F1F1F;
  box-shadow: 0 24px 60px rgba(0,0,0,.35);
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.care-card:hover{
  transform: translateY(-6px);
  border-color: rgba(151,108,83,.35);
  box-shadow: 0 36px 90px rgba(0,0,0,.5);
}

/* Ícone minimalista (linha) */
.care-card__icon{
  width:36px; height:36px;
  display:flex; align-items:center; justify-content:center;
  color:#976C53;   /* cobre/marca */
  margin-bottom:12px;
}
.care-card__icon svg{
  width:30px; height:30px; display:block;
}

/* Título + texto */
.care-card__title{
  font-size:20px;
  font-weight:800;
  letter-spacing:-.01em;
  margin:0 0 8px;
  color:#EDEDED;
}
.care-card__text{
  font-size:16px;
  color:#D2D2D2;
  line-height:1.55;
  margin:0;
}


/* =========================
   HISTÓRIAS REAIS (mantido como aprovado)
   ========================= */
.stories{
  background: linear-gradient(180deg, #121212 0%, #0E0E0E 100%);
  padding: 110px 0 130px;
}
.stories__head{ width:960px; margin:0 auto 40px; text-align:center; }
.stories__eyebrow{
  display:inline-block; font-size:14px; color:#AFAFAF; letter-spacing:.08em; text-transform:uppercase; margin-bottom:10px;
}
.stories__title{ font-size:30px; font-weight:900; letter-spacing:-.01em; margin:0 0 12px; }
.stories__lead{ font-size:18px; color:#D8D8D8; line-height:1.6; margin:0; }

/* Grid 2 colunas */
.stories__grid{
  width:1180px; margin:32px auto 0;
  display:grid; grid-template-columns:1fr 1fr; gap:28px;
}
/* Card */
.story{
  background: linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,0));
  border:1px solid #2A2A2A; border-radius:20px; padding:26px 24px;
  box-shadow:0 24px 70px rgba(0,0,0,.35);
  display:flex; flex-direction:column; align-items:center; transition:.25s ease;
}
.story:hover{ border-color:rgba(151,108,83,.4); transform:translateY(-4px); }
/* Texto */
.story__copy{ margin-bottom:18px; text-align:center; }
.story__eyebrow{ font-size:13px; color:#976C53; margin-bottom:6px; display:block; }
.story__title{ font-size:20px; font-weight:800; letter-spacing:-.01em; margin:0 0 10px; color:#EDEDED; }
.story__text{ font-size:16px; color:#D2D2D2; line-height:1.55; margin:0; }
/* Player */
.story__frame{ display:flex; flex-direction:column; align-items:center; gap:10px; }
.story__chrome{
  width:432px; padding:14px; border-radius:18px;
  background: linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.01));
  border:1px solid #1E1E1E; box-shadow:0 28px 90px rgba(0,0,0,.55);
}
.story__chrome iframe{ display:block; width:432px; height:768px; border-radius:14px; }
.story__note{ font-size:13px; color:#AFAFAF; margin:0; }

/* =========================
   TRANSIÇÃO ENXUTA (mesmo fundo)
   ========================= */
.narrative-bridge{ text-align:center; width:960px; margin:46px auto 26px; }
.bridge--compact .bridge-title{ font-size:24px; margin:0 0 8px; letter-spacing:-.01em; color:#EDEDED; }
.bridge--compact .bridge-lead{ font-size:17px; color:#D8D8D8; margin:0 auto 18px; line-height:1.6; }
.bridge-lead span{ color:#976C53; }
.bridge-arrow{ display:flex; flex-direction:column; align-items:center; gap:10px; color:#976C53; }
.arrow-svg{ width:56px; height:56px; filter:drop-shadow(0 8px 20px rgba(151,108,83,.25)); }
.arrow-chevrons path{ animation:chevronFloat 1.8s ease-in-out infinite; }
.arrow-chevrons path:nth-child(2){ animation-delay:.15s; }
.arrow-chevrons path:nth-child(3){ animation-delay:.30s; }
@keyframes chevronFloat{ 0%,100%{transform:translateY(0);} 50%{transform:translateY(4px);} }
.arrow-glow{ animation:glowPulse 2.6s ease-in-out infinite; }
@keyframes glowPulse{ 0%,100%{filter:drop-shadow(0 0 0 rgba(151,108,83,0));} 50%{filter:drop-shadow(0 0 12px rgba(151,108,83,.25));} }
.bridge-hint{ font-size:13.5px; color:#BEBEBE; }

/* =========================
   TRATAMENTOS — premium com ícones (sem cabeçalhos)
   ========================= */
.treatments__grid{
  width:1180px; margin:14px auto 0;
  display:grid; grid-template-columns:1fr 1fr; gap:18px;
}
.tcard{
  position:relative; padding:24px; border-radius:18px;
  background:
    radial-gradient(120% 120% at 0% 0%, rgba(255,255,255,.04), rgba(255,255,255,0) 60%),
    linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,0));
  border:1px solid #1F1F1F;
  box-shadow:0 24px 60px rgba(0,0,0,.35);
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.tcard:hover{ transform:translateY(-6px); border-color:rgba(151,108,83,.35); box-shadow:0 36px 90px rgba(0,0,0,.5); }

/* Ícones finos */
.tcard__icon{ width:38px; height:38px; display:flex; align-items:center; justify-content:center; color:#976C53; margin-bottom:12px; }
.tcard__icon svg{ width:32px; height:32px; display:block; }

/* Título + texto */
.tcard__title{ font-size:20px; font-weight:800; letter-spacing:-.01em; margin:0 0 10px; color:#EDEDED; }
.tcard__text{ font-size:16px; color:#D2D2D2; line-height:1.55; margin:0; }

/* CTA final */
.treatments__footer{ width:980px; margin:32px auto 0; text-align:center; }
.treatments__disclaimer{ font-size:14.5px; color:#AFAFAF; margin:0 0 16px; }
.treatments__cta{ display:flex; flex-direction:column; align-items:center; gap:12px; }
.treatments .btn--wide{ width:960px; text-align:center; }
.treatments .cta-note{ font-size:14px; color:#AFAFAF; margin:0; }


/* =========================
   APRESENTAÇÃO DO MÉDICO — DESKTOP
   ========================= */
.about-doctor{
  background: linear-gradient(180deg, #121212 0%, #0F0F0F 100%); /* mantém a identidade escura elegante */
  padding: 110px 0 120px;
}

.about__grid{
  width:1180px; margin:0 auto;
  display:grid; grid-template-columns: 540px 1fr; gap:44px; align-items:start;
}

/* Foto com “cromado” premium */
.about__photo{ margin:0; }
.photo-chrome{
  border-radius:22px;
  padding:14px;
  background: linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.01));
  border:1px solid #1E1E1E;
  box-shadow: 0 30px 90px rgba(0,0,0,.55);
}
.about__photo img{
  display:block; width:100%; height:auto; border-radius:16px; object-fit:cover;
}
.about__caption{
  font-size:13px; color:#AFAFAF; margin-top:10px; text-align:center;
}

/* Conteúdo */
.about__content{ max-width:600px; }
.about__eyebrow{
  display:inline-block; font-size:14px; color:#AFAFAF; letter-spacing:.08em; text-transform:uppercase; margin-bottom:10px;
}
.about__title{
  margin:0 0 16px; font-size:30px; font-weight:900; letter-spacing:-.01em;
}
.about__block{ margin:18px 0 0; }
.about__label{
  margin:0 0 8px; font-size:14px; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:#976C53;
}
.about__content p{
  margin:0; font-size:16.5px; line-height:1.65; color:#D4D4D4;
}

/* Lista com marcadores “assinatura” */
.about__list{ list-style:none; margin:10px 0 0; padding:0; }
.about__list li{
  position:relative; padding-left:18px; margin:8px 0; color:#D8D8D8; font-size:16px;
}
.about__list li::before{
  content:""; position:absolute; left:0; top:9px; width:8px; height:8px; border-radius:50%;
  background: linear-gradient(180deg, #976C53, #7E5A46); box-shadow:0 0 0 4px rgba(151,108,83,.18);
}

/* CTA discreta */
.about__cta{ display:flex; align-items:center; gap:14px; margin-top:22px; }
.about__note{ font-size:13.5px; color:#AFAFAF; }

/* Botão já existe no seu CSS global */
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  gap:10px; padding:12px 18px; border-radius:12px; border:1px solid transparent;
  font-weight:700; font-size:16px; cursor:pointer; transition:.25s; white-space:nowrap;
  background:linear-gradient(180deg, #976C53, #7E5A46);
  color:#0B0B0B; box-shadow:0 8px 24px rgba(151,108,83,.28);
}
.btn:hover{ transform:translateY(-1px); box-shadow:0 14px 34px rgba(151,108,83,.38); }

/* =========================
   SAÚDE HORMONAL — DESKTOP
   ========================= */
.hormonal{
  background: linear-gradient(180deg, #121212 0%, #0F0F0F 100%);
  padding: 110px 0 120px;
}
.hormonal .container{ width:1180px; margin:0 auto; }

.hormonal__head{
  width: 960px;
  margin: 0 auto 34px;
  text-align: center;
}
.hormonal__eyebrow{
  display:inline-block;
  font-size:14px;
  color:#AFAFAF;
  text-transform:uppercase;
  letter-spacing:.08em;
  margin-bottom:10px;
}
.hormonal__title{
  font-size:30px;
  font-weight:900;
  letter-spacing:-.01em;
  margin:0 0 12px;
}
.hormonal__lead{
  font-size:18px;
  color:#D8D8D8;
  line-height:1.55;
  margin:0;
}

.hormonal__grid{
  display:grid;
  grid-template-columns: 1fr 1fr;  /* duas colunas */
  gap: 22px;
}

/* Card premium */
.hcard{
  background: linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,0));
  border:1px solid #1F1F1F;
  border-radius:20px;
  padding: 20px 20px 24px;
  box-shadow: 0 26px 70px rgba(0,0,0,.38);
  transition: transform .25s ease, border-color .25s ease, box-shadow .25s ease;
  display:flex; flex-direction:column; align-items:center;
}
.hcard:hover{
  transform: translateY(-4px);
  border-color: rgba(151,108,83,.35);        /* cobre da marca */
  box-shadow: 0 36px 90px rgba(0,0,0,.55);
}

/* Topline */
.hcard__topline{
  width:100%;
  text-align:center;
  margin-bottom:12px;
}
.hcard__eyebrow{
  display:inline-block;
  font-size:13px; color:#976C53; text-transform:uppercase; letter-spacing:.08em;
  margin-bottom:6px;
}
.hcard__title{
  margin:0; font-size:20px; font-weight:800; letter-spacing:-.01em; color:#EDEDED;
}

/* Moldura do vídeo (cromado premium) */
.hcard__video{ width:100%; display:flex; justify-content:center; }
.hvideo{
  width:560px;  /* igual ao iframe */
  padding:14px;
  border-radius:18px;
  background: linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.01));
  border:1px solid #1E1E1E;
  box-shadow: 0 28px 90px rgba(0,0,0,.55);
}
.hvideo iframe{
  display:block;
  width:560px; height:315px; /* 16:9 */
  border-radius:12px;
}

/* Nota breve sob o vídeo */
.hcard__note{
  font-size:14px; color:#AFAFAF; margin:10px 0 0; text-align:center;
}

/* =========================
   CHAMADA FINAL — DESKTOP
   ========================= */
.closing-cta{
  background: linear-gradient(180deg, #101010 0%, #0E0E0E 100%); /* mantém identidade escura */
  padding: 100px 0 120px;
  position: relative;
  overflow: hidden;
}

/* linha/halo sutil para dar “final editorial” */
.closing-cta::before{
  content:"";
  position:absolute; left:50%; top:0; transform:translateX(-50%);
  width:1180px; height:1px;
  background: linear-gradient(90deg, rgba(151,108,83,0) 0%, rgba(151,108,83,.45) 50%, rgba(151,108,83,0) 100%);
  opacity:.7;
}
.closing-cta::after{
  content:"";
  position:absolute; left:50%; top:-120px; transform:translateX(-50%);
  width:720px; height:240px;
  background: radial-gradient(60% 60% at 50% 100%, rgba(151,108,83,.12) 0%, rgba(151,108,83,0) 70%);
  pointer-events:none;
}

.closing-wrap{
  width:980px; margin:0 auto; text-align:center;
}

.closing-title{
  font-size:30px; font-weight:900; letter-spacing:-.01em;
  margin:0 0 12px; color:#EDEDED;
}

.closing-lead{
  font-size:18px; line-height:1.6; color:#D8D8D8;
  margin:0 auto 18px; max-width:860px;
}
.closing-lead span{ color:#976C53; }

/* Reuso do botão largo (mesma largura do vídeo principal/CTAs) */
.closing-cta .btn--wide{
  width:960px;
  text-align:center;
  margin-top:6px;
}

.closing-note{
  font-size:14px; color:#AFAFAF; margin:12px 0 0;
}

/* =========================
   FOOTER — DESKTOP
   ========================= */
.site-footer{
  background: linear-gradient(180deg, #0F0F0F 0%, #0B0B0B 100%);
  padding: 56px 0 36px;
  position: relative;
  overflow: hidden;
}

/* linha de brilho superior */
.site-footer::before{
  content:"";
  position:absolute; left:50%; top:0; transform:translateX(-50%);
  width:1180px; height:1px;
  background: linear-gradient(90deg, rgba(151,108,83,0) 0%, rgba(151,108,83,.45) 50%, rgba(151,108,83,0) 100%);
  opacity:.7;
}

.site-footer .container{ width:1180px; margin:0 auto; }

.footer__grid{
  display:grid;
  grid-template-columns: 1fr 1fr;   /* marca | contatos */
  align-items:center;
  gap: 20px;
}

.footer__brand img{
  display:block;
  width:220px; height:auto;   /* recomendado 220×60 px */
  filter: drop-shadow(0 8px 20px rgba(0,0,0,.35));
}

/* Contatos */
.contact{
  list-style:none; margin:0; padding:0;
  display:flex; flex-direction:column; gap:10px;
}
.contact__item{
  display:flex; align-items:center; gap:10px;
  color:#D4D4D4; font-size:15.5px;
}
.icon{
  width:20px; height:20px; color:#976C53; flex:0 0 20px;
}
.icon svg{ width:20px; height:20px; display:block; }

.contact__link{
  color:#EAEAEA; text-decoration:none; border-bottom:1px solid transparent; transition:.2s;
}
.contact__link:hover{ color:#fff; border-bottom-color: rgba(151,108,83,.45); }

/* Bottom line */
.footer__bottom{
  margin-top: 20px;
  padding-top: 16px;
  border-top:1px solid #1C1C1C;
  display:flex; align-items:center; gap:10px; justify-content:center;
  color:#AFAFAF; font-size:13.5px;
}
.footer__bottom .dot{ opacity:.5; }
.footer__bottom .dev{
  color:#CFCFCF; text-decoration:none; border-bottom:1px solid transparent; transition:.2s;
}
.footer__bottom .dev:hover{
  color:#fff; border-bottom-color: rgba(151,108,83,.45);
}

/* Botão flutuante (mantido) */
.whatsapp-float{
  position: fixed;
  bottom: 32px;
  right: 36px;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  z-index: 1100;
  -webkit-tap-highlight-color: transparent;
}
.whatsapp-float__btn{
  width: 56px; height: 56px; border-radius: 50%;
  background: #25D366; /* verde oficial */
  display: grid; place-items: center;
  box-shadow: 0 10px 28px rgba(0,0,0,.35);
  border: 1px solid rgba(0,0,0,.18);
  transition: transform .2s ease, box-shadow .2s ease;
}
/* Ícone oficial como imagem */
.wa-ico-img{ display:block; width:26px; height:26px; }

/* Label “pill” (mantido) */
.whatsapp-float__label{
  overflow: hidden;
  max-width: 0;
  opacity: 0;
  transform: translateX(6px);
  white-space: nowrap;
  padding: 10px 0;
  color: #EDEDED;
  background: rgba(20,20,20,.92);
  border: 1px solid #2A2A2A;
  border-radius: 12px;
  line-height: 1;
  font-size: 14px;
  transition: max-width .28s ease, opacity .22s ease, transform .22s ease, padding .22s ease;
}
.whatsapp-float:hover .whatsapp-float__btn,
.whatsapp-float:focus-visible .whatsapp-float__btn{
  transform: translateY(-2px);
  box-shadow: 0 16px 36px rgba(0,0,0,.45);
}
.whatsapp-float:hover .whatsapp-float__label,
.whatsapp-float:focus-visible .whatsapp-float__label{
  max-width: 220px;
  opacity: 1;
  transform: translateX(0);
  padding: 10px 14px;
}

/* cor do glyph oficial */
.wa-ico-svg{ width:26px; height:26px; display:block; fill:#fff; }


/* ==========================================================
   HERO — MOBILE/TABLET: imagem 100% topo + conteúdo 50% sobreposto
   (desktop intocado)
   ========================================================== */

/* Tablet (≤ 992px) */
@media (max-width: 992px){
  /* controla o quanto o conteúdo “sobe” sobre a imagem (~50%) */
  .hero{ --hero-overlap: clamp(72px, 50vw, 240px); }

  /* hero ocupa altura do conteúdo; degradê cobre toda a seção (vertical) */
  .hero{
    height: auto; min-height: 0;
    padding-top: 56px;
    padding-bottom: 28px;
    position: relative;
    background: linear-gradient(180deg, #B2B2B2 0%, #3A3A3A 30%, #1A1A1A 55%, #0B0B0B 100%);
  }

  /* container com respiro e acima da foto */
  .hero .container{
    width: min(1180px, 92%);
    margin: 0 auto;
    padding-inline: 24px;      /* alinhamento à esquerda */
    position: relative;
    z-index: 2;                /* conteúdo sempre acima */
  }

  /* Foto 100% de largura e centralizada */
.hero__photo{
  position: relative;
  order: -1;
  z-index: 1;
  /* full-bleed: ocupa 100% da largura da janela e centraliza */
  width: 100vw;
  left: 50%;
  transform: translateX(-50%);
  margin: 0;
  pointer-events: none;
}

.hero__photo img{
  display: block;
  width: 100%;
  height: auto;
  object-fit: contain;
  object-position: center top; /* centraliza o recorte do PNG */
}


  /* LOGO + TEXTOS + CTA abaixo da imagem, sobrepondo ~50% */
  .hero__logo{
    position: relative;
    z-index: 3;
    margin: 0 0 12px 0;
    margin-top: calc(-1 * var(--hero-overlap));   /* sobe sobre a imagem */
  }
  .hero__grid{
    position: relative;
    z-index: 3;
    margin: 0;                                    /* logo já fez o overlap */
    max-width: 100%;
  }
  .hero__copy{ max-width: 100%; }

  /* tipografia confortável */
  .hero__title{ font-size: 34px; }
  .hero__name{ font-size: 17px; }
  .hero__bullets li{ margin: 8px 0; }

  /* CTA 100% de largura (como pediu para mobile) */
  .hero .btn{
    width: 100%;
    font-size: 15.5px;
    padding: 12px 16px;
  }
}

/* Mobile (≤ 768px) — micro ajustes */
@media (max-width: 768px){
  .hero{
    padding-top: 60px;
    padding-bottom: calc(24px + env(safe-area-inset-bottom));
    --hero-overlap: clamp(66px, 50vw, 220px); /* ~50% do viewport */
  }
  .hero .container{ padding-inline: 20px; }
  .hero__title{ font-size: 28px; }
  .hero__name{ font-size: 16px; }
}

/* Mobile pequeno (≤ 480px) — ainda mais fino */
@media (max-width: 480px){
  .hero .container{ padding-inline: 14px; }
  .hero{ --hero-overlap: clamp(60px, 52vw, 200px); }
  .hero__title{ font-size: 26px; }
  .eyebrow{ font-size: 14px; }
  .hero .btn{ font-size: 15px; padding: 10px 14px; }
}

/* ==========================================================
   HERO — remover qualquer fundo/overlay na foto (mobile/tablet)
   ========================================================== */
@media (max-width: 992px){
  .hero__photo,
  .hero__photo picture,
  .hero__photo img{
    background: transparent !important;
  }
  .hero__photo::before,
  .hero__photo::after{
    content: none !important;
    display: none !important;
    background: none !important;
    height: 0 !important;
  }
}


/* ==========================================================
   VÍDEO DE VENDAS — RESPONSIVO (tablet/mobile)
   ========================================================== */

/* Laptop/containers fluidos */
@media (max-width: 1200px){
  .sales-video .container{ width: min(1180px, 92%); margin: 0 auto; }
  .sales-head{ width: 92%; margin: 0 auto 28px; }
  .video-frame{ margin-top: 20px; }
  .video-chrome{
    width: 100%;
    max-width: 860px;                /* respira bem em laptop */
  }
  .video-chrome iframe{
    width: 100%;
    height: auto;
    aspect-ratio: 16 / 9;            /* mantém 16:9 sem “esmagar” */
    border-radius: 12px;
  }
  .sales-video .btn--wide{
    width: min(100%, 860px);         /* mesma largura do player */
  }
}

/* Tablet (≤ 992px) */
@media (max-width: 992px){
  .sales-head{ width: 92%; margin-bottom: 22px; }
  .sales-title{ font-size: 28px; }
  .sales-lead{ font-size: 17px; }

  .video-chrome{
    max-width: 720px;
    padding: 12px;                   /* cromado mais contido */
    border-radius: 16px;
  }
  .video-chrome iframe{ border-radius: 10px; }
  .sales-video .btn--wide{ width: min(100%, 720px); }
  .cta-note{ font-size: 13.5px; }
}

/* Mobile (≤ 768px) */
@media (max-width: 768px){
  .sales-video{ padding: 70px 0 90px; }
  .sales-head{ width: 100%; margin-bottom: 18px; text-align: center; }
  .sales-eyebrow{ font-size: 13px; margin-bottom: 8px; }
  .sales-title{ font-size: 24px; margin-bottom: 10px; }
  .sales-lead{ font-size: 16px; line-height: 1.55; }

  .video-chrome{
    max-width: 100%;
    padding: 10px;
    border-radius: 14px;
    box-shadow: 0 22px 60px rgba(0,0,0,.45);
  }
  .video-cta{ gap: 10px; }
  .sales-video .btn--wide{
    width: 100%;
    text-align: center;
  }
  .cta-note{
    margin: 0;
    font-size: 13px;
    color: #AFAFAF;
  }
}

/* Mobile pequeno (≤ 480px) */
@media (max-width: 480px){
  .sales-title{ font-size: 22px; }
  .sales-lead{ font-size: 15.5px; }
  .video-chrome{ padding: 8px; border-radius: 12px; }
  .video-chrome iframe{ border-radius: 8px; }
  .sales-video{ padding: 60px 0 80px; }
  .sales-video .btn--wide{ font-size: 15px; padding: 12px 14px; }
}

/* ==========================================================
   ÁREAS DE ATUAÇÃO — RESPONSIVO (tablet/mobile)
   ========================================================== */

/* Laptop (≤ 1200px): container e larguras fluidas */
@media (max-width: 1200px){
  .care-areas .container{ width: min(1180px, 92%); margin: 0 auto; }
  .care-head{ width: 92%; }
  .care-grid{ width: 92%; gap: 16px; }
}

/* Tablet (≤ 992px) */
@media (max-width: 992px){
  .care-areas{ padding: 80px 0 100px; }
  .care-head{ margin-bottom: 24px; }
  .care-title{ font-size: 28px; }
  .care-lead{ font-size: 17px; line-height: 1.55; }

  .care-grid{
    grid-template-columns: 1fr 1fr;  /* mantém 2 colunas no tablet */
    gap: 16px;
  }

  .care-card{
    padding: 20px;
    border-radius: 16px;
    box-shadow: 0 22px 60px rgba(0,0,0,.4);
  }
  .care-card__icon{ width: 34px; height: 34px; margin-bottom: 10px; }
  .care-card__icon svg{ width: 28px; height: 28px; }

  .care-card__title{ font-size: 19px; margin-bottom: 8px; }
  .care-card__text{ font-size: 15.5px; line-height: 1.55; }
}

/* Mobile (≤ 768px) */
@media (max-width: 768px){
  .care-areas{ padding: 70px 0 90px; }
  .care-head{ width: 100%; margin-bottom: 18px; }
  .care-title{ font-size: 24px; }
  .care-lead{ font-size: 16px; }

  .care-grid{
    width: 100%;
    grid-template-columns: 1fr;   /* 1 coluna */
    gap: 14px;
  }

  .care-card{
    padding: 18px;
    border-radius: 14px;
    box-shadow: 0 20px 56px rgba(0,0,0,.42);
  }
  .care-card__icon{ width: 32px; height: 32px; }
  .care-card__icon svg{ width: 26px; height: 26px; }

  .care-card__title{ font-size: 18px; }
  .care-card__text{ font-size: 15.5px; }
}

/* Mobile pequeno (≤ 480px) */
@media (max-width: 480px){
  .care-areas{ padding: 60px 0 80px; }
  .care-title{ font-size: 22px; }
  .care-card{ padding: 16px; border-radius: 12px; }
  .care-card__title{ font-size: 17px; }
  .care-card__text{ font-size: 15px; }
}

/* ==========================================================
   HISTÓRIAS + TRANSIÇÃO + TRATAMENTOS — RESPONSIVO
   (mantém o visual premium do desktop; adapta tablet/mobile)
   ========================================================== */

/* Laptop (≤ 1200px): containers e larguras fluidas */
@media (max-width: 1200px){
  .stories .container{ width: min(1180px, 92%); margin: 0 auto; }
  .stories__head{ width: 92%; }
  .stories__grid{ width: 92%; gap: 22px; }

  .narrative-bridge{ width: 92%; }

  .treatments__grid{ width: 92%; gap: 16px; }
  .treatments__footer{ width: min(980px, 92%); }
}

/* Tablet (≤ 992px) */
@media (max-width: 992px){
  .stories{ padding: 90px 0 110px; }
  .stories__title{ font-size: 28px; }
  .stories__lead{ font-size: 17px; }

  /* mantém 2 colunas no tablet, com cards mais compactos */
  .stories__grid{
    grid-template-columns: 1fr 1fr;
    gap: 18px;
  }
  .story{
    padding: 22px 20px;
    border-radius: 18px;
    box-shadow: 0 22px 60px rgba(0,0,0,.4);
  }
  .story__title{ font-size: 19px; }
  .story__text{ font-size: 15.5px; }

  /* player vertical fluido (9:16) */
  .story__chrome{
    width: 100%;
    max-width: 360px;
    padding: 12px;
    border-radius: 16px;
  }
  .story__chrome iframe{
    width: 100%;
    height: auto;
    aspect-ratio: 9 / 16;
    border-radius: 12px;
  }
  .story__note{ font-size: 13px; }

  /* transição enxuta */
  .bridge--compact .bridge-title{ font-size: 22px; margin-bottom: 8px; }
  .bridge--compact .bridge-lead{ font-size: 16px; }
  .arrow-svg{ width: 52px; height: 52px; }

  /* tratamentos: 2 colunas no tablet */
  .treatments__grid{
    grid-template-columns: 1fr 1fr;
    gap: 16px;
  }
  .tcard{
    padding: 20px;
    border-radius: 16px;
    box-shadow: 0 22px 60px rgba(0,0,0,.42);
  }
  .tcard__icon{ width: 34px; height: 34px; margin-bottom: 10px; }
  .tcard__icon svg{ width: 28px; height: 28px; }
  .tcard__title{ font-size: 19px; }
  .tcard__text{ font-size: 15.5px; }

  .treatments__footer{ text-align: center; }
  .treatments__disclaimer{ font-size: 14px; }
  .treatments__footer .btn--wide{ width: min(100%, 720px); }
}

/* Mobile (≤ 768px) */
@media (max-width: 768px){
  .stories{ padding: 80px 0 100px; }
  .stories__head{ width: 100%; margin-bottom: 18px; }
  .stories__title{ font-size: 24px; }
  .stories__lead{ font-size: 16px; line-height: 1.55; }

  /* 1 coluna */
  .stories__grid{
    width: 100%;
    grid-template-columns: 1fr;
    gap: 14px;
  }
  .story{
    padding: 18px;
    border-radius: 14px;
    box-shadow: 0 20px 56px rgba(0,0,0,.42);
  }
  .story__title{ font-size: 18px; }
  .story__text{ font-size: 15.5px; }
  .story__chrome{ max-width: 100%; padding: 10px; border-radius: 14px; }
  .story__chrome iframe{ border-radius: 10px; }

  /* transição */
  .narrative-bridge{ width: 100%; margin: 36px auto 20px; }
  .bridge--compact .bridge-title{ font-size: 20px; }
  .bridge--compact .bridge-lead{ font-size: 15.5px; }
  .arrow-svg{ width: 46px; height: 46px; }

  /* tratamentos: 1 coluna */
  .treatments__grid{
    width: 100%;
    grid-template-columns: 1fr;
    gap: 14px;
  }
  .tcard{ padding: 18px; border-radius: 14px; }
  .tcard__icon{ width: 32px; height: 32px; }
  .tcard__icon svg{ width: 26px; height: 26px; }
  .tcard__title{ font-size: 18px; }
  .tcard__text{ font-size: 15.5px; }

  .treatments__footer{ width: 100%; margin-top: 26px; }
  .treatments__disclaimer{ font-size: 13.5px; }
  .treatments__footer .btn--wide{ width: 100%; }
  .treatments .cta-note,
  .cta-note{ font-size: 13px; }
}

/* Mobile pequeno (≤ 480px) */
@media (max-width: 480px){
  .stories{ padding: 70px 0 90px; }
  .stories__title{ font-size: 22px; }
  .stories__lead{ font-size: 15.5px; }

  .story{ padding: 16px; border-radius: 12px; }
  .story__title{ font-size: 17px; }
  .story__text{ font-size: 15px; }
  .story__chrome{ padding: 8px; border-radius: 12px; }
  .story__chrome iframe{ border-radius: 8px; }

  .bridge--compact .bridge-title{ font-size: 19px; }
  .bridge--compact .bridge-lead{ font-size: 15px; }
  .arrow-svg{ width: 40px; height: 40px; }

  .tcard{ padding: 16px; border-radius: 12px; }
  .tcard__title{ font-size: 17px; }
  .tcard__text{ font-size: 15px; }
}

/* ==========================================================
   APRESENTAÇÃO DO MÉDICO — RESPONSIVO (tablet/mobile)
   ========================================================== */

/* Laptop (≤ 1200px): container e grid mais fluídos */
@media (max-width: 1200px){
  .about-doctor .container{ width: min(1180px, 92%); margin: 0 auto; }
  .about__grid{ grid-template-columns: 500px 1fr; gap: 36px; }
}

/* Tablet (≤ 992px): 1 coluna, foto acima, texto confortável */
@media (max-width: 992px){
  .about-doctor{ padding: 90px 0 110px; }

  .about__grid{
    grid-template-columns: 1fr;
    gap: 22px;
    width: 100%;
  }

  /* FOTO */
  .about__photo{ max-width: 600px; margin: 0 auto; }
  .photo-chrome{
    padding: 12px;
    border-radius: 18px;
    box-shadow: 0 24px 70px rgba(0,0,0,.42);
    border: 1px solid #1E1E1E;
    background: linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.01));
  }
  .about__photo img{ border-radius: 12px; }
  .about__caption{ font-size: 12.5px; }

  /* TEXTO */
  .about__content{
    max-width: 720px;
    margin: 0 auto;
    text-align: left;
  }
  .about__eyebrow{ font-size: 13px; margin-bottom: 8px; }
  .about__title{ font-size: 28px; margin: 0 0 12px; }
  .about__label{ font-size: 13px; margin-bottom: 6px; }
  .about__content p{ font-size: 15.5px; line-height: 1.6; }

  .about__list li{
    font-size: 15.5px;
    margin: 6px 0;
    padding-left: 16px;
  }
  .about__list li::before{ top: 8px; width: 7px; height: 7px; }

  /* CTA discreta */
  .about__cta{ gap: 12px; margin-top: 18px; }
  .about__cta .btn{ font-size: 15px; padding: 11px 16px; }
  .about__note{ font-size: 13px; }
}

/* Mobile (≤ 768px): refinamentos de escala e sombras */
@media (max-width: 768px){
  .about-doctor{ padding: 70px 0 90px; }
  .about__photo{ max-width: 520px; }
  .photo-chrome{ padding: 10px; border-radius: 16px; box-shadow: 0 20px 56px rgba(0,0,0,.42); }
  .about__photo img{ border-radius: 10px; }

  .about__title{ font-size: 24px; }
  .about__content p{ font-size: 15.5px; }
  .about__list li{ font-size: 15px; }
  .about__cta{ gap: 10px; }
}

/* Mobile pequeno (≤ 480px): toque final e botão 100% */
@media (max-width: 480px){
  .about-doctor{ padding: 60px 0 80px; }
  .about__photo{ max-width: 100%; }
  .photo-chrome{ padding: 8px; border-radius: 12px; }
  .about__title{ font-size: 22px; }
  .about__content p{ font-size: 15px; }
  .about__cta{ flex-direction: column; align-items: stretch; gap: 8px; }
  .about__cta .btn{ width: 100%; text-align: center; }
  .about__note{ font-size: 12.5px; }
}

/* ==========================================================
   SAÚDE HORMONAL + CHAMADA FINAL + FOOTER — RESPONSIVO
   (mantém o visual premium do desktop; adapta tablet/mobile)
   ========================================================== */

/* ---------------- Laptop (≤ 1200px) ---------------- */
@media (max-width: 1200px){
  /* SAÚDE HORMONAL */
  .hormonal .container{ width: min(1180px, 92%); margin: 0 auto; }
  .hormonal__head{ width: 92%; margin: 0 auto 30px; }
  .hormonal__grid{ gap: 20px; }
  .hvideo{
    width: 100%;
    max-width: 640px;
  }
  .hvideo iframe{
    width: 100%;
    height: auto;
    aspect-ratio: 16 / 9;
    border-radius: 12px;
  }

  /* CHAMADA FINAL */
  .closing-wrap{ width: min(980px, 92%); margin: 0 auto; }
  .closing-cta::before{ width: 92%; }
  .closing-cta::after{ width: min(720px, 88%); }

  /* FOOTER */
  .site-footer .container{ width: min(1180px, 92%); margin: 0 auto; }
  .footer__grid{ gap: 18px; }
}

/* ---------------- Tablet (≤ 992px) ---------------- */
@media (max-width: 992px){
  /* SAÚDE HORMONAL */
  .hormonal{ padding: 90px 0 110px; }
  .hormonal__title{ font-size: 28px; }
  .hormonal__lead{ font-size: 17px; line-height: 1.55; }
  .hormonal__grid{
    grid-template-columns: 1fr 1fr;   /* mantém 2 colunas no tablet */
    gap: 18px;
  }
  .hcard{
    padding: 18px 18px 22px;
    border-radius: 18px;
    box-shadow: 0 24px 66px rgba(0,0,0,.44);
  }
  .hcard__eyebrow{ font-size: 12.5px; }
  .hcard__title{ font-size: 19px; }
  .hvideo{
    max-width: 720px;
    padding: 12px;
    border-radius: 16px;
  }
  .hcard__note{ font-size: 13.5px; }


  /* FOOTER */
  .footer__grid{
    grid-template-columns: 1fr 1fr;
    align-items: start;
    gap: 16px;
  }
  .footer__brand img{ width: 200px; }
  .contact__item{ font-size: 15px; }
}

/* ---------------- Mobile (≤ 768px) ---------------- */
@media (max-width: 768px){
  /* SAÚDE HORMONAL */
  .hormonal{ padding: 80px 0 100px; }
  .hormonal__head{ width: 100%; margin-bottom: 18px; text-align: center; }
  .hormonal__title{ font-size: 24px; }
  .hormonal__lead{ font-size: 16px; }
  .hormonal__grid{
    grid-template-columns: 1fr;       /* 1 coluna */
    gap: 14px;
  }
  .hcard{
    padding: 16px 16px 20px;
    border-radius: 14px;
    box-shadow: 0 20px 56px rgba(0,0,0,.42);
  }
  .hcard__eyebrow{ font-size: 12.5px; }
  .hcard__title{ font-size: 18px; }
  .hvideo{
    max-width: 100%;
    padding: 10px;
    border-radius: 14px;
    box-shadow: 0 22px 60px rgba(0,0,0,.45);
  }
  .hvideo iframe{
    aspect-ratio: 16 / 9;
    border-radius: 10px;
  }
  .hcard__note{ font-size: 13px; margin-top: 8px; }

  /* FOOTER */
  .site-footer{ padding: 48px 0 30px; }
  .footer__grid{
    grid-template-columns: 1fr;       /* empilha */
    gap: 18px;
    text-align: center;
  }
  .footer__brand{ display: flex; justify-content: center; }
  .footer__brand img{ width: 200px; height: auto; }
  .contact{
    align-items: center;
    gap: 8px;
  }
  .contact__item{ justify-content: center; font-size: 15px; }
  .contact__link{ border-bottom-width: 0; } /* mobile clean */
  .footer__bottom{
    margin-top: 16px;
    padding-top: 14px;
    font-size: 13px;
    flex-wrap: wrap;
    gap: 6px;
  }
}

/* ---------------- Mobile pequeno (≤ 480px) ---------------- */
@media (max-width: 480px){
  /* SAÚDE HORMONAL */
  .hormonal{ padding: 70px 0 90px; }
  .hormonal__title{ font-size: 22px; }
  .hcard{ padding: 14px; border-radius: 12px; }
  .hcard__title{ font-size: 17px; }
  .hvideo{ padding: 8px; border-radius: 12px; }
  .hvideo iframe{ border-radius: 8px; }
  .hcard__note{ font-size: 12.5px; }


  /* FOOTER */
  .footer__brand img{ width: 180px; }
  .contact__item{ font-size: 14.5px; }
  .footer__bottom{ font-size: 12.5px; }
}


/* ==========================================================
   CHAMADA FINAL (#agende) — RESPONSIVO (apenas overrides)
   ========================================================== */

/* Laptop (≤ 1200px) */
@media (max-width: 1200px){
  .closing-wrap{ width: min(980px, 92%); margin: 0 auto; }
  .closing-cta::before{ width: 92%; }
  .closing-cta::after{ width: min(720px, 88%); }
}

/* Tablet (≤ 992px) */
@media (max-width: 992px){
  .closing-cta{ padding: 90px 0 110px; }
  .closing-title{ font-size: 28px; }
  .closing-lead{
    font-size: 17px;
    line-height: 1.55;
    max-width: 92%;
    margin: 0 auto 16px;
  }
  .closing-cta .btn--wide{ width: min(100%, 720px); }

  /* halo/linha ajustados */
  .closing-cta::before{ width: 92%; }
  .closing-cta::after{
    width: min(680px, 86%);
    height: 220px;
    top: -100px;
  }
}

/* Mobile (≤ 768px) */
@media (max-width: 768px){
  .closing-cta{ padding: 70px 0 90px; }
  .closing-wrap{ width: 100%; text-align: center; }
  .closing-title{ font-size: 24px; margin-bottom: 10px; }
  .closing-lead{ font-size: 16px; line-height: 1.55; margin-bottom: 14px; }
  .closing-cta .btn--wide{ width: 100%; text-align: center; }
  .closing-note{ font-size: 13px; }

  .closing-cta::before{ width: 92%; }
  .closing-cta::after{
    width: min(560px, 86%);
    height: 200px;
    top: -80px;
  }
}

/* Mobile pequeno (≤ 480px) */
@media (max-width: 480px){
  .closing-cta{ padding: 60px 0 80px; }
  .closing-title{ font-size: 22px; }
  .closing-lead{ font-size: 15.5px; }
  .closing-cta .btn--wide{ font-size: 15px; padding: 12px 14px; }
  .closing-cta::after{
    width: min(480px, 88%);
    height: 180px;
    top: -70px;
  }
}

/* CHAMADA FINAL (#agende) — tornar o container fluido */
@media (max-width: 1200px){
  #agende .container{
    width: min(1180px, 92%);
    margin: 0 auto;
  }
}

@media (max-width: 992px){
  #agende .container{
    width: min(1180px, 92%);
    margin: 0 auto;
  }
}

@media (max-width: 768px){
  #agende .container{
    width: 100%;
    padding-inline: 20px;   /* respiro lateral no mobile */
    margin: 0 auto;
  }
  #agende .closing-wrap{
    width: 100%;
    max-width: none;        /* libera a largura para 100% da tela */
  }
  #agende .btn--wide{
    width: 100%;            /* botão realmente 100% da tela */
    max-width: none;
  }
}

/* Mobile pequeno */
@media (max-width: 480px){
  #agende .container{ padding-inline: 14px; }
}

