/* ============================================================
   OdontoFlow · Páginas Legais · legal.css
   Reutiliza tokens da landing, layout focado em documento.
   ============================================================ */
@import url("https://fonts.googleapis.com/css2?family=Instrument+Serif:ital@0;1&family=Geist:wght@400;500;700&family=JetBrains+Mono:wght@400;500&display=swap");

:root{
  --ink-900:#0E1A2E; --ink-700:#1B2B47; --ink-500:#3D4A66; --ink-300:#7A8499;
  --paper-50:#F4EFE3; --paper-100:#EAE3D2; --paper-200:#DDD3BD;
  --accent-gold:#B0916A; --accent-deep:#6B5135; --guarantee:#3F6B5C;
  --shadow-soft:rgba(14,26,46,0.06); --shadow-medium:rgba(14,26,46,0.12);
  --font-serif:"Instrument Serif","EB Garamond",Lora,serif;
  --font-sans:"Geist","Söhne","GT America",Inter,system-ui,sans-serif;
  --font-mono:"JetBrains Mono","IBM Plex Mono",ui-monospace,monospace;
  --space-1:4px; --space-2:8px; --space-3:12px; --space-4:16px; --space-6:24px;
  --space-8:32px; --space-12:48px; --space-16:64px; --space-24:96px;
  --tracking-kicker:0.18em;
}

*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--font-sans);
  color:var(--ink-700);
  background:var(--paper-50);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
:where(h1,h2,h3,h4,p,ul,ol,figure){margin:0}
a{color:inherit;text-decoration:none}

/* ===== Header doc ===== */
.doc-header{
  position:sticky;top:0;z-index:50;
  background:var(--paper-50);
  border-bottom:1px solid var(--paper-200);
  padding:20px 0;
}
.doc-header .container{display:flex;justify-content:space-between;align-items:baseline;gap:24px}
.doc-header__brand{font-family:var(--font-serif);font-size:22px;letter-spacing:-0.01em;color:var(--ink-900)}
.doc-header__brand em{font-style:italic;color:var(--accent-deep)}
.doc-header__back{
  font-family:var(--font-mono);font-size:11px;letter-spacing:0.18em;text-transform:uppercase;
  color:var(--ink-500);transition:color 180ms ease;
}
.doc-header__back:hover{color:var(--ink-900)}
.doc-header__back .arr{margin-right:8px;font-family:var(--font-mono)}

/* ===== Container ===== */
.container{
  width:100%;max-width:780px;
  margin:0 auto;padding-left:20px;padding-right:20px;
}
.container--wide{max-width:1180px}

/* ===== Hero do documento ===== */
.doc-hero{padding:72px 0 48px;border-bottom:1px solid var(--paper-200);margin-bottom:64px}
.doc-hero__kicker{
  display:block;font-family:var(--font-mono);font-size:11px;font-weight:500;
  letter-spacing:var(--tracking-kicker);text-transform:uppercase;
  color:var(--ink-300);line-height:1.4;margin-bottom:24px;
}
.doc-hero__title{
  font-family:var(--font-serif);font-weight:400;
  font-size:48px;line-height:1.1;letter-spacing:-0.01em;
  color:var(--ink-900);max-width:22ch;text-wrap:balance;
}
.doc-hero__title em{font-style:italic;color:var(--accent-deep)}
.doc-hero__meta{
  margin-top:32px;display:grid;grid-template-columns:1fr;gap:16px;
  padding-top:32px;border-top:1px solid var(--paper-200);
}
.doc-hero__meta-row{
  display:grid;grid-template-columns:120px 1fr;gap:16px;align-items:baseline;
  font-family:var(--font-mono);font-size:11px;letter-spacing:0.16em;text-transform:uppercase;
  color:var(--ink-500);line-height:1.5;
}
.doc-hero__meta-row .lbl{color:var(--ink-300)}
.doc-hero__meta-row .val{color:var(--ink-700)}
.doc-hero__abstract{
  margin-top:40px;font-family:var(--font-serif);font-style:italic;
  font-size:20px;line-height:1.5;color:var(--ink-500);
  max-width:48ch;
}

/* ===== Sumário ===== */
.doc-toc{
  margin-bottom:64px;padding:32px;background:var(--paper-100);
  border:1px solid var(--paper-200);
}
.doc-toc__title{
  font-family:var(--font-mono);font-size:11px;font-weight:500;
  letter-spacing:0.18em;text-transform:uppercase;
  color:var(--ink-300);margin-bottom:16px;
}
.doc-toc ol{list-style:none;padding:0;display:flex;flex-direction:column;gap:8px;counter-reset:toc}
.doc-toc li{counter-increment:toc;display:grid;grid-template-columns:36px 1fr;gap:12px;align-items:baseline}
.doc-toc li::before{
  content:counter(toc,lower-roman) ".";
  font-family:var(--font-mono);font-size:10px;letter-spacing:0.2em;
  color:var(--ink-300);text-transform:uppercase;
}
.doc-toc li a{font-size:15px;line-height:1.5;color:var(--ink-700);transition:color 180ms ease}
.doc-toc li a:hover{color:var(--accent-deep)}

