/* Legal pages (Privacy Policy, Terms of Service) + footer legal links.
   Provides readable typography + proper padding for content rendered by
   page.php's the_content() on dark theme. */

/* ── Footer legal row ── */
.footer-bottom {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
	gap: 8px 18px;
}

.footer-bottom p {
	margin: 0;
}

.footer-legal {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	font-size: var(--fs-body-sm, 0.875rem);
}

.footer-legal a {
	color: var(--color-text-secondary, #b1b5c3);
	text-decoration: none;
	transition: color 0.2s ease;
}

.footer-legal a:hover {
	color: var(--color-text-primary, #fcfcfd);
}

.footer-legal-sep {
	color: var(--color-text-muted, #777e90);
}

/* ── Generic page (page.php) — used by Privacy Policy + Terms of Service ── */
.section.page-default {
	padding: 64px 0 96px;
}

.section.page-default .container {
	max-width: 820px;
}

.section.page-default .section-header {
	text-align: center;
	margin-bottom: 40px;
}

.section.page-default .section-header h1 {
	font-size: clamp(2rem, 4vw, 3rem);
	color: var(--color-text-primary, #fcfcfd);
	margin: 0;
	line-height: 1.15;
}

.section.page-default .entry-content {
	color: var(--color-text-body, #c0c7cf);
	font-size: 1rem;
	line-height: 1.75;
	background: var(--color-bg-secondary, #1c1929);
	border: 1px solid var(--color-border, #272b30);
	border-radius: 16px;
	padding: 40px 48px;
}

.section.page-default .entry-content > *:first-child {
	margin-top: 0;
}

.section.page-default .entry-content > *:last-child {
	margin-bottom: 0;
}

.section.page-default .entry-content h1,
.section.page-default .entry-content h2,
.section.page-default .entry-content h3,
.section.page-default .entry-content h4,
.section.page-default .entry-content h5,
.section.page-default .entry-content h6 {
	color: var(--color-text-primary, #fcfcfd);
	font-weight: 700;
	line-height: 1.3;
	margin-top: 32px;
	margin-bottom: 12px;
}

.section.page-default .entry-content h2 { font-size: 1.5rem; }
.section.page-default .entry-content h3 { font-size: 1.25rem; }
.section.page-default .entry-content h4 { font-size: 1.0625rem; }

.section.page-default .entry-content p {
	margin: 0 0 16px;
}

.section.page-default .entry-content strong,
.section.page-default .entry-content b {
	color: var(--color-text-primary, #fcfcfd);
	font-weight: 700;
}

.section.page-default .entry-content em,
.section.page-default .entry-content i {
	font-style: italic;
}

.section.page-default .entry-content a {
	color: var(--color-accent-orange, #ff592c);
	text-decoration: underline;
	text-underline-offset: 3px;
}

.section.page-default .entry-content a:hover {
	color: var(--color-text-primary, #fcfcfd);
}

.section.page-default .entry-content ul,
.section.page-default .entry-content ol {
	padding-left: 24px;
	margin: 0 0 16px;
}

.section.page-default .entry-content li {
	margin-bottom: 8px;
}

.section.page-default .entry-content li::marker {
	color: var(--color-accent-orange, #ff592c);
}

.section.page-default .entry-content blockquote {
	border-left: 3px solid var(--color-accent-orange, #ff592c);
	padding: 4px 20px;
	margin: 20px 0;
	color: var(--color-text-secondary, #b1b5c3);
	font-style: italic;
}

.section.page-default .entry-content hr {
	border: 0;
	border-top: 1px solid var(--color-border, #272b30);
	margin: 32px 0;
}

.section.page-default .entry-content table {
	width: 100%;
	border-collapse: collapse;
	margin: 16px 0;
}

.section.page-default .entry-content th,
.section.page-default .entry-content td {
	border: 1px solid var(--color-border, #272b30);
	padding: 10px 14px;
	text-align: left;
}

.section.page-default .entry-content th {
	background: var(--color-bg-tertiary, #26213c);
	color: var(--color-text-primary, #fcfcfd);
	font-weight: 600;
}

.section.page-default .entry-content code {
	background: var(--color-bg-tertiary, #26213c);
	border: 1px solid var(--color-border, #272b30);
	padding: 1px 8px;
	border-radius: 4px;
	font-size: 0.875em;
	color: var(--color-text-primary, #fcfcfd);
}

.section.page-default .entry-content img,
.section.page-default .entry-content video {
	max-width: 100%;
	height: auto;
	border-radius: 8px;
}

@media (max-width: 640px) {
	.section.page-default {
		padding: 40px 0 64px;
	}
	.section.page-default .entry-content {
		padding: 24px 20px;
		border-radius: 12px;
	}
}
