/* Gerado a partir de salao.config.ts — cores injetadas no build */
:root {
  --fundo: #f7f6f3;
  --fundo-alt: #E3E1DC;
  --texto: #35322c;
  --texto-suave: #6e6a61;
  --destaque: #BA9438;
  --destaque-escuro: #8c6e2a;
  --claro: #ffffff;
  --verde: #5A826B;
  --rosa: #E99D93;
  --pessego: #FFE2D9;
  --rosa-pastel: #FCBCB5;
  --sombra: 0 10px 30px rgba(53, 50, 44, .07);
  --sombra-forte: 0 16px 40px rgba(53, 50, 44, .13);
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }

body {
  font-family: "Inter", system-ui, sans-serif;
  background: var(--fundo);
  color: var(--texto);
  line-height: 1.7;
}

h1, h2, h3 { font-family: "Fraunces", Georgia, serif; line-height: 1.15; font-weight: 600; letter-spacing: -.01em; }
h1 { font-size: clamp(2.1rem, 5vw, 3.4rem); }
h1 em { font-style: italic; color: var(--destaque-escuro); }
h2 { font-size: clamp(1.6rem, 3.2vw, 2.3rem); margin-bottom: .6rem; }
h3 { font-size: 1.18rem; margin-bottom: .4rem; }
a { color: var(--destaque-escuro); }

.container { max-width: 1080px; margin: 0 auto; padding: 0 1.4rem; }
.container-estreito { max-width: 780px; }

.kicker {
  text-transform: uppercase; letter-spacing: .18em; font-size: .74rem;
  font-weight: 600; color: var(--rosa); margin-bottom: .6rem;
}

/* Topo */
.topo { background: rgba(255,255,255,.92); backdrop-filter: blur(8px); border-bottom: 1px solid var(--fundo-alt); position: sticky; top: 0; z-index: 10; }
.topo-inner { display: flex; align-items: center; gap: 1.6rem; padding: .85rem 1.4rem; }
.logo { font-family: "Fraunces", serif; font-size: 1.3rem; font-weight: 600; color: var(--texto); text-decoration: none; letter-spacing: .01em; }
.topo nav { display: flex; gap: 1.3rem; margin-left: auto; }
.topo nav a { color: var(--texto-suave); text-decoration: none; font-size: .93rem; font-weight: 500; transition: color .15s; }
.topo nav a:hover { color: var(--destaque-escuro); }

/* Botões */
.btn {
  display: inline-block; padding: .8rem 1.6rem; border-radius: 999px;
  text-decoration: none; font-weight: 600; font-size: .95rem;
  transition: transform .15s ease, box-shadow .15s ease, background .15s ease;
}
.btn-primario { background: var(--destaque); color: var(--claro); box-shadow: 0 6px 18px rgba(186, 148, 56, .35); }
.btn-primario:hover { background: var(--destaque-escuro); transform: translateY(-2px); box-shadow: 0 10px 24px rgba(186, 148, 56, .4); }
.btn-secundario { border: 1.5px solid var(--destaque); color: var(--destaque-escuro); }
.btn-secundario:hover { background: rgba(186, 148, 56, .08); transform: translateY(-2px); }
.cta-botoes { display: flex; gap: .9rem; flex-wrap: wrap; margin-top: 1.6rem; }

/* Hero */
.hero { background: linear-gradient(165deg, var(--pessego) 0%, var(--fundo) 68%); overflow: hidden; }
.hero-grid { display: grid; grid-template-columns: 1.15fr .85fr; gap: 2.5rem; align-items: center; padding-top: 4.5rem; padding-bottom: 4rem; }
.hero-interna { padding: 3.6rem 0 2.6rem; background: linear-gradient(165deg, var(--pessego) 0%, var(--fundo) 75%); }
.hero-tag { text-transform: uppercase; letter-spacing: .16em; font-size: .76rem; color: var(--verde); font-weight: 600; margin-bottom: 1rem; }
.hero-tag a { text-decoration: none; color: inherit; }
.hero-sub { max-width: 620px; margin-top: 1.1rem; color: var(--texto-suave); font-size: 1.08rem; }