/* ===== Conteúdo ===== */
.doc-section{
  padding:48px 0;border-top:1px solid var(--paper-200);
  display:grid;grid-template-columns:60px 1fr;gap:24px;
}
.doc-section:first-of-type{border-top:0;padding-top:0}
.doc-section__num{
  font-family:var(--font-mono);font-size:11px;font-weight:500;
  letter-spacing:0.18em;color:var(--ink-300);padding-top:6px;
}
.doc-section__body{display:flex;flex-direction:column;gap:20px}
.doc-section__title{
  font-family:var(--font-serif);font-weight:400;
  font-size:28px;line-height:1.2;letter-spacing:-0.005em;
  color:var(--ink-900);max-width:32ch;text-wrap:balance;
}
.doc-section__title em{font-style:italic;color:var(--accent-deep)}
.doc-section__subtitle{
  font-family:var(--font-sans);font-weight:500;
  font-size:17px;line-height:1.35;letter-spacing:-0.005em;
  color:var(--ink-900);margin-top:8px;
  padding-top:20px;border-top:1px solid var(--paper-200);
  max-width:42ch;
}
.doc-section p{
  font-size:16px;line-height:1.7;color:var(--ink-700);
  max-width:62ch;
}
.doc-section p strong{color:var(--ink-900);font-weight:500}
.doc-section p em{font-family:var(--font-serif);font-style:italic;color:var(--accent-deep);font-size:1.05em}
.doc-section ul,.doc-section ol{padding-left:0;list-style:none}
.doc-section ul li,.doc-section ol li{
  position:relative;padding-left:24px;margin-bottom:10px;
  font-size:16px;line-height:1.7;color:var(--ink-700);max-width:62ch;
}
.doc-section ul li::before{
  content:"—";position:absolute;left:0;color:var(--accent-deep);font-family:var(--font-mono);
}
.doc-section ol{counter-reset:l}
.doc-section ol li{counter-increment:l}
.doc-section ol li::before{
  content:counter(l,lower-alpha) ".";position:absolute;left:0;
  color:var(--ink-300);font-family:var(--font-mono);font-size:11px;letter-spacing:0.14em;text-transform:uppercase;top:2px;
}
.doc-section .note{
  margin-top:8px;padding:16px 20px;background:var(--paper-100);
  border-left:2px solid var(--accent-gold);
  font-family:var(--font-mono);font-size:13px;line-height:1.6;color:var(--ink-500);
}
.doc-section .note strong{color:var(--ink-900);font-weight:500}

/* ===== Disclaimer ===== */
.doc-disclaimer{
  margin:64px 0;padding:24px 32px;background:var(--paper-100);
  border:1px solid var(--paper-200);
  font-family:var(--font-mono);font-size:12px;line-height:1.6;
  color:var(--ink-500);max-width:none;
}
.doc-disclaimer strong{color:var(--ink-900);font-weight:500}

/* ===== Outros docs (cross-link) ===== */
.doc-related{
  margin-top:96px;padding-top:48px;border-top:1px solid var(--paper-200);
}
.doc-related__title{
  font-family:var(--font-mono);font-size:11px;font-weight:500;
  letter-spacing:0.18em;text-transform:uppercase;
  color:var(--ink-300);margin-bottom:24px;
}
.doc-related__grid{display:grid;grid-template-columns:1fr;gap:16px}
.doc-related a{
  display:grid;grid-template-columns:1fr auto;gap:16px;align-items:baseline;
  padding:20px 0;border-top:1px solid var(--paper-200);
  transition:padding 180ms ease;
}
.doc-related a:hover{padding-left:8px}
.doc-related a:last-child{border-bottom:1px solid var(--paper-200)}
.doc-related a .name{
  font-family:var(--font-serif);font-size:22px;line-height:1.2;
  color:var(--ink-900);letter-spacing:-0.005em;
}
.doc-related a .arr{
  font-family:var(--font-mono);font-size:11px;letter-spacing:0.18em;
  text-transform:uppercase;color:var(--ink-300);
  transition:color 180ms ease,transform 180ms ease;
}
.doc-related a:hover .arr{color:var(--accent-deep);transform:translateX(4px)}

/* ===== Footer doc ===== */
.doc-footer{
  background:var(--ink-900);color:var(--paper-200);
  padding:48px 0 32px;margin-top:96px;
  border-top:1px solid var(--ink-500);
}
.doc-footer .container{
  display:flex;flex-direction:column;gap:24px;
  font-family:var(--font-mono);font-size:11px;letter-spacing:0.18em;
  text-transform:uppercase;
}
.doc-footer__brand{
  font-family:var(--font-serif);font-size:28px;letter-spacing:-0.01em;
  color:var(--paper-50);text-transform:none;
}
.doc-footer__brand em{font-style:italic;color:var(--accent-gold)}
.doc-footer__row{display:flex;flex-wrap:wrap;gap:24px;align-items:baseline;color:#6a7385}
.doc-footer__row a{color:var(--paper-50);transition:color 180ms ease}
.doc-footer__row a:hover{color:var(--accent-gold)}

/* ===== Desktop ===== */
@media (min-width:1024px){
  .doc-hero{padding:120px 0 64px;margin-bottom:96px}
  .doc-hero__title{font-size:64px}
  .doc-hero__meta-row{grid-template-columns:160px 1fr}
  .doc-section{grid-template-columns:80px 1fr;gap:48px;padding:64px 0}
  .doc-section__title{font-size:32px}
  .doc-related__grid{grid-template-columns:1fr 1fr;gap:24px}
}
