/* =====================================================================
   Vanessa — páginas institucionais (layout específico)
   Depende de historia.css (tokens, nav, footer, botões, .gplay).
   ===================================================================== */

/* page header */
/* gradiente passa por baixo do nav (transparente no topo, igual ao landing) */
.page-hero { position:relative; overflow:hidden; margin-top:-70px; padding:142px 0 48px; }
.page-hero::before { content:""; position:absolute; inset:0; z-index:-1; background:var(--grad-hero); }
.page-hero .eyebrow { margin-bottom:16px; }
.page-hero h1 { font-family:var(--serif); font-weight:500; font-size:clamp(34px,5.2vw,56px);
  line-height:1.06; letter-spacing:-.025em; margin:0 0 16px; text-wrap:balance; }
.page-hero h1 em { font-style:italic; color:var(--brand); }
.page-hero .lead { font-size:clamp(17px,2vw,20px); color:var(--ink-2); margin:0; max-width:none; text-wrap:pretty; }
.page-hero .updated { display:inline-flex; align-items:center; gap:8px; margin-top:22px; font-size:13px; color:var(--muted); }
.page-hero .updated svg { width:15px; height:15px; }

/* legal prose */
.prose { max-width:none; margin:0; padding:64px 0 40px; }
.prose .toc { display:flex; flex-wrap:wrap; gap:8px; margin-bottom:48px; }
.prose .toc a { font-size:13.5px; font-weight:600; color:var(--ink-2); background:var(--surface);
  border:.5px solid var(--line); border-radius:var(--r-pill); padding:9px 16px; transition:.2s; }
.prose .toc a:hover { color:var(--brand); border-color:var(--brand-soft); background:var(--brand-tint); }
.prose section { margin-bottom:42px; scroll-margin-top:90px; }
.prose h2 { font-family:var(--serif); font-weight:500; font-size:26px; letter-spacing:-.015em; line-height:1.16;
  margin:0 0 16px; display:flex; gap:13px; align-items:baseline; }
.prose h2 .n { font-size:15px; font-weight:600; color:var(--brand); font-family:var(--sans); flex-shrink:0;
  width:30px; }
.prose h3 { font-size:17px; font-weight:700; letter-spacing:-.01em; margin:24px 0 10px; }
.prose p { font-size:16.5px; line-height:1.66; color:var(--ink-2); margin:0 0 14px; text-wrap:pretty; }
.prose p:last-child { margin-bottom:0; }
.prose strong { color:var(--ink); font-weight:650; }
.prose ul.bullets { display:flex; flex-direction:column; gap:11px; margin:6px 0 16px; }
.prose ul.bullets li { position:relative; padding-left:18px; font-size:16px; line-height:1.55; color:var(--ink-2); }
.prose ul.bullets li::before { content:""; position:absolute; left:0; top:10px; width:7px; height:7px;
  border-radius:50%; background:var(--brand); }
.prose .callout { background:var(--surface); border:.5px solid var(--line); border-left:3px solid var(--brand);
  border-radius:var(--r-md); padding:20px 22px; margin:18px 0; display:flex; gap:15px; }
.prose .callout svg { width:22px; height:22px; color:var(--brand); flex-shrink:0; margin-top:1px; }
.prose .callout p { margin:0; font-size:15.5px; color:var(--ink); }
.prose .callout strong { color:var(--ink); }
.prose a.inline { color:var(--brand); font-weight:600; text-decoration:underline; text-underline-offset:2px; }

/* contact */
.contact { max-width:none; margin:0; padding:56px 0 40px; }
.contact-grid { display:grid; grid-template-columns:1fr 1.1fr; gap:48px; align-items:start; }
.contact-cards { display:flex; flex-direction:column; gap:16px; }
.ccard { background:var(--surface); border:.5px solid var(--line); border-radius:var(--r-xl); padding:24px 26px;
  box-shadow:var(--shadow); display:flex; gap:16px; align-items:flex-start; }
