/* ============================================================
   JONAS STEPHÂNI ADVOGADOS — Sistema de Design
   Azul refinado · Branco · Tema claro moderno (estilo Jurri)
   Instrument Serif · Inter Tight · JetBrains Mono
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Instrument+Serif:ital@0;1&family=Inter+Tight:ital,wght@0,300;0,400;0,500;0,600;0,700;1,400&family=JetBrains+Mono:wght@400;500&display=swap');

:root {
  /* Azul profundo (superfícies escuras) */
  --ink:#0E1E3A; --ink-2:#13284A; --navy:#1B3563; --navy-light:#244379; --navy-pale:#3B5C94;
  /* Azul de marca (acento) — mapeado nos tokens "gold" p/ compatibilidade */
  --gold:#2F5A9E; --gold-bright:#4E7CC0; --gold-light:#6E97D0; --gold-pale:#BCD0EC; --gold-deep:#1C3D72; --gold-soft:#CBDAEF;
  --brand-gold:#C9A24B;
  --line:rgba(47,90,158,.20); --line-2:rgba(47,90,158,.10);
  /* Branco / claro frio */
  --paper:#F6F9FD; --paper-warm:#ECF1F9; --paper-card:#FFFFFF; --warm:#F1F5FB; --off:#EEF3FA;
  /* Neutros frios */
  --g100:#EEF2F8; --g200:#DCE4EF; --g300:#BCC8DA; --g400:#7E8AA0; --g500:#5A6678; --g600:#2E3954;
  --rule:#E2E9F3; --rule-soft:#EEF3F9;
  /* Texto slate */
  --text:#13243F; --ink-soft:#3C4861; --ink-mute:#62708A;
  /* WhatsApp */
  --wpp:#25D366; --wpp-h:#1EBE5A;
  /* Tons suaves de categoria (frios, elegantes) */
  --c-trab:#27497E; --c-trab-bg:#E7EEF8;
  --c-emp:#3A5560;  --c-emp-bg:#E7EEF1;
  --c-piso:#2E5E55; --c-piso-bg:#E3F0EC;
  /* Sistema */
  --maxw:1200px; --gutter:clamp(20px,5vw,56px);
  --r-sm:10px; --r-md:16px; --r-lg:22px;
  --shadow-sm:0 1px 2px rgba(19,40,74,.04), 0 4px 16px rgba(19,40,74,.05);
  --shadow-md:0 10px 26px rgba(19,40,74,.08), 0 22px 50px rgba(19,40,74,.07);
  --shadow-lg:0 18px 44px rgba(19,40,74,.13), 0 44px 88px rgba(19,40,74,.10);
  --serif:'Instrument Serif', Georgia, serif;
  --sans:'Inter Tight', system-ui, -apple-system, sans-serif;
  --mono:'JetBrains Mono', ui-monospace, monospace;
  --ease:cubic-bezier(.16,1,.3,1);
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; -webkit-font-smoothing: antialiased; overflow-x: hidden; }
body { overflow-x: hidden; }
body {
  font-family: var(--sans); font-weight: 400;
  background: var(--paper); color: var(--text);
  line-height: 1.75; font-size: 16px; overflow-x: hidden;
}
::selection { background: var(--gold-pale); color: var(--ink); }
select, option { line-height: 1.3; }
/* Custom dropdown (substitui menu nativo) */
.csel { position: relative; }
.csel-native { position: absolute !important; width: 1px !important; height: 1px !important; opacity: 0 !important; pointer-events: none !important; padding: 0 !important; margin: 0 !important; }
.csel-btn { width: 100%; display: flex; align-items: center; justify-content: space-between; gap: 10px; padding: 13px 15px; border: 1px solid var(--rule); border-radius: var(--r-sm); background: #fff; color: var(--text); font-family: var(--sans); font-size: 16px; line-height: 1.3; text-align: left; cursor: pointer; transition: border-color .2s; }
.csel-btn:hover { border-color: var(--gold-soft); }
.csel.open .csel-btn { border-color: var(--gold); }
.csel-arr { color: var(--gold); font-size: 12px; transition: transform .2s; }
.csel.open .csel-arr { transform: rotate(180deg); }
.csel-list { position: absolute; top: calc(100% + 4px); left: 0; right: 0; z-index: 60; background: #fff; border: 1px solid var(--gold-soft); border-radius: var(--r-sm); box-shadow: var(--shadow-md); padding: 5px; max-height: 260px; overflow-y: auto; display: none; }
.csel.open .csel-list { display: block; }
.csel-opt { padding: 11px 13px; border-radius: 7px; font-size: 15px; color: var(--ink-soft); cursor: pointer; transition: background .12s, color .12s; }
.csel-opt:hover { background: var(--paper-warm); color: var(--text); }
.csel-opt.sel { background: rgba(47,90,158,.08); color: var(--gold-deep); font-weight: 600; }
select { appearance: none; -webkit-appearance: none; -moz-appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M2 4l4 4 4-4' stroke='%232F5A9E' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") !important; background-repeat: no-repeat !important; background-position: right 14px center !important; padding-right: 38px !important; }
img { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }

/* ---------- Tipografia ---------- */
.serif { font-family: var(--serif); }
.mono  { font-family: var(--mono); }
h1, h2, h3, .display { font-family: var(--serif); font-weight: 400; line-height: 1.1; letter-spacing: -.02em; color: var(--text); }
h1, .display { font-size: clamp(2.8rem, 6.5vw, 5rem); line-height: 1.05; }
h2 { font-size: clamp(2rem, 4vw, 3.1rem); }
h3 { font-size: clamp(1.4rem, 2.4vw, 1.9rem); }
em.gold, .gold-i { font-style: italic; color: var(--gold); font-weight: 400; }

.eyebrow { font-family: var(--sans); font-size: 11px; font-weight: 600; letter-spacing: .34em; text-transform: uppercase; color: var(--gold); display: inline-flex; align-items: center; gap: 14px; }
.eyebrow::before { content:""; width: 34px; height: 1px; background: var(--gold); }
.eyebrow.center::after { content:""; width: 34px; height: 1px; background: var(--gold); }
.eyebrow.light { color: var(--gold-pale); }
.eyebrow.light::before, .eyebrow.light.center::after { background: var(--gold-pale); opacity:.7; }

.lead { font-size: clamp(1.02rem, 1.5vw, 1.2rem); color: var(--ink-soft); line-height: 1.8; font-weight: 300; max-width: 62ch; }
.measure { max-width: 66ch; }

/* ---------- Layout ---------- */
.wrap { max-width: var(--maxw); margin: 0 auto; padding-inline: var(--gutter); }
section { padding-block: clamp(64px, 8.5vw, 124px); }
.section-head { max-width: 760px; margin-bottom: clamp(40px, 5vw, 60px); }
.section-head .eyebrow { margin-bottom: 22px; }
.section-head .lead { margin-top: 22px; }
.center { text-align: center; }
.center .lead, .center .section-head { margin-inline: auto; }
.head-orn { display:flex; align-items:center; justify-content:center; gap:12px; margin-top:22px; }
.head-orn::before, .head-orn::after { content:""; width:44px; height:1px; background:var(--gold); opacity:.5; }
.head-orn .d { width:6px; height:6px; background:var(--gold); transform:rotate(45deg); }

/* ---------- Botões ---------- */
.btn { display: inline-flex; align-items: center; gap: 10px; font-family: var(--sans); font-weight: 600; font-size: 12px; letter-spacing: .16em; text-transform: uppercase; padding: 16px 30px; border-radius: var(--r-sm); border: 1px solid var(--ink); background: var(--ink); color: #fff; cursor: pointer; transition: all .3s var(--ease); }
.btn:hover { background: var(--gold); border-color: var(--gold); color:#fff; transform: translateY(-2px); box-shadow: var(--shadow-md); }
.btn .arr { transition: transform .3s var(--ease); }
.btn:hover .arr { transform: translateX(5px); }
.btn.ghost { background: transparent; color: var(--ink); border-color: var(--g300); }
.btn.ghost:hover { background: var(--ink); color: #fff; border-color: var(--ink); }
.btn.gold { background: var(--gold); border-color: var(--gold); color:#fff; }
.btn.gold:hover { background: var(--gold-deep); border-color: var(--gold-deep); }
.btn.outline-gold { background: transparent; color: var(--gold-deep); border-color: var(--gold); }
.btn.outline-gold:hover { background: var(--gold); color:#fff; border-color: var(--gold); }
.btn.lg { padding: 18px 36px; font-size: 12.5px; }
.btn.on-dark.ghost { color: rgba(255,255,255,.9); border-color: rgba(255,255,255,.3); }
.btn.on-dark.ghost:hover { background: rgba(255,255,255,.08); color: #fff; border-color: var(--gold-pale); }
.btn.wpp { background: var(--wpp); border-color: var(--wpp); color:#fff; box-shadow:0 8px 28px rgba(37,211,102,.26); }
.btn.wpp:hover { background: var(--wpp-h); border-color: var(--wpp-h); }

.link-arr { font-family: var(--sans); font-size: 11px; font-weight: 600; letter-spacing: .14em; text-transform: uppercase; color: var(--gold-deep); display: inline-flex; align-items: center; gap: 9px; transition: gap .3s var(--ease), color .25s; }
.link-arr:hover { gap: 13px; color: var(--gold); }
.overlap { margin-top: -64px; position: relative; z-index: 5; }

/* ---------- Topbar / Header ---------- */
.topbar { background: var(--ink); color: rgba(255,255,255,.72); font-family: var(--mono); font-size: 11px; letter-spacing: .04em; border-bottom: 1px solid var(--line-2); }
.topbar .wrap { display: flex; align-items: center; justify-content: space-between; gap: 16px; padding-block: 9px; flex-wrap: wrap; }
.topbar a { color: var(--gold-pale); transition: color .2s; }
.topbar a:hover { color: #fff; }
.topbar .sep { opacity: .3; }
.topbar-left { display: flex; gap: 16px; flex-wrap: wrap; align-items: center; }
.topbar-right { display: flex; gap: 14px; align-items: center; }

header.site { position: sticky; top: 0; z-index: 100; background: rgba(14,30,58,.9); backdrop-filter: blur(16px); border-bottom: 1px solid var(--line); }
header.site .wrap { display: flex; align-items: center; justify-content: space-between; gap: 24px; padding-block: 16px; }
.brand { display: flex; align-items: center; gap: 14px; }
.brand-mark { width: 50px; height: 50px; flex-shrink: 0; border: 1px solid var(--brand-gold); border-radius: 1px; display: grid; place-items: center; font-family: var(--serif); font-weight: 400; font-size: 27px; letter-spacing: -0.5px; text-indent: 0; color: var(--brand-gold); background: transparent; }
.brand-mark + span { padding-left: 16px; border-left: 1px solid rgba(201,162,75,.4); }
.brand-name { display:block; font-family: var(--serif); font-size: 20px; font-weight: 400; line-height: 1; letter-spacing: .06em; text-transform: uppercase; color: #fff; }
.brand-sub { display:block; font-family: var(--sans); font-size: 8px; font-weight:600; letter-spacing: .24em; color: rgba(255,255,255,.55); text-transform: uppercase; margin-top: 6px; white-space: nowrap; }
nav.primary { display: flex; align-items: center; gap: 26px; }
nav.primary a { font-family: var(--sans); font-size: 11.5px; font-weight: 500; letter-spacing: .12em; text-transform: uppercase; color: rgba(255,255,255,.8); position: relative; padding-block: 6px; transition: color .25s; }
nav.primary a::after { content:""; position:absolute; left:0; bottom:0; width:0; height:1px; background: var(--gold-pale); transition: width .3s var(--ease); }
nav.primary a:hover { color: #fff; }
nav.primary a:hover::after { width: 100%; }
.nav-cta { display: flex; align-items: center; gap: 12px; }
.menu-btn { display: none; }

/* ---------- HERO ---------- */
.hero { position: relative; overflow: hidden; background: var(--ink); isolation: isolate; }
.hero__bg { position: absolute; inset: 0; z-index: -3; background-size: cover; background-position: center 38%; transform: scale(1.05); filter: brightness(.34) saturate(.85) contrast(1.02); }
.hero__bg.noimg { background-color: #0e1e3a; background-image: repeating-linear-gradient(135deg, rgba(120,160,220,.05) 0 2px, transparent 2px 16px); filter:none; transform:none; }
.hero__overlay { position: absolute; inset: 0; z-index: -2; background:
  radial-gradient(ellipse at 50% 6%, rgba(80,130,210,.22) 0%, transparent 55%),
  radial-gradient(ellipse at center, rgba(14,30,58,.5) 0%, rgba(14,30,58,.82) 64%, var(--ink) 100%); }
.hero__grid { position:absolute; inset:0; z-index:-1; background-image: linear-gradient(rgba(150,180,230,.06) 1px, transparent 1px), linear-gradient(90deg, rgba(150,180,230,.06) 1px, transparent 1px); background-size: 64px 64px; mask-image: radial-gradient(ellipse at center, #000 0%, transparent 72%); }
.hero .eyebrow { color: var(--gold-pale); }
.hero .eyebrow::before, .hero .eyebrow.center::after { background: var(--gold-pale); opacity:.7; }

/* glass pillars */
.glass-pillars { display:flex; flex-wrap:wrap; border:1px solid rgba(255,255,255,.16); border-radius: var(--r-md); background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.02)); backdrop-filter: blur(10px); overflow:hidden; position:relative; }
.glass-pillars::before { content:""; position:absolute; top:0; left:0; right:0; height:1px; background: linear-gradient(90deg, transparent, var(--gold-light) 30%, var(--gold-light) 70%, transparent); opacity:.6; }
.gp { flex:1; min-width: 180px; padding: 26px 24px; border-right: 1px solid rgba(255,255,255,.1); transition: background .45s var(--ease); }
.gp:last-child { border-right:none; }
.gp:hover { background: radial-gradient(ellipse at top, rgba(110,150,210,.16), transparent 70%); }
.gp .l { font-family: var(--sans); font-size: 10px; font-weight: 600; letter-spacing: .26em; text-transform: uppercase; color: var(--gold-pale); margin-bottom: 12px; }
.gp .v { font-family: var(--serif); font-style: italic; font-size: 1.6rem; color: #fff; line-height: 1.1; }
.gp .s { font-family: var(--sans); font-size: 12px; font-weight: 300; color: rgba(255,255,255,.6); margin-top: 10px; line-height: 1.5; }

/* ---------- Trust marquee ---------- */
.trust { background: var(--ink-2); border-top: 1px solid var(--line-2); border-bottom: 1px solid var(--line-2); padding-block: 18px; overflow: hidden; }
.trust-track { display: flex; align-items: center; gap: 0; animation: marquee 46s linear infinite; width: max-content; }
.trust-track:hover { animation-play-state: paused; }
.trust-pill { display: inline-flex; align-items: center; gap: 10px; font-family: var(--sans); font-size: 11px; font-weight: 500; letter-spacing: .22em; text-transform: uppercase; color: rgba(255,255,255,.6); white-space: nowrap; padding-inline: 26px; }
.trust-pill .ck { color: var(--gold-pale); }
.trust-pill::after { content:""; width:4px; height:4px; background: var(--gold-pale); border-radius:50%; opacity:.55; margin-left: 26px; }
@keyframes marquee { 0%{transform:translateX(0)} 100%{transform:translateX(-50%)} }

/* ---------- BANNER página interna ---------- */
.banner { position: relative; background: var(--ink); color: #fff; overflow: hidden; isolation: isolate; padding-block: clamp(48px,7vw,90px); }
.banner__bg { position:absolute; inset:0; z-index:-2; background-color:#0e1e3a; background-image: url('https://images.unsplash.com/photo-1505664194779-8beaceb93744?w=1920&q=80'); background-size:cover; background-position:center 35%; filter: brightness(.52) saturate(.82); }
.banner__overlay { position:absolute; inset:0; z-index:-1; background: radial-gradient(ellipse at 28% 0%, rgba(80,130,210,.16), transparent 55%), linear-gradient(100deg, rgba(14,30,58,.93) 0%, rgba(14,30,58,.66) 60%, rgba(14,30,58,.4) 100%); }
.banner h1 { color:#fff; margin-top:16px; font-size: clamp(2rem,4.5vw,3.4rem); }
.banner .lead { color: rgba(255,255,255,.72); margin-top:16px; }
.crumb { display:flex; flex-wrap:wrap; gap:9px; align-items:center; font-family: var(--mono); font-size: 11px; letter-spacing:.04em; }
.crumb a { color: var(--gold-pale); }
.crumb a:hover { color:#fff; }
.crumb .sl { opacity:.4; }
.crumb .cur { color:#fff; }

/* ---------- Cards ---------- */
.card { background: var(--paper-card); border: 1px solid var(--rule); border-radius: var(--r-md); padding: 32px; transition: transform .3s var(--ease), box-shadow .3s var(--ease), border-color .3s; position: relative; overflow: hidden; }
.card::before { content:""; position:absolute; top:0; left:0; width:0; height:2px; background: var(--gold); transition: width .4s var(--ease); }
.card:hover { transform: translateY(-5px); box-shadow: var(--shadow-md); border-color: var(--gold-soft); }
.card:hover::before { width: 100%; }
.card h3 { margin-bottom: 10px; }
.grid { display: grid; gap: 22px; }
.g-2 { grid-template-columns: repeat(2,1fr); }
.g-3 { grid-template-columns: repeat(3,1fr); }
.g-4 { grid-template-columns: repeat(4,1fr); }

/* Chips */
.chips { display:flex; flex-wrap:wrap; gap:10px; }
.chip { font-family: var(--sans); font-size: 13px; font-weight: 500; padding: 9px 16px; border: 1px solid var(--rule); border-radius: 50px; background: var(--paper-card); color: var(--ink-soft); transition: all .25s var(--ease); white-space: nowrap; }
.chip:hover { border-color: var(--gold); color: var(--gold-deep); transform: translateY(-1px); }

/* Listas de link */
.linklist { list-style:none; display:grid; gap:1px; }
.linklist a { display:flex; align-items:center; gap:10px; padding: 10px 12px; border-radius: var(--r-sm); font-size: 15px; color: var(--ink-soft); transition: background .2s, color .2s, padding .2s; }
.linklist a::before { content:"›"; color: var(--gold); font-family: var(--mono); }
.linklist a:hover { background: rgba(47,90,158,.07); color: var(--gold-deep); padding-left: 16px; }

/* Pílula de categoria */
.cat-pill { font-family: var(--sans); font-size: 10.5px; font-weight: 600; letter-spacing: .14em; text-transform: uppercase; padding: 6px 13px; border-radius: 50px; display: inline-block; }

/* Cartão de área (practice) */
.pcard { background: var(--paper-card); border: 1px solid var(--rule); border-radius: var(--r-lg); padding: 36px 32px; transition: transform .35s var(--ease), box-shadow .35s, border-color .35s; display:block; position: relative; overflow: hidden; }
.pcard::before { content:""; position:absolute; top:0; left:0; width:42px; height:1px; background: var(--gold); transition: width .45s var(--ease); }
.pcard::after { content:""; position:absolute; top:0; left:0; width:1px; height:42px; background: var(--gold); transition: height .45s var(--ease); }
.pcard:hover { transform: translateY(-5px); box-shadow: var(--shadow-md); border-color: var(--gold-soft); }
.pcard:hover::before { width: 100%; }
.pcard:hover::after { height: 100%; }
.pcard__ic { width: 62px; height: 62px; border-radius: 50%; border: 1px solid var(--gold); color: var(--gold); display: grid; place-items: center; margin-bottom: 24px; font-family: var(--serif); font-style: italic; font-size: 26px; transition: background .3s, color .3s; }
.pcard:hover .pcard__ic { background: var(--gold); color: #fff; }
.pcard h3 { font-size: 1.55rem; margin-bottom: 10px; }
.pcard p { color: var(--ink-soft); font-size: 14.5px; font-weight: 300; line-height: 1.7; margin-bottom: 20px; }

/* Pilares (faixa escura) */
.pillar .num { font-family: var(--serif); font-style: italic; font-size: 2rem; color: var(--gold-pale); margin-bottom: 16px; display:grid; place-items:center; width:60px; height:60px; border:1px solid var(--gold-pale); border-radius:50%; }
.pillar h3 { color: #fff; font-size: 1.6rem; margin-bottom: 10px; }
.pillar p { color: rgba(255,255,255,.66); font-size: 14.5px; font-weight: 300; line-height: 1.7; }

/* Artigo */
.article { background: var(--paper-card); border: 1px solid var(--rule); border-radius: var(--r-lg); overflow: hidden; display:block; transition: transform .35s var(--ease), box-shadow .35s; }
.article:hover { transform: translateY(-5px); box-shadow: var(--shadow-md); }
.article .ph, .article .imgwrap { border-radius:0; border:none; border-bottom: 1px solid var(--rule); min-height: 200px; }
.article .imgwrap { height: 210px; overflow:hidden; }
.article .imgwrap img { width:100%; height:100%; object-fit:cover; transition: transform .6s var(--ease); }
.article:hover .imgwrap img { transform: scale(1.05); }
.article .body { padding: 26px 28px 30px; }
.article .meta { font-family: var(--sans); font-size: 10px; font-weight: 600; letter-spacing: .16em; text-transform: uppercase; color: var(--gold); margin-bottom: 14px; }
.article h3 { font-size: 1.5rem; line-height: 1.2; margin-bottom: 12px; }
.article .date { font-family: var(--mono); font-size: 11px; color: var(--ink-mute); }

/* ---------- Stat ---------- */
.stat .n { font-family: var(--serif); font-style: italic; font-size: clamp(2.6rem,4vw,3.4rem); color: var(--gold); line-height: 1; }
.stat .l { font-family: var(--sans); font-size: 10.5px; font-weight: 600; letter-spacing: .2em; text-transform: uppercase; color: var(--ink-mute); margin-top: 12px; }

/* ---------- SOBRE — moldura dupla ---------- */
.sobre-photo { position: relative; aspect-ratio: 4/5; }
.sobre-photo img { width:100%; height:100%; object-fit: cover; border-radius: var(--r-md); position: relative; z-index:1; filter: grayscale(.06) contrast(1.03); }
.sobre-photo::before { content:""; position:absolute; top:-14px; left:-14px; right:16px; bottom:16px; border:1px solid var(--gold); border-radius: var(--r-md); opacity:.5; z-index:0; }
.sobre-photo::after { content:""; position:absolute; top:16px; left:16px; right:-14px; bottom:-14px; border:1px solid var(--gold); border-radius: var(--r-md); opacity:.2; z-index:0; }
.cred-card { background: var(--paper-card); border: 1px solid var(--gold-soft); border-radius: var(--r-md); padding: 22px 24px; box-shadow: var(--shadow-md); }
.cred-card .oab { font-family: var(--mono); font-size: 12px; letter-spacing: .08em; color: var(--gold-deep); }
.signature { font-family: var(--serif); font-style: italic; font-size: 2rem; color: var(--text); }

/* drop cap */
.dropcap::first-letter { font-family: var(--serif); font-style: italic; font-size: 4rem; float: left; line-height: .8; margin: .3rem .55rem 0 0; color: var(--gold-deep); }

/* ---------- Links relacionados ---------- */
.related { background: var(--paper-warm); border-top: 1px solid var(--rule); }
.related .col h4 { font-family: var(--sans); font-size: 11px; font-weight: 600; letter-spacing: .18em; text-transform: uppercase; color: var(--gold-deep); margin-bottom: 14px; }

/* ---------- FAQ ---------- */
.faq-item { border-bottom: 1px solid var(--rule); }
.faq-q { width:100%; text-align:left; background:none; border:none; cursor:pointer; padding: 26px 0; display:flex; justify-content:space-between; gap:20px; align-items:center; font-family: var(--serif); font-size: clamp(1.25rem,2vw,1.6rem); font-weight:400; color: var(--text); }
.faq-q .ic { color: var(--gold); font-size: 24px; transition: transform .3s var(--ease); flex-shrink:0; }
.faq-item.open .faq-q .ic { transform: rotate(45deg); }
.faq-a { max-height: 0; overflow: hidden; transition: max-height .35s var(--ease); }
.faq-a .inner { padding-bottom: 26px; color: var(--ink-soft); font-weight: 300; max-width: 72ch; }

/* ---------- Footer ---------- */
footer.site { background: var(--ink); color: rgba(255,255,255,.62); padding-block: clamp(60px,7vw,92px) 36px; border-top: 1px solid var(--line); }
footer.site a { color: rgba(255,255,255,.62); transition: color .2s; }
footer.site a:hover { color: var(--gold-pale); }
.foot-grid { display:grid; grid-template-columns: 1.5fr 1fr 1fr 1fr; gap: 40px; }
.foot-col h4 { font-family: var(--sans); font-size: 11px; font-weight:600; letter-spacing: .2em; text-transform: uppercase; color: var(--gold-pale); margin-bottom: 18px; }
.foot-col ul { list-style:none; display:grid; gap: 10px; }
.foot-col li { font-size: 14px; }
.foot-brand p { font-size: 14px; color: rgba(255,255,255,.52); margin-top: 16px; max-width: 36ch; font-weight: 300; }
.foot-bottom { display:flex; justify-content:space-between; gap:20px; flex-wrap:wrap; align-items:center; margin-top: 56px; padding-top: 24px; border-top: 1px solid var(--line-2); font-family: var(--mono); font-size: 11px; color: rgba(255,255,255,.42); }

/* ---------- Placeholder de imagem (fallback) ---------- */
.ph { position: relative; border-radius: var(--r-md); overflow: hidden; background-color: var(--paper-warm); background-image: repeating-linear-gradient(135deg, rgba(47,90,158,.06) 0 2px, transparent 2px 12px); border: 1px solid var(--rule); display: grid; place-items: center; min-height: 220px; }
.ph::after { content: attr(data-label); font-family: var(--mono); font-size: 11px; letter-spacing: .1em; text-transform: uppercase; color: var(--gold-deep); opacity: .8; padding: 7px 13px; border: 1px dashed var(--gold-soft); border-radius: 4px; background: rgba(255,255,255,.6); text-align: center; max-width: 80%; }
.ph.tall { min-height: 480px; }
.imgframe { position: relative; border-radius: var(--r-md); overflow: hidden; }
.imgframe img { width:100%; height:100%; object-fit: cover; display:block; }

/* ---------- Família de temas (Áreas de Atuação) ---------- */
.fam { background: var(--paper-card); border: 1px solid var(--rule); border-radius: var(--r-lg); padding: 26px 24px 22px; transition: transform .3s var(--ease), box-shadow .3s, border-color .3s; }
.fam:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); border-color: var(--gold-soft); }
.fam__hd { display: flex; align-items: center; gap: 13px; padding-bottom: 15px; margin-bottom: 8px; border-bottom: 1px solid var(--rule); }
.fam__ic { width: 42px; height: 42px; flex-shrink: 0; border: 1px solid var(--gold); border-radius: 50%; display: grid; place-items: center; font-family: var(--serif); font-style: italic; font-size: 19px; color: var(--gold-deep); transition: background .3s, color .3s; }
.fam:hover .fam__ic { background: var(--gold); color: #fff; }
.fam__hd h3 { font-size: 1.2rem; margin: 0; line-height: 1.12; }

/* ---------- Reveal ---------- */
.reveal { opacity: 0; transform: translateY(24px); transition: opacity .9s var(--ease), transform .9s var(--ease); }
.reveal.in { opacity: 1; transform: none; }

/* ---------- Efeitos: entrada do hero ---------- */
@keyframes heroUp { from { opacity:0; transform: translateY(22px); } to { opacity:1; transform:none; } }
@keyframes heroKen { from { transform: scale(1.06); } to { transform: scale(1.16); } }
.hero__bg { animation: heroKen 20s ease-out forwards; }
.hero .wrap > * { opacity: 0; animation: heroUp 1s var(--ease) forwards; }
.hero .wrap > *:nth-child(1) { animation-delay: .08s; }
.hero .wrap > *:nth-child(2) { animation-delay: .20s; }
.hero .wrap > *:nth-child(3) { animation-delay: .32s; }
.hero .wrap > *:nth-child(4) { animation-delay: .44s; }
.hero .wrap > *:nth-child(5) { animation-delay: .58s; }

/* microinteração nos glass pillars */
.gp { position: relative; }
.gp::after { content:""; position:absolute; top:0; left:50%; transform:translateX(-50%); width:0; height:1px; background: var(--gold-light); box-shadow: 0 0 14px var(--gold-light); transition: width .6s var(--ease); }
.gp:hover::after { width: 70%; }

/* barra de progresso de leitura */
.progress { position: fixed; top: 0; left: 0; height: 2px; width: 0; background: linear-gradient(90deg, var(--gold), var(--gold-light)); z-index: 200; transition: width .1s linear; }

@media (prefers-reduced-motion: reduce) {
  .hero__bg, .hero .wrap > * { animation: none; opacity: 1; }
  .reveal { transition: none; }
}

/* ---------- Divisor ---------- */
.rule-orn { display:flex; align-items:center; gap:16px; }
.rule-orn::before, .rule-orn::after { content:""; height:1px; background: var(--rule); flex:1; }
.rule-orn .dot { width:6px; height:6px; background: var(--gold); transform:rotate(45deg); }

/* ---------- Seção escura ---------- */
.dark { position: relative; background: var(--ink); color:#fff; overflow:hidden; isolation:isolate; }
.dark .eyebrow { color: var(--gold-pale); }
.dark .eyebrow::before, .dark .eyebrow.center::after { background: var(--gold-pale); opacity:.7; }
.dark h2 { color:#fff; }
.dark .lead { color: rgba(255,255,255,.7); }
.glow-tr { position:absolute; top:-40%; right:-25%; width:680px; height:680px; background: radial-gradient(circle, rgba(80,130,210,.12), transparent 70%); border-radius:50%; z-index:-1; }
.glow-bl { position:absolute; bottom:-40%; left:-25%; width:680px; height:680px; background: radial-gradient(circle, rgba(80,130,210,.08), transparent 70%); border-radius:50%; z-index:-1; }

/* ---------- Artigo / página-folha (conteúdo) ---------- */
.article-grid { display:grid; grid-template-columns: 240px minmax(0,1fr); gap: clamp(36px,5vw,64px); align-items:start; }
.article-grid > * { min-width: 0; }
.toc { position: sticky; top: 96px; border:1px solid var(--rule); border-radius: var(--r-md); padding: 22px 24px; background: var(--paper-card); }
.toc h4 { font-family: var(--mono); font-size: 10.5px; font-weight:500; letter-spacing:.18em; text-transform:uppercase; color: var(--gold-deep); margin-bottom: 14px; }
.toc ul { list-style:none; display:grid; gap:2px; }
.toc a { display:block; padding:7px 10px; border-left:2px solid var(--rule); font-size:13.5px; color: var(--ink-soft); transition: all .2s; }
.toc a:hover, .toc a.active { border-left-color: var(--gold); color: var(--gold-deep); background: rgba(47,90,158,.05); }
.prose { max-width: 70ch; min-width: 0; }
.prose .ctable { table-layout: fixed; }
.prose .ctable th, .prose .ctable td { overflow-wrap: anywhere; word-break: break-word; }
.keyfacts { max-width: 100%; }
.prose > p { color: var(--ink-soft); margin-bottom: 1.15rem; font-weight: 300; line-height: 1.85; }
.prose h2 { font-size: clamp(1.6rem,3vw,2.2rem); margin: 2.6rem 0 1rem; scroll-margin-top: 90px; }
.prose h2:first-child { margin-top: 0; }
.prose h3 { font-size: 1.4rem; margin: 1.9rem 0 .6rem; }
.prose ul, .prose ol { margin: 0 0 1.25rem 1.1rem; color: var(--ink-soft); font-weight: 300; display:grid; gap:.55rem; }
.prose li { line-height: 1.7; }
.prose strong { color: var(--text); font-weight: 600; }
.prose a { color: var(--gold-deep); border-bottom: 1px solid var(--gold-soft); transition: border-color .2s; }
.prose a:hover { border-color: var(--gold); }
.callout { background: var(--paper-warm); border-left: 3px solid var(--gold); border-radius: 0 var(--r-sm) var(--r-sm) 0; padding: 20px 24px; margin: 1.7rem 0; }
.callout .lbl { font-family: var(--mono); font-size: 10.5px; letter-spacing:.14em; text-transform:uppercase; color: var(--gold-deep); margin-bottom: 8px; display:block; }
.callout p { margin: 0; color: var(--ink-soft); font-weight: 300; }
@media (max-width: 860px) { .article-grid { grid-template-columns: 1fr; } .toc { position: static; } }
@media (max-width: 720px) {
  a.article[style*="grid-template-columns"] { grid-template-columns: 1fr !important; }
  a.article[style*="grid-template-columns"] .imgwrap { border-right: none !important; border-bottom: 1px solid var(--rule) !important; min-height: 220px !important; height: 220px !important; }
}
@media (max-width: 560px) {
  .ctable { table-layout: fixed; font-size: 12.5px; }
  .ctable th, .ctable td { padding: 9px 9px; word-break: break-word; overflow-wrap: anywhere; hyphens: auto; }
  .keyfacts { grid-template-columns: 1fr 1fr; }
  .keyfacts .kf .v { font-size: 1.2rem; }
}

/* ---------- Elementos didáticos (folha) ---------- */
.keyfacts { display:grid; grid-template-columns:repeat(auto-fit,minmax(140px,1fr)); gap:1px; background:var(--rule); border:1px solid var(--rule); border-radius:var(--r-md); overflow:hidden; margin:1.8rem 0; }
.keyfacts .kf { background:var(--paper-card); padding:18px 20px; }
.keyfacts .kf .k { font-family:var(--mono); font-size:10px; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-mute); display:block; margin-bottom:7px; }
.keyfacts .kf .v { font-family:var(--serif); font-size:1.35rem; color:var(--gold-deep); line-height:1.15; }
.ctable { width:100%; border-collapse:collapse; margin:1.8rem 0; font-size:14px; border:1px solid var(--rule); border-radius:var(--r-md); overflow:hidden; }
.ctable th, .ctable td { padding:13px 15px; text-align:left; border-bottom:1px solid var(--rule); }
.ctable thead th { background:var(--ink); color:#fff; font-family:var(--sans); font-size:10.5px; font-weight:600; letter-spacing:.08em; text-transform:uppercase; }
.ctable tbody th { font-weight:600; color:var(--text); background:var(--paper-warm); font-size:13.5px; }
.ctable tbody tr:last-child td, .ctable tbody tr:last-child th { border-bottom:none; }
.ctable .yes { color:#2E5E55; font-weight:600; }
.ctable .no { color:#9A3B3B; }
.steps { display:grid; gap:14px; margin:1.8rem 0; }
.step { display:grid; grid-template-columns:auto 1fr; gap:20px; align-items:start; padding:22px 24px; border:1px solid var(--rule); border-radius:var(--r-md); background:var(--paper-card); transition:border-color .25s, box-shadow .25s; }
.step:hover { border-color:var(--gold-soft); box-shadow:var(--shadow-sm); }
.step .sn { width:42px; height:42px; border-radius:50%; border:1px solid var(--gold); color:var(--gold-deep); display:grid; place-items:center; font-family:var(--serif); font-style:italic; font-size:20px; flex-shrink:0; }
.step .st { font-family:var(--serif); font-size:1.25rem; color:var(--text); margin-bottom:5px; }
.step p { margin:0; font-size:14.5px; }
.checklist { list-style:none !important; margin:1.3rem 0 !important; display:grid; gap:.7rem; }
.checklist li { display:block; position:relative; padding-left:28px; line-height:1.6; }
.checklist li::before { content:"✓"; position:absolute; left:0; top:0; color:var(--gold); font-weight:700; }
.figure { margin:2rem 0; border:1px solid var(--rule); border-radius:var(--r-md); overflow:hidden; }
.figure img { width:100%; display:block; max-height:360px; object-fit:cover; }
.figure figcaption { font-family:var(--mono); font-size:11px; color:var(--ink-mute); padding:11px 16px; background:var(--paper-warm); letter-spacing:.03em; }

/* ---------- Botão flutuante WhatsApp ---------- */
.wpp-float { transition: transform .25s var(--ease), box-shadow .25s; }
.wpp-float:hover { transform: scale(1.08); box-shadow: 0 16px 40px rgba(37,211,102,.55) !important; }
.wpp-float::after { content:"Fale conosco"; position:absolute; right:72px; white-space:nowrap; background:var(--ink); color:#fff; font-family:var(--sans); font-size:12px; font-weight:500; padding:8px 14px; border-radius:8px; opacity:0; transform:translateX(8px); transition:opacity .25s, transform .25s; pointer-events:none; }
.wpp-float:hover::after { opacity:1; transform:translateX(0); }
@media (max-width:600px){ .wpp-float{ width:54px !important; height:54px !important; bottom:16px !important; right:16px !important; } .wpp-float::after{ display:none; } }

/* ---------- Responsivo ---------- */
@media (max-width: 980px) {
  .g-4 { grid-template-columns: repeat(2,1fr); }
  .foot-grid { grid-template-columns: 1fr 1fr; }
  .nav-cta .btn { display: none; }
  .menu-btn { display: inline-flex; }
  /* Menu mobile (dropdown via :focus-within — funciona sem JS em todas as páginas) */
  header.site .wrap { position: relative; }
  nav.primary {
    position: absolute; top: 100%; left: 0; right: 0;
    flex-direction: column; gap: 0; align-items: stretch;
    background: var(--ink-2); border-top: 1px solid var(--line); border-bottom: 1px solid var(--line);
    box-shadow: var(--shadow-lg);
    max-height: 0; overflow: hidden; opacity: 0; visibility: hidden; pointer-events: none;
    transition: max-height .32s var(--ease), opacity .25s var(--ease);
    z-index: 60;
  }
  header.site:focus-within nav.primary, header.site.nav-open nav.primary { max-height: 70vh; opacity: 1; visibility: visible; pointer-events: auto; }
  nav.primary a { padding: 15px var(--gutter); font-size: 12.5px; color: rgba(255,255,255,.88); border-bottom: 1px solid var(--line-2); }
  nav.primary a:last-child { border-bottom: none; }
  nav.primary a::after { display: none; }
  .menu-btn { display: inline-flex !important; font-size: 22px; padding: 8px 14px; line-height: 1; color: var(--gold-pale) !important; background: transparent !important; border: 1px solid rgba(212,180,122,.55) !important; }
  .menu-btn:hover { background: rgba(212,180,122,.12) !important; color: #fff !important; }
}
@media (max-width: 720px) {
  body { font-size: 15.5px; }
  .g-2, .g-3, .g-4 { grid-template-columns: 1fr; }
  /* calculadoras e seções 2-colunas: empilhar no mobile */
  [style*="grid-template-columns:1fr 1fr"], [style*="grid-template-columns: 1fr 1fr"] { grid-template-columns: 1fr !important; }
  /* qualquer .wrap com grid inline (proporções .82fr/1.18fr, repeat(3,1fr) dos rodapés relacionados etc.) colapsa */
  .wrap[style*="grid-template-columns"], .related .wrap[style*="grid-template-columns"] { grid-template-columns: 1fr !important; }
  /* molduras decorativas da foto do advogado não podem vazar a viewport */
  .sobre-photo::before, .sobre-photo::after { left: 6px !important; right: 6px !important; top: 8px !important; bottom: 8px !important; }
  .card[style*="position:sticky"], .toc { position: static !important; }
  /* Home — Quem Somos: esconder a 2ª foto no mobile e remover deslocamento */
  .home-about-photos .imgframe:nth-child(2) { display: none; }
  .home-about-photos .imgframe { margin-top: 0 !important; aspect-ratio: 16/10 !important; }
  .topbar-left { display: none; }
}
/* ---------- Ajustes mobile: grids 2-col inline, foto e cards flutuantes ---------- */
@media (max-width: 820px) {
  /* colapsa qualquer grid 2-col definido inline (sobre, piso, quem-somos, hubs) */
  .wrap[style*="grid-template-columns"] { grid-template-columns: 1fr !important; align-items: start !important; }
  /* foto do advogado: vai pro topo, tamanho contido, alinhada ao texto */
  .sobre-photo { aspect-ratio: 4/5; width: 100%; max-width: 320px; margin: 0 0 8px; }
  /* cards flutuantes (ex.: "8,5×" do piso) saem do absoluto e fluem perto do título */
  .card[style*="position:absolute"] { position: static !important; inset: auto !important; max-width: 100% !important; margin: 0 0 22px !important; box-shadow: var(--shadow-md) !important; }
  /* a coluna da foto/figura do piso vem depois do texto para o card ficar junto do título */
  .article-grid { grid-template-columns: 1fr; }
}

/* ============================================================
   CAMADA DE ACENTO DOURADO (navy + ouro) — site inteiro
   ============================================================ */
:root { --amber:#D4B47A; --amber-deep:#B8945A; --amber-pale:#E8D5A0; }

/* ---- HERO (Home) ---- */
.hero__bg { filter: brightness(.42) saturate(1.05) contrast(1.04) sepia(.06); transform: scale(1.06); }
.hero__overlay {
  background:
    radial-gradient(ellipse 90% 55% at 50% -6%, rgba(212,180,122,.30) 0%, rgba(212,180,122,.06) 38%, transparent 60%),
    radial-gradient(ellipse 70% 60% at 12% 108%, rgba(47,90,158,.55) 0%, transparent 55%),
    radial-gradient(ellipse 60% 50% at 92% 18%, rgba(96,140,210,.22) 0%, transparent 50%),
    linear-gradient(165deg, rgba(16,32,62,.62) 0%, rgba(18,38,72,.80) 48%, rgba(10,20,42,.96) 100%);
}
.hero__grid { background-image: linear-gradient(rgba(212,180,122,.07) 1px, transparent 1px), linear-gradient(90deg, rgba(212,180,122,.07) 1px, transparent 1px); }
.hero .eyebrow { color: var(--amber); }
.hero .eyebrow::before, .hero .eyebrow.center::after { background: var(--amber); opacity:.85; }
.hero h1 em.gold { color: var(--amber) !important; }
.hero { border-bottom: 1px solid rgba(212,180,122,.30); }
.glass-pillars::before { background: linear-gradient(90deg, transparent, var(--amber) 28%, var(--amber) 72%, transparent); opacity:.8; }
.glass-pillars { border-color: rgba(212,180,122,.28); background: linear-gradient(180deg, rgba(212,180,122,.07), rgba(255,255,255,.02)); }
.gp .l { color: var(--amber); }
.gp:hover { background: radial-gradient(ellipse at top, rgba(212,180,122,.16), transparent 70%); }
.gp::after { background: var(--amber); box-shadow:0 0 14px var(--amber); }
.hero .btn.on-dark.ghost { border-color: rgba(212,180,122,.45); }
.hero .btn.on-dark.ghost:hover { background: rgba(212,180,122,.12); color:#fff; border-color: var(--amber); }

/* ---- BANNER (páginas internas) ---- */
.banner__bg { filter: brightness(.46) saturate(1.05) contrast(1.04) sepia(.06); }
.banner__overlay {
  background:
    radial-gradient(ellipse 95% 70% at 28% -10%, rgba(212,180,122,.30) 0%, rgba(212,180,122,.06) 40%, transparent 62%),
    radial-gradient(ellipse 70% 80% at 100% 110%, rgba(47,90,158,.5) 0%, transparent 55%),
    linear-gradient(100deg, rgba(16,32,62,.92) 0%, rgba(18,38,72,.74) 55%, rgba(10,20,42,.6) 100%);
}
.banner { border-bottom: 1px solid rgba(212,180,122,.30); }
.banner .eyebrow.light { color: var(--amber); }
.banner .eyebrow.light::before, .banner .eyebrow.light.center::after { background: var(--amber); opacity:.85; }
.crumb a { color: var(--amber); }
.crumb a:hover { color:#fff; }

/* ---- Trust marquee ---- */
.trust { background: linear-gradient(180deg, #122a4d 0%, #0c1a34 100%); border-top:1px solid rgba(212,180,122,.14); }
.trust-pill .ck { color: var(--amber); }
.trust-pill::after { background: var(--amber); }

/* ---- Acentos no corpo ---- */
.eyebrow { color: var(--amber-deep); }
.eyebrow::before, .eyebrow.center::after { background: var(--amber); }
.head-orn .d { background: var(--amber); }
.head-orn::before, .head-orn::after { background: var(--amber); opacity:.55; }
.link-arr { color: var(--amber-deep); }
.link-arr:hover { color: var(--amber-deep); }
.stat .n { color: var(--amber-deep); }
.faq-q .ic { color: var(--amber-deep); }
.linklist a::before { color: var(--amber); }
.signature, .dropcap::first-letter { color: var(--amber-deep); }
.btn.gold { background: var(--amber-deep); border-color: var(--amber-deep); }
.btn.gold:hover { background: var(--ink); border-color: var(--ink); }
.related .col h4 { color: var(--amber-deep); }

/* ---- Faixas escuras ---- */
.dark .eyebrow, .dark .eyebrow.center { color: var(--amber); }
.dark .eyebrow::before, .dark .eyebrow.center::after { background: var(--amber); opacity:.85; }
.dark h2 em, .dark h2 em.gold { color: var(--amber-pale) !important; }
.pillar .num { border-color: var(--amber); color: var(--amber-pale); }
.glow-tr { background: radial-gradient(circle, rgba(212,180,122,.12), transparent 70%); }
.glow-bl { background: radial-gradient(circle, rgba(212,180,122,.07), transparent 70%); }

/* ---- Reverter ao AZUL (pedido do cliente): ícones I–VI, barra dos cards, link após assinatura ---- */
.pcard__ic { border-color: var(--gold); color: var(--gold-deep); }
.pcard:hover .pcard__ic { background: var(--gold); color:#fff; border-color: var(--gold); }
.pcard::before, .pcard::after { background: var(--gold); }
.card::before { background: var(--gold); }
.signature + .link-arr { color: var(--gold-deep); }
.signature + .link-arr:hover { color: var(--gold); }

