/* --------------------------------------------------------------------------
 * Legal pages (privacy, cookie, KVKK, impressum)
 * Language-tabbed document with progressive enhancement.
 * ---------------------------------------------------------------------- */
.legal-document {
	padding-top: var(--jai-space-2xl);
}

.legal-document__inner {
	max-width: 75ch;
}

/* Language tab bar. Hidden until JS confirms support, so no-JS users see
 * every language panel stacked and fully readable. */
.legal-tabs {
	display: none;
	flex-wrap: wrap;
	gap: var(--jai-space-xs);
	margin-bottom: var(--jai-space-2xl);
	padding-bottom: var(--jai-space-md);
	border-bottom: 1px solid var(--jai-color-border);
}

.js .legal-tabs[data-legal-tabs] {
	display: flex;
}

.legal-tabs__tab {
	padding: var(--jai-space-xs) var(--jai-space-lg);
	border: 1px solid var(--jai-color-border);
	border-radius: var(--jai-radius-md);
	background: var(--jai-color-white);
	color: var(--jai-color-muted);
	font-family: var(--jai-font-heading);
	font-size: var(--jai-font-size-sm);
	font-weight: 600;
	letter-spacing: 0.02em;
	cursor: pointer;
	transition: color var(--jai-transition), background-color var(--jai-transition), border-color var(--jai-transition);
}

.legal-tabs__tab:hover {
	color: var(--jai-color-primary);
	border-color: var(--jai-color-accent-soft);
}

.legal-tabs__tab.is-active {
	background: var(--jai-color-primary);
	border-color: var(--jai-color-primary);
	color: var(--jai-color-white);
}

.legal-tabs__tab:focus-visible {
	outline: 2px solid var(--jai-color-accent-2);
	outline-offset: 2px;
}

/* Panels. No-JS: divider between stacked language versions. */
.legal-panel + .legal-panel {
	margin-top: var(--jai-space-3xl);
	padding-top: var(--jai-space-2xl);
	border-top: 2px solid var(--jai-color-border);
}

.js .legal-panel {
	display: none;
}

.js .legal-panel.is-active {
	display: block;
}

.js .legal-panel + .legal-panel {
	margin-top: 0;
	padding-top: 0;
	border-top: 0;
}

.legal-panel__updated {
	margin: 0 0 var(--jai-space-2xl);
	padding: var(--jai-space-xs) var(--jai-space-md);
	display: inline-block;
	border-radius: var(--jai-radius-sm);
	background: var(--jai-color-surface);
	color: var(--jai-color-muted);
	font-size: var(--jai-font-size-sm);
}

.legal-section + .legal-section {
	margin-top: var(--jai-space-2xl);
}

.legal-section__heading {
	margin: 0 0 var(--jai-space-md);
	font-size: 1.5rem;
	line-height: var(--jai-line-height-tight);
	color: var(--jai-color-primary);
}

.legal-section__body {
	color: var(--jai-color-text);
	font-size: var(--jai-font-size-base);
	line-height: var(--jai-line-height);
}

.legal-section__body p {
	margin: 0 0 var(--jai-space-md);
}

.legal-section__body ul,
.legal-section__body ol {
	margin: 0 0 var(--jai-space-md);
	padding-left: var(--jai-space-lg);
}

.legal-section__body li {
	margin-bottom: var(--jai-space-2xs);
}

.legal-section__body a {
	color: var(--jai-color-accent);
	text-decoration: underline;
}

.legal-section__body a:hover {
	color: var(--jai-color-primary);
}

.legal-section__body strong {
	color: var(--jai-color-primary);
}

/* Definition-style rows used by Impressum / contact-data blocks. */
.legal-section__body dl {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--jai-space-2xs) var(--jai-space-lg);
	margin: 0 0 var(--jai-space-md);
}

.legal-section__body dt {
	font-weight: 600;
	color: var(--jai-color-primary);
}

.legal-section__body dd {
	margin: 0 0 var(--jai-space-sm);
}

@media (min-width: 768px) {
	.legal-section__body dl {
		grid-template-columns: 14rem 1fr;
	}

	.legal-section__body dd {
		margin-bottom: 0;
	}
}
