/* ═══════════════════════════════════════════════════
   FOGAGNOLO ADVOCACIA — Tema Jurídico Premium
   Cores: Navy Escuro + Dourado Clássico
   ═══════════════════════════════════════════════════ */

/* ─── 1. TOKENS ─── */
:root {
  /* Backgrounds */
  --bg:   #07101A;
  --bg-2: #0C1622;
  --bg-3: #101D2C;
  --card:  #111E2D;
  --card-2:#182435;

  /* Borders */
  --border:      rgba(255,255,255,0.07);
  --border-gold: rgba(201,168,76,0.30);
  --border-blue: rgba(30,80,140,0.25);

  /* Brand — Dourado Clássico */
  --gold:       #C9A84C;
  --gold-dark:  #A07830;
  --gold-light: #E8C870;
  --gold-dim:   rgba(201,168,76,0.12);

  /* Acento — Navy Azul */
  --blue:       #1E508C;
  --blue-light: #4A7FBB;
  --blue-dim:   rgba(30,80,140,0.12);

  /* Outros */
  --emerald: #2EAA76;
  --red:     #EF4444;

  /* Gradientes */
  --grad-brand:  linear-gradient(135deg, #C9A84C 0%, #E8C870 100%);
  --grad-hero:   linear-gradient(135deg, #1E3A5F 0%, #0C1622 60%, #07101A 100%);
  --grad-card:   linear-gradient(135deg, rgba(201,168,76,.06) 0%, rgba(30,80,140,.06) 100%);
  --grad-dark:   linear-gradient(180deg, #07101A 0%, #0C1622 100%);
  --grad-text:   linear-gradient(135deg, #C9A84C 0%, #E8C870 50%, #C9A84C 100%);

  /* Texto */
  --text:        #F2EEE6;
  --text-muted:  rgba(242,238,230,0.65);
  --text-subtle: rgba(242,238,230,0.35);
  --success:     #2EAA76;
  --error:       #EF4444;

  /* Espaçamento */
  --space-1:4px;  --space-2:8px;   --space-3:12px;  --space-4:16px;
  --space-5:20px; --space-6:24px;  --space-8:32px;  --space-10:40px;
  --space-12:48px;--space-16:64px; --space-20:80px; --space-24:96px;

  /* Tipografia */
  --font:       'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  --font-serif: 'Georgia', 'Times New Roman', serif;

  /* Bordas arredondadas */
  --r-sm:4px; --r-md:10px; --r-lg:16px; --r-xl:24px; --r-2xl:32px; --r-full:9999px;

  /* Sombras */
  --sh-sm:   0 2px 8px rgba(0,0,0,.4);
  --sh-md:   0 8px 24px rgba(0,0,0,.5);
  --sh-lg:   0 20px 60px rgba(0,0,0,.6);
  --sh-gold: 0 0 30px rgba(201,168,76,.20), 0 8px 32px rgba(0,0,0,.4);
  --sh-card: 0 0 0 1px rgba(255,255,255,.05), 0 20px 60px rgba(0,0,0,.5);

  /* Transições */
  --fast: 150ms ease;
  --base: 260ms ease;
  --slow: 450ms cubic-bezier(.4,0,.2,1);

  --container: 1180px;
  --pad: clamp(16px,4vw,24px);
}

/* ─── 2. RESET ─── */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0 }
html { scroll-behavior:smooth; font-size:16px; -webkit-text-size-adjust:100% }
body { font-family:var(--font); color:var(--text); background:var(--bg); line-height:1.6; -webkit-font-smoothing:antialiased }
img,svg { display:block; max-width:100% }
a { color:inherit; text-decoration:none }
ul,ol { list-style:none }
button { font-family:inherit; cursor:pointer; border:none; background:none }
input,textarea,select { font-family:inherit }
address { font-style:normal }

/* ─── 3. TIPOGRAFIA ─── */
h1,h2,h3,h4,h5,h6 { font-weight:700; line-height:1.15; color:var(--text); letter-spacing:-.02em }
h1 { font-size:clamp(2rem,5vw,3.4rem); font-weight:800 }
h2 { font-size:clamp(1.5rem,3vw,2.3rem) }
h3 { font-size:clamp(1.05rem,1.8vw,1.3rem); font-weight:600 }
p  { color:var(--text-muted); line-height:1.75 }

.gradient-text {
  background: var(--grad-text);
  background-size: 200% auto;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  animation: shimmer-text 5s linear infinite;
}

/* ─── 4. LAYOUT ─── */
.container { width:100%; max-width:var(--container); margin:0 auto; padding:0 var(--pad) }
.section    { padding:var(--space-20) 0 }
.section--alt { background:var(--bg-2) }
.section-header { text-align:center; max-width:680px; margin:0 auto var(--space-12) }
.section-header h2 { margin:var(--space-3) 0 var(--space-4) }
.section-header p  { font-size:1.1rem }

.grid-2 { display:grid; grid-template-columns:1fr; gap:var(--space-6) }
.grid-3 { display:grid; grid-template-columns:1fr; gap:var(--space-6) }
.grid-4 { display:grid; grid-template-columns:1fr 1fr; gap:var(--space-6) }

@media(min-width:640px){
  .grid-2 { grid-template-columns:repeat(2,1fr) }
  .grid-4 { grid-template-columns:repeat(2,1fr) }
}
@media(min-width:900px){
  .grid-3 { grid-template-columns:repeat(3,1fr) }
  .grid-4 { grid-template-columns:repeat(4,1fr) }
}

/* ─── 5. BADGE ─── */
.badge {
  display:inline-flex; align-items:center; gap:6px;
  font-size:.75rem; font-weight:700; letter-spacing:.07em; text-transform:uppercase;
  padding:5px 14px; border-radius:var(--r-full);
  background:var(--gold-dim); color:var(--gold);
  border:1px solid rgba(201,168,76,.22);
}

/* ─── 6. BOTÕES ─── */
.btn {
  display:inline-flex; align-items:center; gap:var(--space-2);
  font-family:var(--font); font-weight:700; font-size:1rem; line-height:1;
  padding:14px 26px; border-radius:var(--r-full);
  border:2px solid transparent; transition:all var(--base);
  white-space:nowrap; cursor:pointer; text-decoration:none; position:relative; overflow:hidden
}
.btn::after {
  content:''; position:absolute; top:0; left:-100%; width:60%; height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.12),transparent);
  transition:.6s ease; pointer-events:none
}
.btn:hover::after { left:140% }

.btn--primary {
  background:var(--grad-brand); color:#1a0e00;
  box-shadow: var(--sh-gold)
}
.btn--primary:hover {
  transform:translateY(-2px);
  box-shadow: 0 0 40px rgba(201,168,76,.35), 0 12px 40px rgba(0,0,0,.4)
}
.btn--primary:active { transform:translateY(0) }

.btn--outline {
  background:transparent; color:var(--gold);
  border-color:rgba(201,168,76,.4)
}
.btn--outline:hover {
  background:rgba(201,168,76,.08); border-color:var(--gold);
  transform:translateY(-2px)
}

.btn--ghost {
  background:rgba(255,255,255,.06); color:var(--text); border-color:var(--border)
}
.btn--ghost:hover { background:rgba(255,255,255,.1); transform:translateY(-2px) }

.btn--lg  { padding:17px 34px; font-size:1.1rem }
.btn--sm  { padding:10px 18px; font-size:.9rem }
.btn--block { width:100%; justify-content:center }

/* ─── 7. CARDS ─── */
.card {
  background:var(--card); border:1px solid var(--border);
  border-radius:var(--r-lg); padding:var(--space-6);
  position:relative; overflow:hidden;
  transition:all var(--base)
}
.card:hover {
  border-color:rgba(201,168,76,.25);
  box-shadow: 0 0 30px rgba(201,168,76,.05), 0 20px 60px rgba(0,0,0,.5);
  transform:translateY(-3px)
}
.card--feature::after {
  content:''; position:absolute; top:0; left:0; right:0; height:2px;
  background:var(--grad-brand); opacity:0; transition:opacity var(--base)
}
.card--feature:hover::after { opacity:1 }

.card__icon {
  width:52px; height:52px; border-radius:var(--r-md);
  background:var(--gold-dim); border:1px solid rgba(201,168,76,.15);
  display:flex; align-items:center; justify-content:center;
  margin-bottom:var(--space-4); color:var(--gold);
  transition:all var(--base)
}
.card:hover .card__icon {
  background:var(--grad-brand); color:#1a0e00; border-color:transparent;
  box-shadow:0 0 16px rgba(201,168,76,.25)
}
.card__title { margin-bottom:var(--space-2); font-size:1.1rem }
.card__desc  { font-size:.95rem; color:var(--text-muted); line-height:1.65 }

/* Checklist */
.checklist { display:flex; flex-direction:column; gap:var(--space-3) }
.checklist li {
  display:flex; align-items:flex-start; gap:var(--space-3);
  font-size:.95rem; color:var(--text-muted)
}
.checklist li::before {
  content:''; width:20px; height:20px; border-radius:50%; flex-shrink:0; margin-top:2px;
  background:var(--emerald);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");
  background-size:12px; background-position:center; background-repeat:no-repeat
}

/* ─── 8. NAVEGAÇÃO ─── */
.nav {
  position:sticky; top:0; z-index:100;
  background:rgba(7,16,26,.94);
  backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid var(--border)
}
.nav__inner { display:flex; align-items:center; height:68px; gap:var(--space-6) }
.nav__logo {
  display:flex; align-items:center; gap:10px;
  font-weight:800; font-size:1.15rem; color:var(--text); letter-spacing:-.02em; flex-shrink:0
}
.nav__logo-icon {
  width:36px; height:36px; border-radius:10px;
  background:var(--grad-brand);
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 0 14px rgba(201,168,76,.25)
}
.nav__links { display:none; align-items:center; gap:2px; margin:0 auto }
.nav__links a {
  font-size:.88rem; font-weight:500; color:var(--text-muted);
  padding:7px 13px; border-radius:var(--r-full); transition:all var(--fast)
}
.nav__links a:hover { color:var(--gold); background:var(--gold-dim) }
.nav__actions { display:flex; align-items:center; gap:var(--space-3); margin-left:auto }
.nav__cta { padding:9px 18px; font-size:.875rem }

.nav__toggle-input { display:none }
.nav__hamburger {
  display:flex; flex-direction:column; justify-content:center; gap:5px;
  width:36px; height:36px; padding:6px; cursor:pointer;
  border-radius:var(--r-sm); transition:background var(--fast)
}
.nav__hamburger:hover { background:rgba(255,255,255,.06) }
.nav__hamburger span { display:block; height:2px; background:var(--text-muted); border-radius:2px; transition:all var(--base) }
.nav__toggle-input:checked ~ .nav__mobile-menu {
  display:flex; flex-direction:column;
  position:absolute; top:68px; left:0; right:0;
  background:rgba(7,16,26,.98); border-bottom:1px solid var(--border);
  padding:var(--space-4) var(--pad); gap:var(--space-2);
  box-shadow:var(--sh-lg); z-index:99
}
.nav__mobile-menu { display:none }
.nav__mobile-menu a {
  font-size:1rem; font-weight:500; color:var(--text-muted);
  padding:12px 16px; border-radius:var(--r-md); transition:background var(--fast)
}
.nav__mobile-menu a:hover { background:var(--gold-dim); color:var(--gold) }
.nav__mobile-menu .btn { width:100%; justify-content:center; margin-top:var(--space-2) }

@media(min-width:900px){
  .nav__links { display:flex }
  .nav__hamburger { display:none }
}

/* ─── 9. HERO ─── */
.hero {
  position:relative; overflow:hidden;
  background:var(--bg);
  padding:var(--space-20) 0 0; min-height:88vh;
  display:flex; align-items:center
}
.hero__grid {
  position:absolute; inset:0; z-index:0; pointer-events:none;
  background-image:
    linear-gradient(rgba(201,168,76,.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(201,168,76,.03) 1px, transparent 1px);
  background-size: 70px 70px
}
.hero__glow {
  position:absolute; right:0; top:50%; transform:translateY(-50%);
  width:600px; height:600px;
  background:radial-gradient(circle, rgba(30,80,140,.12) 0%, transparent 65%);
  z-index:1; pointer-events:none
}
.hero__overlay {
  position:absolute; inset:0; z-index:2; pointer-events:none;
  background:linear-gradient(90deg, rgba(7,16,26,.98) 45%, rgba(7,16,26,.70) 70%, rgba(7,16,26,.15) 100%)
}
.hero__fade {
  position:absolute; bottom:0; left:0; right:0; height:200px; z-index:3; pointer-events:none;
  background:linear-gradient(0deg, var(--bg) 0%, transparent 100%)
}
.hero__deco {
  position:absolute; right:5%; top:50%; transform:translateY(-50%);
  font-size:clamp(160px,22vw,320px); line-height:1;
  color:rgba(201,168,76,.04);
  pointer-events:none; z-index:2; user-select:none;
  font-family:var(--font-serif); font-weight:700;
  animation:float 10s ease-in-out infinite;
}
.hero__inner {
  position:relative; z-index:4;
  padding-bottom:var(--space-24)
}
.hero__label {
  display:inline-flex; align-items:center; gap:10px;
  font-size:.76rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase;
  color:rgba(201,168,76,.7); margin-bottom:var(--space-6);
  animation:fadeUp .5s ease both
}
.hero__heading { max-width:660px; margin-bottom:var(--space-5); animation:fadeUp .5s .1s ease both }
.hero__sub {
  font-size:clamp(.95rem,1.6vw,1.1rem); color:var(--text-muted);
  max-width:520px; margin-bottom:var(--space-8); animation:fadeUp .5s .2s ease both
}
.hero__actions {
  display:flex; flex-wrap:wrap; gap:var(--space-4);
  margin-bottom:var(--space-10); animation:fadeUp .5s .3s ease both
}
.hero__trust {
  display:flex; flex-wrap:wrap; gap:var(--space-6);
  animation:fadeUp .5s .4s ease both
}
.trust-badge {
  display:inline-flex; align-items:center; gap:8px;
  font-size:.88rem; font-weight:500; color:var(--text-muted)
}
.trust-badge svg { color:var(--emerald); flex-shrink:0 }

/* ─── 10. TRUST BAR ─── */
.trust-bar {
  background:rgba(201,168,76,.03);
  border-top:1px solid rgba(201,168,76,.08);
  border-bottom:1px solid rgba(201,168,76,.08);
  padding:var(--space-6) 0
}
.trust-bar__inner {
  display:flex; flex-wrap:wrap; align-items:center; justify-content:center; gap:var(--space-8)
}
.trust-bar__item {
  display:flex; align-items:center; gap:var(--space-3);
  font-size:.88rem; font-weight:600; color:var(--text-muted)
}
.trust-bar__item svg { color:var(--gold) }

/* ─── 11. STEPS ─── */
.steps { display:flex; flex-direction:column; gap:0; max-width:700px; margin:0 auto }
.step  { display:flex; gap:var(--space-6); padding-bottom:var(--space-8); position:relative }
.step:not(:last-child)::before {
  content:''; position:absolute; left:23px; top:52px; bottom:0; width:2px;
  background:linear-gradient(to bottom,rgba(201,168,76,.3),transparent)
}
.step__num {
  width:48px; height:48px; border-radius:50%;
  background:var(--grad-brand); color:#1a0e00; font-weight:800; font-size:1.1rem;
  display:flex; align-items:center; justify-content:center; flex-shrink:0;
  box-shadow:var(--sh-gold)
}
.step__content { padding-top:10px }
.step__content h3 { margin-bottom:var(--space-2); color:var(--text) }
.step__content p  { font-size:.95rem }

/* ─── 12. SPECIALIST / LAWYER ─── */
.specialist-grid {
  display:grid; grid-template-columns:1fr; gap:var(--space-12); align-items:center
}
@media(min-width:900px) { .specialist-grid { grid-template-columns:1fr 1fr; gap:var(--space-16) } }

.specialist-photo {
  position:relative; border-radius:var(--r-xl); overflow:hidden;
  box-shadow:0 0 0 1px var(--border-gold), var(--sh-lg)
}
.specialist-photo img {
  width:100%; height:auto; aspect-ratio:4/5;
  object-fit:cover; object-position:center top; display:block; max-height:560px
}
.specialist-photo__badge {
  position:absolute; bottom:var(--space-5); left:var(--space-5); right:var(--space-5);
  background:rgba(7,16,26,.90); backdrop-filter:blur(12px);
  border:1px solid var(--border-gold); border-radius:var(--r-md);
  padding:var(--space-4) var(--space-5); display:flex; align-items:center; gap:var(--space-3)
}
.specialist-photo__badge .dot {
  width:10px; height:10px; border-radius:50%; background:var(--emerald);
  box-shadow:0 0 0 3px rgba(46,170,118,.2); flex-shrink:0
}
.specialist-photo__badge p    { font-size:.82rem; color:var(--text-muted); margin:0 }
.specialist-photo__badge strong { color:var(--text); display:block; font-size:.95rem }
.specialist-content h2 { margin-bottom:var(--space-5) }
.specialist-content p  { margin-bottom:var(--space-4); font-size:.98rem }
.specialist-stats {
  display:grid; grid-template-columns:repeat(3,1fr); gap:var(--space-4);
  margin:var(--space-8) 0
}
.specialist-stat {
  background:var(--card); border:1px solid var(--border);
  border-radius:var(--r-md); padding:var(--space-4); text-align:center;
  transition:all var(--base)
}
.specialist-stat:hover { border-color:var(--border-gold) }
.specialist-stat__num {
  font-size:1.8rem; font-weight:800;
  background:var(--grad-brand); -webkit-background-clip:text;
  -webkit-text-fill-color:transparent; background-clip:text; line-height:1
}
.specialist-stat__label { font-size:.76rem; color:var(--text-subtle); margin-top:4px }

/* ─── 13. FAQ ─── */
.faq-list { max-width:760px; margin:0 auto }
details.faq-item {
  border:1px solid var(--border); border-radius:var(--r-md);
  margin-bottom:var(--space-3); overflow:hidden; transition:all var(--base)
}
details.faq-item:hover { border-color:rgba(201,168,76,.2) }
details.faq-item[open] { border-color:var(--border-gold); background:rgba(201,168,76,.025) }
summary.faq-question {
  display:flex; align-items:center; justify-content:space-between;
  padding:var(--space-5) var(--space-6); cursor:pointer;
  font-weight:600; font-size:1rem; color:var(--text);
  list-style:none; gap:var(--space-4); user-select:none
}
summary.faq-question::-webkit-details-marker { display:none }
.faq-icon {
  width:28px; height:28px; border-radius:50%;
  background:var(--gold-dim); color:var(--gold);
  display:flex; align-items:center; justify-content:center;
  flex-shrink:0; transition:all var(--base); font-size:18px; font-weight:400; line-height:1
}
details.faq-item[open] .faq-icon { background:var(--grad-brand); color:#1a0e00; transform:rotate(45deg) }
.faq-answer { padding:0 var(--space-6) var(--space-5); font-size:.95rem; color:var(--text-muted); line-height:1.75 }
.faq-answer a { color:var(--gold); font-weight:500 }

/* ─── 14. AREAS DE ATUACAO ─── */
.area-card {
  background:var(--card); border:1px solid var(--border);
  border-radius:var(--r-lg); padding:var(--space-6);
  transition:all var(--base); position:relative; overflow:hidden
}
.area-card::after {
  content:''; position:absolute; top:0; left:0; right:0; height:2px;
  background:var(--grad-brand); opacity:0; transition:opacity var(--base)
}
.area-card:hover { border-color:rgba(201,168,76,.3); transform:translateY(-4px); box-shadow:0 0 30px rgba(201,168,76,.06) }
.area-card:hover::after { opacity:1 }
.area-icon {
  width:52px; height:52px; border-radius:var(--r-md);
  background:var(--gold-dim); border:1px solid rgba(201,168,76,.15);
  display:flex; align-items:center; justify-content:center;
  margin-bottom:var(--space-4); color:var(--gold); font-size:22px;
  transition:all var(--base)
}
.area-card:hover .area-icon { background:var(--grad-brand); color:#1a0e00; border-color:transparent }
.area-card h3 { margin-bottom:var(--space-2); font-size:1.05rem }
.area-card p  { font-size:.9rem }

/* ─── 15. CTA FINAL ─── */
.cta-final {
  background:var(--bg-2); padding:var(--space-20) 0;
  text-align:center; position:relative; overflow:hidden;
  border-top:1px solid rgba(201,168,76,.1); border-bottom:1px solid rgba(201,168,76,.1)
}
.cta-final::before {
  content:''; position:absolute; left:50%; top:50%; transform:translate(-50%,-50%);
  width:700px; height:700px;
  background:radial-gradient(circle, rgba(30,80,140,.08) 0%, transparent 65%);
  pointer-events:none
}
.cta-final__inner  { position:relative; z-index:1 }
.cta-final h2 { color:var(--text); max-width:580px; margin:0 auto var(--space-4) }
.cta-final p  { color:var(--text-muted); margin-bottom:var(--space-8); font-size:1.05rem }
.cta-note { margin-top:var(--space-5); font-size:.85rem; color:var(--text-subtle) }

/* ─── 16. FOOTER ─── */
.footer {
  background:rgba(0,0,0,.65); border-top:1px solid var(--border);
  padding:var(--space-16) 0 0; color:var(--text-subtle)
}
.footer__top {
  display:grid; grid-template-columns:1fr; gap:var(--space-10);
  padding-bottom:var(--space-12); border-bottom:1px solid var(--border)
}
@media(min-width:640px)  { .footer__top { grid-template-columns:repeat(2,1fr) } }
@media(min-width:1024px) { .footer__top { grid-template-columns:2fr 1fr 1fr 2fr } }

.footer__logo-text {
  font-size:1.1rem; font-weight:800; color:var(--text); letter-spacing:-.02em;
  display:flex; align-items:center; gap:10px; margin-bottom:var(--space-4)
}
.footer__logo-icon {
  width:30px; height:30px; border-radius:8px; background:var(--grad-brand);
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 0 10px rgba(201,168,76,.2)
}
.footer__brand p { font-size:.86rem; color:var(--text-subtle); max-width:280px; margin-bottom:var(--space-5) }
.footer__trust-list { display:flex; flex-direction:column; gap:var(--space-2) }
.footer__trust-item {
  display:flex; align-items:center; gap:8px; font-size:.78rem; color:var(--text-subtle)
}
.footer__trust-item svg { color:var(--emerald); flex-shrink:0 }

.footer__col h3 {
  font-size:.75rem; font-weight:700; color:var(--text);
  letter-spacing:.06em; text-transform:uppercase; margin-bottom:var(--space-5)
}
.footer__col ul { display:flex; flex-direction:column; gap:var(--space-3) }
.footer__col ul a { font-size:.86rem; color:var(--text-subtle); transition:color var(--fast) }
.footer__col ul a:hover { color:var(--gold) }

.footer__company h3 {
  font-size:.75rem; font-weight:700; color:var(--text);
  letter-spacing:.06em; text-transform:uppercase; margin-bottom:var(--space-5)
}
.footer__company address { font-size:.8rem; color:var(--text-subtle); line-height:1.9 }
.footer__company address strong { color:rgba(242,238,230,.65) }
.footer__company address a { color:var(--text-subtle); transition:color var(--fast) }
.footer__company address a:hover { color:var(--gold) }
.footer__hours { margin-top:var(--space-4); font-size:.73rem; color:var(--text-subtle); border-top:1px solid var(--border); padding-top:var(--space-4) }
.footer__bottom {
  display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between;
  gap:var(--space-4); padding:var(--space-6) 0; font-size:.76rem; color:var(--text-subtle)
}
.footer__bottom-links { display:flex; flex-wrap:wrap; gap:var(--space-4) }
.footer__bottom-links a { color:var(--text-subtle); transition:color var(--fast) }
.footer__bottom-links a:hover { color:var(--gold) }

/* ─── 17. PÁGINAS SECUNDÁRIAS ─── */
.page-hero {
  background:var(--bg-2); padding:var(--space-16) 0 var(--space-12);
  border-bottom:1px solid var(--border);
  position:relative; overflow:hidden
}
.page-hero::before {
  content:''; position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(201,168,76,.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(201,168,76,.025) 1px, transparent 1px);
  background-size:70px 70px; pointer-events:none
}
.page-hero .badge { margin-bottom:var(--space-4) }
.page-hero h1 { margin-bottom:var(--space-4) }
.page-hero p  { font-size:1.05rem; max-width:560px }

/* ─── 18. POLICY CONTENT ─── */
.policy-content { max-width:800px; margin:0 auto }
.policy-content h2 {
  font-size:1.45rem; margin:var(--space-10) 0 var(--space-4);
  padding-bottom:var(--space-3); border-bottom:1px solid var(--border); color:var(--text)
}
.policy-content h2:first-child { margin-top:0 }
.policy-content h3 { font-size:1rem; margin:var(--space-6) 0 var(--space-3); color:var(--text-muted) }
.policy-content p  { margin-bottom:var(--space-4); font-size:.95rem; color:var(--text-muted); line-height:1.8 }
.policy-content ul,.policy-content ol { margin:var(--space-4) 0; padding-left:var(--space-6) }
.policy-content ul { list-style:disc }
.policy-content ol { list-style:decimal }
.policy-content li { font-size:.95rem; color:var(--text-muted); line-height:1.8; margin-bottom:var(--space-2) }
.policy-content a  { color:var(--gold); font-weight:500 }
.policy-content strong { color:var(--text-muted) }
.policy-update {
  background:var(--gold-dim); border:1px solid rgba(201,168,76,.2);
  border-radius:var(--r-md); padding:var(--space-4) var(--space-5);
  margin-bottom:var(--space-8); font-size:.9rem; color:var(--gold); font-weight:500
}

/* ─── 19. CONTATO ─── */
.contact-card {
  background:var(--card); border:1px solid var(--border);
  border-radius:var(--r-lg); padding:var(--space-8) var(--space-6);
  text-align:center; transition:all var(--base)
}
.contact-card:hover { border-color:var(--border-gold); box-shadow:0 0 24px rgba(201,168,76,.05); transform:translateY(-3px) }
.contact-card-icon {
  width:64px; height:64px; border-radius:var(--r-lg);
  background:var(--gold-dim); border:1px solid rgba(201,168,76,.2);
  color:var(--gold); display:flex; align-items:center; justify-content:center; margin:0 auto var(--space-4)
}
.contact-card h3 { margin-bottom:var(--space-2); font-size:1.05rem }
.contact-card p  { font-size:.88rem; margin-bottom:var(--space-3) }
.contact-card a  { color:var(--gold); font-weight:700; font-size:.95rem; transition:color var(--fast) }
.contact-card a:hover { color:var(--gold-light) }

.form-group { margin-bottom:var(--space-5) }
.form-group label {
  display:block; font-size:.82rem; font-weight:700; color:var(--text-muted);
  margin-bottom:var(--space-2); letter-spacing:.02em
}
.form-group input,.form-group select,.form-group textarea {
  width:100%; padding:12px 16px;
  border:1.5px solid var(--border); border-radius:var(--r-md);
  font-size:.95rem; color:var(--text); background:var(--card);
  transition:border-color var(--fast),box-shadow var(--fast); outline:none
}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus {
  border-color:var(--gold); box-shadow:0 0 0 3px rgba(201,168,76,.1)
}
.form-group select option { background:var(--card); color:var(--text) }
.form-group textarea { resize:vertical; min-height:120px }
.form-group input::placeholder,.form-group textarea::placeholder { color:var(--text-subtle) }
.form-privacy { font-size:.78rem; color:var(--text-subtle); margin-top:var(--space-4) }
.form-privacy a { color:var(--gold) }
.contact-form-wrap { max-width:640px; margin:0 auto }

/* ─── 20. SOBRE / VALORES ─── */
.value-card {
  background:var(--card); border:1px solid var(--border);
  border-radius:var(--r-lg); padding:var(--space-6); transition:all var(--base)
}
.value-card:hover { box-shadow:0 0 24px rgba(201,168,76,.05); border-color:var(--border-gold) }
.value-icon {
  width:48px; height:48px; border-radius:var(--r-md); background:var(--grad-brand);
  display:flex; align-items:center; justify-content:center; margin-bottom:var(--space-4); font-size:20px
}
.value-card h3 { margin-bottom:var(--space-2); font-size:1rem }
.value-card p  { font-size:.88rem }

.company-info-box {
  background:var(--card); border:1px solid var(--border); border-radius:var(--r-lg); padding:var(--space-8)
}
.company-info-box dl { display:grid; grid-template-columns:auto 1fr; gap:var(--space-3) var(--space-8) }
.company-info-box dt { font-weight:700; font-size:.88rem; color:var(--text-muted); white-space:nowrap }
.company-info-box dd { font-size:.88rem; color:var(--text-subtle) }
.company-info-box dd a { color:var(--gold); font-weight:500 }
@media(max-width:640px){
  .company-info-box dl { grid-template-columns:1fr; gap:var(--space-2) }
  .company-info-box dt { margin-bottom:-8px }
}

.compliance-strip { display:flex; flex-wrap:wrap; gap:var(--space-4); align-items:center }
.compliance-badge {
  display:flex; align-items:center; gap:8px;
  background:var(--card); border:1px solid var(--border);
  border-radius:var(--r-full); padding:8px 16px;
  font-size:.86rem; font-weight:600; color:var(--text-muted)
}
.compliance-badge svg { color:var(--emerald) }

/* ─── 21. SCROLL REVEAL ─── */
.reveal {
  opacity:0; transform:translateY(24px);
  transition:opacity .6s ease, transform .6s ease
}
.reveal.visible { opacity:1; transform:translateY(0) }
.reveal[data-delay="100"] { transition-delay:.1s }
.reveal[data-delay="200"] { transition-delay:.2s }
.reveal[data-delay="300"] { transition-delay:.3s }
.reveal[data-delay="400"] { transition-delay:.4s }

/* ─── 22. ANIMAÇÕES ─── */
@keyframes float {
  0%,100% { transform:translateY(-50%) rotate(-2deg) }
  50%      { transform:translateY(calc(-50% - 18px)) rotate(2deg) }
}
@keyframes fadeUp {
  from { opacity:0; transform:translateY(24px) }
  to   { opacity:1; transform:translateY(0) }
}
@keyframes shimmer-text {
  0%   { background-position: 0% center }
  100% { background-position: 200% center }
}

/* ─── 23. RESPONSIVO ─── */
@media(max-width:640px){
  :root { --pad:16px }
  .section { padding:var(--space-12) 0 }
  .hero { padding-top:var(--space-12); min-height:auto }
  .hero__deco { right:-3%; opacity:.4; font-size:clamp(120px,55vw,200px) }
  .hero__overlay { background:linear-gradient(180deg,rgba(7,16,26,.97) 0%,rgba(7,16,26,.88) 100%) }
  .hero__actions { flex-direction:column }
  .hero__actions .btn { width:100%; justify-content:center }
}

/* ─── 24. PRINT ─── */
@media print{
  .nav,.hero__deco,.cta-final,.footer__bottom-links { display:none }
  body { font-size:12pt; background:#fff; color:#000 }
  a[href]::after { content:" (" attr(href) ")" }
}
