/* ===== FONTE INSTRUCTION — @font-face ===== */
@font-face {
  font-family: 'Instruction';
  src: url('assets/fonts/Instruction.otf') format('opentype');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Instruction';
  src: url('assets/fonts/Instruction_Bold.otf') format('opentype');
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Instruction';
  src: url('assets/fonts/Instruction_Italic.otf') format('opentype');
  font-weight: 400;
  font-style: italic;
  font-display: swap;
}
@font-face {
  font-family: 'Instruction';
  src: url('assets/fonts/Instruction_Bold_Italic.otf') format('opentype');
  font-weight: 700;
  font-style: italic;
  font-display: swap;
}

/* ===== CUSTOM PROPERTIES ===== */
:root {
  --azul-marinho:     #1C3461;
  --azul-medio:       #4A7AB5;
  --azul-claro:       #8BADD4;
  --azul-muito-claro: #D6E4F0;
  --azul-suave:       #EEF4FA;
  --off-white:        #F8F7F4;
  --branco:           #FFFFFF;
  --texto-escuro:     #1a1a1a;
  --texto-medio:      #555555;
  --texto-suave:      #888888;

  --font:    'Instruction', system-ui, sans-serif;
  --nav-h:   72px;
  --max-w:   1280px;
  --pad-x:   clamp(1.25rem, 5vw, 3rem);
  --radius:  2px;
  --trans:   0.28s ease;
  --shadow:  0 2px 20px rgba(28, 52, 97, 0.09);
}

/* ===== RESET ===== */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 16px; overflow-x: hidden; }
body {
  font-family: var(--font);
  font-weight: 400;
  color: var(--texto-escuro);
  background: var(--branco);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}
img { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; }
button { background: none; border: none; cursor: pointer; font-family: inherit; }
address { font-style: normal; }

/* ===== CONTAINER ===== */
.container {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 0 var(--pad-x);
}

/* ===== BOTÕES ===== */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.8rem 1.9rem;
  font-family: var(--font);
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  border: 1.5px solid transparent;
  border-radius: var(--radius);
  transition: background var(--trans), color var(--trans), border-color var(--trans), transform var(--trans);
  cursor: pointer;
  white-space: nowrap;
}
.btn:hover { transform: translateY(-1px); }
.btn--primary { background: var(--azul-marinho); color: var(--branco); border-color: var(--azul-marinho); }
.btn--primary:hover { background: var(--azul-medio); border-color: var(--azul-medio); }
.btn--white { background: var(--branco); color: var(--azul-marinho); border-color: var(--branco); }
.btn--white:hover { background: var(--azul-muito-claro); border-color: var(--azul-muito-claro); }
.btn--outline-white { background: transparent; color: var(--branco); border-color: rgba(255,255,255,0.45); }
.btn--outline-white:hover { background: rgba(255,255,255,0.07); border-color: var(--branco); }

/* ===== TIPOGRAFIA DE SEÇÃO ===== */
.section-eyebrow {
  font-family: var(--font);
  font-size: 13px;
  font-weight: 400;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--azul-medio);
  margin-bottom: 0.75rem;
}
.section-eyebrow--light { color: var(--azul-claro); }

.section-title {
  font-family: var(--font);
  font-size: clamp(36px, 4.5vw, 52px);
  font-weight: 700;
  line-height: 1.1;
  color: var(--azul-marinho);
  margin-bottom: 1rem;
}
.section-title--light { color: var(--branco); }

.section-desc {
  font-size: 17px;
  font-weight: 400;
  color: var(--texto-medio);
  max-width: 560px;
  line-height: 1.75;
}
.section-header { margin-bottom: 3rem; }

/* ===== REVEAL ===== */
.reveal { opacity: 0; transform: translateY(20px); transition: opacity 0.6s ease, transform 0.6s ease; }
.reveal.visible { opacity: 1; transform: translateY(0); }

/* ===== NAV ===== */
.nav {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 100;
  height: var(--nav-h);
  background: var(--branco);
  border-bottom: 1px solid var(--azul-muito-claro);
  transition: box-shadow var(--trans);
}
.nav.scrolled { box-shadow: var(--shadow); }

.nav__inner {
  height: 100%;
  display: flex;
  align-items: center;
  gap: 1.5rem;
  padding: 0 var(--pad-x);
  max-width: calc(var(--max-w) + var(--pad-x) * 2);
  margin: 0 auto;
}

.nav__brand { display: flex; align-items: center; flex-shrink: 0; }
.nav__logo  { height: 38px; width: auto; display: block; }

