/* ============================================================
   GINA CABELEIREIROS — style.css · V4 "Marfim & Espresso"
   Editorial de luxo: marfim quente, tinta escura, dourado rico,
   navbar espresso fixa, secções escuras, tipografia em grande.
   ============================================================ */

:root {
  /* Fundos */
  --marfim: #F4EFE4;
  --marfim-claro: #FBF8F0;
  --cartao: #FFFDF7;

  /* Texto */
  --tinta: #211C14;
  --tinta-suave: #5C5446;

  /* Dourado */
  --dourado: #B08A3E;
  --dourado-vivo: #C9A24B;
  --dourado-hover: #97742F;
  --dourado-claro: #E5D9BD;

  /* Escuro dramático */
  --noite: #1F1A13;
  --noite-suave: #2A241B;
  --marfim-sobre-noite: rgba(244, 239, 228, 0.82);

  --borda: #E2D8C2;

  --font-display: 'Cormorant Garamond', Georgia, serif;
  --font-body: 'Jost', 'Segoe UI', sans-serif;

  --radius: 10px;
  --radius-pill: 999px;
  --shadow-soft: 0 10px 40px rgba(33, 28, 20, 0.08);
  --transition: 0.3s ease;
  --ease-luxo: cubic-bezier(0.22, 1, 0.36, 1);
  --container: 1180px;
}

* { margin: 0; padding: 0; box-sizing: border-box; }

::selection { background: var(--dourado); color: var(--marfim-claro); }

html { scroll-behavior: smooth; overflow-x: hidden; }
html.lenis { scroll-behavior: auto; }

body {
  font-family: var(--font-body);
  font-weight: 400;
  color: var(--tinta);
  background: var(--marfim);
  line-height: 1.7;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}

img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
ul { list-style: none; }

.container { max-width: var(--container); margin: 0 auto; padding: 0 28px; }

h1, h2, h3 {
  font-family: var(--font-display);
  font-weight: 600;
  line-height: 1.06;
  color: var(--tinta);
  letter-spacing: -0.015em;
}

h1 { font-size: clamp(3rem, 7.5vw, 5.4rem); }
h2 { font-size: clamp(2.3rem, 4.8vw, 3.5rem); }
h3 { font-size: 1.5rem; }

h1 em, h2 em { font-style: italic; font-weight: 500; color: var(--dourado); }

.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  font-size: 0.76rem;
  font-weight: 500;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--dourado);
  margin-bottom: 18px;
}

.eyebrow::before {
  content: '';
  width: 34px; height: 1px;
  background: var(--dourado);
}

.eyebrow.centro::after {
  content: '';
  width: 34px; height: 1px;
  background: var(--dourado);
}

.linha-dourada { display: none; }

.texto-secundario { color: var(--tinta-suave); }

/* ============================================================
   PRELOADER
   ============================================================ */

.preloader {
  position: fixed;
  inset: 0;
  z-index: 9999;
  background: var(--marfim);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 26px;
  transition: transform 0.9s var(--ease-luxo);
}

.preloader img {
  width: 130px;
  opacity: 0;
  transform: scale(0.88);
  animation: preloaderLogo 1s var(--ease-luxo) forwards;
}

.preloader .preloader-linha {
  width: 0; height: 1px;
  background: var(--dourado);
  animation: preloaderLinha 0.8s var(--ease-luxo) 0.45s forwards;
}

.preloader.sair { transform: translateY(-100%); }
.preloader.removido { display: none; }

@keyframes preloaderLogo { to { opacity: 1; transform: scale(1); } }
@keyframes preloaderLinha { to { width: 130px; } }

/* ============================================================
   BOTÕES
   ============================================================ */

.btn {
  position: relative;
  display: inline-block;
  font-family: var(--font-body);
  font-size: 0.9rem;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 16px 38px;
  border-radius: var(--radius-pill);
  border: 1px solid transparent;
  cursor: pointer;
  text-align: center;
  overflow: hidden;
  transition: color var(--transition), border-color var(--transition), transform var(--transition), box-shadow var(--transition);
  z-index: 1;
}

.btn::before {
  content: '';
  position: absolute;
  inset: 0;
  background: var(--tinta);
  transform: translateY(101%);
  transition: transform 0.45s var(--ease-luxo);
  z-index: -1;
  border-radius: var(--radius-pill);
}

.btn:hover::before { transform: translateY(0); }

.btn-dourado {
  background: var(--dourado);
  color: var(--marfim-claro);
  box-shadow: 0 8px 24px rgba(176, 138, 62, 0.35);
}
.btn-dourado:hover { transform: translateY(-2px); color: var(--marfim-claro); }

.btn-outline { background: transparent; color: var(--tinta); border-color: var(--tinta); }
.btn-outline:hover { color: var(--marfim-claro); }

.escuro .btn-outline { color: var(--marfim-claro); border-color: rgba(244,239,228,0.5); }
.escuro .btn-outline::before { background: var(--marfim-claro); }
.escuro .btn-outline:hover { color: var(--noite); }

/* ============================================================
   TOPBAR + HEADER (escuro, sempre fixo)
   ============================================================ */

.topbar {
  background: var(--noite);
  color: var(--marfim-sobre-noite);
  font-size: 0.74rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  max-height: 40px;
  overflow: hidden;
  border-bottom: 1px solid rgba(244, 239, 228, 0.08);
  transition: max-height 0.4s var(--ease-luxo);
}

.topbar .container {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  padding-top: 10px;
  padding-bottom: 10px;
}

.topbar a, .topbar span em { color: var(--dourado-vivo); font-style: normal; }

.header.scrolled .topbar { max-height: 0; }

.header {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 100;
  background: rgba(31, 26, 19, 0.92);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-bottom: 1px solid rgba(244, 239, 228, 0.08);
  transition: background var(--transition);
}

.header.scrolled { background: rgba(31, 26, 19, 0.98); }

.header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 88px;
}

