:root {
  --black: #000000;
  --bg: #0a0a0a;
  --bg-card: #111111;
  --bg-soft: #1a1a1a;
  --gold: #C5A46D;
  --gold-soft: #d8bf90;
  --gold-dark: #9e7e4b;
  --white: #ffffff;
  --grey: #D9D9D9;
  --grey-soft: #b3b3b3;
  --grey-mute: #707070;
  --line: rgba(217, 217, 217, 0.12);
  --line-gold: rgba(197, 164, 109, 0.30);
  --wa: #25D366;
  --wa-dark: #1da855;
  --maxw: 1280px;
  --maxw-narrow: 920px;
  --easing: cubic-bezier(0.4, 0, 0.2, 1);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; background: var(--black); }
body {
  margin: 0;
  font-family: 'Inter', system-ui, -apple-system, sans-serif;
  color: var(--grey);
  background: var(--black);
  font-size: 17px;
  line-height: 1.75;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img { max-width: 100%; height: auto; display: block; }
a { color: var(--gold); text-decoration: none; transition: color .2s var(--easing); }
a:hover { color: var(--gold-soft); }

h1, h2, h3, h4 {
  font-family: 'Cormorant Garamond', 'Times New Roman', serif;
  color: var(--white);
  font-weight: 400;
  line-height: 1.1;
  letter-spacing: -0.005em;
  margin: 0 0 0.6em;
}
h1 { font-size: clamp(2.4rem, 5.6vw, 4.2rem); font-weight: 400; }
h2 { font-size: clamp(2rem, 4.2vw, 3.1rem); font-weight: 400; }
h3 { font-size: 1.25rem; font-family: 'Inter', sans-serif; font-weight: 500; letter-spacing: 0.04em; text-transform: uppercase; }
h4 { font-size: 1.1rem; font-weight: 500; letter-spacing: 0.04em; text-transform: uppercase; color: var(--gold); margin-bottom: 16px; }
p { margin: 0 0 1.1em; }
strong { color: var(--white); font-weight: 500; }
.italic { font-style: italic; color: var(--gold); }

.container { max-width: var(--maxw); margin: 0 auto; padding: 0 32px; }
.narrow { max-width: var(--maxw-narrow); }
.center { text-align: center; }

/* Eyebrow */
.eyebrow {
  font-family: 'Inter', sans-serif;
  font-size: 0.74rem;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--gold);
  margin: 0 0 1.4em;
  font-weight: 500;
}
.eyebrow-line { display: inline-flex; align-items: center; gap: 14px; }
.eyebrow-line::before {
  content: '';
  width: 36px;
  height: 1px;
  background: var(--gold);
}

/* Gold rule */
.gold-rule {
  display: block;
  width: 72px;
  height: 1px;
  background: var(--gold);
  margin: 28px 0;
}

/* WhatsApp icon (original silhouette white) */
.wa-icon { width: 22px; height: 22px; flex-shrink: 0; fill: currentColor; }

/* Buttons */
.btn-wa {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  background: #25D366;
  color: #fff;
  font-family: 'Inter', sans-serif;
  font-weight: 600;
  font-size: 0.92rem;
  padding: 13px 22px 13px 18px;
  border-radius: 999px;
  border: none;
  cursor: pointer;
  text-decoration: none;
  transition: background .2s var(--easing), transform .2s var(--easing), box-shadow .2s var(--easing);
  box-shadow: 0 14px 32px rgba(37,211,102,.30), 0 2px 6px rgba(0,0,0,.20);
}
.btn-wa:hover { background: var(--wa-dark); color: #fff; transform: translateY(-2px); }
.btn-wa-sm { padding: 9px 14px 9px 12px; font-size: 0.84rem; }
.btn-wa-sm .wa-icon { width: 18px; height: 18px; }
.btn-wa-lg { padding: 16px 28px 16px 22px; font-size: 1rem; }
.btn-wa-lg .wa-icon { width: 24px; height: 24px; }

.btn-gold {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  background: transparent;
  color: var(--gold);
  border: 1px solid var(--gold);
  padding: 14px 28px;
  font-family: 'Inter', sans-serif;
  font-weight: 500;
  font-size: 0.85rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  text-decoration: none;
  transition: background .2s var(--easing), color .2s var(--easing);
}
.btn-gold:hover { background: var(--gold); color: var(--black); }

/* HERO — 2 colunas: conteúdo à esquerda (com respiro), logo à direita. BG image full-bleed com overlay */
.hero {
  position: relative;
  overflow: hidden;
  min-height: clamp(600px, 86vh, 800px);
  display: flex;
  align-items: center;
  padding: clamp(56px, 7vw, 96px) 0;
}
.hero-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}
.hero-bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center right;
  filter: brightness(0.42) saturate(0.65);
}
.hero-bg::after {
  content: '';
  position: absolute;
  inset: 0;
  background:
    linear-gradient(100deg, rgba(0,0,0,0.86) 0%, rgba(0,0,0,0.66) 55%, rgba(0,0,0,0.40) 100%),
    radial-gradient(35% 30% at 22% 35%, rgba(197, 164, 109, 0.10), transparent 60%);
}
.hero-inner {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(0, 1.3fr) minmax(0, 1fr);
  gap: clamp(40px, 6vw, 80px);
  align-items: center;
  width: 100%;
}
.hero-content {
  max-width: 620px;
  padding-left: clamp(24px, 3vw, 40px);
}
.hero-logo-col {
  display: flex;
  justify-content: center;
  align-items: center;
  padding-right: clamp(24px, 3vw, 40px);
}
.hero-logo {
  display: inline-block;
  text-decoration: none;
}
.hero-logo img {
  width: clamp(220px, 26vw, 360px);
  height: auto;
  display: block;
}
.hero h1 {
  font-size: clamp(2rem, 4.2vw, 3.2rem);
  line-height: 1.08;
  margin-bottom: 0.4em;
}
.hero .lead {
  font-size: 1.02rem;
  color: var(--grey-soft);
  max-width: 560px;
  margin: 24px 0 32px;
  line-height: 1.65;
}
.hero-bullets {
  list-style: none;
  padding: 0;
  margin: 0 0 36px;
  display: grid;
  gap: 12px;
  max-width: 560px;
}
.hero-bullets li { font-size: 0.96rem; }
.hero-bullets li {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  color: var(--grey);
  font-size: 1rem;
}
.hero-bullets li::before {
  content: '';
  width: 18px;
  height: 18px;
  flex-shrink: 0;
  margin-top: 4px;
  background: var(--gold);
  mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='black' d='M9 16.2L4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/></svg>") center/12px no-repeat;
  -webkit-mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='black' d='M9 16.2L4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/></svg>") center/12px no-repeat;
}

