/* ===========================
   Essence Wellness — Style
   =========================== */
:root{
  /* Paleta Essence (6 cores) */
  --essence-bg:#ede7e3;        /* Branco Essência (fundo base) */
  --essence-surface:#ede7e3;   /* Superfícies claras → usa o mesmo branco Essência */
  --essence-surface-2:#d9d9d6; /* Secundário / cartões / divisórias */
  --essence-text:#6d6d6d;      /* Corpo de texto */
  --essence-black:#1c1c1c;     /* Títulos / contraste */
  --essence-gold:#c9a66b;      /* CTA premium / detalhes */
  --essence-sage:#a0a996;      /* Subtítulos / accents “natureza” */

  /* Versões com transparência (derivadas da paleta) */
  --black-rgb: 28 28 28;       /* #1c1c1c em RGB */
  --gold-rgb: 201 166 107;     /* #c9a66b em RGB */
  --sage-rgb: 160 169 150;     /* #a0a996 em RGB */

  /* Utilitários */
  --radius:25px;
  --shadow:0 15px 40px rgb(var(--black-rgb) / .08); /* sombra só com “Preto Profundo” */
  --maxw:1100px;
}


/* Base */
html,body{
  background:var(--essence-bg);
  color:var(--essence-text);
  margin:0;
  line-height:1.45;
  font-family:Lato, system-ui, -apple-system, Segoe UI, Roboto, Arial, "Noto Sans", "Helvetica Neue", sans-serif;
}
h1,h2,h3{
  font-family:"Libre Baskerville", Georgia, serif;
  color:var(--essence-black);
  margin:0 0 .5rem;
}
h1{ font-size:clamp(2rem, 3vw + 1rem, 3.25rem); line-height:1.1 }
h2{ font-size:clamp(1.5rem, 1.5vw + .9rem, 2rem) }
h3{ font-size:1.1rem; letter-spacing:.2px }
p{ line-height:1.6; margin:.5rem 0 1rem }
a{ color:inherit; text-decoration:none }
.wrap{ max-width:var(--maxw); margin:0 auto; padding:0 20px }
.mono{ font-family:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace; font-size:.92rem }

/* Helpers */
.mt-10{ margin-top:10px }
.mt-12{ margin-top:12px }
.mt-14{ margin-top:14px }
.m0{ margin:0 }

/* Barra de anúncio (fixa no topo) */
.announcement {
  position: sticky;
  top: 0px;
  z-index: 1000;
  width: 100vw;
  max-width: 100%;
  background: var(--essence-black);
  color: #fff;
  text-align: center;
  padding: 1rem .75rem;
  font-weight: 700;
  letter-spacing: .3px;
  font-size: 1.1rem;
  line-height: 1.4;
  border-bottom: 1px solid rgba(255,255,255,.1);
  font-family: Montserrat, sans-serif;
  box-sizing: border-box;
}
.announcement b {
  color: var(--essence-gold);
}

/* Versão mobile */
@media(max-width:600px){
  .announcement {
    font-size: .95rem;
    padding: .9rem .6rem;
  }
}


/* Hero */
.promo-msg {
  grid-column: 1 / -1;
  font-family: Montserrat, sans-serif;
  font-size: 2.1rem;
  font-weight: 700;
  color: var(--essence-gold);
  margin-top: -50px;
  margin-bottom: -25px;
  text-align: center;
  text-transform: uppercase;
  letter-spacing: 1px;
}

.hero{
  padding:84px 0 52px; position:relative; background:var(--essence-bg);
}
.hero-inner{
  display:grid;
  grid-template-columns:1.15fr .85fr;
  gap:32px;
  align-items:stretch;;
}

/* Card de texto */
.hero-card{
  background:var(--essence-surface);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:32px;
  border:2px solid rgba(0,0,0,.04);
}
/* Eyebrow */
.hero-card .eyebrow {
  font-family: Montserrat, sans-serif;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  font-weight: 600;
  color: var(--essence-sage);   /* Verde sálvia elegante */
  font-size: 0.9rem;
  margin-bottom: 14px;
}

