/* shared legal/info page styles */
.legal-hero { padding: 80px 0 40px; border-bottom: 1px solid var(--line); position: relative; overflow: hidden; }
.legal-hero h1 { font-size: clamp(40px, 6vw, 76px); letter-spacing: -0.035em; line-height: 1; margin: 0; max-width: 18ch; }
.legal-hero h1 .ochre { color: var(--ochre); }
.legal-hero p { color: var(--fg-1); font-size: 17px; line-height: 1.55; max-width: 56ch; margin-top: 22px; }

.legal-wrap { display: grid; grid-template-columns: 240px 1fr; gap: 64px; padding: 56px 0; }
@media (max-width: 900px) { .legal-wrap { grid-template-columns: 1fr; } }
.legal-toc { position: sticky; top: 96px; align-self: start; font-family: var(--font-mono); font-size: 12px; border-left: 1px solid var(--line); padding-left: 16px; }
.legal-toc h4 { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.14em; color: var(--fg-3); text-transform: uppercase; margin: 0 0 12px; }
.legal-toc a { display: block; color: var(--fg-2); padding: 6px 0; }
.legal-toc a:hover { color: var(--ochre); }
.legal-toc .num { color: var(--fg-3); margin-right: 8px; }

.legal-doc h2 { font-size: 22px; letter-spacing: -0.015em; margin: 56px 0 14px; padding-top: 24px; border-top: 1px solid var(--line); font-weight: 600; }
.legal-doc h2:first-child { margin-top: 0; padding-top: 0; border-top: none; }
.legal-doc h2 .id { font-family: var(--font-mono); font-size: 12px; color: var(--ochre); margin-right: 12px; letter-spacing: 0.1em; }
.legal-doc p, .legal-doc li { color: var(--fg-1); font-size: 15px; line-height: 1.65; }
.legal-doc ul { padding-left: 18px; margin: 12px 0 16px; }
.legal-doc ul li { margin-bottom: 6px; }
.legal-doc .meta-strip { display: flex; gap: 24px; flex-wrap: wrap; font-family: var(--font-mono); font-size: 11px; color: var(--fg-3); letter-spacing: 0.08em; padding: 14px 16px; border: 1px solid var(--line); border-radius: 4px; background: var(--bg-1); margin-bottom: 32px; }
.legal-doc .meta-strip b { color: var(--fg-0); font-weight: 600; }

/* About page specific */
.values-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--line); border: 1px solid var(--line); border-radius: var(--radius); margin-top: 36px; }
@media (max-width: 800px) { .values-grid { grid-template-columns: 1fr; } }
.value { background: var(--bg-1); padding: 28px; min-height: 200px; }
.value .vn { font-family: var(--font-mono); font-size: 11px; color: var(--ochre); letter-spacing: 0.12em; }
.value h3 { font-size: 20px; letter-spacing: -0.015em; margin: 12px 0 8px; }
.value p { color: var(--fg-2); font-size: 14px; line-height: 1.55; margin: 0; }

.team-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: var(--line); border: 1px solid var(--line); border-radius: var(--radius); margin-top: 24px; }
@media (max-width: 900px) { .team-grid { grid-template-columns: 1fr 1fr; } }
.team-cell { background: var(--bg-1); padding: 24px; }
.team-cell .av { width: 56px; height: 56px; border-radius: 50%; background: linear-gradient(135deg, color-mix(in srgb, var(--ochre) 30%, var(--bg-2)), var(--bg-3)); color: var(--ochre); display: grid; place-items: center; font-weight: 700; font-size: 16px; font-family: var(--font-mono); }
.team-cell h4 { font-size: 16px; margin: 14px 0 4px; font-weight: 600; }
.team-cell p { color: var(--fg-3); font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.06em; text-transform: uppercase; margin: 0; }

/* API endpoint table */
.api-list { border: 1px solid var(--line); border-radius: var(--radius); overflow: hidden; margin-top: 12px; }
.api-row { display: grid; grid-template-columns: 70px 2fr 3fr; gap: 12px; padding: 14px 18px; border-bottom: 1px solid var(--line); align-items: center; font-family: var(--font-mono); font-size: 13px; }
.api-row:last-child { border-bottom: none; }
.api-row .verb { font-size: 10px; font-weight: 700; padding: 3px 8px; border-radius: 2px; letter-spacing: 0.1em; text-align: center; }
.api-row .verb.get { background: color-mix(in srgb, var(--pos) 18%, transparent); color: var(--pos); }
.api-row .verb.post { background: color-mix(in srgb, var(--ochre) 18%, transparent); color: var(--ochre); }
.api-row .verb.patch { background: color-mix(in srgb, var(--contractor-blue) 18%, transparent); color: var(--contractor-blue); }
.api-row .verb.del { background: color-mix(in srgb, var(--neg) 18%, transparent); color: var(--neg); }
.api-row .path { color: var(--fg-0); }
.api-row .desc { color: var(--fg-2); font-family: var(--font-display); font-size: 13px; }

.codeblock { background: var(--bg-2); border: 1px solid var(--line); border-radius: 4px; padding: 16px 18px; margin: 14px 0 24px; font-family: var(--font-mono); font-size: 12px; color: var(--fg-1); line-height: 1.55; overflow: auto; white-space: pre; }
.codeblock .key { color: var(--ochre); }
.codeblock .str { color: var(--client-green); }
.codeblock .com { color: var(--fg-3); }