/* Sections */
.section { padding: clamp(80px, 10vw, 140px) 0; position: relative; }
.section-soft { background: var(--bg-soft); }
.section + .section, .hero + .section { border-top: 1px solid var(--line); }

/* COMO POSSO AJUDAR (services) */
.services {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(36px, 5vw, 60px);
  margin-top: 60px;
}
.service {
  padding: 32px 0;
  border-top: 1px solid var(--line-gold);
  position: relative;
}
.service h3 {
  font-family: 'Cormorant Garamond', serif;
  font-weight: 500;
  font-size: 1.6rem;
  text-transform: none;
  letter-spacing: -0.005em;
  color: var(--white);
  margin: 0 0 12px;
}
.service p { color: var(--grey-soft); margin: 0; font-size: 0.98rem; line-height: 1.65; }

/* CTA strip — agora com imagem de fundo */
.cta-strip {
  position: relative;
  background: var(--black);
  text-align: center;
  padding: clamp(64px, 9vw, 110px) 24px;
  border-top: 1px solid var(--line-gold);
  border-bottom: 1px solid var(--line-gold);
  overflow: hidden;
}
.cta-strip-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}
.cta-strip-bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0.15;
  filter: grayscale(100%) contrast(1.1);
}
.cta-strip-bg::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(0,0,0,0.85) 0%, rgba(0,0,0,0.72) 50%, rgba(0,0,0,0.88) 100%);
}
.cta-strip-inner { position: relative; z-index: 1; }
.cta-strip .eyebrow { color: var(--gold); }
.cta-strip h2 {
  font-style: italic;
  max-width: 760px;
  margin: 0 auto 1em;
}

/* Lawyer bio — agora com foto do advogado */
.bio-grid {
  display: grid;
  grid-template-columns: 0.85fr 1.15fr;
  gap: clamp(40px, 6vw, 80px);
  align-items: center;
}
.bio-photo {
  position: relative;
  aspect-ratio: 4 / 5;
  max-width: 460px;
}
.bio-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: grayscale(15%);
}
.bio-photo::before {
  content: '';
  position: absolute;
  inset: 24px -24px -24px 24px;
  border: 1px solid var(--gold);
  z-index: -1;
  pointer-events: none;
}
.bio-content h2 {
  font-style: italic;
  margin-bottom: 0;
}
.bio-content .gold-rule { margin: 20px 0 12px; }
.bio-role { color: var(--grey-mute); font-size: 0.86rem; letter-spacing: 0.18em; text-transform: uppercase; margin: 0 0 28px; }
.bio-text p { font-size: 1.02rem; color: var(--grey); line-height: 1.85; margin-bottom: 1.1em; }
.bio-text p:last-child { margin-bottom: 0; }

/* Diferenciais (3 blocks) */
.diferenciais-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--line-gold);
  margin-top: 60px;
}
.diferencial {
  background: var(--bg);
  padding: 48px 38px;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}