.logo { display: flex; align-items: center; gap: 13px; }
.logo img { height: 58px; width: auto; }
.logo .logo-texto {
  font-family: var(--font-display);
  font-size: 1.35rem;
  font-weight: 600;
  line-height: 1.05;
  color: var(--marfim-claro);
}
.logo .logo-texto span {
  color: var(--dourado-vivo);
  display: block;
  font-size: 0.68rem;
  font-family: var(--font-body);
  font-weight: 500;
  letter-spacing: 0.26em;
  text-transform: uppercase;
  margin-top: 3px;
}

.nav { display: flex; align-items: center; gap: 34px; }

.nav a {
  font-size: 0.88rem;
  font-weight: 400;
  letter-spacing: 0.05em;
  color: var(--marfim-sobre-noite);
  position: relative;
  transition: color var(--transition);
}

.nav a:not(.btn)::after {
  content: '';
  position: absolute;
  left: 0; bottom: -6px;
  width: 0; height: 1px;
  background: var(--dourado-vivo);
  transition: width 0.35s var(--ease-luxo);
}

.nav a:not(.btn):hover { color: var(--dourado-vivo); }
.nav a:not(.btn):hover::after, .nav a.ativo::after { width: 100%; }
.nav a.ativo { color: var(--marfim-claro); }

.nav .btn { padding: 12px 28px; font-size: 0.78rem; color: var(--marfim-claro); }

.menu-toggle {
  display: none;
  background: none; border: none; cursor: pointer;
  width: 30px; height: 22px; position: relative; z-index: 110;
}
.menu-toggle span {
  display: block; width: 100%; height: 2px;
  background: var(--marfim-claro);
  position: absolute; left: 0;
  transition: var(--transition);
}
.menu-toggle span:nth-child(1) { top: 0; }
.menu-toggle span:nth-child(2) { top: 10px; }
.menu-toggle span:nth-child(3) { top: 20px; }
.menu-toggle.aberto span:nth-child(1) { top: 10px; transform: rotate(45deg); }
.menu-toggle.aberto span:nth-child(2) { opacity: 0; }
.menu-toggle.aberto span:nth-child(3) { top: 10px; transform: rotate(-45deg); }

/* ============================================================
   SECÇÕES + ORNAMENTO + MODO ESCURO
   ============================================================ */

.seccao { padding: 130px 0; position: relative; }
.seccao.suave { background: var(--marfim-claro); }

.seccao.escuro {
  background: var(--noite);
  color: var(--marfim-sobre-noite);
}

.seccao.escuro h1, .seccao.escuro h2, .seccao.escuro h3 { color: var(--marfim-claro); }
.seccao.escuro .texto-secundario,
.seccao.escuro p { color: var(--marfim-sobre-noite); }
.seccao.escuro .eyebrow { color: var(--dourado-vivo); }
.seccao.escuro .eyebrow::before, .seccao.escuro .eyebrow.centro::after { background: var(--dourado-vivo); }

.seccao-cabeca { max-width: 680px; margin-bottom: 70px; }
.seccao-cabeca.centro { margin-left: auto; margin-right: auto; text-align: center; }
.seccao-cabeca.centro .eyebrow { justify-content: center; }
.seccao-cabeca p { color: var(--tinta-suave); margin-top: 18px; font-size: 1.05rem; }
.seccao.escuro .seccao-cabeca p { color: var(--marfim-sobre-noite); }

.ornamento {
  position: absolute;
  width: 580px; height: 580px;
  background: url('../img/logo-dourado.png') center/contain no-repeat;
  opacity: 0.06;
  pointer-events: none;
  z-index: 0;
  will-change: transform;
}

.ornamento.direita { right: -190px; top: 60px; }
.ornamento.esquerda { left: -190px; bottom: 40px; }
.seccao.escuro .ornamento { opacity: 0.07; background-image: url('../img/logo-branco.png'); }

.seccao > .container { position: relative; z-index: 1; }

/* ============================================================
   HERO
   ============================================================ */

.hero {
  min-height: 96vh;
  display: flex;
  align-items: center;
  padding: 190px 0 100px;
  background:
    radial-gradient(1100px 500px at 85% 0%, rgba(201, 162, 75, 0.10), transparent 60%),
    linear-gradient(180deg, var(--marfim) 0%, var(--marfim-claro) 100%);
  position: relative;
  overflow: hidden;
}

.hero-grid {
  display: grid;
  grid-template-columns: 1.08fr 0.92fr;
  gap: 70px;
  align-items: center;
  position: relative;
  z-index: 1;
}

.hero h1 { margin: 8px 0 26px; }

.hero h1 .palavra { display: inline-block; overflow: hidden; vertical-align: bottom; }
.hero h1 .palavra > span {
  display: inline-block;
  transform: translateY(110%);
  transition: transform 0.9s var(--ease-luxo);
}
.hero.entrar h1 .palavra > span { transform: translateY(0); }

.hero .eyebrow, .hero p, .hero-botoes {
  opacity: 0;
  transform: translateY(18px);
  transition: opacity 0.8s var(--ease-luxo), transform 0.8s var(--ease-luxo);
}

.hero .linha-hero { display: none; }

.hero.entrar .eyebrow { opacity: 1; transform: none; transition-delay: 0.1s; }
.hero.entrar p { opacity: 1; transform: none; transition-delay: 0.85s; }
.hero.entrar .hero-botoes { opacity: 1; transform: none; transition-delay: 1.05s; }

.hero p {
  color: var(--tinta-suave);
  font-size: 1.12rem;
  max-width: 480px;
  margin-bottom: 40px;
}

.hero-botoes { display: flex; gap: 16px; flex-wrap: wrap; align-items: center; }

.hero-foto { position: relative; }

.hero-foto::before {
  content: '';
  position: absolute;
  inset: 26px -26px -26px 26px;
  border: 1px solid var(--dourado);
  border-radius: var(--radius);
  z-index: 0;
  opacity: 0;
  transition: opacity 0.8s ease 1.2s;
}

