/* ─── Policy page (Terms / Refund / Privacy) ─────────────────────── */

.dp-page--policy .dp-main {
	background: var(--dp-bg);
}

.dp-policy {
	display: block;
}

/* ─── Header ─────────────────────────────────────────────────────── */

.dp-policy__head {
	padding: clamp(3.5rem, 7vw, 5.5rem) 0 clamp(2rem, 4vw, 3rem);
	text-align: left;
	border-bottom: 1px solid var(--dp-border);
	margin-bottom: clamp(2.5rem, 5vw, 4rem);
}

.dp-policy__head .dp-container {
	max-width: 760px;
}

.dp-policy__eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--dp-primary);
	background: color-mix(in srgb, var(--dp-primary) 8%, transparent);
	border-radius: 999px;
	padding: 6px 14px;
	margin: 0 0 22px;
}

.dp-policy__title {
	font-size: clamp(2.25rem, 5vw, 3.25rem);
	font-weight: 700;
	letter-spacing: -0.04em;
	line-height: 1.05;
	color: var(--dp-text);
	margin: 0 0 18px;
}

.dp-policy__meta {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-size: 13px;
	color: var(--dp-text-3);
	margin: 0;
}

.dp-policy__meta time {
	color: var(--dp-text-2);
	font-weight: 500;
	font-variant-numeric: tabular-nums;
}

/* ─── Body / prose ───────────────────────────────────────────────── */

.dp-policy__body {
	padding: 0 0 clamp(3rem, 6vw, 5rem);
}

.dp-policy__body .dp-container {
	max-width: 760px;
}

.dp-policy__prose {
	font-size: 16px;
	line-height: 1.7;
	color: var(--dp-text-2);
}

.dp-policy__prose > * + * {
	margin-top: 1em;
}

/* H2 — major section. First gets a flat top; subsequent get separator. */
.dp-policy__prose h2 {
	font-size: clamp(1.4rem, 2.4vw, 1.7rem);
	font-weight: 700;
	letter-spacing: -0.02em;
	line-height: 1.3;
	color: var(--dp-text);
	margin-top: 2.6em;
	margin-bottom: 0.5em;
	padding-top: 1.6em;
	border-top: 1px solid var(--dp-border);
	scroll-margin-top: 96px;
}

.dp-policy__prose > h2:first-child {
	margin-top: 0;
	padding-top: 0;
	border-top: 0;
}

/* H3 — subsection. Slightly smaller, tighter. */
.dp-policy__prose h3 {
	font-size: 1.125rem;
	font-weight: 700;
	letter-spacing: -0.01em;
	line-height: 1.35;
	color: var(--dp-text);
	margin-top: 1.6em;
	margin-bottom: 0.4em;
	scroll-margin-top: 96px;
}

.dp-policy__prose h4 {
	font-size: 1rem;
	font-weight: 600;
	color: var(--dp-text);
	margin-top: 1.4em;
	margin-bottom: 0.35em;
}

/* Reset margin-top for first heading of a kind right after another heading. */
.dp-policy__prose h2 + h3,
.dp-policy__prose h3 + h4 {
	margin-top: 0.6em;
}

.dp-policy__prose p {
	margin: 0 0 1em;
}

.dp-policy__prose a {
	color: var(--dp-primary);
	text-decoration: underline;
	text-decoration-color: color-mix(in srgb, var(--dp-primary) 30%, transparent);
	text-underline-offset: 3px;
	transition: text-decoration-color 0.15s, color 0.15s;
}

.dp-policy__prose a:hover {
	color: var(--dp-primary-hover);
	text-decoration-color: var(--dp-primary-hover);
}

.dp-policy__prose strong {
	color: var(--dp-text);
	font-weight: 600;
}

.dp-policy__prose ul,
.dp-policy__prose ol {
	margin: 0.4em 0 1.1em;
	padding-left: 1.4em;
}

.dp-policy__prose li {
	margin-bottom: 0.35em;
}

.dp-policy__prose li::marker {
	color: var(--dp-text-3);
}

.dp-policy__prose blockquote {
	margin: 1.4em 0;
	padding: 0.9em 1.2em;
	border-left: 3px solid var(--dp-primary);
	background: var(--dp-bg-alt);
	border-radius: 0 8px 8px 0;
	color: var(--dp-text-2);
	font-style: normal;
}

.dp-policy__prose blockquote p:last-child {
	margin-bottom: 0;
}

.dp-policy__prose code {
	background: var(--dp-bg-alt);
	padding: 0.1em 0.4em;
	border-radius: 4px;
	font-size: 0.92em;
	color: var(--dp-text);
	font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
}

.dp-policy__prose pre {
	background: var(--dp-bg-alt);
	padding: 1em 1.25em;
	border-radius: 10px;
	overflow-x: auto;
	font-size: 0.9em;
	line-height: 1.55;
	margin: 1.4em 0;
}

.dp-policy__prose pre code {
	background: transparent;
	padding: 0;
	font-size: inherit;
}

.dp-policy__prose hr {
	border: 0;
	border-top: 1px solid var(--dp-border);
	margin: 2.2em 0;
}

.dp-policy__prose table {
	width: 100%;
	border-collapse: collapse;
	margin: 1.4em 0;
	font-size: 0.95em;
}

.dp-policy__prose th,
.dp-policy__prose td {
	padding: 0.7em 0.9em;
	border-bottom: 1px solid var(--dp-border);
	text-align: left;
	vertical-align: top;
}

.dp-policy__prose th {
	background: var(--dp-bg-alt);
	font-weight: 600;
	color: var(--dp-text);
}

.dp-policy__prose img {
	max-width: 100%;
	height: auto;
	border-radius: 10px;
	margin: 1.4em 0;
}

@media (max-width: 540px) {
	.dp-policy__prose {
		font-size: 15.5px;
		line-height: 1.65;
	}

	.dp-policy__prose h2 {
		padding-top: 1.3em;
	}
}
