/* ===========================================
   BASE.CSS — estilos comuns a todas as páginas
   (variáveis, tipografia, cabeçalho, rodapé, botões)
   =========================================== */

:root{
  --ink:#17150f;
  --ink-soft:#262218;
  --gold:#c9a13b;
  --gold-light:#e8c873;
  --cream:#f4ecd9;
  --olive:#4a5a3a;
  --rust:#7a3b22;
  --max:1180px;
}
*{box-sizing:border-box; margin:0; padding:0;}
html{scroll-behavior:smooth;}
body{
  background:var(--cream);
  color:var(--ink);
  font-family:'Jost', sans-serif;
  line-height:1.6;
}
h1,h2,h3{
  font-family:'Fraunces', serif;
  font-weight:600;
  letter-spacing:0.01em;
}
.eyebrow{
  font-family:'Jost', sans-serif;
  text-transform:uppercase;
  letter-spacing:0.22em;
  font-size:0.72rem;
  color:var(--gold);
  font-weight:600;
}
.wrap{
  max-width:var(--max);
  margin:0 auto;
  padding:0 24px;
}
a{color:inherit; text-decoration:none;}

/* HEADER */
header{
  background:var(--ink);
  position:sticky; top:0; z-index:50;
  border-bottom:1px solid rgba(201,161,59,0.25);
}
.nav{
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 24px;
  max-width:var(--max); margin:0 auto;
}
.brand{
  display:flex; align-items:center; gap:10px;
  color:var(--cream);
}
.brand img{height:42px; width:auto;}
.brand span{font-family:'Fraunces', serif; font-size:1.15rem; color:var(--gold-light); letter-spacing:0.03em;}
.nav-links{display:flex; gap:30px; list-style:none;}
.nav-links a{
  color:var(--cream); font-size:0.92rem; letter-spacing:0.03em;
  opacity:0.85; transition:opacity 0.2s, color 0.2s;
  padding-bottom:4px;
}
.nav-links a:hover{opacity:1; color:var(--gold-light);}
.nav-links a.active{opacity:1; color:var(--gold-light); border-bottom:2px solid var(--gold);}
.nav-cta{
  background:var(--gold);
  color:var(--ink);
  padding:9px 18px;
  border-radius:3px;
  font-size:0.88rem;
  font-weight:600;
  letter-spacing:0.02em;
  white-space:nowrap;
}
.nav-cta:hover{background:var(--gold-light);}
.menu-toggle{display:none; background:none; border:none; color:var(--cream); font-size:1.6rem; cursor:pointer;}

/* BOTÕES */
.btn-primary{
  background:var(--gold);
  color:var(--ink);
  padding:14px 28px;
  border-radius:3px;
  font-weight:600;
  letter-spacing:0.02em;
  font-size:0.96rem;
  display:inline-flex;
  align-items:center;
  gap:8px;
  transition:background 0.2s, transform 0.2s;
}
.btn-primary:hover{background:var(--gold-light); transform:translateY(-1px);}
.btn-secondary{
  border:1px solid rgba(244,236,217,0.35);
  color:var(--cream);
  padding:14px 28px;
  border-radius:3px;
  font-size:0.96rem;
  transition:border-color 0.2s, background 0.2s;
}
.btn-secondary:hover{border-color:var(--gold-light); background:rgba(244,236,217,0.06);}

/* PAGE HERO (cabeçalho de topo das subpáginas) */
.page-hero{
  background:
    radial-gradient(ellipse at 25% 0%, rgba(201,161,59,0.16), transparent 55%),
    var(--ink);
  color:var(--cream);
  padding:70px 0;
  border-bottom:6px solid var(--gold);
  text-align:center;
}
.page-hero h1{font-size:clamp(2rem, 4vw, 2.8rem); color:var(--cream);}
.page-hero p{color:#cfc6ad; margin-top:14px; max-width:520px; margin-left:auto; margin-right:auto;}

/* FOOTER */
footer{
  background:var(--ink);
  color:#a89f86;
  padding:36px 0;
  text-align:center;
  font-size:0.85rem;
}
footer .brand-foot{
  color:var(--gold-light);
  font-family:'Fraunces', serif;
  font-size:1rem;
  margin-bottom:8px;
  display:block;
}

/* WHATSAPP FLUTUANTE */
.whats-float{
  position:fixed;
  bottom:24px;
  right:24px;
  background:var(--olive);
  color:#fff;
  width:58px;
  height:58px;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  box-shadow:0 12px 28px rgba(0,0,0,0.3);
  z-index:60;
  font-size:1.5rem;
  transition:transform 0.2s;
}
.whats-float:hover{transform:scale(1.08);}

@media (max-width: 880px){
  .nav-links, .nav-cta{display:none;}
  .menu-toggle{display:block;}
}