.hero.entrar .hero-foto::before { opacity: 0.55; }

.hero-foto .mascara {
  position: relative;
  z-index: 1;
  overflow: hidden;
  border-radius: 6px;
  box-shadow: var(--shadow-soft);
  clip-path: inset(0 0 100% 0);
  transition: clip-path 1.1s var(--ease-luxo) 0.35s;
}

.hero.entrar .hero-foto .mascara { clip-path: inset(0 0 0% 0); }

.hero-foto .mascara > * {
  transform: scale(1.12);
  transition: transform 1.6s var(--ease-luxo) 0.35s;
}

.hero.entrar .hero-foto .mascara > * { transform: scale(1); }

.hero-foto img { aspect-ratio: 4 / 5; width: 100%; object-fit: cover; }

/* ============================================================
   PLACEHOLDERS
   ============================================================ */

.foto-placeholder {
  background: linear-gradient(150deg, #EAE0CC 0%, #DCCCA9 55%, #C9B384 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgba(33, 28, 20, 0.4);
  font-family: var(--font-display);
  font-size: 1.4rem;
  font-style: italic;
  overflow: hidden;
}

.foto-placeholder svg { opacity: 0.4; }
.hero-foto .foto-placeholder { aspect-ratio: 4 / 5; }

/* ============================================================
   MARQUEE — faixa escura refinada
   ============================================================ */

.marquee {
  overflow: hidden;
  padding: 22px 0;
  background: var(--noite);
}

.marquee-faixa { display: flex; width: max-content; animation: marquee 36s linear infinite; }
.marquee:hover .marquee-faixa { animation-play-state: paused; }

.marquee-faixa span {
  font-family: var(--font-body);
  font-size: 0.82rem;
  font-weight: 500;
  letter-spacing: 0.4em;
  text-transform: uppercase;
  color: var(--dourado-vivo);
  white-space: nowrap;
}

.marquee-faixa span::after {
  content: '✦';
  margin: 0 38px;
  opacity: 0.45;
}

@keyframes marquee { to { transform: translateX(-50%); } }

/* ============================================================
   BANDA FRASE
   ============================================================ */

.banda-frase {
  padding: 100px 0;
  background: var(--marfim-claro);
  border-top: 1px solid var(--borda);
  border-bottom: 1px solid var(--borda);
  text-align: center;
}

.banda-frase p {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 500;
  font-size: clamp(1.5rem, 3vw, 2.3rem);
  line-height: 1.4;
  color: var(--tinta);
  max-width: 840px;
  margin: 0 auto;
}

.banda-frase p em { color: var(--dourado); }

.banda-frase span {
  display: inline-block;
  margin-top: 22px;
  font-size: 0.76rem;
  font-weight: 500;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--dourado);
}

/* ============================================================
   REVELAÇÕES
   ============================================================ */

.animar {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 0.55s var(--ease-luxo), transform 0.55s var(--ease-luxo);
  transition-delay: var(--atraso, 0s);
}

.animar.visivel { opacity: 1; transform: translateY(0); }

.revelar-foto {
  clip-path: inset(100% 0 0 0);
  transition: clip-path 1s var(--ease-luxo);
  transition-delay: var(--atraso, 0s);
}

.revelar-foto.visivel { clip-path: inset(0 0 0 0); }

/* ============================================================
   SOBRE
   ============================================================ */

.sobre-grid {
  display: grid;
  grid-template-columns: 0.9fr 1.1fr;
  gap: 80px;
  align-items: center;
}

.sobre-foto {
  position: relative;
  width: 90%; /* 10% mais pequeno que a Hero */
}

.sobre-foto::before {
  content: '';
  position: absolute;
  inset: 26px -26px -26px 26px;
  border: 1px solid var(--dourado);
  border-radius: var(--radius);
  z-index: 0;
  opacity: 0.55;
}

.sobre-foto .foto-placeholder,
.sobre-foto img {
  position: relative;
  z-index: 1;
  overflow: hidden;
  border-radius: 6px;
  box-shadow: var(--shadow-soft);

  aspect-ratio: 4 / 5;
  width: 100%;
  object-fit: cover;
}

.sobre-texto p {
  color: var(--tinta-suave);
  margin-bottom: 18px;
  font-size: 1.02rem;
}

.destaques {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-top: 42px;
  padding-top: 36px;
  border-top: 1px solid var(--borda);
}

.destaque .icone {
  width: 46px;
  height: 46px;
  border: 1px solid var(--dourado);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--dourado);
  margin-bottom: 14px;
  transition: var(--transition);
}

.destaque:hover .icone {
  background: var(--dourado);
  color: var(--marfim-claro);
  transform: translateY(-3px);
}

.destaque h3 {
  font-family: var(--font-body);
  font-size: 0.98rem;
  font-weight: 500;
}

.destaque p {
  font-size: 0.88rem;
  color: var(--tinta-suave);
  margin: 4px 0 0;
}

/* ============================================================
   NÚMEROS
   ============================================================ */

.numeros {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 30px;
  text-align: center;
}

.numero-bloco { position: relative; padding: 10px 0; }

.numero-bloco + .numero-bloco::before {
  content: '';
  position: absolute;
  left: 0; top: 15%;
  height: 70%; width: 1px;
  background: var(--borda);
}

.numero-bloco .valor {
  font-family: var(--font-display);
  font-size: clamp(3rem, 6vw, 4.6rem);
  font-weight: 600;
  color: var(--tinta);
  line-height: 1;
}

.numero-bloco .valor em { font-style: italic; color: var(--dourado); font-weight: 500; }

.numero-bloco .rotulo {
  font-size: 0.78rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--tinta-suave);
  margin-top: 14px;
}

/* ============================================================
   SERVIÇOS — tabs, cartões de destaque e lista de preços
   ============================================================ */

.tabs-categorias {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: center;
  margin-bottom: 58px;
}