.nav__links {
  display: none;
  align-items: center;
  gap: 2rem;
  margin-left: auto;
}
.nav__links a {
  font-size: 13px;
  font-weight: 400;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--texto-medio);
  transition: color var(--trans);
}
.nav__links a:hover { color: var(--azul-marinho); }

.nav__cta { display: none; margin-left: 1rem; padding: 0.6rem 1.3rem; font-size: 13px; }

.nav__hamburger { display: flex; flex-direction: column; gap: 5px; margin-left: auto; padding: 0.5rem; }
.nav__hamburger span { display: block; width: 22px; height: 1.5px; background: var(--azul-marinho); transition: transform var(--trans), opacity var(--trans); }

@media (min-width: 768px) {
  .nav__links { display: flex; }
  .nav__cta   { display: inline-flex; }
  .nav__hamburger { display: none; }
}
@media (min-width: 1024px) {
  :root { --nav-h: 90px; }
  .nav__links { gap: 48px; }
  .nav__logo { height: 46px; }
}

/* ===== MOBILE MENU ===== */
.mobile-menu {
  position: fixed;
  top: 0; right: 0; bottom: 0;
  width: 280px; z-index: 200;
  background: var(--branco);
  border-left: 1px solid var(--azul-muito-claro);
  padding: 1.5rem;
  display: flex; flex-direction: column; gap: 1.5rem;
  transform: translateX(100%);
  transition: transform 0.32s cubic-bezier(0.4, 0, 0.2, 1);
}
.mobile-menu.open { transform: translateX(0); }
.mobile-menu__close { align-self: flex-end; font-size: 1.1rem; color: var(--azul-marinho); padding: 0.25rem 0.5rem; }
.mobile-menu nav { display: flex; flex-direction: column; }
.mobile-menu nav a { font-size: 1rem; color: var(--texto-escuro); padding: 0.8rem 0; border-bottom: 1px solid var(--azul-suave); letter-spacing: 0.03em; }
.mobile-menu__oab { font-size: 13px; color: var(--texto-suave); line-height: 1.5; margin-top: auto; }
.mobile-overlay { position: fixed; inset: 0; z-index: 150; background: rgba(28,52,97,0.38); opacity: 0; pointer-events: none; transition: opacity 0.32s ease; }
.mobile-overlay.open { opacity: 1; pointer-events: all; }

/* ===== HERO ===== */
.hero {
  min-height: 100vh;
  background: var(--azul-marinho);
  display: flex;
  align-items: center;
  position: relative;
  overflow: hidden;
  padding: calc(var(--nav-h) + 2.5rem) 1.25rem 3.5rem;
}
@media (min-width: 640px) {
  .hero { padding-left: 2rem; padding-right: 2rem; padding-bottom: 4rem; }
}
.hero__bg-mono {
  position: absolute; top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  font-family: var(--font);
  font-size: clamp(180px, 38vw, 500px);
  font-weight: 700;
  color: var(--branco);
  opacity: 0.03;
  user-select: none; white-space: nowrap;
  letter-spacing: -0.04em; line-height: 1; pointer-events: none;
}
.hero__inner { position: relative; z-index: 1; max-width: var(--max-w); margin: 0 auto; width: 100%; }
.hero__logo { height: 56px; width: auto; margin-bottom: 2rem; display: block; }
.hero__eyebrow { font-size: 13px; font-weight: 400; letter-spacing: 0.22em; text-transform: uppercase; color: var(--azul-claro); margin-bottom: 1.5rem; }
.hero__headline {
  font-family: var(--font);
  font-size: clamp(32px, 7vw, 72px);
  font-weight: 700;
  line-height: 1.08;
  color: var(--branco);
  margin-bottom: 1.4rem;
  max-width: 820px;
}
.hero__sub { font-size: 17px; font-weight: 400; color: var(--azul-claro); max-width: 520px; line-height: 1.75; margin-bottom: 2.5rem; }
.hero__ctas { display: flex; flex-wrap: wrap; gap: 1rem; margin-bottom: 1rem; }
.hero__oab { font-size: 13px; color: rgba(255,255,255,0.28); letter-spacing: 0.04em; margin-bottom: 4rem; }

