/* Shared layout for Tunneler policy / docs pages. Built on brand.css tokens. */
.topnav { position: sticky; top: 0; z-index: 20; backdrop-filter: blur(10px);
  background: color-mix(in oklab, var(--void) 80%, transparent); border-bottom: 1px solid var(--line); }
.topnav .wrap { max-width: 860px; margin: 0 auto; padding: 0 24px; height: 60px; display: flex; align-items: center; gap: 18px; }
.topnav .brand { display: flex; align-items: center; gap: 10px; }
.topnav .brand img { width: 24px; height: 24px; }
.topnav .brand .wm { font: 700 13px/1 var(--font-mono); letter-spacing: 0.24em; text-transform: uppercase; color: var(--ink-strong); }
.topnav .sp { flex: 1; }
.topnav a.back { color: var(--ink-dim); font-size: 14px; }
.topnav a.back:hover { color: var(--ink); }

.doc { max-width: 760px; margin: 0 auto; padding: 56px 24px 96px; }
.doc .eyebrow { font: 500 12px var(--font-mono); letter-spacing: 0.16em; text-transform: uppercase; color: var(--cyan-400); }
.doc h1 { font: 800 clamp(2rem, 5vw, 2.8rem) var(--font-display); letter-spacing: -0.02em; margin: 10px 0 8px; }
.doc .meta { color: var(--ink-faint); font: 500 13px var(--font-mono); margin-bottom: 8px; }
.doc .lead { font-size: 18px; color: var(--ink-dim); margin: 18px 0 8px; }
.doc h2 { font: 700 22px var(--font-display); margin: 40px 0 12px; letter-spacing: -0.01em; color: var(--ink-strong); }
.doc h3 { font: 700 16px var(--font-display); margin: 26px 0 8px; color: var(--ink-strong); }
.doc p, .doc li { color: var(--ink); font-size: 15px; line-height: 1.7; }
.doc ul, .doc ol { padding-left: 22px; margin: 12px 0; }
.doc li { margin: 6px 0; }
.doc li::marker { color: var(--amber-400); }
.doc a { color: var(--link); }
.doc strong { color: var(--ink-strong); }
.doc hr { border: none; border-top: 1px solid var(--line); margin: 36px 0; }
.doc .callout { background: var(--surface); border: 1px solid var(--line); border-left: 3px solid var(--amber-500); border-radius: var(--r-2); padding: 14px 16px; margin: 20px 0; font-size: 14px; color: var(--ink-dim); }
.doc .callout.warn { border-left-color: var(--hold); }
.doc table { width: 100%; border-collapse: collapse; margin: 16px 0; background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-2); overflow: hidden; }
.doc th, .doc td { text-align: left; padding: 10px 12px; border-bottom: 1px solid var(--line); font-size: 14px; vertical-align: top; }
.doc th { color: var(--ink-faint); font: 600 12px var(--font-mono); text-transform: uppercase; letter-spacing: 0.04em; }
.doc tr:last-child td { border-bottom: none; }
.doc .toc { display: flex; flex-wrap: wrap; gap: 8px; margin: 18px 0 8px; }
.doc .toc a { font: 500 13px var(--font-mono); color: var(--ink-dim); border: 1px solid var(--line); border-radius: var(--r-pill); padding: 4px 11px; }
.doc .toc a:hover { border-color: var(--amber-400); color: var(--ink-strong); }

.docfoot { border-top: 1px solid var(--line); }
.docfoot .wrap { max-width: 760px; margin: 0 auto; padding: 28px 24px; display: flex; gap: 14px; align-items: center; color: var(--ink-faint); font-size: 13px; flex-wrap: wrap; }
.docfoot .wrap .sp { flex: 1; }
.docfoot a { color: var(--ink-dim); } .docfoot a:hover { color: var(--ink); }
.pill-status { display: inline-flex; align-items: center; gap: 7px; }
.pill-status .dot { width: 9px; height: 9px; border-radius: 50%; background: var(--go); box-shadow: 0 0 10px var(--go); }