/* Arte decorativa do hero */
.hero-arte { position: relative; height: 380px; }
.arte-circulo { position: absolute; border-radius: 50%; }
.arte-c1 { width: 300px; height: 300px; right: 10px; top: 20px; background: var(--rosa-pastel); opacity: .85; }
.arte-c2 { width: 190px; height: 190px; right: 200px; bottom: 0; background: var(--verde); opacity: .9; }
.arte-anel { position: absolute; width: 210px; height: 210px; right: 0; bottom: 30px; border: 3px solid var(--destaque); border-radius: 50%; }
.arte-monograma {
  position: absolute; right: 105px; top: 105px;
  font-family: "Fraunces", serif; font-style: italic; font-weight: 500;
  font-size: 7.5rem; color: var(--claro); line-height: 1;
  text-shadow: 0 6px 24px rgba(53,50,44,.18);
}
.arte-badge {
  position: absolute; left: 30px; top: 0;
  background: var(--claro); border-radius: 50%; width: 108px; height: 108px;
  display: grid; place-content: center; text-align: center;
  font-size: .74rem; text-transform: uppercase; letter-spacing: .1em; color: var(--texto-suave);
  box-shadow: var(--sombra-forte); rotate: -8deg;
}
.arte-badge strong { font-family: "Fraunces", serif; font-size: 1.5rem; color: var(--destaque-escuro); letter-spacing: 0; }

/* Faixa de números */
.numeros { background: var(--verde); color: var(--claro); }
.numeros-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); gap: 1rem; padding-top: 1.9rem; padding-bottom: 1.9rem; }
.numero { text-align: center; }
.numero strong { display: block; font-family: "Fraunces", serif; font-size: 1.9rem; font-weight: 600; color: var(--pessego); line-height: 1.2; }
.numero span { font-size: .84rem; opacity: .92; }

/* Seções */
.secao { padding: 4rem 0; }
.secao-alt { background: var(--fundo-alt); }
.secao-sub { color: var(--texto-suave); margin-bottom: 1.6rem; max-width: 640px; }
.secao .container-estreito p { margin-bottom: 1rem; }

/* Cards */
.grid-cards { display: grid; grid-template-columns: repeat(auto-fit, minmax(270px, 1fr)); gap: 1.2rem; margin-top: 1.6rem; }
.card { background: var(--claro); border: 1px solid rgba(0,0,0,.045); border-radius: 18px; padding: 1.7rem 1.5rem; box-shadow: var(--sombra); }
.card p { color: var(--texto-suave); font-size: .95rem; }
.card-icone { display: grid; place-content: center; width: 52px; height: 52px; border-radius: 14px; background: var(--pessego); color: var(--destaque-escuro); margin-bottom: 1rem; }
.card-icone svg { width: 26px; height: 26px; }
.card-preco { margin-top: .8rem; font-weight: 600; color: var(--destaque-escuro); }
.card-link { text-decoration: none; display: block; transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease; }
.card-link:hover { transform: translateY(-4px); box-shadow: var(--sombra-forte); border-color: var(--rosa-pastel); }
.card-link h3 { color: var(--texto); }
.card-cta { display: inline-block; margin-top: .9rem; font-weight: 600; color: var(--destaque-escuro); font-size: .9rem; }

