/* ============================================================
   RSH ADVOGADOS — Reis Simas & Heidrich
   Folha de estilo principal | Identidade: autoridade jurídica
   Paleta: navy profundo + dourado + off-white
   ============================================================ */

:root {
  --navy-900: #08172b;
  --navy-800: #0b1f3a;
  --navy-700: #102a4c;
  --navy-600: #16385f;
  --gold: #c8a24b;
  --gold-soft: #d9bd78;
  --gold-deep: #a9853a;
  --ivory: #f6f2e9;
  --paper: #faf8f3;
  --ink: #1c2430;
  --slate: #4a586b;
  --slate-light: #7c8aa0;
  --line: #e4ddd0;
  --white: #ffffff;

  --serif: "Cormorant Garamond", "Playfair Display", Georgia, serif;
  --sans: "Manrope", "Inter", system-ui, -apple-system, sans-serif;

  --maxw: 1200px;
  --radius: 4px;
  --shadow-sm: 0 4px 18px rgba(8, 23, 43, 0.08);
  --shadow-md: 0 18px 50px rgba(8, 23, 43, 0.16);
  --ease: cubic-bezier(0.22, 1, 0.36, 1);
}

* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  font-family: var(--sans);
  color: var(--ink);
  background: var(--paper);
  line-height: 1.7;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
.wrap { width: 100%; max-width: var(--maxw); margin: 0 auto; padding: 0 28px; }
h1, h2, h3, h4 { font-family: var(--serif); font-weight: 600; line-height: 1.12; color: var(--navy-800); letter-spacing: -0.01em; }

