/* ============================================================
   myrole.co — legal pages
   Calm, readable, on the brand tokens. ../01-brand-foundation/design-tokens.css
   ============================================================ */
* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  font-family: var(--mr-font-body);
  background: var(--mr-bg);
  color: var(--mr-text);
  -webkit-font-smoothing: antialiased;
  line-height: 1.6;
  background-image: radial-gradient(110% 50% at 90% -10%, rgba(31,224,106,.05), transparent 50%);
}
a { color: var(--mr-signal-deep); text-decoration: none; }
a:hover { text-decoration: underline; }

/* top bar */
.topnav { border-bottom: 1px solid var(--mr-border); background: color-mix(in srgb, var(--mr-paper-50) 85%, transparent); backdrop-filter: blur(10px); position: sticky; top: 0; z-index: 10; }
.topnav .row { max-width: 1000px; margin: 0 auto; padding: 0 28px; height: 64px; display: flex; align-items: center; justify-content: space-between; }
.brand { display: inline-flex; align-items: center; gap: 9px; color: var(--mr-text); }
.brand .mark { width: 27px; height: 27px; flex: none; }
.brand .wm { font-family: var(--mr-font-display); font-weight: 700; font-size: 22px; letter-spacing: -.02em; line-height: 1; }
.brand .dot { color: var(--mr-signal); } .brand .co { color: var(--mr-text-muted); font-weight: 600; }
.topnav a.back { font-size: 13.5px; font-weight: 500; color: var(--mr-text-secondary); }

.wrap { max-width: 800px; margin: 0 auto; padding: 0 28px; }
.dochead { padding: 56px 0 28px; border-bottom: 1px solid var(--mr-border); }
.dochead .eyebrow { font-family: var(--mr-font-mono); font-size: 11px; letter-spacing: .16em; text-transform: uppercase; color: var(--mr-text-muted); }
.dochead h1 { font-family: var(--mr-font-display); font-weight: 600; font-size: clamp(34px, 5vw, 50px); letter-spacing: -.02em; margin: 14px 0 12px; }
.dochead .meta { font-size: 13.5px; color: var(--mr-text-muted); display: flex; gap: 16px; flex-wrap: wrap; }

/* draft banner */
.draft-banner { display: flex; gap: 12px; align-items: flex-start; background: var(--mr-amber-50); border: 1px solid #EBD3A3; border-radius: 12px; padding: 14px 16px; margin: 26px 0 0; font-size: 13.5px; color: #7a571a; }
.draft-banner .ico { flex: none; color: #B9821F; }
.draft-banner b { color: #5e4313; }

/* layout w/ TOC */
.doc { display: grid; grid-template-columns: 200px 1fr; gap: 44px; padding: 36px 0 90px; align-items: start; }
.toc { position: sticky; top: 84px; font-size: 13px; }
.toc .label { font-family: var(--mr-font-mono); font-size: 10px; letter-spacing: .12em; text-transform: uppercase; color: var(--mr-text-muted); margin-bottom: 12px; }
.toc ul { list-style: none; display: flex; flex-direction: column; gap: 2px; }
.toc a { display: block; padding: 6px 10px; border-radius: 7px; color: var(--mr-text-secondary); border-left: 2px solid transparent; }
.toc a:hover { background: var(--mr-bg-sunken); text-decoration: none; color: var(--mr-text); }

.body h2 { font-family: var(--mr-font-display); font-weight: 600; font-size: 22px; letter-spacing: -.01em; margin: 38px 0 12px; scroll-margin-top: 84px; }
.body h2:first-child { margin-top: 0; }
.body h3 { font-size: 16px; font-weight: 600; margin: 22px 0 8px; }
.body p { margin: 0 0 14px; color: var(--mr-text-secondary); }
.body ul { margin: 0 0 16px; padding-left: 20px; color: var(--mr-text-secondary); }
.body li { margin: 6px 0; }
.body strong { color: var(--mr-text); }
.body .lead { font-size: 17px; color: var(--mr-text); }
.placeholder { background: var(--mr-bg-sunken); border: 1px dashed var(--mr-border-strong); border-radius: 8px; padding: 2px 7px; font-family: var(--mr-font-mono); font-size: .85em; color: var(--mr-text-muted); }

.contact-card { background: var(--mr-bg-raised); border: 1px solid var(--mr-border); border-radius: 14px; padding: 22px 24px; margin-top: 30px; box-shadow: var(--mr-shadow-sm); }
.contact-card h3 { font-family: var(--mr-font-display); font-size: 17px; margin-bottom: 6px; }
.contact-card p { font-size: 14px; color: var(--mr-text-secondary); margin: 2px 0; }

footer.foot { border-top: 1px solid var(--mr-border); padding: 30px 0 60px; }
footer.foot .row { max-width: 800px; margin: 0 auto; padding: 0 28px; display: flex; justify-content: space-between; gap: 16px; flex-wrap: wrap; font-size: 12.5px; color: var(--mr-text-muted); }
footer.foot .links { display: flex; gap: 16px; flex-wrap: wrap; }
footer.foot .links a { color: var(--mr-text-secondary); }

@media (max-width: 760px){ .doc { grid-template-columns: 1fr; } .toc { display: none; } }