/* Tabela de preços */
.tabela-precos { width: 100%; border-collapse: collapse; background: var(--claro); border-radius: 16px; overflow: hidden; box-shadow: var(--sombra); }
.tabela-precos th, .tabela-precos td { text-align: left; padding: .85rem 1.15rem; }
.tabela-precos thead tr { background: var(--pessego); }
.tabela-precos th { font-size: .78rem; text-transform: uppercase; letter-spacing: .1em; color: var(--destaque-escuro); }
.tabela-precos tbody tr { border-top: 1px solid var(--fundo-alt); }
.tabela-precos tbody tr:hover { background: var(--fundo); }
.tabela-precos td:nth-child(2) { font-weight: 600; color: var(--destaque-escuro); white-space: nowrap; }
.apartir { font-weight: 400; font-size: .78rem; color: var(--texto-suave); }
.nota { margin-top: 1rem; font-size: .9rem; color: var(--texto-suave); }

/* CTA faixa */
.cta-faixa { background: var(--verde); color: var(--claro); padding: 3.5rem 0; text-align: center; position: relative; overflow: hidden; }
.cta-faixa::before, .cta-faixa::after { content: ""; position: absolute; border-radius: 50%; opacity: .14; background: var(--claro); }
.cta-faixa::before { width: 340px; height: 340px; left: -120px; top: -170px; }
.cta-faixa::after { width: 260px; height: 260px; right: -90px; bottom: -140px; }
.cta-faixa h2 { color: var(--claro); }
.cta-faixa p { color: var(--pessego); max-width: 560px; margin: .7rem auto 0; }
.cta-faixa .cta-botoes { justify-content: center; }
.cta-faixa .btn-secundario { border-color: var(--pessego); color: var(--claro); }
.cta-faixa .btn-secundario:hover { background: rgba(255,255,255,.12); }

/* FAQ */
.faq-item { background: var(--claro); border: 1px solid rgba(0,0,0,.045); border-radius: 14px; margin-top: .8rem; padding: 1rem 1.2rem; box-shadow: var(--sombra); }
.faq-item summary { font-weight: 600; cursor: pointer; list-style: none; position: relative; padding-right: 1.6rem; }
.faq-item summary::after { content: "+"; position: absolute; right: 0; top: 0; font-family: "Fraunces", serif; font-size: 1.25rem; color: var(--destaque); transition: rotate .2s; }
.faq-item[open] summary::after { rotate: 45deg; }
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item p { margin-top: .7rem; color: var(--texto-suave); }

/* Rodapé */
.rodape { background: var(--texto); color: var(--fundo-alt); padding: 3.4rem 0 1.2rem; }
.rodape h3 { color: var(--pessego); }
.rodape h4 { margin-bottom: .6rem; font-size: .8rem; text-transform: uppercase; letter-spacing: .12em; color: var(--rosa-pastel); }
.rodape-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 1.8rem; }
.rodape p, .rodape a { font-size: .92rem; color: var(--fundo-alt); }
.rodape a { display: block; margin-bottom: .35rem; text-decoration: none; }
.rodape a:hover { color: var(--pessego); }
.rodape-base { margin-top: 2.2rem; padding-top: 1.1rem; border-top: 1px solid rgba(255,255,255,.14); }
.rodape-base p { font-size: .83rem; opacity: .75; }

/* WhatsApp flutuante */
.wa-flutuante {
  position: fixed; right: 1.2rem; bottom: 1.2rem;
  display: flex; align-items: center; gap: .5rem;
  background: #25d366; color: #fff; padding: .8rem 1.3rem; border-radius: 999px;
  font-weight: 700; font-size: .95rem; text-decoration: none;
  box-shadow: 0 8px 24px rgba(0,0,0,.28); z-index: 20;
  transition: transform .15s ease;
}
.wa-flutuante:hover { transform: scale(1.05); }

@media (max-width: 860px) {
  .hero-grid { grid-template-columns: 1fr; padding-top: 3rem; padding-bottom: 2.5rem; }
  .hero-arte { height: 300px; max-width: 420px; margin: 0 auto; scale: .82; transform-origin: top center; }
}
@media (max-width: 720px) {
  .topo nav { display: none; }
  .topo-inner .btn { margin-left: auto; padding: .6rem 1.1rem; font-size: .85rem; }
}
