/* Extracted from templates/legal.html (redesign 2026-05-31). */
*,*::before,*::after { box-sizing: border-box; margin: 0; padding: 0; }
    :root[data-theme="dark"] {
      --bg: #0A0F1E; --bg-elev: #0F1729; --bg-card: rgba(255,255,255,0.025);
      --line: rgba(255,255,255,0.07); --line-2: rgba(255,255,255,0.14);
      --txt: #F1F5F9; --txt-muted: #94A3B8; --txt-faint: #64748B;
    }
    :root[data-theme="light"] {
      --bg: #F6F7FB; --bg-elev: #FFFFFF; --bg-card: #FFFFFF;
      --line: #E5E9F0; --line-2: #CDD5E0;
      --txt: #0F172A; --txt-muted: #475569; --txt-faint: #94A3B8;
    }
    body {
      font-family: var(--ff-body); color: var(--txt);
      background: var(--bg); min-height: 100vh;
      -webkit-font-smoothing: antialiased;
      line-height: 1.65;
    }

    /* Header */
    .lg-hdr {
      position: sticky; top: 0; z-index: 10;
      display: flex; align-items: center; gap: 16px;
      padding: 14px 32px; height: 64px;
      background: color-mix(in oklab, var(--bg) 85%, transparent);
      backdrop-filter: saturate(140%) blur(12px);
      -webkit-backdrop-filter: saturate(140%) blur(12px);
      border-bottom: 1px solid var(--line);
    }
    .lg-hdr a.brand {
      display: inline-flex; align-items: center; gap: 11px;
      text-decoration: none; color: var(--txt);
    }
    .lg-hdr .brand img { height: 28px; }
    .lg-hdr .brand-wm {
      font-family: var(--ff-display); font-size: 19px; font-weight: 500;
      letter-spacing: -0.012em;
    }
    .lg-hdr .brand-wm em {
      font-style: italic;
      background: var(--grad-text);
      -webkit-background-clip: text; background-clip: text;
      color: transparent;
    }
    .lg-hdr .spacer { flex: 1; }
    .lg-hdr .lang-tog {
      display: inline-flex; padding: 3px;
      background: color-mix(in oklab, var(--txt) 5%, transparent);
      border: 1px solid var(--line);
      border-radius: 999px;
    }
    .lg-hdr .lang-tog a {
      font-family: var(--ff-mono); font-size: 11px; font-weight: 500;
      text-transform: uppercase; letter-spacing: 0.08em;
      padding: 4px 12px; border-radius: 999px;
      text-decoration: none;
      color: var(--txt-faint);
      transition: all 0.18s;
    }
    .lg-hdr .lang-tog a.is-on {
      background: var(--bg-elev);
      color: var(--txt);
    }
    .lg-hdr a.back-link {
      font-family: var(--ff-mono); font-size: 11px; font-weight: 500;
      text-transform: uppercase; letter-spacing: 0.1em;
      color: var(--txt-muted); text-decoration: none;
      padding: 8px 14px; border-radius: 999px;
      transition: all 0.18s;
    }
    .lg-hdr a.back-link:hover {
      background: color-mix(in oklab, var(--txt) 5%, transparent);
      color: var(--txt);
    }

    /* Main */
    .lg-main {
      max-width: 760px; margin: 0 auto;
      padding: 56px 28px 80px;
    }
    .lg-kicker {
      font-family: var(--ff-mono); font-size: 11px; font-weight: 500;
      text-transform: uppercase; letter-spacing: 0.16em;
      color: var(--txt-faint);
      margin-bottom: 14px;
    }
    h1.lg-title {
      font-family: var(--ff-display); font-weight: 500;
      font-size: clamp(2.4rem, 1.6rem + 2vw, 3.6rem);
      line-height: 1.04; letter-spacing: -0.025em;
      color: var(--txt); margin-bottom: 20px;
    }
    h1.lg-title em {
      font-style: italic;
      background: var(--grad-text);
      -webkit-background-clip: text; background-clip: text;
      color: transparent;
    }
    .lg-meta {
      font-family: var(--ff-mono); font-size: 11px;
      text-transform: uppercase; letter-spacing: 0.08em;
      color: var(--txt-faint);
      margin-bottom: 36px;
      padding-bottom: 24px; border-bottom: 1px solid var(--line);
    }
    .lg-section { margin-bottom: 36px; }
    .lg-section h2 {
      font-family: var(--ff-display); font-weight: 500;
      font-size: 1.5rem; line-height: 1.2;
      letter-spacing: -0.018em;
      color: var(--txt); margin: 36px 0 14px;
    }
    .lg-section h2:first-child { margin-top: 0; }
    .lg-section h3 {
      font-family: var(--ff-display); font-weight: 500;
      font-size: 1.15rem; letter-spacing: -0.012em;
      color: var(--txt); margin: 22px 0 10px;
    }
    .lg-section p {
      color: var(--txt-muted);
      margin-bottom: 14px;
      font-size: 16px;
    }
    .lg-section p strong { color: var(--txt); font-weight: 500; }
    .lg-section ul, .lg-section ol {
      padding-left: 24px; margin: 6px 0 18px;
      color: var(--txt-muted);
    }
    .lg-section ul li, .lg-section ol li {
      margin-bottom: 8px; padding-left: 4px;
    }
    .lg-section a {
      color: var(--c-accent);
      text-decoration: underline;
      text-underline-offset: 2px;
    }
    .lg-section .lg-note {
      padding: 18px 22px;
      background: var(--bg-card);
      border: 1px solid var(--line);
      border-radius: 14px;
      margin: 18px 0;
    }
    .lg-section .lg-note__lbl {
      font-family: var(--ff-mono); font-size: 10px; font-weight: 500;
      text-transform: uppercase; letter-spacing: 0.16em;
      color: var(--c-accent);
      margin-bottom: 6px;
    }

    .lg-toc {
      padding: 22px 26px;
      background: var(--bg-card);
      border: 1px solid var(--line);
      border-radius: 16px;
      margin-bottom: 40px;
    }
    .lg-toc__lbl {
      font-family: var(--ff-mono); font-size: 11px; font-weight: 500;
      text-transform: uppercase; letter-spacing: 0.16em;
      color: var(--txt-faint);
      margin-bottom: 12px;
    }
    .lg-toc ol {
      list-style: none; padding: 0; margin: 0;
      display: grid; grid-template-columns: 1fr 1fr; gap: 8px 18px;
      counter-reset: toc;
    }
    @media (max-width: 600px) { .lg-toc ol { grid-template-columns: 1fr; } }
    .lg-toc li { counter-increment: toc; padding-left: 0; margin: 0; }
    .lg-toc li::before {
      content: counter(toc, decimal-leading-zero) ". ";
      font-family: var(--ff-mono); font-size: 11px;
      color: var(--txt-faint); letter-spacing: 0.04em;
      margin-right: 6px;
    }
    .lg-toc a {
      color: var(--txt); text-decoration: none;
      font-size: 14px; font-weight: 500;
      transition: color 0.18s;
    }
    .lg-toc a:hover { color: var(--c-accent); }

    .lg-foot {
      margin-top: 56px; padding-top: 24px;
      border-top: 1px solid var(--line);
      font-family: var(--ff-mono); font-size: 11px;
      text-transform: uppercase; letter-spacing: 0.1em;
      color: var(--txt-faint);
      display: flex; gap: 18px; flex-wrap: wrap;
    }
    .lg-foot a { color: var(--txt-muted); text-decoration: none; }
    .lg-foot a:hover { color: var(--c-accent); }
