@charset "UTF-8";
:root {
	color-scheme: light dark;

	/* Brand Hues */
	--cnn-blue-main-400: #4C8DFF;
	--cnn-blue-main-500: #0D5AE5;
	--cnn-blue-main-600: #0B50D0;
	--cnn-blue-main-700: #0A46BC;
	--cnn-blue-deep-700: #003D70;

	/* Accent */
	--cnn-orange-400: #E96A12;
	--cnn-orange-600: #C24E00;

	/* Neutrals / Ink */
	--cnn-ink-900: #0B0F14;
	--cnn-ink-800: #161C24;
	--cnn-ink-700: #202833;
	--cnn-ink-600: #2D3643;
	--cnn-ink-500: #5E6C80;
	--cnn-ink-400: #748095;
	--cnn-ink-200: #C2CBD6;
	--cnn-ink-100: #E6EBF1;
	--cnn-ink-050: #F7F9FC;

	/* Roles (Light) */
	--cnn-bg: #FFFFFF;
	--cnn-surface: var(--cnn-ink-050);
	--cnn-text: var(--cnn-ink-900);
	--cnn-text-muted: var(--cnn-ink-500);
	--cnn-link: var(--cnn-blue-main-500);
	--cnn-focus: var(--cnn-blue-main-400);
	--cnn-placeholder: #627185;

	/* Link visited default (wird unten via @supports präzisiert) */
	--cnn-link-visited: var(--cnn-link);

	/* Border-Tokens (A11y) */
	--cnn-border-weak: #E6EBF1;
	--cnn-border-ui:#81909F;
	--cnn-border: var(--cnn-border-weak);

	/* Buttons */
	--cnn-btn-primary-bg: var(--cnn-blue-main-500);
	--cnn-btn-primary-fg: #FFFFFF;
	--cnn-btn-accent-bg: var(--cnn-orange-600);
	--cnn-btn-accent-fg: #FFFFFF;
	--cnn-btn-dark-bg: var(--cnn-ink-900);
	--cnn-btn-dark-fg: #FFFFFF;
	--cnn-btn-dark-bg-hover: var(--cnn-ink-800);
	--cnn-btn-dark-bg-active: var(--cnn-ink-700);

	/* Layout */
	--cnn-container-max: 70rem;
	--cnn-container-max-lg: 80rem;
	--cnn-container-pad: clamp(1.5rem, 2vw, 1.75rem);

	/* Spacing Scale */
	--cnn-space-1:  clamp(0.25rem, 0.60vw, 0.375rem);
	--cnn-space-2:  clamp(0.50rem, 0.80vw, 0.625rem);
	--cnn-space-3:  clamp(0.75rem, 1.00vw, 0.875rem);
	--cnn-space-4:  clamp(1.00rem, 1.20vw, 1.125rem);
	--cnn-space-5:  clamp(1.25rem, 1.60vw, 1.50rem);
	--cnn-space-6:  clamp(1.50rem, 2.00vw, 1.75rem);
	--cnn-space-8:  clamp(2.00rem, 3.00vw, 2.50rem);
	--cnn-space-10: clamp(2.50rem, 3.80vw, 3.00rem);
	--cnn-space-12: clamp(3.00rem, 4.80vw, 4.00rem);
	--cnn-space-16: clamp(4.00rem, 6.40vw, 6.00rem);

	/* Typography base */
	--cnn-font-family: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
	--cnn-body-size: clamp(0.875rem, 0.40vw + 0.875rem, 1.0625rem);
	--cnn-body-line: 1.55;

	/* Headings */
	--cnn-h1-size: clamp(2.5rem,  4.5vw, 3.5rem);
	--cnn-h2-size: clamp(1.75rem, 3.4vw, 2.5rem);
	--cnn-h3-size: clamp(1.375rem,2.4vw, 1.75rem);
	--cnn-h4-size: clamp(1.125rem,1.8vw, 1.375rem);

	/* Letter-spacing */
	--cnn-ls-tight: -0.01em;
	--cnn-ls-wide: 0.04em;

	/* Radii & Shadows */
	--cnn-radius-lg: 1rem;
	--cnn-radius-md: 0.625rem;
	--cnn-radius-sm: 0.5rem;
	--cnn-shadow-1: 0 0.25rem 0.75rem rgba(0,0,0,.06);
	--cnn-shadow-2: 0 0.5rem 1.75rem rgba(0,0,0,.08);
}

