/* ─────────────────────────────────────────────
   Gentleman Peptides — legal / policy pages.
   Banner + sticky-TOC sidebar + numbered sections + dark CTA.
   ───────────────────────────────────────────── */

.gp-legal-page {
	max-width: 1280px;
	margin: 0 auto;
	padding: 0 32px 96px;
}

/* ── Banner ───────────────────────────────────── */
.gp-legal-header {
	padding: 64px 0 32px;
	border-bottom: 1px solid var(--line);
	margin-bottom: 48px;
	max-width: 880px;
}
.gp-legal-header h1 {
	font-family: var(--display);
	font-weight: 400;
	font-size: clamp(40px, 5vw, 76px);
	letter-spacing: -0.025em;
	line-height: 0.98;
	margin: 14px 0 18px;
}
.gp-legal-header h1 em {
	font-style: italic;
	color: var(--accent);
}
.gp-legal-meta {
	margin: 0 0 22px;
}
.gp-legal-updated {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 7px 16px;
	border-radius: 999px;
	background: var(--paper-2);
	border: 1px solid var(--line);
	font-family: var(--mono);
	font-size: 11px;
	color: var(--ink-3);
	letter-spacing: 0.04em;
}
.gp-legal-updated .dot {
	display: inline-block;
	width: 7px; height: 7px;
	border-radius: 999px;
	background: var(--ok);
	animation: gp-legal-pulse 2.4s infinite;
}
.gp-legal-updated .mono {
	text-transform: uppercase;
	letter-spacing: 0.12em;
	font-weight: 600;
	color: var(--ink-2);
}
@keyframes gp-legal-pulse { 0%,100% { opacity: 1; } 50% { opacity: 0.4; } }
.gp-legal-lede {
	font-size: 18px;
	line-height: 1.6;
	color: var(--ink-2);
	max-width: 720px;
	margin: 0;
}

/* ── Shell: TOC + body ────────────────────────── */
.gp-legal-shell {
	display: grid;
	grid-template-columns: 280px 1fr;
	gap: 64px;
	align-items: start;
}

/* ── Sticky TOC sidebar ──────────────────────── */
.gp-legal-toc {
	position: sticky;
	top: 96px;
	align-self: start;
}
.gp-legal-toc-inner {
	background: #fff;
	border: 1px solid var(--line);
	border-radius: var(--r-lg);
	padding: 22px 18px;
	max-height: calc(100vh - 120px);
	overflow-y: auto;
}
.gp-legal-toc-label {
	font-family: var(--mono);
	font-size: 10px;
	color: var(--ink-3);
	letter-spacing: 0.12em;
	text-transform: uppercase;
	font-weight: 600;
	padding: 0 10px 10px;
}
.gp-legal-toc ol {
	list-style: none;
	margin: 0;
	padding: 0;
}
.gp-legal-toc li { margin: 0; }
.gp-legal-toc a {
	display: flex;
	gap: 10px;
	padding: 10px 12px;
	border-radius: var(--r);
	text-decoration: none;
	color: var(--ink-2);
	font-size: 13px;
	line-height: 1.4;
	transition: background .12s, color .12s;
	align-items: flex-start;
}
.gp-legal-toc a:hover {
	background: var(--paper-2);
	color: var(--ink);
}
.gp-legal-toc a.active {
	background: var(--accent-tint);
	color: var(--accent);
	font-weight: 500;
}
.gp-legal-toc a .num {
	font-family: var(--mono);
	font-size: 10px;
	color: var(--ink-4);
	letter-spacing: 0.06em;
	flex-shrink: 0;
	padding-top: 2px;
	min-width: 16px;
}
.gp-legal-toc a.active .num { color: var(--accent); }
.gp-legal-toc a .lbl { flex: 1; min-width: 0; }
.gp-legal-toc a .arrow {
	margin-left: auto;
	color: var(--ink-4);
	font-size: 14px;
}
.gp-legal-toc a:hover .arrow { color: var(--accent); }
.gp-legal-toc-sep {
	height: 1px;
	background: var(--line);
	margin: 18px 4px;
}
.gp-legal-toc ol.other a .lbl {
	font-family: var(--display);
	font-size: 14px;
	font-weight: 500;
}

/* ── Body: numbered sections ─────────────────── */
.gp-legal-body { display: flex; flex-direction: column; }