/* H1 */
.hero-card h1 {
  font-family: "Libre Baskerville", Georgia, serif;
  font-size: clamp(2.1rem, 2.5vw + 0.5rem, 3.1rem);
  line-height: 0.95;          /* melhora a leitura */
  letter-spacing: -0.2px;     /* ajusta o tracking */
  font-weight: 700;
  margin-bottom: 20px;
  color: var(--essence-black);
  max-width: 18ch;            /* força quebra em ~18 caracteres por linha */
}


/* Subtítulo */
.hero-card .sub {
  font-family: Lato, sans-serif;
  font-size: 1.15rem;
  font-weight: 400;
  line-height: 1.65;
  color: var(--essence-text);
  max-width: 46ch;        /* limita largura → mais fluido */
  margin-bottom: 28px;
}


.sub{ font-size:1.05rem; color:var(--essence-text-dim) }
.hero-actions{ display:flex; gap:12px; flex-wrap:wrap; margin-top:12px }
.hero-bullets{ margin:18px 0 0; padding-left:18px }

/* CTA */
.cta{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.5rem;
  background:var(--essence-gold);
  color:#1b140f;
  padding:14px 22px;
  border-radius:999px;
  font-weight:700;
  font-family:Montserrat, sans-serif;
  border:0;
  cursor:pointer;
  text-decoration:none;
  box-shadow:0 10px 24px rgba(201,166,107,.35);
  transition:transform .15s ease;
}
.cta:hover{ transform:translateY(-1px) }
.cta.secondary{
  background:transparent;
  color:var(--essence-black);
  border:1px solid rgba(0,0,0,.12);
}

/* Imagem lado direito — MAIOR */
.hero-side {
  background:url("../img/oleo-salvia-hero.svg") center/cover no-repeat;
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  min-height:80px; /* aumentada */
  position:relative;
  overflow:hidden;
  border:2px solid rgba(0,0,0,.06);
}
.hero-side-inner{
  position:absolute;
  inset:0;
  display:grid;
  place-items:center;
  padding:24px;
  text-align:center
}
.badge{
  position:absolute;
  right:18px;
  top:18px;
  background:var(--essence-sage);
  color:#0f120e;
  padding:8px 12px;
  border-radius:999px;
  font-weight:700;
  font-family:Montserrat, sans-serif;
  font-size:.85rem
}
.lotus{
  position:absolute;
  inset:auto -10% -8% auto;
  opacity:.07;
  font-family:"Qwitcher Grypen", cursive;
  font-size:9rem;
  color:#000
}

/* Secções */
.section{ padding:48px 0 }
.section-two-cols .two-cols{
  display:grid; grid-template-columns:1fr 1fr; gap:24px;
}

/* Cartões & grelhas */
.grid {
  display: grid;
  gap: 18px;
}

.grid.cols-3 {
  grid-template-columns: repeat(3, 1fr);
  gap: 50px;
}

.card {
  min-height: 280px;               /* altura mínima maior */
  padding: 32px;                   /* mais respiro interno */
  flex: 1;
  border-radius: var(--radius);
  background: var(--essence-surface);
  box-shadow: var(--shadow);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.card:hover {
  transform: translateY(-8px);     /* levanta um pouco */
  box-shadow: 0 16px 32px rgba(0,0,0,0.15); 
}

/* Apenas o título da secção */
#servicos h2 {
  text-align: center;
  font-size: 2.2rem;
  font-family: "Libre Baskerville", Georgia, serif;
  font-weight: 700;
  margin-bottom: 12px;
  color: var(--essence-black);
}

/* Apenas o subtítulo logo abaixo do h2 */
#servicos > .wrap > p {
  text-align: center;
  font-size: 1.05rem;
  color: var(--essence-text);
  margin-bottom: 32px;
}


/* Etiquetas pequenas */
.pill {
  display: inline-block;
  background: var(--essence-surface-2);
  color: var(--essence-black);
  padding: 6px 10px;
  border-radius: 999px;
  font-size: .8rem;
  font-weight: 700;
  font-family: Montserrat, sans-serif;
  border: 2px solid rgba(0,0,0,.06);
}

/* Preços */
.price {
  font-family: Montserrat, sans-serif;
  font-weight: 700;
  margin: 16px 0 20px;
}

.old-price {
  text-decoration: line-through;
  color: var(--essence-text-dim);
  margin-right: 8px;
  font-size: 1rem;
}

.new-price {
  color: var(--essence-gold);      /* destaque premium */
  font-size: 1.3rem;
  font-weight: 700;
}