/* Dark Theme Tokens (via Klasse) */
.cnn-dark {
	color-scheme: dark;
	--cnn-bg: var(--cnn-ink-900);
	--cnn-surface: var(--cnn-ink-800);
	--cnn-text: #F2F5FA;
	--cnn-text-muted: #C8D0DC;
	--cnn-link: var(--cnn-blue-main-400);
	--cnn-focus: var(--cnn-blue-main-400);
	--cnn-border-weak: #243040;
	--cnn-border-ui:#607189;
	--cnn-border: var(--cnn-border-weak);
	--cnn-placeholder: #9BA7BA;

	/* Dark-Button invertiert */
	--cnn-btn-dark-bg: #FFFFFF;
	--cnn-btn-dark-fg: var(--cnn-ink-900);
	--cnn-btn-dark-bg-hover: #F2F5FA;
	--cnn-btn-dark-bg-active: #E6EBF1;
}
.cnn-light { color-scheme: light; }

/* zentraler Fokusstil */
:focus-visible { outline: 0.1875rem solid var(--cnn-focus); outline-offset: 0.1875rem; }

.cnn-a {
	color: var(--cnn-link);
	text-decoration: underline;
	text-underline-offset: 0.1875rem;
	text-decoration-skip-ink: auto;
}
.cnn-a:visited { color: var(--cnn-link-visited); }
.cnn-a:hover { text-decoration-thickness: 0.125rem; }
.cnn-a:active { text-decoration-thickness: 0.15625rem; }

/* Layout */
.cnn-container {
	max-width: var(--cnn-container-max);
	margin-inline: auto;
	padding-inline: max(var(--cnn-container-pad), 1rem);
}
@media (min-width: 100rem) {
	.cnn-container { max-width: var(--cnn-container-max-lg); }
}

.cnn-grid { display: grid; gap: var(--cnn-space-6); }
.cnn-grid-2 { grid-template-columns: repeat(2, minmax(0,1fr)); }
.cnn-grid-3 { grid-template-columns: repeat(3, minmax(0,1fr)); }

.cnn-stack-4 > * + * { margin-top: var(--cnn-space-4); }
.cnn-stack-6 > * + * { margin-top: var(--cnn-space-6); }
.cnn-stack-8 > * + * { margin-top: var(--cnn-space-8); }
.cnn-stack-12 > * + * { margin-top: var(--cnn-space-12); }

/* Typografie */
.cnn-h1 { font: 800 var(--cnn-h1-size)/1.1 var(--cnn-font-family); letter-spacing: var(--cnn-ls-tight); margin: 0 0 var(--cnn-space-3); }
.cnn-h2 { font: 700 var(--cnn-h2-size)/1.2 var(--cnn-font-family); margin: 0 0 var(--cnn-space-2); }
.cnn-h3 { font: 600 var(--cnn-h3-size)/1.25 var(--cnn-font-family); margin: var(--cnn-space-6) 0 var(--cnn-space-2); }
.cnn-h4 { font: 500 var(--cnn-h4-size)/1.3 var(--cnn-font-family); margin: var(--cnn-space-4) 0 var(--cnn-space-2); }

.cnn-f1 {
	font-family: "Moderat Black", "Inter", system-ui, sans-serif;
	font-size: 1.05em;
	font-weight: 900;
	letter-spacing: -0.01em;
	line-height: 1;
}

@media (min-width: 30rem) {
	.cnn-f1 {
		font-size: 1.1em;
	}
}

.cnn-f2 {
	font-family: "Moderat Black", "Inter", system-ui, sans-serif;
	font-weight: 900;
	letter-spacing: -0.01em;
	line-height: 1.1;
}

.cnn-lead  { font: 500 clamp(1.125rem, 2.2vw, 1.25rem)/1.5 var(--cnn-font-family); color: var(--cnn-text); max-width: 70ch; }
.cnn-body  { font: 400 var(--cnn-body-size)/var(--cnn-body-line) var(--cnn-font-family); max-width: 78ch; }
.cnn-small { font: 400 clamp(0.8125rem, 1.6vw, 0.875rem)/1.5 var(--cnn-font-family); }
.cnn-micro { font: 400 clamp(0.75rem, 1.4vw, 0.75rem)/1.4 var(--cnn-font-family); }
.cnn-uppercase { text-transform: uppercase; letter-spacing: var(--cnn-ls-wide); }
.cnn-tabular { font-variant-numeric: tabular-nums; }
.cnn-brand {
	font-family: "Moderat Black", "Inter", system-ui, sans-serif;
	font-weight: 900;
	font-size: clamp(2rem, 4vw, 3.25rem);
	line-height: 1;
	letter-spacing: -0.01em;
	display: inline-block;
}