.eyebrow {
  font-family: var(--sans); font-size: 12px; font-weight: 700; letter-spacing: 0.28em;
  text-transform: uppercase; color: var(--gold-deep); display: inline-flex; align-items: center; gap: 12px;
}
.eyebrow::before { content: ""; width: 34px; height: 1px; background: var(--gold); display: inline-block; }

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex; align-items: center; gap: 10px; font-family: var(--sans); font-weight: 600;
  font-size: 14px; letter-spacing: 0.04em; padding: 15px 30px; border-radius: var(--radius);
  cursor: pointer; transition: all .35s var(--ease); border: 1px solid transparent;
}
.btn-gold { background: var(--gold); color: var(--navy-900); }
.btn-gold:hover { background: var(--gold-soft); transform: translateY(-2px); box-shadow: 0 10px 26px rgba(200,162,75,.35); }
.btn-outline { border-color: rgba(255,255,255,.4); color: #fff; }
.btn-outline:hover { background: rgba(255,255,255,.08); border-color: var(--gold); }
.btn-ghost { border-color: var(--line); color: var(--navy-800); }
.btn-ghost:hover { border-color: var(--gold); color: var(--gold-deep); }
.btn .arr { transition: transform .35s var(--ease); }
.btn:hover .arr { transform: translateX(4px); }

/* ============================================================ HEADER / NAV ============================================================ */
.site-header { position: fixed; top: 0; left: 0; right: 0; z-index: 100; transition: all .4s var(--ease); padding: 18px 0; }
.site-header.solid { background: rgba(8,23,43,.96); backdrop-filter: blur(10px); box-shadow: 0 1px 0 rgba(200,162,75,.18); padding: 12px 0; }
.nav { display: flex; align-items: center; justify-content: space-between; }
.brand { display: flex; align-items: center; gap: 13px; }
.brand-mark { width: 46px; height: 46px; flex: none; }
.brand-text { line-height: 1; }
.brand-text .bt-name { font-family: var(--serif); font-size: 21px; font-weight: 700; color: #fff; letter-spacing: .02em; }
.brand-text .bt-sub { font-family: var(--sans); font-size: 9.5px; font-weight: 600; letter-spacing: 0.34em; text-transform: uppercase; color: var(--gold-soft); margin-top: 3px; }
.nav-links { display: flex; align-items: center; gap: 30px; list-style: none; }
.nav-links > li { position: relative; }
.nav-links a { font-size: 14px; font-weight: 500; color: rgba(255,255,255,.86); letter-spacing: .02em; padding: 8px 0; transition: color .25s; }
.nav-links a:hover, .nav-links a.active { color: var(--gold-soft); }
.has-sub > a::after { content: "›"; margin-left: 6px; opacity: .6; }
.submenu { position: absolute; top: 100%; left: -16px; min-width: 250px; background: #fff; border-radius: 6px; box-shadow: var(--shadow-md); padding: 10px; opacity: 0; visibility: hidden; transform: translateY(8px); transition: all .28s var(--ease); border-top: 3px solid var(--gold); }
.has-sub:hover .submenu { opacity: 1; visibility: visible; transform: translateY(0); }
.submenu a { display: block; color: var(--navy-800); padding: 11px 14px; border-radius: 4px; font-size: 14px; }
.submenu a:hover { background: var(--ivory); color: var(--gold-deep); }
.nav-cta { display: flex; align-items: center; gap: 16px; }
.nav-toggle { display: none; background: none; border: none; cursor: pointer; flex-direction: column; gap: 5px; }
.nav-toggle span { width: 26px; height: 2px; background: #fff; display: block; transition: .3s; }

/* ============================================================ HERO SYSTEM ============================================================ */
.hero { position: relative; overflow: hidden; background: radial-gradient(120% 120% at 80% 0%, #143055 0%, var(--navy-800) 42%, var(--navy-900) 100%); color: #fff; }
.hero-art { position: absolute; inset: 0; z-index: 1; pointer-events: none; }
.hero-art svg { width: 100%; height: 100%; }
.hero-grain { position: absolute; inset: 0; z-index: 2; opacity: .5; pointer-events: none; background-image: radial-gradient(rgba(255,255,255,.05) 1px, transparent 1px); background-size: 4px 4px; mix-blend-mode: overlay; }
.hero-fade { position: absolute; left: 0; right: 0; bottom: 0; height: 140px; z-index: 3; background: linear-gradient(to bottom, transparent, var(--paper)); }
.hero-fade.ivory { background: linear-gradient(to bottom, transparent, var(--ivory)); }
.hero .wrap { position: relative; z-index: 5; }

.hero-home { min-height: 100vh; display: flex; align-items: center; padding: 150px 0 120px; }
.hero-home .h-eyebrow { color: var(--gold-soft); margin-bottom: 26px; }
.hero-home h1 { font-size: clamp(42px, 6.4vw, 86px); color: #fff; max-width: 15ch; }
.hero-home h1 .accent { color: var(--gold-soft); font-style: italic; }
.hero-home p.lead { font-size: clamp(17px, 2vw, 20px); color: rgba(255,255,255,.82); max-width: 56ch; margin: 28px 0 38px; font-weight: 300; }
.hero-actions { display: flex; flex-wrap: wrap; gap: 16px; align-items: center; }
.hero-stats { display: flex; gap: 46px; margin-top: 72px; flex-wrap: wrap; }
.hero-stats .stat .num { font-family: var(--serif); font-size: clamp(34px, 4vw, 48px); font-weight: 700; color: var(--gold-soft); line-height: 1; }
.hero-stats .stat .lbl { font-size: 13px; color: rgba(255,255,255,.7); margin-top: 8px; letter-spacing: .04em; max-width: 22ch; }

.hero-page { min-height: 58vh; display: flex; align-items: flex-end; padding: 170px 0 64px; }
.hero-page .h-eyebrow { color: var(--gold-soft); margin-bottom: 18px; }
.hero-page h1 { font-size: clamp(38px, 5.2vw, 68px); color: #fff; max-width: 18ch; }
.hero-page p.sub { font-size: clamp(16px, 1.6vw, 19px); color: rgba(255,255,255,.8); max-width: 60ch; margin-top: 22px; font-weight: 300; }
.breadcrumb { font-size: 13px; color: rgba(255,255,255,.6); margin-bottom: 22px; letter-spacing: .03em; }
.breadcrumb a:hover { color: var(--gold-soft); }
.breadcrumb span { margin: 0 8px; opacity: .5; }

/* ============================================================ SECTIONS ============================================================ */
section { position: relative; }
.section { padding: 110px 0; }
.section.tight { padding: 80px 0; }
.section-head { max-width: 720px; margin-bottom: 56px; }
.section-head.center { margin-left: auto; margin-right: auto; text-align: center; }
.section-head.center .eyebrow::after { content: ""; width: 34px; height: 1px; background: var(--gold); display: inline-block; }
.section-head h2 { font-size: clamp(30px, 4vw, 50px); margin-top: 18px; }
.section-head p { color: var(--slate); font-size: 17px; margin-top: 18px; }
.bg-navy { background: var(--navy-800); color: #fff; }
.bg-navy h2, .bg-navy h3 { color: #fff; }
.bg-navy .section-head p { color: rgba(255,255,255,.75); }
.bg-ivory { background: var(--ivory); }

/* ---------- Specialties cards ---------- */
.cards-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
.spec-card { background: #fff; border: 1px solid var(--line); border-radius: 6px; padding: 36px 30px; transition: all .4s var(--ease); position: relative; overflow: hidden; display: flex; flex-direction: column; }
.spec-card::before { content: ""; position: absolute; top: 0; left: 0; width: 100%; height: 3px; background: var(--gold); transform: scaleX(0); transform-origin: left; transition: transform .4s var(--ease); }
.spec-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-md); border-color: transparent; }
.spec-card:hover::before { transform: scaleX(1); }
.spec-ic { width: 52px; height: 52px; color: var(--gold-deep); margin-bottom: 22px; }
.spec-card h3 { font-size: 23px; margin-bottom: 14px; }
.spec-card ul { list-style: none; margin: 14px 0 22px; }
.spec-card ul li { font-size: 14px; color: var(--slate); padding: 6px 0 6px 20px; position: relative; }
.spec-card ul li::before { content: ""; position: absolute; left: 0; top: 13px; width: 7px; height: 7px; border: 1.5px solid var(--gold); transform: rotate(45deg); }
.spec-card .more { margin-top: auto; font-size: 13px; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; color: var(--gold-deep); display: inline-flex; gap: 8px; }
.spec-card .more .arr { transition: transform .3s; }
.spec-card:hover .more .arr { transform: translateX(5px); }

/* ---------- About split ---------- */
.split { display: grid; grid-template-columns: 1.05fr .95fr; gap: 64px; align-items: center; }
.split.rev { grid-template-columns: .95fr 1.05fr; }
.split-media { position: relative; }
.split-media img { border-radius: 8px; box-shadow: var(--shadow-md); width: 100%; object-fit: cover; }
.split-media .badge { position: absolute; bottom: -26px; left: -26px; background: var(--navy-800); color: #fff; padding: 24px 30px; border-radius: 8px; box-shadow: var(--shadow-md); border-bottom: 3px solid var(--gold); }
.split-media .badge .b-num { font-family: var(--serif); font-size: 40px; font-weight: 700; color: var(--gold-soft); line-height: 1; }
.split-media .badge .b-lbl { font-size: 12px; letter-spacing: .08em; text-transform: uppercase; color: rgba(255,255,255,.78); margin-top: 6px; }
.prose p { color: var(--slate); margin-bottom: 18px; font-size: 16.5px; }
.prose p:last-child { margin-bottom: 0; }

/* ---------- Stats band ---------- */
.stats-band { display: grid; grid-template-columns: repeat(3, 1fr); gap: 30px; text-align: center; }
.stats-band .s-item { padding: 20px; }
.stats-band .s-num { font-family: var(--serif); font-size: clamp(40px, 5vw, 62px); font-weight: 700; color: var(--gold-soft); line-height: 1; }
.stats-band .s-lbl { font-size: 14px; letter-spacing: .04em; color: rgba(255,255,255,.78); margin-top: 12px; }
.stats-band .s-item + .s-item { border-left: 1px solid rgba(255,255,255,.12); }

/* ---------- Differentials ---------- */
.diff-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 2px; background: var(--line); border: 1px solid var(--line); border-radius: 8px; overflow: hidden; }
.diff-item { background: var(--paper); padding: 40px 38px; transition: background .35s; }
.diff-item:hover { background: #fff; }
.diff-item .d-num { font-family: var(--serif); font-size: 22px; color: var(--gold-deep); font-weight: 700; }
.diff-item .d-line { width: 40px; height: 2px; background: var(--gold); margin: 16px 0 20px; }
.diff-item h3 { font-size: 21px; margin-bottom: 12px; }
.diff-item p { color: var(--slate); font-size: 15.5px; }

/* ---------- Radar / posts ---------- */
.posts-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 26px; }
.post-card { background: #fff; border: 1px solid var(--line); border-radius: 8px; overflow: hidden; transition: all .4s var(--ease); display: flex; flex-direction: column; }
.post-card:hover { transform: translateY(-5px); box-shadow: var(--shadow-md); }
.post-top { padding: 14px 26px; background: var(--navy-800); }
.post-tag { font-size: 11px; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; color: var(--gold-soft); }
.post-body { padding: 26px; display: flex; flex-direction: column; flex: 1; }
.post-body h3 { font-size: 19px; line-height: 1.25; margin-bottom: 12px; }
.post-body p { font-size: 14.5px; color: var(--slate); margin-bottom: 18px; }
.post-meta { margin-top: auto; display: flex; align-items: center; justify-content: space-between; font-size: 13px; color: var(--slate-light); }
.post-meta a { color: var(--gold-deep); font-weight: 700; letter-spacing: .04em; }

/* ---------- Team ---------- */
.team-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 26px; }
.team-card { background: #fff; border: 1px solid var(--line); border-radius: 8px; overflow: hidden; transition: all .4s var(--ease); }
.team-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-md); }
.team-photo { aspect-ratio: 3/3.4; overflow: hidden; background: var(--navy-700); position: relative; }
.team-photo img { width: 100%; height: 100%; object-fit: cover; filter: grayscale(18%); transition: transform .6s var(--ease), filter .4s; }
.team-card:hover .team-photo img { transform: scale(1.05); filter: grayscale(0%); }
.team-info { padding: 22px 22px 26px; }
.team-info h3 { font-size: 20px; margin-bottom: 6px; }
.team-info .oab { font-size: 12.5px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--gold-deep); }
.team-info .email { font-size: 13.5px; color: var(--slate); margin-top: 10px; display: inline-flex; align-items: center; gap: 7px; word-break: break-all; }
.team-info .email:hover { color: var(--gold-deep); }

/* ---------- CTA band ---------- */
.cta-band { position: relative; overflow: hidden; background: radial-gradient(120% 120% at 15% 10%, #143055, var(--navy-900)); color: #fff; padding: 96px 0; text-align: center; }
.cta-band .cta-art { position: absolute; inset: 0; opacity: .5; }
.cta-band h2 { font-size: clamp(30px, 4vw, 48px); color: #fff; max-width: 20ch; margin: 0 auto 18px; position: relative; }
.cta-band p { color: rgba(255,255,255,.8); max-width: 52ch; margin: 0 auto 34px; position: relative; }

/* ---------- Content article ---------- */
.article { display: grid; grid-template-columns: 1fr 320px; gap: 60px; align-items: start; }
.article .body h2 { font-size: 30px; margin: 38px 0 18px; }
.article .body h2:first-child { margin-top: 0; }
.article .body h3 { font-size: 22px; margin: 30px 0 12px; color: var(--navy-700); }
.article .body p { color: var(--slate); margin-bottom: 18px; font-size: 16.5px; }
.article .body .lead-p { font-size: 19px; color: var(--navy-700); font-family: var(--serif); line-height: 1.5; margin-bottom: 26px; }
.feature-list { display: grid; gap: 2px; background: var(--line); border: 1px solid var(--line); border-radius: 8px; overflow: hidden; margin: 30px 0; }
.feature-list .fl-item { background: #fff; padding: 26px 28px; }
.feature-list .fl-item h4 { font-family: var(--serif); font-size: 19px; color: var(--navy-800); margin-bottom: 8px; }
.feature-list .fl-item p { font-size: 15px; margin: 0; }
.aside { position: sticky; top: 110px; }
.aside-card { background: var(--navy-800); color: #fff; border-radius: 10px; padding: 34px 30px; border-bottom: 3px solid var(--gold); }
.aside-card h3 { color: #fff; font-size: 23px; margin-bottom: 14px; }
.aside-card p { color: rgba(255,255,255,.78); font-size: 15px; margin-bottom: 22px; }
.aside-links { margin-top: 26px; }
.aside-links .al-title { font-size: 12px; letter-spacing: .18em; text-transform: uppercase; color: var(--gold-soft); margin-bottom: 14px; }
.aside-links a { display: flex; align-items: center; justify-content: space-between; padding: 13px 0; border-top: 1px solid rgba(255,255,255,.12); font-size: 15px; color: rgba(255,255,255,.88); }
.aside-links a:hover { color: var(--gold-soft); padding-left: 4px; transition: .25s; }

/* ---------- Contact ---------- */
.contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 56px; align-items: start; }
.contact-list { display: grid; gap: 18px; margin: 30px 0; }
.contact-item { display: flex; gap: 18px; align-items: flex-start; padding: 22px 24px; background: #fff; border: 1px solid var(--line); border-radius: 8px; transition: .3s; }
.contact-item:hover { border-color: var(--gold); box-shadow: var(--shadow-sm); }
.contact-item .ci-ic { width: 42px; height: 42px; flex: none; color: var(--gold-deep); }
.contact-item .ci-label { font-size: 12px; letter-spacing: .12em; text-transform: uppercase; color: var(--slate-light); font-weight: 700; }
.contact-item .ci-val { font-size: 16px; color: var(--navy-800); font-weight: 600; margin-top: 3px; }
.form-card { background: #fff; border: 1px solid var(--line); border-radius: 10px; padding: 40px; box-shadow: var(--shadow-sm); }
.field { margin-bottom: 20px; }
.field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.field label { display: block; font-size: 13px; font-weight: 600; color: var(--navy-700); margin-bottom: 8px; letter-spacing: .02em; }
.field input, .field select, .field textarea { width: 100%; padding: 13px 16px; border: 1px solid var(--line); border-radius: 5px; font-family: var(--sans); font-size: 15px; color: var(--ink); background: var(--paper); transition: .25s; }
.field textarea { resize: vertical; min-height: 120px; }
.field input:focus, .field select:focus, .field textarea:focus { outline: none; border-color: var(--gold); background: #fff; box-shadow: 0 0 0 3px rgba(200,162,75,.12); }
.map-embed { border-radius: 10px; overflow: hidden; border: 1px solid var(--line); box-shadow: var(--shadow-sm); }
.map-embed iframe { width: 100%; height: 340px; border: 0; display: block; }

/* ============================================================ FOOTER ============================================================ */
.footer { background: var(--navy-900); color: rgba(255,255,255,.7); padding: 80px 0 0; }
.footer-top { display: grid; grid-template-columns: 1.6fr 1fr 1fr 1.2fr; gap: 44px; padding-bottom: 56px; border-bottom: 1px solid rgba(255,255,255,.1); }
.footer-brand .brand-text .bt-name { font-size: 24px; }
.footer-brand p { font-size: 15px; margin: 22px 0; max-width: 34ch; line-height: 1.7; }
.footer-soc { display: flex; gap: 12px; }
.footer-soc a { width: 40px; height: 40px; border: 1px solid rgba(255,255,255,.16); border-radius: 50%; display: flex; align-items: center; justify-content: center; transition: .3s; }
.footer-soc a:hover { background: var(--gold); border-color: var(--gold); color: var(--navy-900); }
.footer-soc svg { width: 17px; height: 17px; }
.footer-col h4 { color: #fff; font-family: var(--sans); font-size: 13px; letter-spacing: .16em; text-transform: uppercase; margin-bottom: 22px; }
.footer-col a { display: block; font-size: 14.5px; padding: 7px 0; transition: .25s; }
.footer-col a:hover { color: var(--gold-soft); padding-left: 4px; }
.footer-contact .fc-item { font-size: 14.5px; margin-bottom: 16px; }
.footer-contact .fc-item strong { display: block; font-size: 12px; letter-spacing: .1em; text-transform: uppercase; margin-bottom: 3px; color: var(--gold-soft); }
.footer-bottom { display: flex; align-items: center; justify-content: space-between; padding: 26px 0; font-size: 13px; color: rgba(255,255,255,.5); }
.footer-bottom a:hover { color: var(--gold-soft); }

/* ============================================================ REVEAL ============================================================ */
.reveal { opacity: 0; transform: translateY(28px); transition: opacity .8s var(--ease), transform .8s var(--ease); }
.reveal.in { opacity: 1; transform: none; }
.reveal.d1 { transition-delay: .08s; } .reveal.d2 { transition-delay: .16s; }
.reveal.d3 { transition-delay: .24s; } .reveal.d4 { transition-delay: .32s; }

/* ============================================================ RESPONSIVE ============================================================ */
@media (max-width: 1024px) {
  .cards-grid, .team-grid { grid-template-columns: repeat(2, 1fr); }
  .posts-grid { grid-template-columns: 1fr; }
  .split, .split.rev, .contact-grid, .article { grid-template-columns: 1fr; gap: 40px; }
  .article .aside { position: static; }
  .footer-top { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 860px) {
  .nav-links, .nav-cta .btn { display: none; }
  .nav-toggle { display: flex; }
  .nav-links.open { display: flex; position: absolute; top: 100%; left: 0; right: 0; flex-direction: column; background: var(--navy-900); padding: 20px 28px; gap: 6px; box-shadow: var(--shadow-md); }
  .nav-links.open > li { width: 100%; border-bottom: 1px solid rgba(255,255,255,.08); }
  .nav-links.open .submenu { position: static; opacity: 1; visibility: visible; transform: none; box-shadow: none; background: transparent; border: none; padding: 0 0 8px 14px; }
  .nav-links.open .submenu a { color: rgba(255,255,255,.7); }
  .hero-stats { gap: 30px; }
  .stats-band { grid-template-columns: 1fr; }
  .stats-band .s-item + .s-item { border-left: none; border-top: 1px solid rgba(255,255,255,.12); }
  .diff-grid { grid-template-columns: 1fr; }
  .field-row { grid-template-columns: 1fr; }
}
@media (max-width: 560px) {
  .wrap { padding: 0 20px; }
  .cards-grid, .team-grid { grid-template-columns: 1fr; }
  .footer-top { grid-template-columns: 1fr; }
  .hero-actions { flex-direction: column; align-items: stretch; }
  .hero-actions .btn { justify-content: center; }
}

/* ===== Logo oficial ===== */
.brand-logo{height:50px;width:auto;display:block;}
.site-header.solid .brand-logo{height:44px;transition:height .4s var(--ease);}
.footer-logo{height:58px;width:auto;display:block;margin-bottom:8px;}

/* ===== Publicações por advogado (Equipe) ===== */
.team-articles{margin-top:16px;border-top:1px solid var(--line);padding-top:14px;}
.team-articles .ta-title{font-size:11px;letter-spacing:.13em;text-transform:uppercase;color:var(--gold-deep);font-weight:700;margin-bottom:8px;}
.team-articles a{display:block;font-size:13px;color:var(--slate);line-height:1.4;padding:8px 0 8px 16px;position:relative;border-top:1px solid var(--line);}
.team-articles a:first-of-type{border-top:none;}
.team-articles a::before{content:"";position:absolute;left:0;top:13px;width:6px;height:6px;border:1.5px solid var(--gold);transform:rotate(45deg);}
.team-articles a:hover{color:var(--gold-deep);}
.team-articles .ta-empty{font-size:13px;color:var(--slate-light);font-style:italic;}

/* ===== Radar — filtros e autoria ===== */
.radar-filters{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:42px;}
.radar-filters button{font-family:var(--sans);font-size:13px;font-weight:600;letter-spacing:.03em;padding:9px 18px;border-radius:40px;border:1px solid var(--line);background:#fff;color:var(--slate);cursor:pointer;transition:.25s;}
.radar-filters button:hover{border-color:var(--gold);color:var(--gold-deep);}
.radar-filters button.active{background:var(--navy-800);color:#fff;border-color:var(--navy-800);}
.post-author{font-size:12.5px;color:var(--slate-light);margin-top:2px;}
.post-author b{color:var(--gold-deep);font-weight:700;}

/* ============================================================
   v3 · FUTURISTA — HEROES EM MOVIMENTO
   ============================================================ */
:root{ --cyan:#5fe0ff; --cyan-soft:#9aeeff; }

/* canvas de partículas/constelação */
.hero-particles{position:absolute;inset:0;z-index:0;width:100%;height:100%;display:block;}
.hero.fx .hero-art{z-index:1;}
.hero.fx .hero-grain{z-index:2;}
.hero.fx .hero-fade{z-index:3;}
.hero.fx .wrap{z-index:6;}

/* brilho/halo reutilizável */
.fx-glow{filter:drop-shadow(0 0 6px rgba(95,224,255,.55));}
.fx-glow-gold{filter:drop-shadow(0 0 5px rgba(217,189,120,.6));}

/* aurora de fundo (blobs que respiram) */
.fx-aurora{animation:fxAurora 18s ease-in-out infinite alternate;transform-origin:center;}
@keyframes fxAurora{0%{opacity:.5;transform:translate(0,0) scale(1);}100%{opacity:.85;transform:translate(40px,-20px) scale(1.12);}}

/* rotas de carga “fluindo” (dash em movimento) */
.fx-route{stroke-dasharray:14 12;animation:fxFlow 3.2s linear infinite;}
.fx-route.s2{animation-duration:4.6s;}
.fx-route.s3{animation-duration:6s;}
@keyframes fxFlow{to{stroke-dashoffset:-260;}}

/* contrail do avião (rastro desenhando) */
.fx-trail{stroke-dasharray:8 10;animation:fxFlow 1.1s linear infinite;}

/* nós/portos pulsando */
.fx-pulse{transform-origin:center;animation:fxPulse 2.6s ease-in-out infinite;}
.fx-pulse.b{animation-delay:.8s;}
.fx-pulse.c{animation-delay:1.5s;}
@keyframes fxPulse{0%,100%{opacity:.35;transform:scale(.7);}50%{opacity:1;transform:scale(1.25);}}

/* varredura do radar */
.fx-sweep{transform-origin:0 0;animation:fxSweep 7s linear infinite;}
@keyframes fxSweep{to{transform:rotate(360deg);}}

/* navio deslizando + balanço */
.fx-ship{animation:fxGlideShip 30s linear infinite;}
.fx-ship .bob{animation:fxBob 5s ease-in-out infinite;}
@keyframes fxGlideShip{0%{transform:translateX(-360px);}100%{transform:translateX(1640px);}}
@keyframes fxBob{0%,100%{transform:translateY(0) rotate(0deg);}50%{transform:translateY(-7px) rotate(-.6deg);}}

/* avião cruzando + leve oscilação */
.fx-plane{animation:fxGlidePlane 19s linear infinite;}
.fx-plane .bobp{animation:fxBob 3.4s ease-in-out infinite;}
@keyframes fxGlidePlane{0%{transform:translateX(1620px);}100%{transform:translateX(-420px);}}

/* contêineres/dados flutuando */
.fx-float{animation:fxFloat 6s ease-in-out infinite;}
.fx-float.b{animation-duration:7.5s;animation-delay:.6s;}
.fx-float.c{animation-duration:9s;animation-delay:1.2s;}
@keyframes fxFloat{0%,100%{transform:translateY(0);}50%{transform:translateY(-16px);}}

/* linha de varredura/scanner horizontal nos heroes internos */
.fx-scan{animation:fxScan 6.5s ease-in-out infinite;}
@keyframes fxScan{0%{transform:translateY(-40px);opacity:0;}15%{opacity:.7;}85%{opacity:.7;}100%{transform:translateY(520px);opacity:0;}}

/* horizonte/grade com leve respiração */
.fx-grid{animation:fxGrid 9s ease-in-out infinite alternate;}
@keyframes fxGrid{from{opacity:.10;}to{opacity:.24;}}

/* paralaxe (controlado via JS com --px/--py) */
.hero.fx .fx-parallax{transform:translate(calc(var(--px,0)*1px),calc(var(--py,0)*1px));transition:transform .25s ease-out;}

/* acessibilidade: reduz movimento */
@media (prefers-reduced-motion: reduce){
  .fx-route,.fx-trail,.fx-pulse,.fx-sweep,.fx-ship,.fx-ship .bob,.fx-plane,.fx-plane .bobp,
  .fx-float,.fx-scan,.fx-grid,.fx-aurora{animation:none !important;}
  .hero.fx .fx-parallax{transform:none !important;}
}

/* avião da home: esquerda -> direita (acompanha o navio) */
.fx-plane.ltr{animation-name:fxGlidePlaneLTR;}
@keyframes fxGlidePlaneLTR{0%{transform:translateX(-420px);}100%{transform:translateX(1620px);}}
/* tagline sob o título do hero (ex.: Advogados e Consultores) */
.hero-page .h-tag{font-family:var(--sans);font-size:clamp(13px,1.4vw,15px);font-weight:700;letter-spacing:.34em;text-transform:uppercase;color:var(--gold-soft);margin-top:14px;}

/* === v3: estados de voo extras === */
@keyframes fxTakeoff{0%{transform:translate(1520px,300px) rotate(8deg);}100%{transform:translate(-380px,30px) rotate(8deg);}}
@keyframes fxLanding{0%{transform:translate(1520px,40px) rotate(-9deg);}100%{transform:translate(-380px,320px) rotate(0deg);}}
.fx-plane.takeoff{animation-name:fxTakeoff;animation-duration:17s;}
.fx-plane.landing{animation-name:fxLanding;animation-duration:18s;}
/* === hero O Escritório: assinatura + caneta === */
.fx-sign{stroke-dasharray:130;stroke-dashoffset:130;animation:fxSign 5.5s ease-in-out infinite;}
@keyframes fxSign{0%{stroke-dashoffset:130;}42%{stroke-dashoffset:0;}80%{stroke-dashoffset:0;}100%{stroke-dashoffset:130;}}
.fx-pen{animation:fxPen 5.5s ease-in-out infinite;}
@keyframes fxPen{0%,100%{transform:translate(0,0) rotate(0deg);}20%{transform:translate(-3px,2px) rotate(-3deg);}45%{transform:translate(-7px,5px) rotate(-5deg);}}
/* versalete para o título do hero */
.h1-sc{font-variant:small-caps;font-variant-caps:small-caps;letter-spacing:.015em;}

/* === v4: ajustes === */
/* navio parado, porém flutuando (Aduaneiro) */
.fx-shipfloat{animation:fxShipFloat 5.5s ease-in-out infinite;}
@keyframes fxShipFloat{0%,100%{transform:translate(880px,300px);}50%{transform:translate(880px,289px);}}
/* grade mais discreta (menos poluição) */
@keyframes fxGrid{from{opacity:.05;}to{opacity:.12;}}
.hero-grain{opacity:.30;}
/* hero da home cabendo na tela */
.hero-home{padding:116px 0 70px;}
.hero-home h1{font-size:clamp(40px,5.2vw,70px);}
.hero-home p.lead{margin:22px 0 30px;}
.hero-stats{margin-top:44px;gap:40px;}

/* === v4.1: hero da home — azul mais baixo, texto branco protegido === */
.hero-home{padding:118px 0 96px;}
.hero-home .hero-fade{height:70px;}

/* === v4.2: transição azul->claro mais fluída + azul estendido === */
.hero-fade{height:200px;background:linear-gradient(to bottom,rgba(250,248,243,0) 0%, rgba(250,248,243,0) 50%, rgba(250,248,243,.7) 82%, rgba(250,248,243,1) 100%);}
.hero-fade.ivory{background:linear-gradient(to bottom,rgba(246,242,233,0) 0%, rgba(246,242,233,0) 50%, rgba(246,242,233,.7) 82%, rgba(246,242,233,1) 100%);}
.hero-home .hero-fade{height:200px;}
.hero-home{padding-bottom:116px;}
.hero-page{padding-bottom:124px;}