.tab {
  font-family: var(--font-body);
  font-size: 0.82rem;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 12px 28px;
  border-radius: var(--radius-pill);
  border: 1px solid var(--borda);
  background: transparent;
  color: var(--tinta-suave);
  cursor: pointer;
  transition: var(--transition);
}

.tab:hover { border-color: var(--dourado); color: var(--tinta); }

.tab.ativo {
  background: var(--tinta);
  border-color: var(--tinta);
  color: var(--marfim-claro);
}

/* Cartões: usados nos DESTAQUES da página inicial */
.grelha-servicos {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 26px;
}

.cartao-servico {
  background: var(--cartao);
  border: 1px solid var(--borda);
  border-radius: var(--radius);
  padding: 38px 32px;
  position: relative;
  overflow: hidden;
  transition: box-shadow var(--transition), transform var(--transition);
  display: flex;
  flex-direction: column;
}

.cartao-servico::before {
  content: '';
  position: absolute;
  top: 0; left: 0;
  width: 100%; height: 2px;
  background: var(--dourado);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.45s var(--ease-luxo);
}

.cartao-servico:hover { box-shadow: var(--shadow-soft); transform: translateY(-5px); }
.cartao-servico:hover::before { transform: scaleX(1); }

.cartao-servico .categoria-tag {
  font-size: 0.66rem;
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--dourado);
  margin-bottom: 12px;
}

.cartao-servico h3 { font-size: 1.4rem; margin-bottom: 10px; }
.cartao-servico p { font-size: 0.92rem; color: var(--tinta-suave); flex: 1; margin-bottom: 22px; }

.cartao-servico .preco {
  font-family: var(--font-display);
  font-size: 1.5rem;
  font-weight: 600;
  color: var(--dourado);
}

.cartao-servico .rodape-cartao {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 12px;
}

.link-dourado {
  font-size: 0.82rem;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--dourado-hover);
  transition: letter-spacing var(--transition);
  white-space: nowrap;
}

.link-dourado:hover { letter-spacing: 0.14em; }

/* Lista de preços: usada na PÁGINA DE SERVIÇOS completa */
.lista-precos {
  max-width: 1000px;
  margin: 0 auto;
  columns: 2;
  column-gap: 80px;
}

.linha-preco {
  display: flex;
  align-items: baseline;
  gap: 14px;
  padding: 15px 6px;
  border-bottom: 1px solid var(--borda);
  break-inside: avoid;
  transition: background var(--transition);
}

.linha-preco:hover { background: var(--marfim-claro); }

.linha-preco .nome { font-size: 0.98rem; color: var(--tinta); }

.linha-preco .pontos {
  flex: 1;
  border-bottom: 1px dotted var(--dourado-claro);
  transform: translateY(-4px);
  min-width: 24px;
}

.linha-preco .preco {
  font-family: var(--font-display);
  font-size: 1.15rem;
  font-weight: 600;
  color: var(--dourado);
  white-space: nowrap;
}

/* Grupos por categoria na página de serviços */
.grupo-servicos { margin-bottom: 80px; }
.grupo-servicos:last-child { margin-bottom: 0; }

.grupo-servicos .titulo-grupo {
  font-size: clamp(1.7rem, 3vw, 2.3rem);
  text-align: center;
  margin-bottom: 8px;
}

.grupo-servicos .titulo-grupo em { font-style: italic; color: var(--dourado); }

.grupo-servicos .sub-grupo {
  text-align: center;
  font-size: 0.78rem;
  font-weight: 500;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--dourado);
  margin-bottom: 40px;
}

/* ============================================================
   PRODUTOS
   ============================================================ */

.grelha-produtos {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 26px;
}

.cartao-produto {
  background: var(--cartao);
  border: 1px solid var(--borda);
  border-radius: var(--radius);
  overflow: hidden;
  transition: box-shadow var(--transition), transform var(--transition);
  display: flex;
  flex-direction: column;
}

.cartao-produto:hover { box-shadow: var(--shadow-soft); transform: translateY(-5px); }

.cartao-produto .foto-wrap { overflow: hidden; }
.cartao-produto .foto-placeholder, .cartao-produto .foto-wrap img {
  aspect-ratio: 1 / 1;
  width: 100%;
  object-fit: cover;
  transition: transform 4s ease;
}

.cartao-produto:hover .foto-placeholder,
.cartao-produto:hover .foto-wrap img { transform: scale(1.07); }

.cartao-produto .corpo { padding: 24px; display: flex; flex-direction: column; flex: 1; }

.badge {
  align-self: flex-start;
  background: transparent;
  border: 1px solid var(--dourado);
  color: var(--dourado-hover);
  font-size: 0.64rem;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  padding: 4px 12px;
  border-radius: var(--radius-pill);
  margin-bottom: 14px;
}

.cartao-produto h3 { font-size: 1.2rem; margin-bottom: 6px; }
.cartao-produto .descricao { font-size: 0.86rem; color: var(--tinta-suave); flex: 1; margin-bottom: 16px; }
.cartao-produto .preco { font-family: var(--font-display); font-size: 1.4rem; font-weight: 600; color: var(--dourado); margin-bottom: 16px; }
.cartao-produto .btn { width: 100%; padding: 13px; font-size: 0.74rem; }

.centro-botao { text-align: center; margin-top: 58px; }

.filtros {
  display: flex; flex-wrap: wrap; gap: 10px;
  justify-content: center;
  margin-bottom: 54px;
}

/* ============================================================
   GALERIA editorial + molduras para fotos futuras
   ============================================================ */

/* ---------- GALERIA: mosaico ajustado às imagens (masonry) ---------- */

.galeria-mosaico {
  columns: 4 240px;
  column-gap: 16px;
}