/* Prosa-Defaults für Content-Blöcke */
.cnn-prose { max-width: 78ch; }
.cnn-prose :is(p, ul, ol, blockquote, pre) { margin: 0 0 var(--cnn-space-4); }
.cnn-prose h2 { margin: var(--cnn-space-8) 0 var(--cnn-space-2); }
.cnn-prose h3 { margin: var(--cnn-space-6) 0 var(--cnn-space-2); }
.cnn-prose hr { border:0; border-top:1px solid var(--cnn-border-weak); margin: var(--cnn-space-8) 0; }
.cnn-prose code {
	font-family: ui-monospace, SFMono-Regular, Consolas, monospace;
	font-size: .875em;
	background: var(--cnn-surface);
	padding: .15em .35em; border-radius: .25rem;
}
.cnn-prose pre {
	padding: var(--cnn-space-4);
	border: 1px solid var(--cnn-border-weak);
	border-radius: var(--cnn-radius-md);
	overflow: auto;
}
.cnn-prose li + li { margin-top: .25em; }

/* Buttons */
.cnn-btn {
	font: 600 clamp(0.875rem, 1.6vw, 1rem)/1.2 var(--cnn-font-family);
	padding: calc(var(--cnn-space-3) + 0.125rem) var(--cnn-space-5);
	border-radius: var(--cnn-radius-md);
	border: 1px solid transparent;
	cursor: pointer;
	transition: transform .2s ease, background .2s ease, color .2s ease, border-color .2s ease;
	display: inline-flex; align-items: center; gap: 0.5rem; text-decoration: none;
	min-block-size: 2.75rem;
}
.cnn-btn:focus-visible { outline: 0.1875rem solid var(--cnn-focus); outline-offset: 0.1875rem; }
.cnn-btn[disabled], .cnn-btn[aria-disabled="true"] { opacity:.6; cursor:not-allowed; transform:none !important; }

.cnn-btn-primary { background: var(--cnn-btn-primary-bg); color: var(--cnn-btn-primary-fg); }
.cnn-btn-primary:hover { background: var(--cnn-blue-main-600); transform: translateY(-1px); }
.cnn-btn-primary:active { background: var(--cnn-blue-main-700); transform: translateY(0); }