.gp-legal-section {
	display: grid;
	grid-template-columns: 64px 1fr;
	gap: 24px;
	padding: 32px 0;
	border-top: 1px solid var(--line);
	align-items: start;
	scroll-margin-top: 96px;
}
.gp-legal-section:first-child { border-top: 0; padding-top: 0; }

.gp-legal-num {
	font-family: var(--mono);
	font-size: 13px;
	color: var(--accent);
	letter-spacing: 0.08em;
	text-transform: uppercase;
	font-weight: 600;
	padding-top: 8px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 48px; height: 48px;
	border-radius: 999px;
	border: 1.5px solid var(--accent-tint);
	background: var(--accent-tint);
}

.gp-legal-text h2 {
	font-family: var(--display);
	font-weight: 400;
	font-size: clamp(22px, 2.4vw, 30px);
	letter-spacing: -0.015em;
	line-height: 1.15;
	margin: 0 0 16px;
	color: var(--ink);
}
.gp-legal-text p {
	font-size: 15px;
	line-height: 1.75;
	color: var(--ink-2);
	margin: 0 0 16px;
}
.gp-legal-text p:last-child { margin-bottom: 0; }
.gp-legal-text strong {
	color: var(--ink);
	font-weight: 600;
}
.gp-legal-text em {
	font-style: italic;
}
.gp-legal-text a {
	color: var(--accent);
	text-decoration: underline;
	text-decoration-thickness: 1px;
	text-underline-offset: 3px;
}
.gp-legal-text a:hover { text-decoration-thickness: 2px; }
.gp-legal-text ul,
.gp-legal-text ol {
	margin: 0 0 14px 0;
	padding: 0 0 0 20px;
}
.gp-legal-text li {
	font-size: 15px;
	line-height: 1.7;
	color: var(--ink-2);
	margin-bottom: 8px;
	padding-left: 4px;
}
.gp-legal-text ul li::marker { color: var(--accent); }
.gp-legal-text ol li::marker { color: var(--accent); font-family: var(--mono); font-size: 13px; font-weight: 600; }

/* ── Bottom CTA card (dark) ──────────────────── */
.gp-legal-cta {
	margin-top: 48px;
	padding: 36px 40px;
	background: var(--ink);
	color: #fff;
	border-radius: var(--r-lg);
	display: grid;
	grid-template-columns: 1fr auto;
	gap: 32px;
	align-items: center;
}
.gp-legal-cta h3 {
	font-family: var(--display);
	font-weight: 400;
	font-size: 28px;
	letter-spacing: -0.015em;
	margin: 8px 0 6px;
	color: #fff;
}
.gp-legal-cta h3 em { color: #d6c8eb; font-style: italic; }
.gp-legal-cta p {
	font-size: 14px;
	line-height: 1.6;
	color: rgba(255,255,255,0.75);
	margin: 0;
}
.gp-legal-cta-actions {
	display: flex;
	flex-direction: column;
	gap: 8px;
}
.gp-legal-cta-actions .btn {
	white-space: nowrap;
	font-size: 13px;
}

/* ── Responsive ──────────────────────────────── */
@media (max-width: 1024px) {
	.gp-legal-shell { grid-template-columns: 220px 1fr; gap: 40px; }
}
@media (max-width: 880px) {
	.gp-legal-page { padding: 0 16px 64px; }
	.gp-legal-header { padding: 40px 0 24px; margin-bottom: 32px; }
	.gp-legal-shell { grid-template-columns: 1fr; gap: 24px; }
	.gp-legal-toc {
		position: static;
		order: 1;
	}
	.gp-legal-toc-inner { max-height: none; padding: 18px 14px; }
	.gp-legal-toc-sep { display: none; }
	.gp-legal-toc ol.other { display: none; }
	.gp-legal-body { order: 2; }
	.gp-legal-section {
		grid-template-columns: 44px 1fr;
		gap: 14px;
		padding: 24px 0;
	}
	.gp-legal-num {
		width: 38px; height: 38px;
		font-size: 11px;
	}
	.gp-legal-cta {
		grid-template-columns: 1fr;
		padding: 28px 24px;
		gap: 18px;
	}
	.gp-legal-cta-actions .btn { width: 100%; }
}