.galeria-item {
  display: block;
  width: 100%;
  margin: 0 0 16px;
  padding: 0;
  border: none;
  border-radius: 8px;
  overflow: hidden;
  cursor: pointer;
  background: var(--cartao);
  break-inside: avoid;
  position: relative;
  box-shadow: 0 2px 10px rgba(33, 28, 20, 0.06);
  transition: transform 0.4s var(--ease-luxo), box-shadow 0.4s ease;
}

.galeria-item img {
  width: 100%;
  height: auto;        /* ajusta à imagem, não corta */
  display: block;
  transition: transform 0.6s ease;
}

.galeria-item:hover { transform: translateY(-4px); box-shadow: 0 10px 28px rgba(33, 28, 20, 0.14); }
.galeria-item:hover img { transform: scale(1.04); }
.galeria-item:focus-visible { outline: 2px solid var(--dourado); outline-offset: 3px; }

.galeria-acao { text-align: center; margin-top: 36px; }
.galeria-vazia { text-align: center; color: var(--tinta-suave); padding: 40px 0; font-style: italic; }

/* Lightbox (visualizador em grande) */
.lightbox {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 1000;
  background: rgba(20, 17, 12, 0.92);
  align-items: center;
  justify-content: center;
  padding: 30px;
}
.lightbox.aberto { display: flex; }

.lightbox-img {
  max-width: 90vw;
  max-height: 86vh;
  object-fit: contain;
  border-radius: 6px;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.5);
  animation: lightboxEntrar 0.3s var(--ease-luxo);
}
@keyframes lightboxEntrar { from { opacity: 0; transform: scale(0.96); } to { opacity: 1; transform: scale(1); } }

.lightbox-legenda {
  position: absolute;
  bottom: 22px;
  left: 0; right: 0;
  text-align: center;
  color: var(--marfim-claro);
  font-family: var(--font-display);
  font-size: 1.1rem;
  letter-spacing: 0.02em;
}

.lightbox button {
  position: absolute;
  background: rgba(244, 239, 228, 0.12);
  border: none;
  color: var(--marfim-claro);
  cursor: pointer;
  border-radius: 50%;
  transition: background 0.25s ease;
  display: flex;
  align-items: center;
  justify-content: center;
}
.lightbox button:hover { background: rgba(244, 239, 228, 0.25); }

.lightbox-fechar {
  top: 22px; right: 22px;
  width: 48px; height: 48px;
  font-size: 1.8rem;
}
.lightbox-anterior, .lightbox-seguinte {
  top: 50%;
  transform: translateY(-50%);
  width: 52px; height: 52px;
  font-size: 2rem;
}
.lightbox-anterior { left: 22px; }
.lightbox-seguinte { right: 22px; }

@media (max-width: 980px) {
  .galeria-mosaico { columns: 2 160px; column-gap: 12px; }
  .galeria-item { margin-bottom: 12px; }
  .lightbox-anterior, .lightbox-seguinte { width: 42px; height: 42px; font-size: 1.5rem; }
  .lightbox-anterior { left: 8px; }
  .lightbox-seguinte { right: 8px; }
  .lightbox-fechar { top: 12px; right: 12px; }
}

/* ============================================================
   TESTEMUNHOS (secção escura)
   ============================================================ */

.carrossel { position: relative; max-width: 800px; margin: 0 auto; text-align: center; }
.carrossel-janela { overflow: hidden; }
.carrossel-faixa { display: flex; transition: transform 0.6s var(--ease-luxo); }

.testemunho { min-width: 100%; padding: 10px 40px; position: relative; }

.carrossel::before {
  content: '“';
  position: absolute;
  top: -70px; left: 50%;
  transform: translateX(-50%);
  font-family: var(--font-display);
  font-size: 9rem;
  line-height: 1;
  color: var(--dourado-vivo);
  opacity: 0.35;
  pointer-events: none;
}

.estrelas { color: var(--dourado-vivo); font-size: 1.05rem; letter-spacing: 5px; margin-bottom: 24px; }

.testemunho blockquote {
  font-family: var(--font-display);
  font-size: clamp(1.4rem, 2.8vw, 1.9rem);
  font-style: italic;
  font-weight: 500;
  line-height: 1.45;
  color: var(--marfim-claro);
  margin-bottom: 26px;
}

.testemunho cite {
  font-style: normal;
  font-size: 0.82rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--dourado-vivo);
}

.carrossel-setas { display: flex; justify-content: center; gap: 14px; margin-top: 38px; }

.seta {
  width: 48px; height: 48px;
  border-radius: 50%;
  border: 1px solid rgba(244, 239, 228, 0.3);
  background: transparent;
  color: var(--marfim-claro);
  cursor: pointer;
  font-size: 1rem;
  transition: var(--transition);
  display: flex; align-items: center; justify-content: center;
}

.seta:hover { border-color: var(--dourado-vivo); color: var(--dourado-vivo); }

/* ============================================================
   FAQ
   ============================================================ */

.faq-lista { max-width: 780px; margin: 0 auto; }
.faq-item { border-bottom: 1px solid var(--borda); }

.faq-pergunta {
  width: 100%;
  background: none; border: none;
  font-family: var(--font-display);
  font-size: 1.25rem;
  font-weight: 500;
  color: var(--tinta);
  text-align: left;
  padding: 26px 46px 26px 0;
  cursor: pointer;
  position: relative;
  transition: color var(--transition);
}

.faq-pergunta:hover { color: var(--dourado-hover); }

.faq-pergunta::after {
  content: '+';
  position: absolute;
  right: 4px; top: 50%;
  transform: translateY(-50%);
  font-size: 1.7rem;
  color: var(--dourado);
  transition: transform var(--transition);
}

.faq-pergunta[aria-expanded="true"]::after { transform: translateY(-50%) rotate(45deg); }

.faq-resposta { max-height: 0; overflow: hidden; transition: max-height 0.4s var(--ease-luxo); }
.faq-resposta p { color: var(--tinta-suave); font-size: 0.96rem; padding: 0 0 26px; max-width: 660px; }

/* ============================================================
   CONTACTOS
   ============================================================ */