.cnn-btn-accent { background: var(--cnn-btn-accent-bg); color: var(--cnn-btn-accent-fg); }
.cnn-btn-accent:hover { background: #C75300; transform: translateY(-1px); }

.cnn-btn-secondary {
	background: transparent;
	color: var(--cnn-blue-main-600);
	border-color: var(--cnn-blue-main-500);
}
.cnn-btn-secondary:is(:hover, :focus-visible) {
	background: rgba(13,90,229,0.10);
	border-color: var(--cnn-blue-main-500);
}

.cnn-btn-dark {
	background: var(--cnn-btn-dark-bg);
	color: var(--cnn-btn-dark-fg);
	border-color: transparent;
}
.cnn-btn-dark:hover {
	background: var(--cnn-btn-dark-bg-hover);
	transform: translateY(-0.0625rem);
}
.cnn-btn-dark:active {
	background: var(--cnn-btn-dark-bg-active);
	transform: translateY(0);
	filter: brightness(.94);
}
.cnn-dark .cnn-btn-dark:active { filter: brightness(1.06); }

.cnn-dark .cnn-btn-secondary { color: var(--cnn-blue-main-400); border-color: var(--cnn-blue-main-400); }

.cnn-btn-ghost {
	background: transparent;
	color: var(--cnn-text);
	border-color: var(--cnn-border-ui);
}
.cnn-btn-ghost:is(:hover, :focus-visible) {
	background: rgba(0,0,0,0.04);
}

.cnn-btn-dark-outline {
	background: transparent;
	color: var(--cnn-btn-dark-bg);
	border-color: var(--cnn-btn-dark-bg);
}
.cnn-btn-dark-outline:is(:hover, :focus-visible) {
	background: rgba(0,0,0,0.06);
}
.cnn-dark .cnn-btn-dark-outline:is(:hover, :focus-visible) {
	background: rgba(255,255,255,0.10);
}

/* nur für feine Pointer echte Hover-Elevation */
@media (hover:hover) and (pointer:fine) {
	.cnn-btn-primary:hover,
	.cnn-btn-accent:hover { transform: translateY(-1px); }
}

/* Forms */
.cnn-field { display: grid; gap: 0.5rem; }
.cnn-label { font: 500 clamp(0.8125rem, 1.6vw, 0.875rem)/1.3 var(--cnn-font-family); color: var(--cnn-text); }
.cnn-input,
.cnn-select,
.cnn-textarea {
	width: 100%;
	border-radius: var(--cnn-radius-md);
	border: 1px solid var(--cnn-border-ui);
	background: var(--cnn-bg);
	color: var(--cnn-text);
	padding: 0.75rem 0.875rem;
	font: 400 clamp(0.9375rem, 1.8vw, 1rem)/1.4 var(--cnn-font-family);
	transition: border-color .2s, box-shadow .2s, background .2s;
}
/* Placeholder */
.cnn-input::placeholder, .cnn-textarea::placeholder { color: var(--cnn-placeholder); }

.cnn-input:focus, .cnn-select:focus, .cnn-textarea:focus {
	border-color: var(--cnn-blue-main-500);
	box-shadow: 0 0 0 0.25rem rgba(13,90,229,0.30);
}
.cnn-input:focus-visible, .cnn-select:focus-visible, .cnn-textarea:focus-visible { outline: none; }

/* Checkbox / Radio + invalid */
input[type="checkbox"], input[type="radio"] { accent-color: var(--cnn-blue-main-600); }

/* robust: invalid + user-invalid + aria-invalid */
:where(.cnn-input,.cnn-select,.cnn-textarea):is(:invalid, :user-invalid),
:where(.cnn-input,.cnn-select,.cnn-textarea)[aria-invalid="true"]{
	border-color:#da3b2f; background: rgba(218,59,47,.06);
}

.cnn-hint { font: 400 clamp(0.75rem, 1.6vw, 0.8125rem)/1.4 var(--cnn-font-family); color: var(--cnn-text-muted); }
.cnn-hint-error { color:#b3261e; }
.cnn-hint-ok { color:#1e8e3e; }

/* Cards */
.cnn-card {
	background: var(--cnn-surface);
	border: 1px solid var(--cnn-border-weak);
	border-radius: var(--cnn-radius-lg);
	padding: var(--cnn-space-6);
	box-shadow: var(--cnn-shadow-1);
}
.cnn-card > .cnn-h3 { margin-top: 0; }
.cnn-card:focus-within {
	outline: 0.1875rem solid var(--cnn-focus);
	outline-offset: 0.375rem;
}
/* Fokus in dichten Containern */
.cnn-card .cnn-btn:focus-visible { outline-offset: .125rem; }

/* Badges */
.cnn-badge {
	display: inline-flex; align-items: center;
	padding: 0.375rem 0.625rem; border-radius: 999px;
	font: 600 clamp(0.6875rem, 1.6vw, 0.75rem)/1 var(--cnn-font-family);
	border: 1px solid transparent;
}
.cnn-badge-blue {
	background: rgba(13,90,229,0.18);
	color: var(--cnn-blue-main-700);
	border-color: rgba(13,90,229,0.35);
}
.cnn-badge-orange {
	background: rgba(194,78,0,0.18);
	color: #7A2E00;
	border-color: rgba(194,78,0,0.35);
}
.cnn-dark .cnn-badge-blue  { color:#FFF; background:#0c3c91; border-color:#1a57c4; }
.cnn-dark .cnn-badge-orange{ color:#FFF; background:#66300a; border-color:#a34a0d; }

/* Tables (UI-Border) */
.cnn-table-wrap {
	width:100%; overflow-x:auto; -webkit-overflow-scrolling:touch;
	border:1px solid var(--cnn-border-ui); border-radius: var(--cnn-radius-md);
}
.cnn-table {
	width: 100%;
	border-collapse: collapse;
	border: 1px solid var(--cnn-border-ui);
	border-radius: 0;
	overflow: visible;
}
.cnn-table th, .cnn-table td {
	padding: 0.625rem 0.75rem;
	border-bottom: 1px solid var(--cnn-border-ui);
	text-align: left;
}
.cnn-table thead th {
	background: rgba(0,0,0,0.04);
	font-weight: 600;
}

/* Responsive Tabellen – Stack-Pattern mit A11y-sicherem thead */
.cnn-table-wrap .cnn-table { min-width: 40rem; border:0; }

@media (max-width: 40rem) {
	.cnn-table.cnn-table--stack { border:0; }
	.cnn-table.cnn-table--stack thead {
		position:absolute; width:1px; height:1px; overflow:hidden;
		clip:rect(0,0,0,0); white-space:nowrap; border:0; padding:0; margin:-1px;
	}
	.cnn-table.cnn-table--stack tr {
		display:block; border:1px solid var(--cnn-border-ui);
		border-radius: var(--cnn-radius-md); margin-bottom: var(--cnn-space-4); overflow:hidden;
	}
	.cnn-table.cnn-table--stack td {
		display:grid; grid-template-columns: 40% 1fr;
		border-bottom:1px solid var(--cnn-border-weak);
	}
	.cnn-table.cnn-table--stack td:last-child { border-bottom:0; }
	.cnn-table.cnn-table--stack td::before {
		content: attr(data-th); font-weight:600; padding-right: var(--cnn-space-4);
	}
}

/* Hero / Sections */
.cnn-hero {
	padding: var(--cnn-space-16) 0;
	background: linear-gradient(180deg, rgba(0,61,112,0.14) 0%, transparent 100%);
	border-bottom: 1px solid var(--cnn-border-weak);
}
.cnn-section { padding: var(--cnn-space-12) 0; border-bottom: 1px dashed var(--cnn-border-weak); }
.cnn-section:last-child { border-bottom: none; padding-bottom: var(--cnn-space-16); }

/* Icon-Helpers */
.cnn-icon { inline-size: 1em; block-size: 1em; flex:0 0 auto; }
.cnn-icon svg { display:block; inline-size:100%; block-size:100%; fill: currentColor; stroke: currentColor; }
.cnn-icon--lg { inline-size: 1.25em; block-size: 1.25em; }

/* Breadcrumb */
.cnn-breadcrumb {
	display:flex; gap:.5rem; align-items:center;
	font:400 .9375rem/1.4 var(--cnn-font-family); color:var(--cnn-text-muted);
}
.cnn-breadcrumb a { text-decoration:none; color:var(--cnn-link); }
.cnn-breadcrumb .cnn-sep { opacity:.5; }

/* Pagination */
.cnn-pagination { display:flex; gap:.5rem; align-items:center; }
.cnn-pagination a, .cnn-pagination span {
	min-inline-size:2.75rem; min-block-size:2.75rem;
	display:grid; place-items:center;
	border:1px solid var(--cnn-border-ui); border-radius:.5rem; padding:0 .5rem;
}
.cnn-pagination .is-active {
	background: var(--cnn-blue-main-500); color:#fff; border-color:transparent;
}

.cnn-text { color: var(--cnn-text); }
.cnn-text-muted { color: var(--cnn-text-muted); }
.cnn-max-65ch { max-width: 65ch; }
.cnn-max-70ch { max-width: 70ch; }
.cnn-max-78ch { max-width: 78ch; }
.cnn-center { margin-inline: auto; }
.cnn-hide { display: none !important; }

.cnn-sr-only {
	position:absolute !important; width:1px; height:1px; padding:0; margin:-1px;
	overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0;
}

/* bewusst auch außerhalb HC verfügbar */
.cnn-border-strong { border-color: var(--cnn-border-ui) !important; }
.cnn-surface-blue-deep { background: var(--cnn-blue-deep-700); color: #fff;}
.cnn-surface-blue-deep a { color: var(--cnn-blue-main-400);}
.cnn-surface-blue-deep .cnn-border-strong {border-color: rgba(255,255,255,0.3) !important;}

.cnn-mt-4 { margin-top: var(--cnn-space-4); }
.cnn-mt-6 { margin-top: var(--cnn-space-6); }
.cnn-mt-8 { margin-top: var(--cnn-space-8); }
.cnn-mb-4 { margin-bottom: var(--cnn-space-4); }
.cnn-mb-6 { margin-bottom: var(--cnn-space-6); }
.cnn-mb-8 { margin-bottom: var(--cnn-space-8); }
.cnn-p-6  { padding: var(--cnn-space-6); }
.cnn-px-6 { padding-inline: var(--cnn-space-6); }
.cnn-py-12{ padding-block: var(--cnn-space-12); }

/* Media Utilities */
.cnn-media-cover { width:100%; height:100%; object-fit:cover; }
.cnn-media-contain { width:100%; height:100%; object-fit:contain; }

/* Responsive Container-Padding via Variable (Safe-Area bleibt intakt) */
@media (min-width: 48rem)  { :root { --cnn-container-pad: var(--cnn-space-8); } }
@media (min-width: 80rem)  { :root { --cnn-container-pad: var(--cnn-space-10); } }

/* Responsive Grid-Utilities – mit cnn- Präfix */
@media (max-width: 57.5rem) {
	.cnn-grid-2, .cnn-grid-3 { grid-template-columns: 1fr; }
}

/* Breakpoint-Utilities (Doppelpunkte escapen) */
@media (min-width: 30rem) {
	.sm\:cnn-hide { display: none !important; }
	.sm\:cnn-grid-2 { display:grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: var(--cnn-space-6); }
	.sm\:cnn-grid-3 { display:grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: var(--cnn-space-6); }
}
@media (min-width: 48rem) {
	.md\:cnn-hide { display: none !important; }
	.md\:cnn-grid-2 { display:grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: var(--cnn-space-6); }
	.md\:cnn-grid-3 { display:grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: var(--cnn-space-6); }
}
@media (min-width: 64rem) {
	.lg\:cnn-hide { display: none !important; }
	.lg\:cnn-show { display: revert !important; }
	.lg\:cnn-grid-4 { display:grid; grid-template-columns: repeat(4, minmax(0,1fr)); gap: var(--cnn-space-6); }
}
@media (min-width: 80rem) {
	.xl\:cnn-hide { display: none !important; }
}

/* Word-Wrapping / Overflow */
.cnn-wrap { overflow-wrap:anywhere; word-break:break-word; }
.cnn-nowrap  { white-space:nowrap; }
.cnn-ellipsis{ overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }

/* Form States (error/success/disabled) */
.cnn-is-error{ --_bd: #da3b2f; --_bg: rgba(218,59,47,.08); }
.cnn-is-success { --_bd: #1e8e3e; --_bg: rgba(30,142,62,.08); }
.cnn-input.cnn-is-error,
.cnn-select.cnn-is-error,
.cnn-textarea.cnn-is-error { border-color: var(--_bd); background: var(--_bg); }
.cnn-input.cnn-is-success,
.cnn-select.cnn-is-success,
.cnn-textarea.cnn-is-success{ border-color: var(--_bd); background: var(--_bg); }
.cnn-input:disabled, .cnn-select:disabled, .cnn-textarea:disabled {
	opacity:.6; cursor:not-allowed;
	background: rgba(0,0,0,0.04);
}

/* Skip-Link */
.cnn-skiplink {
	position:absolute; left:-9999px; top:auto; width:1px; height:1px; overflow:hidden;
}
.cnn-skiplink:focus-visible {
	position:fixed; left:1rem; top:1rem; width:auto; height:auto; padding:0.625rem 0.875rem;
	background: var(--cnn-bg); color: var(--cnn-text);
	border:0.125rem solid var(--cnn-focus); border-radius: var(--cnn-radius-sm);
	z-index: 10000;
}

/* Aspect-Ratio Utilities (native) */
.cnn-ratio{ width:100%; aspect-ratio: var(--_ratio, auto); }
.cnn-ratio-16x9 { --_ratio: 16 / 9; }
.cnn-ratio-4x3  { --_ratio: 4 / 3; }
.cnn-ratio-1x1  { --_ratio: 1 / 1; }

/* Motion-Fallback (reduzierte Bewegung) */
@media (prefers-reduced-motion: reduce) {
	.cnn-btn { transition: none; transform: none !important; }
	* { scroll-behavior: auto !important; animation: none !important; }
}

/* High-Contrast Opt-in */
@media (prefers-contrast: more) {
	:root { --cnn-focus: #2B6CFF; }
	.cnn-border-strong { border-color: var(--cnn-text) !important; }
	.cnn-btn-primary { border-color: currentColor; box-shadow: inset 0 0 0 .0625rem #fff; }
	.cnn-btn-secondary { border-color: var(--cnn-blue-main-600); }
	.cnn-btn-dark { border-color: currentColor; box-shadow: inset 0 0 0 0.0625rem #fff; }
	.cnn-dark .cnn-btn-dark { box-shadow: inset 0 0 0 0.0625rem #000; }
	.cnn-btn-dark-outline { border-width: 0.125rem; }
}

/* Print-Styles (A4-freundlich) */
@media print {
	:root { color-scheme: light; }
	html, body { background:#fff; color:#000; }
	a { color:#000; text-decoration: none; }
	.cnn-btn, .cnn-skiplink, .cnn-hide { display:none !important; }
	.cnn-container { max-width:none; padding:0; }
	.cnn-card { box-shadow:none; border-color:#000; }
}

/* Breakpoint-Token für Doku/Zustände (optional) */
@media (min-width: 30rem) { :root { --cnn-bp: sm; } }
@media (min-width: 48rem) { :root { --cnn-bp: md; } }
@media (min-width: 64rem) { :root { --cnn-bp: lg; } }
@media (min-width: 80rem) { :root { --cnn-bp: xl; } }

@supports (color: color-mix(in oklab, white 50%, black)) {

	/* Themensichere visited-Farbe */
	:root { --cnn-link-visited: color-mix(in oklab, var(--cnn-link) 88%, black); }
	.cnn-dark { --cnn-link-visited: color-mix(in oklab, var(--cnn-link) 80%, white); }

	.cnn-prose code {
		background: color-mix(in oklab, var(--cnn-surface) 70%, transparent);
	}

	.cnn-btn-secondary:is(:hover, :focus-visible) {
		background: color-mix(in oklab, var(--cnn-blue-main-500) 10%, transparent);
	}
	.cnn-dark .cnn-btn-secondary:is(:hover,:focus-visible) {
		background: color-mix(in oklab, var(--cnn-blue-main-400) 14%, transparent);
		border-color: var(--cnn-blue-main-400);
	}

	.cnn-btn-ghost:is(:hover, :focus-visible) {
		background: color-mix(in oklab, var(--cnn-surface) 60%, transparent);
	}
	.cnn-dark .cnn-btn-ghost:is(:hover,:focus-visible) {
		background: color-mix(in oklab, #ffffff 10%, transparent);
	}

	.cnn-btn-dark:hover {
		background: color-mix(in oklab, var(--cnn-btn-dark-bg) 82%, white);
	}
	.cnn-btn-dark:active {
		background: color-mix(in oklab, var(--cnn-btn-dark-bg) 70%, white);
	}

	.cnn-btn-dark-outline:is(:hover, :focus-visible) {
		background: color-mix(in oklab, var(--cnn-btn-dark-bg) 10%, transparent);
	}
	.cnn-dark .cnn-btn-dark-outline:is(:hover, :focus-visible) {
		background: color-mix(in oklab, #FFFFFF 12%, transparent);
	}

	.cnn-badge-blue {
		background: color-mix(in oklab, var(--cnn-blue-main-500) 18%, transparent);
		border-color: color-mix(in oklab, var(--cnn-blue-main-500) 35%, transparent);
	}
	.cnn-badge-orange {
		background: color-mix(in oklab, var(--cnn-orange-600) 18%, transparent);
		border-color: color-mix(in oklab, var(--cnn-orange-600) 35%, transparent);
	}

	.cnn-hero {
		background: linear-gradient(180deg, color-mix(in oklab, var(--cnn-blue-deep-700) 14%, transparent) 0%, transparent 100%);
	}

	.cnn-table thead th {
		background: color-mix(in oklab, var(--cnn-surface) 70%, transparent);
	}

	.cnn-input:focus, .cnn-select:focus, .cnn-textarea:focus {
		box-shadow: 0 0 0 0.25rem color-mix(in oklab, var(--cnn-blue-main-500) 30%, transparent);
	}
	/* Feinfühliger Shadow auf Dark */
	.cnn-dark .cnn-input:focus,
	.cnn-dark .cnn-select:focus,
	.cnn-dark .cnn-textarea:focus {
		box-shadow: 0 0 0 0.25rem color-mix(in oklab, var(--cnn-blue-main-400) 24%, transparent);
	}

	/* Auswahlfarbe (Selection) */
	::selection {
		background: color-mix(in oklab, var(--cnn-link) 30%, transparent);
		color: var(--cnn-bg);
	}
}

/* Fallback, falls color-mix nicht verfügbar: visited bleibt Link-Farbe */
@supports not (color: color-mix(in oklab, white 50%, black)) {
	:root { --cnn-link-visited: var(--cnn-link); }
}