/* Stats — 2 itens */
.hero__stats { display: flex; flex-wrap: wrap; align-items: center; gap: 0; border-top: 1px solid rgba(255,255,255,0.1); padding-top: 2rem; }
.hero__stat { display: flex; flex-direction: column; padding-right: 2.5rem; }
.hero__stat:not(:first-child) { padding-left: 2.5rem; }
.hero__stat-div { width: 1px; height: 44px; background: rgba(255,255,255,0.14); }
.hero__stat-n { font-size: 2.6rem; font-weight: 700; color: var(--branco); line-height: 1; }
.hero__stat-l { font-size: 13px; font-weight: 400; letter-spacing: 0.1em; text-transform: uppercase; color: var(--azul-claro); margin-top: 0.25rem; }

@media (max-width: 560px) {
  .hero__stats { flex-direction: column; align-items: flex-start; gap: 1.5rem; }
  .hero__stat-div { display: none; }
  .hero__stat { padding: 0; }
  .hero__stat:not(:first-child) { padding-left: 0; }
}
@media (min-width: 1024px) {
  .hero { padding-top: calc(var(--nav-h) + 100px); padding-bottom: 120px; padding-left: 8vw; padding-right: 8vw; }
}
@media (min-width: 1440px) {
  .hero { padding-left: 10vw; padding-right: 10vw; }
}

/* ===== SEÇÕES — PADDING GLOBAL ===== */
section {
  padding-top: 3.5rem;
  padding-bottom: 3.5rem;
  padding-left: 1.25rem;
  padding-right: 1.25rem;
}
@media (min-width: 640px) {
  section { padding-left: 2rem; padding-right: 2rem; }
}
@media (min-width: 1024px) {
  section { padding-top: 120px; padding-bottom: 120px; padding-left: 8vw; padding-right: 8vw; }
  section .container { padding-left: 0; padding-right: 0; max-width: var(--max-w); margin: 0 auto; }
}
@media (min-width: 1440px) {
  section { padding-left: 10vw; padding-right: 10vw; }
}

/* ===== PILARES ===== */
.pilares { background: var(--off-white); }
.pilares__grid { display: grid; grid-template-columns: 1fr; gap: 1.25rem; }
@media (min-width: 640px) { .pilares__grid { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 1024px) { .pilares__grid { gap: 3px; } }

.pilar {
  background: var(--branco);
  padding: 2rem;
  border-top: 3px solid transparent;
  transition: border-top-color var(--trans), box-shadow var(--trans), transform var(--trans);
  cursor: default;
}
.pilar:hover, .pilar:focus-visible { border-top-color: var(--azul-medio); box-shadow: var(--shadow); transform: translateY(-2px); }
.pilar:focus-visible { outline: 2px solid var(--azul-medio); outline-offset: 2px; }
.pilar__bar { width: 28px; height: 2px; background: var(--azul-muito-claro); margin-bottom: 1.5rem; transition: background var(--trans), width var(--trans); }
.pilar:hover .pilar__bar, .pilar:focus-visible .pilar__bar { background: var(--azul-medio); width: 44px; }
.pilar__title { font-size: 26px; font-weight: 700; color: var(--azul-marinho); margin-bottom: 0.75rem; line-height: 1.2; }
.pilar__text  { font-size: 17px; font-weight: 400; color: var(--texto-medio); line-height: 1.75; }

@media (min-width: 1024px) { .pilar { padding: 64px 48px; } }

/* ===== ÁREAS ===== */
.areas { background: var(--branco); }
.areas__grid { display: grid; grid-template-columns: 1fr; border: 1px solid var(--azul-muito-claro); }
@media (min-width: 600px) { .areas__grid { grid-template-columns: repeat(2, 1fr); } }

.area-card { border: 1px solid var(--azul-muito-claro); margin: -1px; }
.area-card--wide { grid-column: 1 / -1; }

.area-card__btn {
  width: 100%; display: flex; align-items: center; gap: 1rem;
  padding: 1.25rem 1.5rem;
  text-align: left; color: var(--azul-marinho);
  transition: background var(--trans), color var(--trans);
}
.area-card__btn:hover { background: var(--azul-suave); }
.area-card__btn[aria-expanded="true"] { background: var(--azul-marinho); color: var(--branco); }
.area-card__btn:focus-visible { outline: 2px solid var(--azul-medio); outline-offset: -2px; }

.area-card__num { font-size: 13px; font-weight: 400; color: var(--azul-claro); flex-shrink: 0; transition: color var(--trans); min-width: 1.5rem; }
.area-card__btn[aria-expanded="true"] .area-card__num { color: rgba(255,255,255,0.4); }
.area-card__name { font-size: 17px; font-weight: 700; flex: 1; letter-spacing: 0.01em; }

.area-card__icon { width: 18px; height: 18px; position: relative; flex-shrink: 0; margin-left: auto; }
.area-card__icon::before, .area-card__icon::after { content: ''; position: absolute; background: currentColor; border-radius: 1px; transition: transform 0.25s ease, opacity 0.25s ease; }
.area-card__icon::before { width: 10px; height: 1.5px; top: 50%; left: 50%; transform: translate(-50%, -50%); }
.area-card__icon::after  { width: 1.5px; height: 10px; top: 50%; left: 50%; transform: translate(-50%, -50%); }
.area-card__btn[aria-expanded="true"] .area-card__icon::after { transform: translate(-50%, -50%) rotate(90deg); opacity: 0; }

.area-card__body { padding: 0 1.5rem 1.5rem; background: var(--azul-marinho); }
.area-card__body[hidden] { display: none; }
.area-card__body > p { font-size: 17px; color: var(--azul-claro); line-height: 1.8; border-top: 1px solid rgba(255,255,255,0.09); padding-top: 1rem; }
.area-card__body p em { color: var(--azul-muito-claro); font-style: italic; }

.area-destaque {
  margin-top: 1.25rem;
  padding: 1.25rem;
  background: rgba(255,255,255,0.05);
  border-left: 3px solid var(--azul-claro);
}
.area-destaque strong {
  display: block;
  font-size: 13px; font-weight: 700;
  letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--azul-muito-claro);
  margin-bottom: 0.6rem;
}
.area-destaque p { border-top: none; padding-top: 0; margin-top: 0; font-size: 15px; }

