/* ============================================
   VERLINGO — LEGAL PAGES (Privacy / Terms)
   Front-end light theme (tokens from styles.css), shared header/footer.
   Two-column sticky-TOC layout with scrollspy, matching the docs.
   ============================================ */

/* ---------- hero ---------- */
.legal-hero { padding: 54px 0 34px; border-bottom: 1px solid var(--line); background: radial-gradient(820px 300px at 50% -40%, var(--cyan-soft), transparent 70%); }
.legal-hero .legal-kicker { display: inline-flex; align-items: center; gap: 7px; font-size: 12.5px; font-weight: 550; color: var(--mute); margin-bottom: 14px; }
.legal-hero .legal-kicker svg { width: 14px; height: 14px; }
.legal-hero .legal-kicker:hover { color: var(--ink); }
.legal-hero h1 { font-size: 42px; font-weight: 600; letter-spacing: -.035em; margin: 0 0 16px; }
.legal-dates { display: flex; gap: 10px; flex-wrap: wrap; margin-bottom: 22px; }
.legal-date { font-size: 12.5px; font-weight: 500; color: var(--mute); background: #fff; border: 1px solid var(--line); padding: 5px 12px; border-radius: 999px; }
.legal-date b { color: var(--ink); font-weight: 600; }
.legal-summary { background: #fff; border: 1px solid var(--line); border-left: 3px solid var(--cyan-2); border-radius: var(--r-md); padding: 16px 18px; font-size: 14.5px; color: #34343a; max-width: 780px; box-shadow: var(--shadow-soft); }
.legal-summary strong { color: var(--ink); font-weight: 600; }

/* ---------- layout ---------- */
.legal-wrap { display: grid; grid-template-columns: 244px minmax(0, 1fr); gap: 52px; align-items: start; padding-top: 42px; padding-bottom: 92px; }
.legal-side { position: sticky; top: 84px; align-self: start; max-height: calc(100vh - 104px); overflow-y: auto; padding-right: 4px; }
.legal-side .toc-h { font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: .08em; color: var(--mute-2); padding: 0 11px 8px; }
.legal-side a { display: block; padding: 6px 11px; border-radius: 8px; color: var(--mute); font-size: 13.5px; line-height: 1.4; }
.legal-side a:hover { background: var(--paper-2); color: var(--ink); }
.legal-side a.active { background: var(--cyan-soft); color: var(--ink); font-weight: 500; }

/* ---------- content ---------- */
.legal-main { min-width: 0; max-width: 780px; }
.legal-main > h2 { font-size: 24px; font-weight: 600; letter-spacing: -.02em; margin: 46px 0 14px; scroll-margin-top: 84px; }
.legal-main > h2:first-child { margin-top: 0; }
.legal-main h3 { font-size: 18px; font-weight: 550; margin: 30px 0 10px; letter-spacing: -.01em; }
.legal-main h4 { font-size: 15px; font-weight: 600; color: var(--ink); margin: 22px 0 8px; }
.legal-main p { margin: 0 0 14px; color: #34343a; }
.legal-main ul, .legal-main ol { margin: 0 0 16px; padding-left: 22px; }
.legal-main li { margin-bottom: 8px; color: #34343a; }
.legal-main strong { color: var(--ink); font-weight: 600; }
.legal-main a { color: var(--cyan-2); }
.legal-main a:hover { text-decoration: underline; }

/* callout boxes (highlight / info / warning) */
.legal-box { border-radius: var(--r-md); padding: 16px 18px; margin: 18px 0; font-size: 14.5px; border: 1px solid; color: #34343a; }
.legal-box p { margin: 0 0 10px; }
.legal-box p:last-child { margin-bottom: 0; }
.legal-box h4 { margin: 0 0 8px; }
.legal-box strong { color: var(--ink); }
.legal-box.tip { background: var(--cyan-soft); border-color: var(--cyan-hairline); }
.legal-box.info { background: var(--paper-2); border-color: var(--line); }
.legal-box.warn { background: rgba(217, 119, 6, .08); border-color: rgba(217, 119, 6, .26); }

/* tables */
.legal-table-wrap { overflow-x: auto; margin: 18px 0; border: 1px solid var(--line); border-radius: var(--r-md); }
.legal-main table { width: 100%; border-collapse: collapse; font-size: 13.5px; }
.legal-main th, .legal-main td { padding: 11px 14px; text-align: left; vertical-align: top; border-bottom: 1px solid var(--line); }
.legal-main th { background: var(--paper-2); color: var(--ink); font-weight: 600; white-space: nowrap; }
.legal-main td:not(:last-child), .legal-main th:not(:last-child) { border-right: 1px solid var(--line); }
.legal-main tbody tr:last-child td { border-bottom: none; }
.legal-main tbody tr:hover { background: var(--paper); }

/* end matter */
.legal-end { margin-top: 50px; padding-top: 28px; border-top: 1px solid var(--line); color: var(--mute); font-size: 13.5px; }
.legal-end a { color: var(--cyan-2); }
.legal-end a:hover { text-decoration: underline; }

@media (max-width: 900px) {
	.legal-wrap { grid-template-columns: 1fr; gap: 0; padding-top: 26px; }
	.legal-side { position: static; max-height: none; overflow: visible; margin-bottom: 26px; background: #fff; border: 1px solid var(--line); border-radius: var(--r-md); padding: 16px; }
	.legal-hero h1 { font-size: 31px; }
	.legal-main { max-width: none; }
}