.diferencial-icon {
  width: 56px;
  height: 56px;
  margin-bottom: 28px;
  color: var(--gold);
}
.diferencial-icon svg { width: 100%; height: 100%; stroke: currentColor; fill: none; stroke-width: 1; stroke-linecap: round; stroke-linejoin: round; }
.diferencial h3 {
  margin-bottom: 18px;
  color: var(--gold);
  font-size: 0.85rem;
  letter-spacing: 0.24em;
}
.diferencial p {
  color: var(--grey-soft);
  font-size: 0.98rem;
  margin: 0 0 1em;
  line-height: 1.7;
}
.diferencial p:last-child { margin-bottom: 0; }

/* Decorative section heading */
.section-head {
  text-align: center;
  margin-bottom: 60px;
}
.section-head .eyebrow { display: inline-flex; }
.section-head h2 {
  font-style: italic;
  max-width: 820px;
  margin: 0 auto;
}

/* Final CTA */
.final-cta {
  text-align: center;
  padding: clamp(80px, 12vw, 140px) 24px;
}
.final-cta h2 { font-style: italic; max-width: 720px; margin: 0 auto 0.6em; }
.final-cta .lead { color: var(--grey-soft); max-width: 600px; margin: 0 auto 40px; font-size: 1.08rem; }

/* WhatsApp float */
.wa-float {
  position: fixed;
  right: 22px;
  bottom: 22px;
  z-index: 100;
  background: #25D366;
  color: #fff;
  padding: 14px 22px 14px 18px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  gap: 12px;
  font-family: 'Inter', sans-serif;
  font-weight: 600;
  font-size: 0.92rem;
  text-decoration: none;
  box-shadow: 0 18px 36px rgba(37,211,102,.35), 0 4px 12px rgba(0,0,0,.30);
  transition: background .2s var(--easing), transform .2s var(--easing);
}
.wa-float:hover { background: var(--wa-dark); color: #fff; transform: translateY(-3px); }
.wa-float svg { width: 24px; height: 24px; }

/* Footer */
.site-footer {
  background: var(--bg);
  border-top: 1px solid var(--line);
  padding: 64px 0 32px;
  color: var(--grey-mute);
  font-size: 0.88rem;
}
.footer-inner {
  display: grid;
  grid-template-columns: 1.5fr 1fr 1fr;
  gap: 48px;
  margin-bottom: 48px;
}
.footer-brand img { height: 80px; width: auto; margin-bottom: 18px; }
.footer-brand p { color: var(--grey-soft); font-size: 0.94rem; margin: 0; line-height: 1.7; max-width: 360px; }
.footer-col h4 {
  color: var(--gold);
  font-size: 0.74rem;
  letter-spacing: 0.22em;
  margin-bottom: 18px;
}
.footer-col a, .footer-col p { display: block; color: var(--grey-soft); margin: 0 0 10px; font-size: 0.94rem; }
.footer-col a:hover { color: var(--gold); }
.footer-legal {
  text-align: center;
  padding-top: 28px;
  border-top: 1px solid var(--line);
  font-size: 0.82rem;
  color: var(--grey-mute);
}

/* Scroll reveal */
[data-anim] {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity .9s var(--easing), transform .9s var(--easing);
}
[data-anim].is-in { opacity: 1; transform: translateY(0); }
@media (prefers-reduced-motion: reduce) {
  [data-anim] { opacity: 1; transform: none; transition: none; }
}

/* Responsive */
@media (max-width: 1024px) {
  .services { grid-template-columns: 1fr; }
  .bio-grid { grid-template-columns: 1fr; gap: 48px; }
  .bio-photo { max-width: 360px; margin: 0; }
  .diferenciais-grid { grid-template-columns: 1fr; gap: 1px; }
  .footer-inner { grid-template-columns: 1fr; gap: 32px; }
}
@media (max-width: 1024px) {
  .hero-inner { grid-template-columns: 1fr; gap: 32px; }
  .hero-logo-col { order: -1; justify-content: flex-start; padding-right: 0; padding-left: clamp(24px, 3vw, 40px); }
  .hero-content { padding-left: clamp(24px, 3vw, 40px); }
  .hero-logo img { width: 200px; }
}
@media (max-width: 768px) {
  body { font-size: 16px; }
  .wa-float span { display: none; }
  .wa-float { padding: 16px; }
  .container { padding: 0 22px; }
  .hero { min-height: 100dvh; padding: 36px 0 60px; }
  .hero-bg img { object-position: center; }
  .hero-bg::after {
    background:
      linear-gradient(180deg, rgba(0,0,0,0.78) 0%, rgba(0,0,0,0.86) 50%, rgba(0,0,0,0.94) 100%);
  }
  .hero-logo img { width: 160px; }
  .hero h1 { font-size: clamp(1.8rem, 7vw, 2.4rem); }
  .hero-bullets li { font-size: 0.92rem; }
  .diferencial { padding: 36px 28px; }
}