@media (min-width: 1024px) {
  .area-card__btn  { padding: 44px 40px; }
  .area-card__body { padding: 0 40px 40px; }
}

/* ===== EQUIPE ===== */
.equipe { background: var(--off-white); }
.equipe__grid { display: grid; grid-template-columns: 1fr; gap: 1.25rem; }
@media (min-width: 640px) { .equipe__grid { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 1024px) { .equipe__grid { gap: 40px; } }

.membro { background: var(--branco); overflow: hidden; box-shadow: var(--shadow); }

.membro__foto-wrap { position: relative; background: var(--azul-marinho); }
.membro__foto { width: 100%; height: 220px; object-fit: cover; object-position: top center; display: block; }
.membro__foto-placeholder {
  width: 100%; height: 220px;
  background: var(--azul-marinho);
  display: flex; align-items: center; justify-content: center;
  font-size: 4rem; font-weight: 700;
  color: rgba(255,255,255,0.15);
}

.membro__header { background: var(--azul-marinho); padding: 1.25rem 1.5rem; display: flex; align-items: center; gap: 0.75rem; }
.membro__initial { width: 44px; height: 44px; border-radius: 50%; background: rgba(255,255,255,0.1); border: 1px solid rgba(255,255,255,0.18); display: flex; align-items: center; justify-content: center; font-size: 1.3rem; font-weight: 700; color: var(--branco); flex-shrink: 0; }
.membro__id { display: flex; flex-direction: column; gap: 0.1rem; }
.membro__name { font-size: 17px; font-weight: 700; color: var(--branco); line-height: 1.2; }
.membro__oab  { font-size: 13px; font-weight: 400; color: var(--azul-claro); letter-spacing: 0.08em; }

.membro__body { padding: 1.25rem 1.5rem; display: flex; flex-direction: column; gap: 0.75rem; }
.membro__bio { font-size: 15px; font-weight: 400; color: var(--texto-medio); line-height: 1.7; }

@media (min-width: 1024px) {
  .membro__header { padding: 44px 40px 36px; }
  .membro__body   { padding: 36px 40px; }
  .membro__foto   { height: 260px; }
  .membro__foto-placeholder { height: 260px; }
}

/* ===== COMO FUNCIONA ===== */
.como-funciona { background: var(--azul-marinho); }
.como-funciona__inner { display: grid; grid-template-columns: 1fr; gap: 3rem; max-width: var(--max-w); margin: 0 auto; }
@media (min-width: 768px) { .como-funciona__inner { grid-template-columns: 1fr 1.1fr; align-items: start; } }

.como-funciona__desc { color: var(--azul-claro); font-size: 17px; line-height: 1.75; margin-top: 0.5rem; max-width: 360px; }
.como-funciona__steps { display: flex; flex-direction: column; }

.etapa { display: flex; gap: 1.5rem; padding: 1.5rem 0; border-bottom: 1px solid rgba(255,255,255,0.07); }
.etapa:last-child { border-bottom: none; }
.etapa__num   { font-size: 2rem; font-weight: 700; color: rgba(255,255,255,0.18); flex-shrink: 0; line-height: 1; min-width: 2.4rem; }
.etapa__title { font-size: 26px; font-weight: 700; color: var(--branco); margin-bottom: 0.35rem; }
.etapa__text  { font-size: 17px; font-weight: 400; color: var(--azul-claro); line-height: 1.7; }

@media (min-width: 1024px) { .etapa { padding: 32px 0; } }

/* ===== TERRITÓRIO ===== */
.territorio { background: var(--branco); }
.territorio__grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 0.75rem; margin-bottom: 2rem; max-width: var(--max-w); }
@media (min-width: 480px) { .territorio__grid { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 768px) { .territorio__grid { grid-template-columns: repeat(4, 1fr); } }
@media (min-width: 1024px) { .territorio__grid { gap: 16px; } }

.cidade { padding: 1rem 1.15rem; border: 1px solid var(--azul-muito-claro); display: flex; flex-direction: column; gap: 0.2rem; transition: border-color var(--trans), background var(--trans); }
.cidade:hover { border-color: var(--azul-medio); background: var(--azul-suave); }
.cidade--sede { border-color: var(--azul-medio); background: var(--azul-suave); }
@media (max-width: 479px) { .cidade--sede { grid-column: span 2; } }
.cidade__label { font-size: 13px; font-weight: 700; letter-spacing: 0.16em; text-transform: uppercase; color: var(--azul-medio); }
.cidade__name  { font-size: 17px; font-weight: 700; color: var(--azul-marinho); }

.territorio__nota { font-size: 15px; font-weight: 400; color: var(--texto-suave); border-left: 2px solid var(--azul-muito-claro); padding-left: 1rem; line-height: 1.65; max-width: var(--max-w); }

/* ===== FAQ ===== */
.faq { background: var(--off-white); }
.faq__inner { display: grid; grid-template-columns: 1fr; gap: 3rem; max-width: var(--max-w); margin: 0 auto; }
@media (min-width: 768px) { .faq__inner { grid-template-columns: 1fr 1.7fr; align-items: start; } }

.faq__desc { font-size: 17px; font-weight: 400; color: var(--texto-medio); line-height: 1.75; margin-top: 0.5rem; }
.faq__accordions { display: flex; flex-direction: column; }

.faq-item { border-bottom: 1px solid var(--azul-muito-claro); }
.faq-item:first-child { border-top: 1px solid var(--azul-muito-claro); }

.faq-item__btn { width: 100%; display: flex; align-items: center; justify-content: space-between; gap: 1.25rem; padding: 1.25rem 0; text-align: left; font-size: 17px; font-weight: 700; color: var(--azul-marinho); transition: color var(--trans); }
.faq-item__btn:hover { color: var(--azul-medio); }
.faq-item__btn:focus-visible { outline: 2px solid var(--azul-medio); outline-offset: 2px; }

.faq-icon { width: 18px; height: 18px; position: relative; flex-shrink: 0; }
.faq-icon::before, .faq-icon::after { content: ''; position: absolute; background: currentColor; border-radius: 1px; transition: transform 0.25s ease, opacity 0.25s ease; }
.faq-icon::before { width: 10px; height: 1.5px; top: 50%; left: 50%; transform: translate(-50%, -50%); }
.faq-icon::after  { width: 1.5px; height: 10px; top: 50%; left: 50%; transform: translate(-50%, -50%); }
.faq-item__btn[aria-expanded="true"] .faq-icon::after { transform: translate(-50%, -50%) rotate(90deg); opacity: 0; }

.faq-item__body { padding-bottom: 1.25rem; }
.faq-item__body[hidden] { display: none; }
.faq-item__body p { font-size: 17px; font-weight: 400; color: var(--texto-medio); line-height: 1.8; }

/* ===== CONTATO ===== */
.contato { background: var(--azul-marinho); }
.contato__inner { display: grid; grid-template-columns: 1fr; gap: 3rem; padding-top: 5rem; padding-bottom: 5rem; max-width: var(--max-w); margin: 0 auto; }
@media (min-width: 768px) { .contato__inner { grid-template-columns: 1fr 1.5fr; } }
@media (min-width: 1024px) { .contato__inner { padding-top: 0; padding-bottom: 0; } }

.contato__logo { height: 44px; width: auto; margin-bottom: 1.5rem; display: block; }
.contato__dados { display: flex; flex-direction: column; gap: 1.75rem; margin-top: 0.5rem; }
.contato__dado  { display: flex; flex-direction: column; gap: 0.3rem; }
.contato__dado-label { font-size: 13px; font-weight: 700; letter-spacing: 0.18em; text-transform: uppercase; color: var(--azul-claro); }
.contato__dado span, .contato__dado a { font-size: 17px; font-weight: 400; color: rgba(255,255,255,0.75); line-height: 1.6; transition: color var(--trans); }
.contato__dado a:hover { color: var(--branco); }

/* Formulário */
.contato__form { display: flex; flex-direction: column; gap: 1rem; }
.form-group { display: flex; flex-direction: column; gap: 0.4rem; }
.form-group label { font-size: 13px; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; color: var(--azul-claro); }
.form-req { color: rgba(255,255,255,0.3); }
.form-group input, .form-group select, .form-group textarea {
  background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.14);
  border-radius: var(--radius); padding: 0.8rem 1rem;
  font-family: var(--font); font-size: 17px; font-weight: 400; color: var(--branco);
  outline: none; transition: border-color var(--trans), background var(--trans);
  -webkit-appearance: none; appearance: none; width: 100%;
}
.form-group select { background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' fill='none'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%238BADD4' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 1rem center; padding-right: 2.5rem; cursor: pointer; }
.form-group select option { background: var(--azul-marinho); color: var(--branco); }
.form-group input::placeholder, .form-group textarea::placeholder { color: rgba(255,255,255,0.22); }
.form-group input:focus, .form-group select:focus, .form-group textarea:focus { border-color: var(--azul-claro); background: rgba(255,255,255,0.09); }
.form-group input.invalid, .form-group textarea.invalid { border-color: #ef9a9a; }
.form-error  { font-size: 13px; color: #ef9a9a; min-height: 1em; }
.form-submit { align-self: flex-start; margin-top: 0.5rem; }
.form-privacy { font-size: 13px; font-weight: 400; color: rgba(255,255,255,0.38); line-height: 1.55; margin-top: 0.25rem; }
.form-oab     { font-size: 13px; font-weight: 400; color: rgba(255,255,255,0.25); }
.form-success { padding: 2rem; background: rgba(255,255,255,0.05); border: 1px solid rgba(139,173,212,0.25); text-align: center; }
.form-success[hidden] { display: none; }
.form-success p { color: var(--azul-claro); font-size: 17px; line-height: 1.65; }
.form-success__oab { margin-top: 0.5rem; font-size: 13px !important; color: rgba(255,255,255,0.25) !important; }

/* ===== FOOTER ===== */
.footer { border-top: 1px solid rgba(255,255,255,0.07); padding: 1.5rem var(--pad-x); }
.footer__inner { display: flex; flex-direction: column; gap: 0.4rem; font-size: 13px; font-weight: 400; color: rgba(255,255,255,0.28); letter-spacing: 0.04em; max-width: var(--max-w); margin: 0 auto; }
@media (min-width: 640px) { .footer__inner { flex-direction: row; justify-content: space-between; align-items: center; } }

/* ===== WHATSAPP FLUTUANTE ===== */
.whatsapp-btn {
  position: fixed;
  bottom: 1.5rem;
  right: 1.5rem;
  z-index: 999;
  display: flex;
  align-items: center;
  gap: 0.55rem;
  background: #25D366;
  color: #fff;
  border-radius: 50px;
  padding: 0.7rem 1.1rem 0.7rem 0.8rem;
  box-shadow: 0 4px 20px rgba(0,0,0,0.18), 0 2px 8px rgba(37,211,102,0.35);
  font-family: var(--font);
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.03em;
  text-decoration: none;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
  white-space: nowrap;
  cursor: pointer;
}
.whatsapp-btn:hover {
  background: #1ebe5d;
  transform: translateY(-2px) scale(1.02);
  box-shadow: 0 8px 28px rgba(0,0,0,0.18), 0 4px 12px rgba(37,211,102,0.45);
}
.whatsapp-btn__icon {
  width: 24px;
  height: 24px;
  flex-shrink: 0;
  display: block;
}
@media (max-width: 540px) {
  .whatsapp-btn {
    bottom: 1.25rem;
    right: 1.25rem;
    padding: 0.85rem;
    border-radius: 50%;
  }
  .whatsapp-btn__label { display: none; }
}

/* ===== SCHEMA (oculto visualmente) ===== */
script[type="application/ld+json"] { display: none; }