.contactos-grid {
  display: grid;
  grid-template-columns: 1fr 1.15fr;
  gap: 64px;
  align-items: stretch;
}

.info-contacto { margin-bottom: 30px; }

.info-contacto h3 {
  font-family: var(--font-body);
  font-size: 0.74rem;
  font-weight: 500;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--dourado);
  margin-bottom: 8px;
}

.info-contacto p, .info-contacto a { font-size: 1.05rem; color: var(--tinta); }
.info-contacto a:hover { color: var(--dourado-hover); }
.info-contacto .nota { font-size: 0.86rem; color: var(--tinta-suave); }
.info-contacto .nota a { font-size: 0.86rem; color: var(--tinta-suave); text-decoration: underline; text-underline-offset: 3px; }

.tabela-horario { width: 100%; border-collapse: collapse; font-size: 0.95rem; }
.tabela-horario td { padding: 10px 0; border-bottom: 1px solid var(--borda); color: var(--tinta-suave); }
.tabela-horario td:last-child { text-align: right; color: var(--tinta); font-weight: 500; }
.tabela-horario .fechado td:last-child { color: var(--tinta-suave); font-style: italic; font-weight: 400; }

.mapa {
  border-radius: var(--radius);
  overflow: hidden;
  border: 1px solid var(--borda);
  box-shadow: var(--shadow-soft);
  min-height: 440px;
  height: 100%;
  position: relative;
  background: var(--cartao);
}

.mapa iframe {
  width: 100%; height: 100%;
  min-height: 440px;
  border: 0;
  display: block;
  filter: saturate(0.85) contrast(1.02);
}

.mapa .mapa-link {
  position: absolute;
  bottom: 14px; left: 14px;
  background: var(--noite);
  color: var(--marfim-claro);
  font-size: 0.78rem;
  letter-spacing: 0.08em;
  padding: 10px 20px;
  border-radius: var(--radius-pill);
  box-shadow: 0 6px 20px rgba(33,28,20,0.3);
  transition: var(--transition);
}

.mapa .mapa-link:hover { background: var(--dourado-hover); }

.redes { display: flex; gap: 12px; margin-top: 8px; }

.redes a {
  width: 44px; height: 44px;
  border: 1px solid var(--borda);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  color: var(--tinta);
  transition: var(--transition);
}

.redes a:hover { background: var(--dourado); border-color: var(--dourado); color: var(--marfim-claro); transform: translateY(-3px); }

/* ============================================================
   CTA FINAL (escuro)
   ============================================================ */

.cta-final { text-align: center; overflow: hidden; }
.cta-final h2 { max-width: 680px; margin: 0 auto 20px; font-size: clamp(2.4rem, 5.2vw, 3.8rem); }
.cta-final p { margin-bottom: 38px; font-size: 1.05rem; }

/* ============================================================
   FOOTER
   ============================================================ */

.footer {
  background: var(--noite);
  color: var(--marfim-sobre-noite);
  padding: 90px 0 0;
  font-size: 0.92rem;
  position: relative;
  overflow: hidden;
  border-top: 1px solid var(--noite-suave);
}

.footer .ornamento { opacity: 0.06; right: -200px; bottom: -160px; background-image: url('../img/logo-branco.png'); }

.footer-grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 1fr;
  gap: 46px;
  padding-bottom: 58px;
  position: relative;
  z-index: 1;
}

.footer .logo img { height: 88px; }

.footer h3 {
  font-family: var(--font-body);
  font-size: 0.74rem;
  font-weight: 500;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--dourado-vivo);
  margin-bottom: 20px;
}

.footer li { margin-bottom: 11px; }
.footer a { transition: color var(--transition); }
.footer a:hover { color: var(--dourado-vivo); }

.footer-base {
  border-top: 1px solid rgba(244, 239, 228, 0.1);
  padding: 24px 0;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 10px;
  font-size: 0.78rem;
  color: rgba(244, 239, 228, 0.4);
  position: relative;
  z-index: 1;
}

/* ============================================================
   WHATSAPP flutuante
   ============================================================ */

.whatsapp-flutuante {
  position: fixed;
  bottom: 28px; right: 28px;
  z-index: 90;
  width: 60px; height: 60px;
  border-radius: 50%;
  background: var(--dourado);
  color: var(--marfim-claro);
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 10px 28px rgba(176, 138, 62, 0.45);
  transition: var(--transition);
}

.whatsapp-flutuante::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: 50%;
  border: 1px solid var(--dourado);
  animation: pulso 3s ease-out infinite;
}

@keyframes pulso {
  0% { transform: scale(1); opacity: 0.9; }
  70%, 100% { transform: scale(1.7); opacity: 0; }
}

.whatsapp-flutuante:hover { background: var(--dourado-hover); transform: scale(1.08); }

/* ============================================================
   PÁGINAS INTERNAS + RESERVAS
   ============================================================ */

.pagina-topo {
  padding: 210px 0 90px;
  background:
    radial-gradient(900px 400px at 80% 0%, rgba(201, 162, 75, 0.10), transparent 60%),
    var(--marfim-claro);
  text-align: center;
  position: relative;
  overflow: hidden;
}

.pagina-topo .eyebrow { justify-content: center; }
.pagina-topo .eyebrow::after { content: ''; width: 34px; height: 1px; background: var(--dourado); }
.pagina-topo p { color: var(--tinta-suave); max-width: 580px; margin: 16px auto 0; font-size: 1.05rem; }

.reservas-grid {
  display: grid;
  grid-template-columns: 0.85fr 1.15fr;
  gap: 74px;
  align-items: start;
}

.passos { margin-top: 38px; }
.passo { display: flex; gap: 20px; margin-bottom: 30px; }

.passo .numero {
  font-family: var(--font-display);
  font-size: 2.2rem;
  font-weight: 600;
  font-style: italic;
  color: var(--dourado);
  line-height: 1;
  min-width: 42px;
}

