@charset "UTF-8";

:root{
  --brand:#1e2a44;
  --brand-600:#24324f;
  --accent:#caa75e;
  --ink:#0f172a;
  --muted:#5b6473;
  --bg:#ffffff;
  --bg-2:#f5f7fb;
  --line:#e6e8ef;

  --radius:14px;
  --radius-sm:10px;

  --shadow-sm:0 6px 16px rgba(0,0,0,.06);
  --shadow-md:0 12px 28px rgba(0,0,0,.12);
  --transition:240ms cubic-bezier(.2,.6,.2,1);
}

/* Reset/estrutura */
*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0; font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color:var(--ink); background:var(--bg); line-height:1.6;
}
img{ max-width:100%; display:block; height:auto; }

.container{ width:min(1200px, 92%); margin-inline:auto; }

/* Botões + badges */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.6rem;
  padding:.8rem 1.2rem; border-radius:10px; font-weight:600; text-decoration:none; cursor:pointer;
  transition: transform var(--transition), box-shadow var(--transition), background var(--transition), color var(--transition), border-color var(--transition);
  border:2px solid transparent;
}
.btn:focus-visible{ outline:2px solid var(--accent); outline-offset:2px; }
.btn-primary{ background:#25D366; color:#0b2917; box-shadow: var(--shadow-sm); }
.btn-primary:hover{ transform: translateY(-2px); box-shadow:0 10px 22px rgba(37,211,102,.35); }
.btn-ghost{ background:#fff; color:var(--brand); border-color: var(--line); }
.btn-ghost:hover{ background:var(--bg-2); transform: translateY(-2px); }

.badge{
  display:inline-flex; align-items:center; gap:.5rem; padding:.5rem .75rem; border-radius:999px;
  font-size:.875rem; background:#eef2ff; color:#374151; border:1px solid #dbe2ff;
}

/* Header / navegação */
header{
  position:sticky; top:0; z-index:1000; background: rgba(255,255,255,.9); backdrop-filter: blur(8px);
  border-bottom:1px solid var(--line);
}
.nav{ display:flex; align-items:center; justify-content:space-between; padding:.9rem 0; }

.brand{ display:flex; align-items:center; gap:.75rem; text-decoration:none; color:var(--brand); }
.brand img.logo{ width:46px; height:46px; border-radius:10px; object-fit:cover; }
.brand .title{ display:flex; flex-direction:column; line-height:1.1; }
.brand .title b{ font-family: Merriweather, Georgia, serif; font-size:1.15rem; letter-spacing:.2px; }
.brand .title span{ color:var(--muted); font-size:.85rem; }

nav ul{ list-style:none; display:flex; gap:1rem; padding:0; margin:0; }
nav a{ color:var(--brand); text-decoration:none; font-weight:600; padding:.5rem .7rem; border-radius:8px; }
nav a:hover{ background:var(--bg-2); }
.nav-cta{ display:flex; align-items:center; gap:.6rem; }

/* mobile nav */
.menu-toggle{
  display:none; background:none; border:1px solid var(--line); border-radius:10px; padding:.55rem .7rem; cursor:pointer;
}
.menu-toggle:focus-visible{ outline:2px solid var(--accent); outline-offset:2px; }
@media (max-width: 900px){
  nav ul{ display:none; position:absolute; top:64px; left:0; right:0; background:#fff; border-bottom:1px solid var(--line); padding:.6rem 5%; flex-direction:column; gap:.25rem; }
  nav ul.open{ display:flex; }
  .menu-toggle{ display:inline-block; }
  .nav-cta{ display:none; }
}

/* Hero */
.hero{
  display:grid; grid-template-columns:1.2fr .9fr; gap:clamp(1rem, 4vw, 3rem);
  align-items:center; padding: clamp(2rem, 5vw, 4rem) 0;
}
.hero h1{
  font-family: Merriweather, Georgia, serif; font-size: clamp(1.9rem, 4.6vw, 3.2rem); line-height:1.15; margin:0 0 1rem;
  color: var(--brand);
}
.hero p.lead{ font-size: clamp(1rem, 1.6vw, 1.2rem); color: var(--muted); margin: 0 0 1.25rem; }
.hero .actions{ display:flex; gap:.75rem; flex-wrap:wrap; }
.hero .proofs{ display:flex; gap:.6rem; flex-wrap:wrap; margin-top:1rem; }
.hero .media{ border-radius: var(--radius); overflow:hidden; box-shadow: var(--shadow-md); border:1px solid var(--line); height: 550px;
    width: 600px;}
.hero .media img{ width:100%; height:100%; object-fit:cover; max-height:560px; }

@media (max-width: 900px){
  .hero{ grid-template-columns:1fr; }
  .hero .media img{ max-height:420px; max-width: 420px; }
}

/* Quem sou */
.about{
  background: var(--bg-2); border-top:1px solid var(--line); border-bottom:1px solid var(--line);
  padding: clamp(2rem, 5vw, 4rem) 0;
}
.about-grid{
  display:grid; grid-template-columns:.95fr 1.05fr; gap: clamp(1rem, 4vw, 3rem); align-items:center;
}
.about .photo{ border-radius: var(--radius); overflow:hidden; border:1px solid var(--line); box-shadow: var(--shadow-sm); }
.about .photo img{ width:100%; height:100%; object-fit:cover; max-height:750px; }
.about h2{ font-family: Merriweather, Georgia, serif; color: var(--brand); font-size: clamp(1.5rem, 3.2vw, 2.2rem); margin:0 0 .5rem; margin-bottom: 25px;}
.about p{ color: var(--muted); margin:.4rem 0; }
.about .badges{ margin-top:.8rem; display:flex; gap:.5rem; flex-wrap:wrap; }

@media (max-width: 900px){
  .about-grid{ grid-template-columns:1fr; }
  .about .photo img{ max-height:550px; }
}

/* Áreas */
.areas{ padding: clamp(2rem, 5vw, 4rem) 0; }
.section-title{
  text-align:center; margin:0 0 1.6rem; color: var(--brand);
  font-family: Merriweather, Georgia, serif; font-size: clamp(1.4rem, 3vw, 2rem);
}
.areas-grid{
  display:grid; gap: clamp(1rem, 2.5vw, 1.6rem);
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
}
.area-card{
  background:#fff; border:1px solid var(--line); border-radius: var(--radius-sm);
  padding:1.1rem; box-shadow: var(--shadow-sm);
  transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
  display:grid; grid-template-columns:56px 1fr; gap:.9rem; align-items:center;
}
.area-card:hover{ transform: translateY(-4px); border-color:#d9dff0; box-shadow: var(--shadow-md); }
.area-card img{ width:56px; height:56px; object-fit:cover; border-radius:10px; border:1px solid var(--line); }
.area-card h3{ margin:.2rem 0 .25rem; font-size:1.05rem; color: var(--brand-600); }
.area-card p{ margin:0; color: var(--muted); font-size:.95rem; }

/* Diferenciais */
.trust{ padding:.6rem 0 2.2rem; }
.trust .chips{ display:flex; gap:.6rem; flex-wrap:wrap; justify-content:center; }

/* Contato */
.contact{ background: var(--bg-2); border-top:1px solid var(--line); padding: clamp(2rem, 5vw, 4rem) 0; }
.contact-grid{ display:grid; grid-template-columns:1.1fr .9fr; gap: clamp(1rem, 4vw, 2rem); }
.card{ background:#fff; border:1px solid var(--line); border-radius: var(--radius); padding: clamp(1rem, 2.5vw, 1.5rem); box-shadow: var(--shadow-sm); }
form .row{ display:grid; grid-template-columns:1fr 1fr; gap:.9rem; }
form .row.single{ grid-template-columns:1fr; }
label{ display:block; font-weight:600; font-size:.95rem; margin-bottom:.35rem; color:var(--brand); }
input, textarea{
  width:100%; border:1px solid var(--line); border-radius:10px; padding:.8rem .9rem; font:inherit; color:var(--ink); background:#fff;
  transition: border-color var(--transition), box-shadow var(--transition);
}
input:focus, textarea:focus{ outline:none; border-color:#cfd6ea; box-shadow:0 0 0 4px rgba(92,121,255,.12); }
textarea{ resize:vertical; min-height:140px; }
.form-actions{ display:flex; gap:.7rem; align-items:center; margin-top:.8rem; flex-wrap:wrap; }
.form-note{ color:var(--muted); font-size:.9rem; }

.contact-aside{ display:flex; flex-direction:column; gap:.9rem; }
.contact-aside .tile{
  display:flex; gap:.9rem; align-items:flex-start; padding:.9rem; border:1px dashed #d8deef; border-radius:12px; background:#fff;
}
.contact-aside .tile img{ width:40px; height:40px; border-radius:10px; object-fit:cover; border:1px solid var(--line); }
.contact-aside .tile h4{ margin:.1rem 0 .2rem; font-size:1rem; color: var(--brand-600); }
.contact-aside .tile p{ margin:0; color:var(--muted); font-size:.95rem; }

@media (max-width: 900px){
  .contact-grid{ grid-template-columns:1fr; }
  form .row{ grid-template-columns:1fr; }
}

/* Footer */
footer{ border-top:1px solid var(--line); padding:1.4rem 0; background:#fff; }
.footer-row{ display:flex; align-items:center; justify-content:space-between; gap:1rem; flex-wrap:wrap; }
.small{ color:var(--muted); font-size:.9rem;text-align: center; }

/* Botão flutuante WhatsApp */
.whatsapp-float{ position:fixed; right:18px; bottom:18px; z-index:1000; }
.whatsapp-float a{
  display:inline-flex; align-items:center; gap:.55rem; background:#25D366; color:#0b2917;
  padding:.8rem 1rem; border-radius:999px; font-weight:700; box-shadow: var(--shadow-md);
}
.whatsapp-float img{ width:20px; height:20px; object-fit:contain; }