.ccard .ic { width:48px; height:48px; border-radius:14px; display:grid; place-items:center; flex-shrink:0;
  background:var(--brand-tint); color:var(--brand); }
.ccard .ic svg { width:23px; height:23px; }
.ccard h3 { font-size:13px; font-weight:700; letter-spacing:.04em; text-transform:uppercase; color:var(--muted); margin:2px 0 6px; }
.ccard .big { font-size:18px; font-weight:650; letter-spacing:-.01em; color:var(--ink); word-break:break-word; }
.ccard a.big:hover { color:var(--brand); }
.ccard p { font-size:14.5px; color:var(--ink-2); margin:4px 0 0; }
.ccard .socials { display:flex; gap:10px; margin-top:10px; }
.ccard .socials a { width:40px; height:40px; border-radius:11px; display:grid; place-items:center;
  background:var(--bg-warm); color:var(--ink-2); transition:.2s; }
.ccard .socials a:hover { background:var(--brand); color:#fff; }
.ccard .socials a svg { width:20px; height:20px; }

.contact-form { background:var(--surface); border:.5px solid var(--line); border-radius:var(--r-2xl);
  padding:34px 34px 36px; box-shadow:var(--shadow-md); }
.contact-form h2 { font-family:var(--serif); font-weight:500; font-size:24px; letter-spacing:-.015em; margin:0 0 22px; }
.field { margin-bottom:18px; }
.field label { display:block; font-size:13px; font-weight:600; color:var(--ink-2); margin-bottom:7px; }
.field input, .field textarea { width:100%; font-family:var(--sans); font-size:15.5px; color:var(--ink);
  background:var(--surface-2); border:1.5px solid var(--line-2); border-radius:var(--r-md); padding:13px 15px;
  transition:border-color .2s, box-shadow .2s; }
.field textarea { resize:vertical; min-height:130px; line-height:1.5; }
.field input:focus, .field textarea:focus { outline:none; border-color:var(--brand);
  box-shadow:0 0 0 3px var(--brand-tint); }
.field input::placeholder, .field textarea::placeholder { color:var(--muted); }
.contact-form .btn { width:100%; margin-top:6px; }
.contact-form .btn svg { width:18px; height:18px; }

/* nav back link */
.nav-back { display:inline-flex; align-items:center; gap:7px; height:42px; font-size:14.5px; font-weight:600; color:var(--ink);
  padding:0 16px; border-radius:var(--r-pill);
  background:color-mix(in srgb, var(--surface) 55%, transparent);
  backdrop-filter:blur(14px) saturate(180%); -webkit-backdrop-filter:blur(14px) saturate(180%);
  box-shadow:inset 0 0 0 1px color-mix(in srgb, #fff 60%, transparent), inset 0 1px 0 rgba(255,255,255,.45), 0 6px 18px rgba(120,80,60,.10);
  transition:box-shadow .2s var(--ease), transform .15s, background .2s, color .2s; }
.nav-back svg { width:17px; height:17px; }
.nav-back:hover { color:var(--brand); background:color-mix(in srgb, var(--surface) 72%, transparent);
  box-shadow:inset 0 0 0 1px color-mix(in srgb, #fff 80%, transparent), inset 0 1px 0 rgba(255,255,255,.5), var(--shadow-md); }

/* subpáginas não usam o menu hamburger (têm o botão "Voltar ao site") */
.nav-toggle { display:none !important; }

@media (max-width:780px) {
  .contact-grid { grid-template-columns:1fr; gap:32px; }
  .contact-form { order:-1; }
}
@media (max-width:680px) {
  .page-hero { padding:118px 0 32px; }
  .prose { padding:44px 0 24px; }
  .prose h2 { font-size:23px; }
}
@media (max-width:440px) {
  /* libera espaço para a marca não ser cortada: "Voltar" vira só a seta */
  .nav-back span:last-child { display:none; }
  .nav-back { padding:9px 10px; }
}