.passo h3 { font-family: var(--font-body); font-size: 1.02rem; font-weight: 500; margin-bottom: 4px; }
.passo p { font-size: 0.92rem; color: var(--tinta-suave); }

.cartao-form {
  background: var(--cartao);
  border: 1px solid var(--borda);
  border-radius: var(--radius);
  padding: 48px;
  box-shadow: var(--shadow-soft);
}

.campo { margin-bottom: 22px; }

.campo label {
  display: block;
  font-size: 0.8rem;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin-bottom: 9px;
}

.campo label .obrigatorio { color: var(--dourado-hover); }

.campo input, .campo select, .campo textarea {
  width: 100%;
  box-sizing: border-box;
  max-width: 100%;
  font-family: var(--font-body);
  font-size: 0.96rem;
  color: var(--tinta);
  padding: 14px 18px;
  border: 1px solid var(--borda);
  border-radius: var(--radius);
  background: var(--marfim-claro);
  transition: border-color var(--transition), box-shadow var(--transition), background var(--transition);
}

/* Campo de data: evita que o ícone de calendário do browser empurre o layout */
.campo input[type="date"] {
  -webkit-appearance: none;
  appearance: none;
  min-width: 0;
}
.campo input[type="date"]::-webkit-calendar-picker-indicator {
  cursor: pointer;
  opacity: 0.6;
  margin-left: auto;
}
.campo input[type="date"]::-webkit-inner-spin-button { display: none; }

.campo input:focus, .campo select:focus, .campo textarea:focus {
  outline: none;
  border-color: var(--dourado);
  background: var(--cartao);
  box-shadow: 0 0 0 3px rgba(176, 138, 62, 0.14);
}

.campo textarea { resize: vertical; min-height: 100px; }