.recorrencia-box {
  background: var(--essence-surface-2);   /* mesma cor dos outros cards */
  border-radius: var(--radius);
  box-shadow: var(--shadow);            /* mesma profundidade */
  padding: 5px 12px;                   /* baixinho */
  max-width: 700px;                     /* só ocupa o espaço necessário */
  margin: 15px auto 0;                  /* centralizado abaixo dos cards */
  text-align: center;
  font-family: Lato, sans-serif;
  font-size: 1.1rem;
  line-height: 1.5;
  color: var(--essence-text);
  opacity: 0;
  transform: translateY(20px);
  animation: fadeUp 1s ease forwards;
}

.recorrencia-box .recorrencia-head {
  font-size: 1.2rem;
  font-weight: 700;
  margin-bottom: 0px;
  color: var(--essence-black);
}

.recorrencia-box strong {
  color: var(--essence-gold);
  font-weight: 700;
}

/* Animação suave */
@keyframes fadeUp {
  from {
    opacity: 0;
    transform: translateY(20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}


/* Prova social */
.reviews{ display:grid; grid-template-columns:1fr 1fr; gap:18px;}
.review {
  background: var(--essence-surface);
  border-radius: 12px;
  border-left:4px solid var(--essence-sage);
  padding: 18px;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.review:hover {
  transform: translateY(-6px);
  box-shadow: 0 14px 28px rgba(0,0,0,0.12);
}

.review.visible {
  opacity: 1;
  transform: translateY(0);
}

.reviews-note{ margin-top:12px; font-size:.92rem }

/* Terapeuta & mapa */
.split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  align-items: stretch;   /* força as colunas a terem a mesma altura */
}

.avatar {
  width: 100%;
  height: auto;          /* mantém proporção natural */
  max-height: 460px;     /* limita a altura */
  border-radius: var(--radius);
  box-shadow: var(--shadow);
}
.map {
  width: 100%;
  height: 320px;           /* altura fixa mais baixa */
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  object-fit: cover;       /* mantém proporção da imagem */
}


.cta-row {
  display: flex;
  gap: 10px;
  margin-top: 12px;
  flex-wrap: wrap;
  justify-content: center; /* centra os botões */
}

.cta-row .cta.secondary {
  min-width: 220px;     /* aumenta a largura mínima */
  text-align: center;   /* centra o texto dentro */
}

.cta-row .cta:last-child {
  min-width: 500px;
}

/* FAQ */
details{
  background:var(--essence-surface);
  border-radius:12px;
  padding:14px 16px;
  box-shadow:var(--shadow);
  border:1px solid rgba(0,0,0,.06)
}
details+details{ margin-top:10px }
summary{ font-weight:700; cursor:pointer }

/* Look & Feel (chips de cor) */
.lookfeel .swatches{ display:flex; gap:10px; flex-wrap:wrap }
.lookfeel .swatches span{
  width:64px; height:40px; border-radius:8px; border:1px solid rgba(0,0,0,.06);
  background:var(--c);
}

/* Calendário */
.section-agenda .calendar-embed{ padding:0; overflow:hidden }

/* Footer */
footer{ padding:36px 0 64px; color:var(--essence-text-dim) }
.footer-wrap{
  display:flex; justify-content:space-between; align-items:center;
  gap:12px; flex-wrap:wrap
}
.brand{
  font-family:'Libre Baskerville',serif;
  color:var(--essence-black);
  font-size:1.05rem
}
.footer-actions{ display:flex; gap:10px; flex-wrap:wrap }

/* Sticky CTA */
.sticky-cta{
  position:fixed;
  right:16px;
  bottom:16px;
  z-index:40;
  background:var(--essence-surface);
  border:1px solid rgba(0,0,0,.08);
  box-shadow:var(--shadow);
  padding:10px 14px;
  border-radius:999px;
  display:flex;
  align-items:center;
  gap:10px
}
.sticky-label{ font-weight:700 }

/* Responsivo */
@media(max-width:900px){
  .hero-inner{ grid-template-columns:1fr }
  .grid.cols-3{ grid-template-columns:1fr }
  .reviews{ grid-template-columns:1fr }
  .split{ grid-template-columns:1fr }
  .sticky-cta{ right:12px; bottom:12px }
  .hero-side{ min-height:320px } /* imagem menor no mobile */
}