.campo .erro-msg { display: none; font-size: 0.8rem; color: #A6543A; margin-top: 6px; text-transform: none; letter-spacing: 0; }
.campo.invalido input, .campo.invalido select { border-color: #C97B5E; }
.campo.invalido .erro-msg { display: block; }
.campo.invalido .botao-expandir { border-color: #C97B5E; }

/* ---------- Serviços: resumo + botão + painel colapsável ---------- */

.ajuda-campo {
  font-size: 0.82rem;
  color: var(--tinta-suave);
  margin: -4px 0 10px;
  text-transform: none;
  letter-spacing: 0;
}

.pessoa-seccao { margin-bottom: 22px; }
.pessoa-seccao + .pessoa-seccao { padding-top: 20px; border-top: 1px solid var(--borda); }

.pessoa-titulo {
  font-family: var(--font-display);
  font-size: 1.15rem;
  color: var(--tinta);
  margin-bottom: 12px;
}

/* Resumo: chips dos serviços escolhidos */
.servicos-resumo {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 12px;
}

.resumo-vazio {
  font-size: 0.85rem;
  color: var(--tinta-suave);
  font-style: italic;
}

.chip-servico {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(176, 138, 62, 0.12);
  border: 1px solid var(--dourado-claro);
  color: var(--tinta);
  font-size: 0.86rem;
  padding: 7px 8px 7px 14px;
  border-radius: var(--radius-pill);
}

.chip-remover {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  border: none;
  background: rgba(151, 116, 47, 0.18);
  color: var(--dourado-hover);
  font-size: 1.05rem;
  line-height: 1;
  cursor: pointer;
  transition: background var(--transition), color var(--transition);
  padding: 0;
}
.chip-remover:hover { background: var(--dourado-hover); color: var(--marfim-claro); }

/* Botão de expandir/recolher */
.botao-expandir {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: var(--cartao);
  border: 1px solid var(--borda);
  border-radius: var(--radius);
  padding: 14px 18px;
  font-family: var(--font-body);
  font-size: 0.92rem;
  color: var(--tinta);
  cursor: pointer;
  transition: border-color var(--transition), background var(--transition);
}
.botao-expandir:hover { border-color: var(--dourado); }
.botao-expandir .botao-seta { color: var(--dourado-hover); transition: transform 0.3s ease; }
.botao-expandir.aberto .botao-seta { transform: rotate(180deg); }
.botao-expandir.aberto { border-color: var(--dourado); border-bottom-left-radius: 0; border-bottom-right-radius: 0; }

/* Painel da lista (recolhido por defeito) */
.servicos-painel {
  display: none;
  border: 1px solid var(--dourado);
  border-top: none;
  border-radius: 0 0 var(--radius) var(--radius);
  background: var(--cartao);
  max-height: 320px;
  overflow-y: auto;
  padding: 8px;
}
.pessoa-seccao.expandido .servicos-painel { display: block; }

.servico-grupo + .servico-grupo { margin-top: 6px; }

.servico-grupo-titulo {
  font-family: var(--font-body);
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--dourado-hover);
  padding: 10px 12px 6px;
}

.servico-opcao {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 11px 12px;
  border-radius: var(--radius);
  cursor: pointer;
  transition: background var(--transition);
  margin: 0;
  text-transform: none;
  letter-spacing: 0;
}

.servico-opcao:hover { background: var(--marfim-claro); }
.servico-opcao input { width: 18px; height: 18px; accent-color: var(--dourado); cursor: pointer; flex-shrink: 0; margin: 0; }
.servico-opcao-nome { flex: 1; font-size: 0.92rem; color: var(--tinta); }
.servico-opcao:has(input:checked) { background: rgba(176, 138, 62, 0.10); }
.servico-opcao:has(input:checked) .servico-opcao-nome { color: var(--dourado-hover); font-weight: 500; }

.linha-dupla { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }

.form-nota { font-size: 0.82rem; color: var(--tinta-suave); text-align: center; margin-top: 20px; }

.form-sucesso { display: none; text-align: center; padding: 34px 10px; }
.form-sucesso.visivel { display: block; }

.form-sucesso .icone-sucesso {
  width: 68px; height: 68px;
  border-radius: 50%;
  border: 1px solid var(--dourado);
  color: var(--dourado);
  display: flex; align-items: center; justify-content: center;
  margin: 0 auto 22px;
  font-size: 1.7rem;
}

/* ============================================================
   ACESSIBILIDADE + MOVIMENTO REDUZIDO
   ============================================================ */

:focus-visible { outline: 2px solid var(--dourado); outline-offset: 3px; }

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  .animar, .revelar-foto { opacity: 1; transform: none; clip-path: none; transition: none; }
  .hero .eyebrow, .hero p, .hero-botoes { opacity: 1; transform: none; transition: none; }
  .hero h1 .palavra > span { transform: none; transition: none; }
  .hero-foto .mascara { clip-path: none; transition: none; }
  .hero-foto .mascara > * { transform: none; transition: none; }
  .hero-foto::before { opacity: 0.55; transition: none; }
  .marquee-faixa { animation: none; }
  .whatsapp-flutuante::before { animation: none; }
  .preloader { display: none; }
  .carrossel-faixa { transition: none; }
  [data-parallax] { transform: none !important; }
}

/* ============================================================
   RESPONSIVO
   ============================================================ */

@media (max-width: 1024px) {
  .grelha-servicos { grid-template-columns: repeat(2, 1fr); }
  .grelha-produtos { grid-template-columns: repeat(2, 1fr); }
  .grelha-galeria { grid-template-columns: repeat(3, 1fr); }
  .grelha-galeria .item:nth-child(6) { grid-column: span 1; }
  .footer-grid { grid-template-columns: 1fr 1fr; }
  .ornamento { width: 420px; height: 420px; }
  .lista-precos { column-gap: 50px; }
  .nav { gap: 22px; }
  .nav a { font-size: 0.82rem; }
}

@media (max-width: 980px) {
  .seccao { padding: 90px 0; }
  .hero { padding-top: 150px; min-height: auto; }
  .topbar { display: none; }

  .hero-grid, .sobre-grid, .contactos-grid, .reservas-grid {
    grid-template-columns: 1fr;
    gap: 50px;
  }

  /* Centrar o conteúdo em mobile */
  .hero-grid { text-align: center; }
  .hero .eyebrow { justify-content: center; }
  .hero-botoes { justify-content: center; flex-wrap: wrap; }
  .hero-foto { margin: 0 auto; }
  .sobre-foto { margin: 0 auto; }

  .hero-foto { max-width: 460px; }
  .hero-foto::before { inset: 16px -14px -14px 16px; }
  .destaques { grid-template-columns: 1fr; gap: 26px; }
  .numeros { grid-template-columns: 1fr; gap: 44px; }
  .numero-bloco + .numero-bloco::before { display: none; }

  .lista-precos { columns: 1; }

  /* Em mobile, o header não pode ter backdrop-filter: ele criaria um
     containing block que limitaria a altura do menu fixo. */
  .header {
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
    background: rgba(31, 26, 19, 0.97);
  }

  /* MENU MOBILE: painel deslizante (alinhado ao topo, com scroll) */
  .nav {
    position: fixed;
    top: 0; right: 0;
    height: 100vh;
    height: 100dvh;
    width: min(82vw, 360px);
    z-index: 102;
    background: var(--noite);
    flex-direction: column;
    justify-content: flex-start;
    align-items: center;
    gap: 22px;
    padding: 110px 30px 50px;
    transform: translateX(100%);
    transition: transform 0.4s var(--ease-luxo);
    box-shadow: -12px 0 30px rgba(0, 0, 0, 0.15);
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
  }

  .nav.aberto { transform: translateX(0); }

  /* véu escuro sobre o resto da página quando o menu está aberto */
  .nav::before {
    content: '';
    position: fixed;
    inset: 0;
    background: rgba(31, 26, 19, 0.3);
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.4s ease;
    z-index: -1;
  }
  .nav.aberto::before { opacity: 1; }

  .nav a {
    font-family: var(--font-display);
    font-size: 1.5rem;
    color: var(--marfim-claro);
    flex-shrink: 0;
  }

  .nav a::after { display: none; }
  .nav a.ativo { color: var(--dourado-vivo); }
  .nav .btn { font-family: var(--font-body); font-size: 0.82rem; margin-top: 10px; padding: 14px 32px; flex-shrink: 0; }

  .menu-toggle { display: block; z-index: 110; }
  .menu-toggle.aberto span { background: var(--marfim-claro); }

  .ornamento { display: none; }
  .carrossel::before { top: -50px; font-size: 6rem; }
}

@media (max-width: 560px) {
  .grelha-servicos, .grelha-produtos { grid-template-columns: 1fr; }
  .grelha-galeria { grid-template-columns: repeat(2, 1fr); grid-auto-rows: 160px; }
  .grelha-galeria .item:nth-child(6) { grid-column: span 2; }
  .footer-grid { grid-template-columns: 1fr; gap: 36px; }
  .linha-dupla { grid-template-columns: 1fr; }
  .cartao-form { padding: 32px 22px; }
  .testemunho { padding: 10px 6px; }
  .pagina-topo { padding: 150px 0 64px; }
  .logo img { height: 46px; }
  .logo .logo-texto { font-size: 1.12rem; }
}
/* Validação por pessoa nas reservas */
.erro-pessoa {
  display: none;
  font-size: 0.82rem;
  color: #A6543A;
  margin-top: 8px;
  text-transform: none;
  letter-spacing: 0;
}
.pessoa-seccao.pessoa-invalida .erro-pessoa { display: block; }
.pessoa-seccao.pessoa-invalida .botao-expandir { border-color: #C97B5E; }

/* "a partir de" antes do preço dos serviços (preços variáveis) */
.preco-prefixo {
  display: inline;
  font-family: var(--font-body);
  font-size: 0.6em;
  font-weight: 400;
  color: var(--tinta-suave);
  letter-spacing: 0.02em;
  text-transform: none;
  margin-right: 2px;
}
