@charset "UTF-8";

/* ==========================================================================
   INHALT
   --------------------------------------------------------------------------
   01  Fonts (@font-face) — IBM Plex
   02  Design-Tokens (:root) + Theme (Dark / Light)
   03  Base / Reset / Globals
   04  Layout — Container, Grid, Stacks, Section, Hero
   05  Typografie — Headings, Body, Lead, Prosa, Fluid-Sizes, Line-Heights
   06  Links
   07  Buttons, CTAs & Chips
   08  Formulare
   09  Cards
   10  Badges & Pills
   11  Tabellen
   12  Navigation — Breadcrumb / Pagination
   13  Icons
   14  Media — Bilder, Aspect-Ratios
   15  Spezialkomponenten — Content-Box, Brandbar, Calendar, Footer-Note
   16  Surfaces & Backgrounds
   17  Utilities — Farbe / Text
   18  Utilities — Borders / Radii / Shadows
   19  Utilities — Spacing (margin, padding)
   20  Utilities — Display / Alignment / Visibility
   21  Utilities — Overflow / Text-Wrapping
   22  Accessibility — Skip-Link, Visually Hidden
   23  Responsive Utilities — Breakpoint-Token & -Klassen
   24  Feature Queries — @supports color-mix (Progressive Enhancement)
   25  Globale Media-Queries — reduced-motion, contrast, print

   Hinweise zu Präfixen:
   - `cnn-…`   Aktuelle Design-System-Klassen (Stand).
   - `cnn2-…`  Hinzugefügt, um Inline-Styles auf der Live-Seite zu
                ersetzen (Ergänzungen zum bestehenden cnn-System).
   - `cnn3-…`  Redesign-Set. Eigene Tokens (`--cnn3-…`) und BEM-Klassen
                (`.cnn3-c-…`, `.cnn3-u-…`, `.cnn3-l-…`, `.cnn3-theme-…`).
                Bare-Element-Stiles (h1-h4, p, a, * Reset …) sind in
                `:where(.cnn3-scope)` eingebettet — d.h. das Redesign
                greift nur innerhalb eines `<div class="cnn3-scope">`.
   - `cn-…`    Legacy / auslaufend, in jedem Abschnitt durch einen
                Kommentar markiert, sollte langfristig abgelöst werden.
   ========================================================================== */


/* ==========================================================================
   01  FONTS — IBM Plex (selbst-gehostet)
   --------------------------------------------------------------------------
   - IBM Plex Sans:           Variable Font (Gewichte 100–700), Roman & Italic
   - IBM Plex Sans Condensed: statisch, 400 & 500
   - IBM Plex Mono:           statisch, 400 & 500
   Dateien unter /fonts/ ablegen (Quelle: github.com/IBM/plex bzw. npm @ibm/plex-*)
   ========================================================================== */

@font-face {
	font-family: "IBM Plex Sans";
	src: url("fonts/IBMPlexSansVar-Roman.woff2") format("woff2");
	font-weight: 100 700;
	font-style: normal;
	font-display: swap;
}
@font-face {
	font-family: "IBM Plex Sans";
	src: url("fonts/IBMPlexSansVar-Italic.woff2") format("woff2");
	font-weight: 100 700;
	font-style: italic;
	font-display: swap;
}
@font-face {
	font-family: "IBM Plex Sans Condensed";
	src: url("fonts/IBMPlexSansCondensed-Regular.woff2") format("woff2");
	font-weight: 400;
	font-style: normal;
	font-display: swap;
}
@font-face {
	font-family: "IBM Plex Sans Condensed";
	src: url("fonts/IBMPlexSansCondensed-Medium.woff2") format("woff2");
	font-weight: 500;
	font-style: normal;
	font-display: swap;
}
@font-face {
	font-family: "IBM Plex Mono";
	src: url("fonts/IBMPlexMono-Regular.woff2") format("woff2");
	font-weight: 400;
	font-style: normal;
	font-display: swap;
}
@font-face {
	font-family: "IBM Plex Mono";
	src: url("fonts/IBMPlexMono-Medium.woff2") format("woff2");
	font-weight: 500;
	font-style: normal;
	font-display: swap;
}


/* ==========================================================================
   02  DESIGN-TOKENS (:root) + THEME (Dark / Light)
   ========================================================================== */

:root {
	color-scheme: light dark;

	/* Brand Hues */
	--cnn-blue-main-400: #4C8DFF;
	--cnn-blue-main-500: #005FAA;
	--cnn-blue-main-600: #005699;
	--cnn-blue-main-700: #0A46BC;
	--cnn-blue-deep-700: #003D70;
	--cnn-black: #111;

	/* Accent */
	--cnn-orange-400: #FF9900;
	--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: #f7f7f7;
	--cnn-surface: var(--cnn-ink-050);
	--cnn-text: var(--cnn-black);
	--cnn-text-muted: var(--cnn-ink-500);
	--cnn-link: var(--cnn-blue-main-600);
	--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-600);
	--cnn-btn-primary-fg: #FFFFFF;
	--cnn-btn-accent-bg: var(--cnn-black);
	--cnn-btn-accent-fg: #FFFFFF;
	--cnn-btn-dark-bg: var(--cnn-black);
	--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: var(--cnn-space-5);

	/* 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:    'IBM Plex Sans', system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
	--cnn-font-condensed: 'IBM Plex Sans Condensed', 'IBM Plex Sans', system-ui, sans-serif;
	--cnn-font-mono:      'IBM Plex Mono', ui-monospace, SFMono-Regular, Consolas, 'Liberation Mono', monospace;
	--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);
}

/* --- Legacy-Tokens (auslaufend, ohne cnn- Präfix) ----------------------- */
:root { --brand-orange: #ff862e; --brand-orange-hover: #f27417; --brand-black: #000806; --brand-blue: #003d70; --brand-blue-hover: #00447d; --text-default: #000806; --text-on-dark: #ffffff; --link: var(--brand-blue); --link-hover: var(--brand-blue-hover); --bd-neutral: #e8e2dc; --bd-strong: #c8beb4; --bd-on-dark: rgba(255, 255, 255, 0.22); --bd-orange: #e2741f; --bd-blue: #1e5a95; --bd-black: #1a232a; --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.06); --shadow-md: 0 6px 18px rgba(0, 0, 0, 0.12); --radius-sm: 4px; --radius-md: 8px; --radius-lg: 14px; --space-1: .25rem; --space-2: .5rem; --space-3: 1rem; --space-4: 1.5rem; --space-5: 2rem; --space-6: 3rem; --fs-vw-xs: 1.2vw; --fs-vw-s: 1.6vw; --fs-vw-m: 1.8vw; --fs-vw-l: 2.4vw; --fs-vw-xl: 3.0vw; --fs-vw-xxl: 4.0vw; --fs-xs-min: .875rem; --fs-xs-max: 1.00rem; --fs-s-min: 1.00rem; --fs-s-max: 1.125rem; --fs-m-min: 1.125rem; --fs-m-max: 1.25rem; --fs-l-min: 1.25rem; --fs-l-max: 1.50rem; --fs-xl-min: 1.50rem; --fs-xl-max: 2.00rem; --fs-xxl-min: 1.75rem; --fs-xxl-max: 2.50rem; --container-max: 1120px; --measure: 72ch; }

/* --- Redesign-Tokens (cnn3) -------------------------------------------- */
:root {
	/* Marken- und Systemfarben */
	--cnn3-color-tinte: #0B4A8C;
	--cnn3-color-schiefer: #2A3950;
	--cnn3-color-kupfer: #C95818;
	--cnn3-color-paper: #FFFFFF;
	--cnn3-color-surface-50: #F6F7FA;
	--cnn3-color-surface-100: #EBEDF2;
	--cnn3-color-border: #D6DAE3;
	--cnn3-color-text-muted: #6B7384;
	--cnn3-color-text-primary: #14181F;

	/* Status */
	--cnn3-color-success: #2F7D5C;
	--cnn3-color-warning: #B8870D;
	--cnn3-color-error:   #B23A36;
	--cnn3-color-info:    #2E7BC4;

	/* Branchen */
	--cnn3-color-branche-it:          #1B7A82;
	--cnn3-color-branche-engineering: #7A6A3D;
	--cnn3-color-branche-business:    #6E3A52;
	--cnn3-color-branche-ai:          #5C4AA8;

	/* Komponenten-Aliase */
	--cnn3-color-cta-bg:        var(--cnn3-color-kupfer);
	--cnn3-color-cta-text:      var(--cnn3-color-paper);
	--cnn3-color-cta-bg-hover:  #B14E15;
	--cnn3-color-cta-bg-active: #9A4412;
	--cnn3-color-link:          var(--cnn3-color-tinte);
	--cnn3-color-link-hover:    var(--cnn3-color-schiefer);
	--cnn3-color-focus-ring:    var(--cnn3-color-tinte);

	/* Schriftfamilien */
	--cnn3-font-sans: "IBM Plex Sans", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
	--cnn3-font-mono: "IBM Plex Mono", ui-monospace, "SFMono-Regular", Menlo, Consolas, monospace;

	/* Schriftgewichte */
	--cnn3-fw-regular:  400;
	--cnn3-fw-medium:   500;
	--cnn3-fw-semibold: 600;

	/* Schriftgrößen — fluide via clamp (Mobile → Desktop) */
	--cnn3-fs-display:    clamp(2.5rem, 1.6rem + 4.5vw, 4.5rem);   /* 40 -> 72 */
	--cnn3-fs-h1:         clamp(2rem,   1.4rem + 3vw,   3rem);     /* 32 -> 48 */
	--cnn3-fs-h2:         clamp(1.5rem, 1.15rem + 1.75vw, 2.25rem);/* 24 -> 36 */
	--cnn3-fs-h3:         1.5rem;     /* 24 */
	--cnn3-fs-h4:         1.25rem;    /* 20 */
	--cnn3-fs-body-large: 1.125rem;   /* 18 */
	--cnn3-fs-body:       1rem;       /* 16 fix */
	--cnn3-fs-body-small: 0.875rem;   /* 14 fix */
	--cnn3-fs-caption:    0.75rem;    /* 12 */
	--cnn3-fs-tag:        0.8125rem;  /* 13 */
	--cnn3-fs-data:       0.9375rem;  /* 15 */
	--cnn3-fs-button:     0.9375rem;  /* 15 */

	/* Line-Heights */
	--cnn3-lh-display:    1.05;
	--cnn3-lh-h1:         1.1;
	--cnn3-lh-h2:         1.15;
	--cnn3-lh-h3:         1.25;
	--cnn3-lh-h4:         1.3;
	--cnn3-lh-body-large: 1.55;
	--cnn3-lh-body:       1.6;
	--cnn3-lh-body-small: 1.55;
	--cnn3-lh-caption:    1.45;
	--cnn3-lh-tag:        1.4;
	--cnn3-lh-data:       1.4;
	--cnn3-lh-button:     1.2;

	/* Letter-Spacing — Default-Werte (entsprechen Messe-Theme) */
	--cnn3-ls-display: -0.02em;
	--cnn3-ls-h1:      -0.015em;
	--cnn3-ls-h2:      -0.01em;
	--cnn3-ls-h3:      -0.005em;
	--cnn3-ls-caption:  0.04em;
	--cnn3-ls-button:   0.01em;

	/* Spacing (4px-Basis) */
	--cnn3-space-1:  0.25rem;  --cnn3-space-2:  0.5rem;   --cnn3-space-3:  0.75rem;
	--cnn3-space-4:  1rem;     --cnn3-space-5:  1.25rem;  --cnn3-space-6:  1.5rem;
	--cnn3-space-7:  2rem;     --cnn3-space-8:  2.5rem;   --cnn3-space-9:  3rem;
	--cnn3-space-10: 4rem;     --cnn3-space-11: 5rem;     --cnn3-space-12: 6rem;

	/* Layout / Radien / Border */
	--cnn3-container-max: 1280px;
	--cnn3-radius-sm:   4px;
	--cnn3-radius-md:   8px;
	--cnn3-radius-lg:   12px;
	--cnn3-radius-pill: 999px;
	--cnn3-border-width:   1px;
	--cnn3-border-default: var(--cnn3-border-width) solid var(--cnn3-color-border);

	/* Schatten — Skala nach Erhebungs-Stufe
	   shadow-0:            keiner (Standard, ruhige Flächen)
	   shadow-1:            leicht — Hover auf Karten (Job, Branche, Insight)
	   shadow-2:            mittel — Searchbar, kleinere schwebende Panels
	   shadow-3:            stark  — Hero-Atlas-Panel, große schwebende Container
	   shadow-inset-hairline: 1px Halo nach unten, akzentuiert obere Lichtkante
	   shadow-focus:        3px Fokus-Ring in Tinte (Inputs, Searchbar)
	   shadow-button-on:    Mini-Erhebung für aktive Segment-Buttons              */
	--cnn3-shadow-inset-hairline: 0 1px 0 rgba(20, 24, 31, 0.02);
	--cnn3-shadow-1: var(--cnn3-shadow-inset-hairline), 0 12px 24px -16px rgba(20, 24, 31, 0.16);
	--cnn3-shadow-2: var(--cnn3-shadow-inset-hairline), 0 8px 24px -16px rgba(20, 24, 31, 0.18);
	--cnn3-shadow-3: var(--cnn3-shadow-inset-hairline), 0 24px 48px -24px rgba(20, 24, 31, 0.18);
	--cnn3-shadow-focus:     0 0 0 3px color-mix(in oklab, var(--cnn3-color-tinte) 16%, transparent);
	--cnn3-shadow-button-on: 0 1px 0 rgba(20, 24, 31, 0.06), 0 2px 6px -2px rgba(20, 24, 31, 0.10);
}

/* 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; }

/* --- cnn3 Theme-Varianten (Letter-Spacing-Overrides) -------------------- */
.cnn3-theme-messe {
	--cnn3-ls-display: -0.02em;
	--cnn3-ls-h1:      -0.015em;
}
.cnn3-theme-atlas {
	--cnn3-ls-display: -0.01em;
	--cnn3-ls-h1:      -0.005em;
}


/* ==========================================================================
   03  BASE / RESET / GLOBALS
   ========================================================================== */

body {
	background: var(--cnn-bg);
	color: var(--cnn-text);
	font: 400 var(--cnn-body-size)/var(--cnn-body-line) var(--cnn-font-family);
	position: relative;
}

/* --- Legacy (auslaufend) ------------------------------------------------- */
img, svg, video, canvas { max-width: 100%; height: auto; }

[hidden] { display: none !important; }

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

/* --- cnn3 Reset / Base (scoped via .cnn3-scope) ------------------------- */
/* Wrapper-Klasse: <div class="cnn3-scope">…Redesign-Markup…</div>
   Verwendet :where(.cnn3-scope) für 0-Specificity, damit Komponenten-Klassen
   (.cnn3-c-…) gewinnen. */

.cnn3-scope,
:where(.cnn3-scope) *,
:where(.cnn3-scope) *::before,
:where(.cnn3-scope) *::after {
	box-sizing: border-box;
	margin: 0;
	padding: 0;
}
.cnn3-scope {
	font-family: var(--cnn3-font-sans);
	font-size: var(--cnn3-fs-body);
	font-weight: var(--cnn3-fw-regular);
	line-height: 1.5;
	color: var(--cnn3-color-text-primary);
	background-color: var(--cnn3-color-paper);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	-webkit-text-size-adjust: 100%;
	text-size-adjust: 100%;
}
:where(.cnn3-scope) :is(img, picture, svg, video) {
	display: block;
	max-width: 100%;
	height: auto;
}
:where(.cnn3-scope) :is(button, input, select, textarea) {
	font: inherit;
	color: inherit;
}
:where(.cnn3-scope) :is(ul, ol) {
	list-style: none;
}
/* Basis-Link-Reset (gestaltete Variante siehe Abschnitt 06) */
:where(.cnn3-scope) a {
	color: inherit;
	text-decoration: none;
}


/* ==========================================================================
   04  LAYOUT — Container, Grid, Stacks, Section, Hero
   ========================================================================== */

/* Container */
.cnn-container {
	width: min(100%, calc(var(--cnn-container-max) + var(--cnn-container-pad) + var(--cnn-container-pad)));
	max-width: none;
	margin-inline: 0 auto;
	padding-inline: var(--cnn-container-pad);
	box-sizing: border-box;
}
@media (min-width: 100rem) {
	.cnn-container {
		width: min(100%, calc(var(--cnn-container-max-lg) + var(--cnn-container-pad) + var(--cnn-container-pad)));
	}
}

/* --- Legacy (auslaufend) ------------------------------------------------- */
.cn-container { max-width: var(--container-max); margin: 0 auto; padding: var(--space-4); }

/* Grid */
.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)); }

@media (max-width: 57.5rem) {
	.cnn-grid-2, .cnn-grid-3 { grid-template-columns: 1fr; }
}

/* Stacks */
.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); }

/* --- Legacy (auslaufend) ------------------------------------------------- */
.cn-stack-xs > * + * { margin-top: var(--space-1); }
.cn-stack-s  > * + * { margin-top: var(--space-2); }
.cn-stack-m  > * + * { margin-top: var(--space-3); }
.cn-stack-l  > * + * { margin-top: var(--space-4); }

/* Sections */
.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); }

/* --- Legacy (auslaufend) ------------------------------------------------- */
.cn-section-0 { padding: 0; }
.cn-section-1 { padding: var(--space-1) 0; }
.cn-section-2 { padding: var(--space-2) 0; }
.cn-section-3 { padding: var(--space-3) 0; }
.cn-section-4 { padding: var(--space-4) 0; }
.cn-section-5 { padding: var(--space-5) 0; }
.cn-section-6 { padding: var(--space-6) 0; }

/* Hero */
.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);
}

/* --- Legacy (auslaufend) ------------------------------------------------- */
.cn-hero { padding: var(--space-6) 0; }
.cn-hero--compact { padding: var(--space-5) 0; }
.cn-hero__title { margin: 0 0 var(--space-3); }
.cn-hero__subtitle { margin: 0 0 var(--space-4); color: #2b2b2b; max-width: 60ch; }
.cn-hero--on-dark .cn-hero__subtitle { color: #eaeaea; }

/* --- Layout-Helper (cnn2) ----------------------------------------------- */
.cnn2-relative        { position: relative; }
.cnn2-cluster         { display: flex; flex-wrap: wrap; gap: var(--cnn-space-3); }
.cnn2-cluster-center  { display: flex; flex-wrap: wrap; gap: var(--cnn-space-3); justify-content: center; }
.cnn2-row-between     { display: flex; flex-wrap: wrap; gap: .75rem; align-items: baseline; justify-content: space-between; }

/* --- cnn3 Container ----------------------------------------------------- */
.cnn3-l-container {
	width: 100%;
	max-width: var(--cnn3-container-max);
	margin-inline: auto;
	padding-inline: var(--cnn3-space-4);
}

/* --- cnn3 Section-Wrapper ----------------------------------------------- */
.cnn3-c-section { padding: var(--cnn3-space-11) 0; border-bottom: var(--cnn3-border-default); }
.cnn3-c-section--tight { padding: var(--cnn3-space-9) 0; }
.cnn3-c-section--dark  { background: var(--cnn3-color-schiefer); color: var(--cnn3-color-paper); }
.cnn3-c-section--dark h2,
.cnn3-c-section--dark h3 { color: var(--cnn3-color-paper); }
.cnn3-c-section--dark p  { color: rgba(255,255,255,.78); }

.cnn3-c-section__header {
	display: flex; justify-content: space-between; align-items: end; gap: var(--cnn3-space-6);
	margin-bottom: var(--cnn3-space-8);
	flex-wrap: wrap;
}
.cnn3-c-section__lead { max-width: 720px; }
.cnn3-c-section__lead p {
	color: var(--cnn3-color-text-muted);
	font-size: var(--cnn3-fs-body-large);
	margin-top: var(--cnn3-space-3);
}
.cnn3-c-section--dark .cnn3-c-section__lead p { color: rgba(255,255,255,.78); }
.cnn3-c-section__eyebrow {
	font-family: var(--cnn3-font-mono); font-size: var(--cnn3-fs-tag);
	letter-spacing: 0.06em; text-transform: uppercase;
	color: var(--cnn3-color-tinte);
	margin-bottom: var(--cnn3-space-3);
	display: inline-flex; align-items: center; gap: var(--cnn3-space-2);
}
.cnn3-c-section__eyebrow::before {
	content: ""; width: 24px; height: 1px; background: currentColor;
}
.cnn3-c-section--dark .cnn3-c-section__eyebrow {
	color: color-mix(in oklab, var(--cnn3-color-kupfer) 80%, white);
}

/* --- cnn3 Hero ---------------------------------------------------------- */
.cnn3-c-hero {
	width: 100%;
	max-width: var(--cnn3-container-max);
	margin-inline: auto;
	padding: var(--cnn3-space-10) var(--cnn3-space-4);
	display: flex;
	flex-direction: column;
	gap: var(--cnn3-space-5);
}
.cnn3-c-hero__display {
	font-family: var(--cnn3-font-sans);
	font-size: var(--cnn3-fs-display);
	line-height: var(--cnn3-lh-display);
	letter-spacing: var(--cnn3-ls-display);
	font-weight: var(--cnn3-fw-semibold);
	color: var(--cnn3-color-text-primary);
	max-width: 22ch;
	text-wrap: balance;
}
.cnn3-c-hero__title {
	font-size: var(--cnn3-fs-h1);
	line-height: var(--cnn3-lh-h1);
	letter-spacing: var(--cnn3-ls-h1);
	font-weight: var(--cnn3-fw-semibold);
	color: var(--cnn3-color-text-primary);
	max-width: 28ch;
	text-wrap: balance;
}
.cnn3-c-hero__subline  { font-size: var(--cnn3-fs-body-large); line-height: var(--cnn3-lh-body-large); color: var(--cnn3-color-text-muted); max-width: 60ch; }
.cnn3-c-hero__audience { font-size: var(--cnn3-fs-body-small); line-height: var(--cnn3-lh-body-small); color: var(--cnn3-color-text-muted); }
.cnn3-c-hero__actions  { display: flex; flex-wrap: wrap; gap: var(--cnn3-space-3); margin-top: var(--cnn3-space-3); }

/* Theme-Hooks für Hero (Letter-Spacing-Overrides in Abschnitt 02) */
.cnn3-theme-messe .cnn3-c-hero__meta {
	display: flex; flex-wrap: wrap; gap: var(--cnn3-space-3);
	font-family: var(--cnn3-font-mono);
	font-size: var(--cnn3-fs-data); line-height: var(--cnn3-lh-data);
	letter-spacing: 0.02em;
	color: var(--cnn3-color-schiefer);
	font-feature-settings: "ss01", "zero";
}
.cnn3-theme-atlas .cnn3-c-hero__subline {
	font-family: var(--cnn3-font-mono);
	font-size: var(--cnn3-fs-tag); line-height: var(--cnn3-lh-tag);
	color: var(--cnn3-color-text-muted);
	display: flex; flex-wrap: wrap; gap: var(--cnn3-space-2);
	font-feature-settings: "ss01", "zero";
}

/* --- cnn3 Hero-X (Site-spezifische 2-Spalten-Variante) ------------------ */
.cnn3-c-hero-x {
	position: relative;
	overflow: hidden;
	border-bottom: var(--cnn3-border-default);
	background:
					radial-gradient(900px 500px at 95% -10%, color-mix(in oklab, var(--cnn3-color-tinte) 8%, transparent), transparent 60%),
					linear-gradient(180deg, var(--cnn3-color-paper), var(--cnn3-color-surface-50));
}
.cnn3-c-hero-x__grid {
	display: grid;
	grid-template-columns: 1.15fr 0.85fr;
	gap: var(--cnn3-space-10);
	align-items: center;
	padding: var(--cnn3-space-11) 0 var(--cnn3-space-10);
}
@media (max-width: 900px) {
	.cnn3-c-hero-x__grid { grid-template-columns: 1fr; padding: var(--cnn3-space-9) 0; }
}
.cnn3-c-hero-x__eyebrow {
	display: inline-flex; align-items: center; gap: var(--cnn3-space-2);
	font-family: var(--cnn3-font-mono);
	font-size: var(--cnn3-fs-tag);
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: var(--cnn3-color-tinte);
	margin-bottom: var(--cnn3-space-5);
}
.cnn3-c-hero-x__eyebrow::before {
	content: ""; width: 24px; height: 1px; background: currentColor;
}
.cnn3-c-hero-x__meta {
	display: flex; flex-wrap: wrap; gap: var(--cnn3-space-3) var(--cnn3-space-6);
	font-family: var(--cnn3-font-mono);
	font-size: var(--cnn3-fs-data);
	letter-spacing: 0.02em;
	color: var(--cnn3-color-schiefer);
	margin: var(--cnn3-space-6) 0 var(--cnn3-space-5);
	padding: var(--cnn3-space-4) 0;
	border-top: var(--cnn3-border-default);
	border-bottom: var(--cnn3-border-default);
}
.cnn3-c-hero-x__meta-item { display: flex; align-items: baseline; gap: var(--cnn3-space-2); }
.cnn3-c-hero-x__meta-label {
	color: var(--cnn3-color-text-muted);
	text-transform: uppercase;
	letter-spacing: 0.06em;
	font-size: var(--cnn3-fs-caption);
}

/* Hero-X — Atlas-Vorschau-Panel */
.cnn3-c-hero-x__panel {
	background: var(--cnn3-color-paper);
	border: var(--cnn3-border-default);
	border-radius: var(--cnn3-radius-lg);
	box-shadow: var(--cnn3-shadow-3);
	overflow: hidden;
}
.cnn3-c-hero-x__panel-head {
	display: flex; align-items: center; justify-content: space-between;
	padding: var(--cnn3-space-3) var(--cnn3-space-4);
	background: var(--cnn3-color-schiefer);
	color: var(--cnn3-color-paper);
	font-family: var(--cnn3-font-mono);
	font-size: var(--cnn3-fs-tag);
	letter-spacing: 0.04em;
}
.cnn3-c-hero-x__panel-head-dots { display: flex; gap: 6px; }
.cnn3-c-hero-x__panel-head-dots span {
	width: 8px; height: 8px; border-radius: 50%;
	background: rgba(255,255,255,.25);
}
.cnn3-c-hero-x__panel-body {
	padding: var(--cnn3-space-5);
	display: flex; flex-direction: column; gap: var(--cnn3-space-3);
}
.cnn3-c-hero-x__row {
	display: grid; grid-template-columns: 1fr auto; gap: var(--cnn3-space-3);
	align-items: center;
	padding: var(--cnn3-space-3);
	border: var(--cnn3-border-default);
	border-radius: var(--cnn3-radius-md);
	background: var(--cnn3-color-paper);
	cursor: pointer;
	transition: border-color .15s ease, background-color .15s ease, transform .15s ease;
}
.cnn3-c-hero-x__row:hover {
	border-color: var(--cnn3-color-tinte);
	background: var(--cnn3-color-surface-50);
	transform: translateY(-1px);
}
.cnn3-c-hero-x__row-title { font-weight: var(--cnn3-fw-medium); font-size: var(--cnn3-fs-body); }
.cnn3-c-hero-x__row-meta {
	font-family: var(--cnn3-font-mono); font-size: var(--cnn3-fs-tag); color: var(--cnn3-color-text-muted);
	display: flex; gap: var(--cnn3-space-2); margin-top: 2px;
}
.cnn3-c-hero-x__row-side {
	font-family: var(--cnn3-font-mono); font-size: var(--cnn3-fs-tag); color: var(--cnn3-color-text-primary);
	white-space: nowrap;
}

/* Hero-X — invertierte (dunkle) Variante */
.cnn3-c-hero-x--invert {
	background:
					radial-gradient(900px 520px at 92% -20%, color-mix(in oklab, var(--cnn3-color-kupfer) 55%, transparent), transparent 60%),
					radial-gradient(700px 500px at  5% 110%, color-mix(in oklab, var(--cnn3-color-schiefer) 70%, transparent), transparent 65%),
					var(--cnn3-color-tinte);
	color: var(--cnn3-color-paper);
	border-bottom-color: transparent;
}
.cnn3-c-hero-x--invert::before {
	content: "";
	position: absolute; inset: 0;
	background-image:
					linear-gradient(rgba(255,255,255,.06) 1px, transparent 1px),
					linear-gradient(90deg, rgba(255,255,255,.06) 1px, transparent 1px);
	background-size: 64px 64px;
	mask-image:        radial-gradient(ellipse at 30% 40%, black 0%, transparent 70%);
	-webkit-mask-image: radial-gradient(ellipse at 30% 40%, black 0%, transparent 70%);
	pointer-events: none;
}
.cnn3-c-hero-x--invert .cnn3-c-hero-x__grid { position: relative; z-index: 1; }
.cnn3-c-hero-x--invert .cnn3-u-display,
.cnn3-c-hero-x--invert .cnn3-c-hero-x__title { color: var(--cnn3-color-paper); }
.cnn3-c-hero-x--invert .cnn3-c-hero__subline  { color: color-mix(in oklab, white 78%, transparent); }
.cnn3-c-hero-x--invert .cnn3-c-hero__audience { color: color-mix(in oklab, white 65%, transparent); }
.cnn3-c-hero-x--invert .cnn3-c-hero-x__eyebrow { color: color-mix(in oklab, var(--cnn3-color-kupfer) 65%, white); }
.cnn3-c-hero-x--invert .cnn3-c-hero-x__meta {
	color: var(--cnn3-color-paper);
	border-top-color: rgba(255,255,255,.18);
	border-bottom-color: rgba(255,255,255,.18);
}
.cnn3-c-hero-x--invert .cnn3-c-hero-x__meta-label { color: color-mix(in oklab, white 65%, transparent); }
.cnn3-c-hero-x--invert .cnn3-c-searchbar { border-color: rgba(255,255,255,.18); }
.cnn3-c-hero-x--invert .cnn3-c-hero-x__panel {
	background: color-mix(in oklab, var(--cnn3-color-tinte) 92%, black);
	border-color: rgba(255,255,255,.14);
	color: var(--cnn3-color-paper);
}
.cnn3-c-hero-x--invert .cnn3-c-hero-x__panel-head {
	background: rgba(0,0,0,.25);
	color: color-mix(in oklab, white 80%, transparent);
}
.cnn3-c-hero-x--invert .cnn3-c-hero-x__row {
	background: rgba(255,255,255,.04);
	border-color: rgba(255,255,255,.12);
	color: var(--cnn3-color-paper);
}
.cnn3-c-hero-x--invert .cnn3-c-hero-x__row:hover {
	background: rgba(255,255,255,.08);
	border-color: color-mix(in oklab, var(--cnn3-color-kupfer) 70%, white);
}
.cnn3-c-hero-x--invert .cnn3-c-hero-x__row-meta,
.cnn3-c-hero-x--invert .cnn3-c-hero-x__row-side {
	color: color-mix(in oklab, white 65%, transparent);
}
.cnn3-c-hero-x--invert .cnn3-c-hero-x__panel .cnn3-c-button--tertiary { color: color-mix(in oklab, var(--cnn3-color-kupfer) 60%, white); }
.cnn3-c-hero-x--invert .cnn3-c-hero-x__panel .cnn3-c-button--tertiary:hover { color: var(--cnn3-color-paper); }
.cnn3-c-hero-x--invert a       { color: color-mix(in oklab, var(--cnn3-color-kupfer) 60%, white); }
.cnn3-c-hero-x--invert a:hover { color: var(--cnn3-color-paper); }

/* --- cnn3 Searchbar (im Hero) ------------------------------------------ */
.cnn3-c-searchbar {
	display: grid;
	grid-template-columns: 1fr 1fr auto;
	gap: var(--cnn3-space-2);
	background: var(--cnn3-color-paper);
	border: 1px solid var(--cnn3-color-border);
	border-radius: var(--cnn3-radius-lg);
	padding: var(--cnn3-space-2);
	margin-top: var(--cnn3-space-5);
	box-shadow: var(--cnn3-shadow-2);
}
.cnn3-c-searchbar__field {
	display: flex; flex-direction: column;
	padding: var(--cnn3-space-2) var(--cnn3-space-3);
	border-radius: var(--cnn3-radius-md);
}
.cnn3-c-searchbar__field:hover { background: var(--cnn3-color-surface-50); }
.cnn3-c-searchbar__label {
	font-family: var(--cnn3-font-mono);
	font-size: 0.6875rem;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--cnn3-color-text-muted);
}
.cnn3-c-searchbar__input {
	border: 0; outline: 0; background: transparent;
	font-size: var(--cnn3-fs-body);
	color: var(--cnn3-color-text-primary);
	padding: 2px 0;
	width: 100%;
}
.cnn3-c-searchbar__input::placeholder { color: var(--cnn3-color-text-muted); }
.cnn3-c-searchbar__cta { align-self: stretch; }
@media (max-width: 720px) {
	.cnn3-c-searchbar { grid-template-columns: 1fr; }
}


/* ==========================================================================
   05  TYPOGRAFIE — Headings, Body, Lead, Prosa, Fluid-Sizes, Line-Heights
   ========================================================================== */

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

/* --- Legacy (auslaufend) ------------------------------------------------- */
.cn-h1 { font-size: clamp(2rem, 2vw + 1.2rem, 3rem); line-height: 1.1; margin: 0 0 var(--space-3); text-wrap: balance; }
.cn-h2 { font-size: clamp(1.5rem, 1.4vw + .9rem, 2.25rem); line-height: 1.2; margin: 0 0 var(--space-3); text-wrap: balance; }
.cn-h3 { font-size: 1.5rem; line-height: 1.3; margin: 0 0 var(--space-2); }

/* Display-/Brand-Typo */
.cnn-f1 {
	font-family: var(--cnn-font-family);
	font-size: 1.05em;
	font-weight: 600;
	letter-spacing: -0.01em;
	line-height: 1;
}
@media (min-width: 30rem) {
	.cnn-f1 {
		font-size: 1.1em;
	}
}

.cnn-f2 {
	font-family: var(--cnn-font-family);
	font-weight: 600;
	letter-spacing: -0.01em;
	line-height: 1;
}

.cnn-brand {
	font-family: var(--cnn-font-family);
	font-weight: 600;
	font-size: clamp(1.125rem,1.8vw, 1.375rem);
	line-height: 1.1;
	letter-spacing: -0.01em;
	display: inline-block;
}

/* --- Legacy Font-Weight-Skala (auslaufend) ------------------------------- */
.cn-f1 { font-weight: 100; }
.cn-f2 { font-weight: 200; }
.cn-f3 { font-weight: 300; }
.cn-f4 { font-weight: 400; }
.cn-f5 { font-weight: 500; }
.cn-f6 { font-weight: 600; }
.cn-f7 { font-weight: 600; }
.cn-f8 { font-weight: 600; }
.cn-f9 { font-weight: 600; }

/* Body / Lead / Small / Micro / Uppercase / Tabular */
.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; }

/* --- Legacy (auslaufend) ------------------------------------------------- */
.cn-lead { font-size: 1.125rem; line-height: 1.6; color: #2b2b2b; }

/* Fluid Font-Sizes (Legacy, auslaufend) ---------------------------------- */
.cn-fs-fluid-xs  { font-size: var(--fs-xs-max); }
.cn-fs-fluid-s   { font-size: var(--fs-s-max); }
.cn-fs-fluid-m   { font-size: var(--fs-m-max); }
.cn-fs-fluid-l   { font-size: var(--fs-l-max); }
.cn-fs-fluid-xl  { font-size: var(--fs-xl-max); }
.cn-fs-fluid-xxl { font-size: var(--fs-xxl-max); }

@supports (font-size: clamp(1rem, 2vw, 2rem)) {
	.cn-fs-fluid-xs  { font-size: clamp(var(--fs-xs-min),  var(--fs-vw-xs),  var(--fs-xs-max)); }
	.cn-fs-fluid-s   { font-size: clamp(var(--fs-s-min),   var(--fs-vw-s),   var(--fs-s-max)); }
	.cn-fs-fluid-m   { font-size: clamp(var(--fs-m-min),   var(--fs-vw-m),   var(--fs-m-max)); }
	.cn-fs-fluid-l   { font-size: clamp(var(--fs-l-min),   var(--fs-vw-l),   var(--fs-l-max)); }
	.cn-fs-fluid-xl  { font-size: clamp(var(--fs-xl-min),  var(--fs-vw-xl),  var(--fs-xl-max)); }
	.cn-fs-fluid-xxl { font-size: clamp(var(--fs-xxl-min), var(--fs-vw-xxl), var(--fs-xxl-max)); }
}

/* Line-Heights (Legacy, auslaufend) -------------------------------------- */
.cn-lh-tight { line-height: 1.15; }
.cn-lh-title { line-height: 1.25; }
.cn-lh-copy  { line-height: 1.6; }

/* Maße / Textbreite */
.cnn-max-65ch { max-width: 65ch; }
.cnn-max-70ch { max-width: 70ch; }
.cnn-max-78ch { max-width: 78ch; }

/* --- Legacy (auslaufend) ------------------------------------------------- */
.cn-max-ch       { max-width: var(--measure); }
.cn-text-balance { text-wrap: balance; }

/* 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; }

/* --- Typografie-Helper (cnn2) ------------------------------------------- */
.cnn2-text-left  { text-align: left !important; }
.cnn2-fs-28      { font-size: 28px; }
.cnn2-list-reset { list-style: none; padding: 0; margin: 0; }

/* --- cnn3 Bare-Typografie (scoped via .cnn3-scope) ---------------------- */
:where(.cnn3-scope) :is(h1, h2, h3, h4) {
	font-family: var(--cnn3-font-sans);
	color: var(--cnn3-color-text-primary);
	text-wrap: balance;
}
:where(.cnn3-scope) h1 { font-size: var(--cnn3-fs-h1); line-height: var(--cnn3-lh-h1); letter-spacing: var(--cnn3-ls-h1); font-weight: var(--cnn3-fw-semibold); }
:where(.cnn3-scope) h2 { font-size: var(--cnn3-fs-h2); line-height: var(--cnn3-lh-h2); letter-spacing: var(--cnn3-ls-h2); font-weight: var(--cnn3-fw-semibold); }
:where(.cnn3-scope) h3 { font-size: var(--cnn3-fs-h3); line-height: var(--cnn3-lh-h3); letter-spacing: var(--cnn3-ls-h3); font-weight: var(--cnn3-fw-medium); }
:where(.cnn3-scope) h4 { font-size: var(--cnn3-fs-h4); line-height: var(--cnn3-lh-h4);                                  font-weight: var(--cnn3-fw-medium); }
:where(.cnn3-scope) p  { font-size: var(--cnn3-fs-body); line-height: var(--cnn3-lh-body); color: var(--cnn3-color-text-primary); text-wrap: pretty; }
:where(.cnn3-scope) :is(ul, ol) { font-size: var(--cnn3-fs-body); line-height: var(--cnn3-lh-body); }

/* --- cnn3 Typografie-Utilities ------------------------------------------ */
.cnn3-u-display {
	font-family: var(--cnn3-font-sans);
	font-size: var(--cnn3-fs-display);
	line-height: var(--cnn3-lh-display);
	letter-spacing: var(--cnn3-ls-display);
	font-weight: var(--cnn3-fw-semibold);
	color: var(--cnn3-color-text-primary);
	text-wrap: balance;
}
.cnn3-u-body-large { font-size: var(--cnn3-fs-body-large); line-height: var(--cnn3-lh-body-large); }
.cnn3-u-body-small { font-size: var(--cnn3-fs-body-small); line-height: var(--cnn3-lh-body-small); }
.cnn3-u-caption {
	font-size: var(--cnn3-fs-caption);
	line-height: var(--cnn3-lh-caption);
	letter-spacing: var(--cnn3-ls-caption);
	text-transform: uppercase;
	color: var(--cnn3-color-text-muted);
}

/* --- cnn3 Mono-Helper: Daten, Tags, Skills, Jobtitel ------------------- */
.cnn3-data, .cnn3-tag {
	font-family: var(--cnn3-font-mono);
	font-feature-settings: "ss01", "zero";
	font-weight: var(--cnn3-fw-regular);
}
.cnn3-data { font-size: var(--cnn3-fs-data); line-height: var(--cnn3-lh-data); }
.cnn3-tag  { font-size: var(--cnn3-fs-tag);  line-height: var(--cnn3-lh-tag); }


/* ==========================================================================
   06  LINKS
   ========================================================================== */

.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; }

/* --- Legacy (auslaufend) ------------------------------------------------- */
.cn-a { color: var(--link); text-decoration-line: underline; text-decoration-color: rgba(0, 61, 112, 0.35); text-underline-offset: 2px; text-decoration-thickness: 1px; }
.cn-a:hover, .cn-a:focus { color: var(--link-hover); text-decoration-color: rgba(0, 68, 125, 0.6); }
.cn-link--inverse { color: #cfe3ff; }
.cn-link--inverse:hover, .cn-link--inverse:focus { color: #ffffff; }

/* --- cnn3 Links (scoped, gestaltete Variante) --------------------------- */
:where(.cnn3-scope) a {
	color: var(--cnn3-color-link);
	text-decoration: underline;
	text-underline-offset: 0.15em;
	text-decoration-thickness: 1px;
	transition: color 0.15s ease, text-decoration-thickness 0.15s ease;
}
:where(.cnn3-scope) a:hover {
	color: var(--cnn3-color-link-hover);
	text-decoration-thickness: 2px;
}
:where(.cnn3-scope) a:focus-visible {
	outline: 2px solid var(--cnn3-color-focus-ring);
	outline-offset: 2px;
	border-radius: var(--cnn3-radius-sm);
	text-decoration: none;
}


/* ==========================================================================
   07  BUTTONS, CTAs & CHIPS
   ========================================================================== */

.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); color: var(--cnn-btn-primary-fg); transform: translateY(-1px); }
.cnn-btn-primary:active { background: var(--cnn-blue-main-700); color: var(--cnn-btn-primary-fg); transform: translateY(0); }

.cnn-btn-accent { background: var(--cnn-btn-accent-bg); color: var(--cnn-btn-accent-fg); }
.cnn-btn-accent:hover { background: var(--cnn-ink-800); 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);
	color: var(--cnn-btn-dark-fg);
	transform: translateY(-0.0625rem);
}
.cnn-btn-dark:active {
	background: var(--cnn-btn-dark-bg-active);
	color: var(--cnn-btn-dark-fg);
	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); }
}

/* --- Primary-Button auf dunklem Hintergrund (cnn2) ---------------------- */
.cnn2-btn-primary-on-dark {
	border-color: #FFFFFF;
	background-color: var(--cnn-blue-main-500);
}

/* --- cnn3 Buttons ------------------------------------------------------- */
.cnn3-c-button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: var(--cnn3-space-2);
	min-height: 44px;
	min-width: 44px;
	padding: var(--cnn3-space-3) var(--cnn3-space-5);
	font-family: var(--cnn3-font-sans);
	font-size: var(--cnn3-fs-button);
	line-height: var(--cnn3-lh-button);
	font-weight: var(--cnn3-fw-medium);
	letter-spacing: var(--cnn3-ls-button);
	border: var(--cnn3-border-width) solid transparent;
	border-radius: var(--cnn3-radius-md);
	cursor: pointer;
	text-decoration: none;
	user-select: none;
	transition: background-color 0.15s ease, color 0.15s ease, border-color 0.15s ease;
}
.cnn3-c-button:focus-visible { outline: 2px solid var(--cnn3-color-focus-ring); outline-offset: 2px; }
.cnn3-c-button:disabled,
.cnn3-c-button[aria-disabled="true"] { opacity: 0.5; cursor: not-allowed; }

/* Primary — Kupfer, weiße Schrift */
.cnn3-c-button--primary {
	background-color: var(--cnn3-color-cta-bg);
	color: var(--cnn3-color-cta-text);
	border-color: var(--cnn3-color-cta-bg);
}
.cnn3-c-button--primary:hover  { background-color: var(--cnn3-color-cta-bg-hover);  border-color: var(--cnn3-color-cta-bg-hover); }
.cnn3-c-button--primary:active { background-color: var(--cnn3-color-cta-bg-active); border-color: var(--cnn3-color-cta-bg-active); }

/* Secondary — Tinte-Outline auf Paper */
.cnn3-c-button--secondary {
	background-color: var(--cnn3-color-paper);
	color: var(--cnn3-color-tinte);
	border-color: var(--cnn3-color-tinte);
}
.cnn3-c-button--secondary:hover  { background-color: var(--cnn3-color-surface-50); }
.cnn3-c-button--secondary:active { background-color: var(--cnn3-color-surface-100); }

/* Tertiary — nur Text in Tinte */
.cnn3-c-button--tertiary {
	background-color: transparent;
	color: var(--cnn3-color-tinte);
	border-color: transparent;
	padding-inline: var(--cnn3-space-2);
}
.cnn3-c-button--tertiary:hover  { color: var(--cnn3-color-link-hover); text-decoration: underline; text-underline-offset: 0.2em; }
.cnn3-c-button--tertiary:active { color: var(--cnn3-color-text-primary); }

/* --- Legacy Buttons / CTAs (auslaufend) --------------------------------- */
.cn-button { display: inline-block; padding: 1rem 1rem; border-radius: var(--radius-lg); font-weight: 600; line-height: 1.15; transition: transform .12s ease; }
.cn-button.cn-cta--neutral { background: #e9e9e9; border: 1px solid var(--bd-neutral); color: var(--text-default); }
.cn-button.cn-cta--accent:hover, .cn-button.cn-cta--accent:focus { background: var(--brand-blue); border-color: var(--bd-blue); color: #fff; }
.cn-button.cn-cta--orange:hover, .cn-button.cn-cta--orange:focus { background: var(--brand-orange); border-color: var(--bd-orange); color: var(--text-default); }
.cn-button.cn-cta--neutral:hover, .cn-button.cn-cta--neutral:focus { background: #e9e9e9; border-color: var(--bd-neutral); color: var(--text-default); }
.cn-button.cn-cta--accent:hover, .cn-button.cn-cta--accent:focus, .cn-button.cn-cta--orange:hover, .cn-button.cn-cta--orange:focus, .cn-button.cn-cta--neutral:hover, .cn-button.cn-cta--neutral:focus { transform: scale(1.03); }
@media (prefers-reduced-motion: reduce) { .cn-button.cn-cta--accent:hover, .cn-button.cn-cta--accent:focus, .cn-button.cn-cta--orange:hover, .cn-button.cn-cta--orange:focus, .cn-button.cn-cta--neutral:hover, .cn-button.cn-cta--neutral:focus { transform: none; } }

/* --- Legacy Chips (auslaufend) ------------------------------------------ */
.cn-chip { display: inline-block; padding: .5rem .75rem; border-radius: 999px; text-decoration: none; font-weight: 600; }
.cn-chip--inverse { background: rgba(255, 255, 255, 0.12); color: #fff; }
.cn-chip--inverse:hover, .cn-chip--inverse:focus { background: rgba(255, 255, 255, 0.2); color: #fff; }


/* ==========================================================================
   08  FORMULARE
   ========================================================================== */

.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 */
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; }

/* 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);
}


/* ==========================================================================
   09  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: none;
}
.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; }

/* --- Link-als-Card-Wrapper (cnn2) --------------------------------------- */
/* z.B. <a class="cnn-card cnn2-link-block" href="…"> */
.cnn2-link-block { display: block; text-decoration: none; color: inherit; }

/* --- cnn3 Card — Atlas-Eintrag ------------------------------------------ */
.cnn3-c-card {
	display: flex;
	flex-direction: column;
	gap: var(--cnn3-space-4);
	background-color: var(--cnn3-color-surface-50);
	border: var(--cnn3-border-default);
	border-radius: var(--cnn3-radius-lg);
	padding: var(--cnn3-space-6);
}
.cnn3-c-card__header {
	font-size: var(--cnn3-fs-h3);
	line-height: var(--cnn3-lh-h3);
	letter-spacing: var(--cnn3-ls-h3);
	font-weight: var(--cnn3-fw-semibold);
	color: var(--cnn3-color-text-primary);
}
.cnn3-c-card__meta {
	display: flex; flex-wrap: wrap; gap: var(--cnn3-space-2);
	font-family: var(--cnn3-font-mono);
	font-size: var(--cnn3-fs-tag); line-height: var(--cnn3-lh-tag);
	color: var(--cnn3-color-text-muted);
	font-feature-settings: "ss01", "zero";
}
.cnn3-c-card__body { font-size: var(--cnn3-fs-body); line-height: var(--cnn3-lh-body); color: var(--cnn3-color-text-primary); }
.cnn3-c-card__footer {
	display: flex; flex-wrap: wrap; gap: var(--cnn3-space-2);
	padding-top: var(--cnn3-space-3);
	border-top: var(--cnn3-border-default);
	font-family: var(--cnn3-font-mono);
	font-size: var(--cnn3-fs-tag); line-height: var(--cnn3-lh-tag);
	color: var(--cnn3-color-text-muted);
	font-feature-settings: "ss01", "zero";
}

/* --- cnn3 Branche-Card -------------------------------------------------- */
.cnn3-c-branchen {
	display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--cnn3-space-5);
}
@media (max-width: 1000px) { .cnn3-c-branchen { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px)  { .cnn3-c-branchen { grid-template-columns: 1fr; } }

.cnn3-c-branche {
	display: flex; flex-direction: column; gap: var(--cnn3-space-4);
	background: var(--cnn3-color-paper);
	border: var(--cnn3-border-default);
	border-radius: var(--cnn3-radius-lg);
	padding: var(--cnn3-space-6);
	text-decoration: none; color: inherit;
	position: relative; overflow: hidden;
	transition: border-color .15s ease, transform .15s ease, box-shadow .15s ease;
}
.cnn3-c-branche::before {
	content: ""; position: absolute; left: 0; top: 0; bottom: 0;
	width: 3px; background: var(--cnn3-branche-color, var(--cnn3-color-tinte));
}
.cnn3-c-branche:hover {
	transform: translateY(-2px);
	border-color: var(--cnn3-branche-color, var(--cnn3-color-tinte));
	box-shadow: var(--cnn3-shadow-1);
}
.cnn3-c-branche__num {
	font-family: var(--cnn3-font-mono); font-size: var(--cnn3-fs-caption); color: var(--cnn3-color-text-muted);
	letter-spacing: 0.06em;
}
.cnn3-c-branche__title {
	font-size: var(--cnn3-fs-h3); line-height: var(--cnn3-lh-h3); font-weight: var(--cnn3-fw-semibold);
	color: var(--cnn3-color-text-primary);
}
.cnn3-c-branche__count {
	font-family: var(--cnn3-font-mono);
	font-size: var(--cnn3-fs-data);
	color: var(--cnn3-branche-color, var(--cnn3-color-tinte));
	display: flex; align-items: baseline; gap: var(--cnn3-space-2);
}
.cnn3-c-branche__count strong { font-size: 1.75rem; font-weight: var(--cnn3-fw-semibold); letter-spacing: -0.01em; }
.cnn3-c-branche__list {
	display: flex; flex-direction: column; gap: var(--cnn3-space-2);
	font-family: var(--cnn3-font-mono); font-size: var(--cnn3-fs-tag); color: var(--cnn3-color-text-muted);
	padding-top: var(--cnn3-space-3); border-top: var(--cnn3-border-default);
}
.cnn3-c-branche--it          { --cnn3-branche-color: var(--cnn3-color-branche-it); }
.cnn3-c-branche--engineering { --cnn3-branche-color: var(--cnn3-color-branche-engineering); }
.cnn3-c-branche--business    { --cnn3-branche-color: var(--cnn3-color-branche-business); }
.cnn3-c-branche--ai          { --cnn3-branche-color: var(--cnn3-color-branche-ai); }

/* --- cnn3 JobCard (Atlas-Eintrag) --------------------------------------- */
.cnn3-c-jobcard {
	display: grid;
	grid-template-columns: 56px 1fr auto;
	gap: var(--cnn3-space-4);
	align-items: start;
	padding: var(--cnn3-space-5);
	background: var(--cnn3-color-paper);
	border: var(--cnn3-border-default);
	border-radius: var(--cnn3-radius-lg);
	text-decoration: none; color: inherit;
	transition: border-color .15s ease, transform .15s ease, box-shadow .15s ease;
}
.cnn3-c-jobcard:hover {
	border-color: var(--cnn3-color-tinte);
	transform: translateY(-1px);
	box-shadow: var(--cnn3-shadow-1);
}
.cnn3-c-jobcard__logo {
	width: 56px; height: 56px; border-radius: var(--cnn3-radius-md);
	background: var(--cnn3-color-surface-100);
	display: grid; place-items: center;
	font-family: var(--cnn3-font-mono); font-weight: var(--cnn3-fw-semibold);
	font-size: 1.125rem; color: var(--cnn3-color-schiefer);
	letter-spacing: -0.01em;
	border: var(--cnn3-border-default);
}
.cnn3-c-jobcard__body { display: flex; flex-direction: column; gap: var(--cnn3-space-2); min-width: 0; }
.cnn3-c-jobcard__title {
	font-size: var(--cnn3-fs-h4); font-weight: var(--cnn3-fw-semibold);
	color: var(--cnn3-color-text-primary);
	letter-spacing: -0.005em;
}
.cnn3-c-jobcard__company {
	font-family: var(--cnn3-font-mono);
	font-size: var(--cnn3-fs-data);
	color: var(--cnn3-color-tinte);
}
.cnn3-c-jobcard__meta {
	display: flex; flex-wrap: wrap; gap: var(--cnn3-space-2) var(--cnn3-space-4);
	font-family: var(--cnn3-font-mono);
	font-size: var(--cnn3-fs-tag);
	color: var(--cnn3-color-text-muted);
}
.cnn3-c-jobcard__meta-item { display: inline-flex; align-items: center; gap: 6px; }
.cnn3-c-jobcard__meta-item::before {
	content: ""; width: 4px; height: 4px; border-radius: 50%; background: currentColor; opacity: .5;
}
.cnn3-c-jobcard__meta-item:first-child::before { display: none; }
.cnn3-c-jobcard__tags { display: flex; flex-wrap: wrap; gap: var(--cnn3-space-2); margin-top: var(--cnn3-space-1); }
.cnn3-c-jobcard__side {
	display: flex; flex-direction: column; align-items: end; gap: var(--cnn3-space-2);
	font-family: var(--cnn3-font-mono); font-size: var(--cnn3-fs-tag); color: var(--cnn3-color-text-muted);
	white-space: nowrap;
}
.cnn3-c-jobcard__date { color: var(--cnn3-color-text-primary); }
.cnn3-c-jobcard__new {
	background: var(--cnn3-color-success); color: var(--cnn3-color-paper);
	padding: 2px 8px; border-radius: var(--cnn3-radius-pill);
	font-size: 0.6875rem; letter-spacing: 0.04em; text-transform: uppercase;
}
@media (max-width: 640px) {
	.cnn3-c-jobcard { grid-template-columns: 48px 1fr; }
	.cnn3-c-jobcard__side { grid-column: 2; align-items: start; }
}

/* --- cnn3 Insight-Card (Editorial) -------------------------------------- */
.cnn3-c-insights { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--cnn3-space-5); }
@media (max-width: 900px) { .cnn3-c-insights { grid-template-columns: 1fr; } }
.cnn3-c-insight {
	display: flex; flex-direction: column; gap: var(--cnn3-space-3);
	background: var(--cnn3-color-paper);
	border: var(--cnn3-border-default);
	border-radius: var(--cnn3-radius-lg);
	padding: var(--cnn3-space-6);
	text-decoration: none; color: inherit;
	transition: border-color .15s ease, transform .15s ease;
}
.cnn3-c-insight:hover { border-color: var(--cnn3-color-tinte); transform: translateY(-2px); }
.cnn3-c-insight__cover {
	height: 160px; border-radius: var(--cnn3-radius-md);
	background:
					repeating-linear-gradient(135deg, var(--cnn3-color-surface-100) 0 12px, var(--cnn3-color-surface-50) 12px 24px);
	border: var(--cnn3-border-default);
	display: grid; place-items: center;
	font-family: var(--cnn3-font-mono); font-size: var(--cnn3-fs-tag); color: var(--cnn3-color-text-muted);
	letter-spacing: 0.04em;
}
.cnn3-c-insight__kicker {
	font-family: var(--cnn3-font-mono); font-size: var(--cnn3-fs-tag);
	letter-spacing: 0.06em; text-transform: uppercase;
	color: var(--cnn3-color-tinte);
}
.cnn3-c-insight__title {
	font-size: var(--cnn3-fs-h4); font-weight: var(--cnn3-fw-semibold); color: var(--cnn3-color-text-primary);
}
.cnn3-c-insight__meta { font-family: var(--cnn3-font-mono); font-size: var(--cnn3-fs-tag); color: var(--cnn3-color-text-muted); }

/* --- cnn3 Dual-CTA-Cards (Studierende / Unternehmen) ------------------- */
.cnn3-c-dual { display: grid; grid-template-columns: 1fr 1fr; gap: var(--cnn3-space-5); }
@media (max-width: 800px) { .cnn3-c-dual { grid-template-columns: 1fr; } }
.cnn3-c-dual__card {
	background: var(--cnn3-color-paper);
	border: var(--cnn3-border-default);
	border-radius: var(--cnn3-radius-lg);
	padding: var(--cnn3-space-8);
	display: flex; flex-direction: column; gap: var(--cnn3-space-5);
}
.cnn3-c-dual__card--invert {
	background: var(--cnn3-color-schiefer);
	color: var(--cnn3-color-paper);
	border-color: var(--cnn3-color-schiefer);
}
.cnn3-c-dual__card--invert h3 { color: var(--cnn3-color-paper); }
.cnn3-c-dual__card--invert p  { color: rgba(255,255,255,.78); }
.cnn3-c-dual__list { display: flex; flex-direction: column; gap: var(--cnn3-space-3); }
.cnn3-c-dual__list li {
	display: grid; grid-template-columns: 24px 1fr; gap: var(--cnn3-space-3); align-items: start;
	font-size: var(--cnn3-fs-body);
}
.cnn3-c-dual__list li::before {
	content: "→";
	font-family: var(--cnn3-font-mono);
	color: var(--cnn3-color-kupfer);
	font-weight: var(--cnn3-fw-medium);
}

/* --- Legacy Cards (auslaufend) ------------------------------------------ */
.cn-card { border: 1px solid var(--bd-neutral); border-radius: var(--radius-md); box-shadow: var(--shadow-sm); background: #fff; transition: box-shadow .2s ease, border-color .2s ease, transform .2s ease; }
.cn-card:hover { box-shadow: var(--shadow-md); border-color: var(--bd-strong); transform: translateY(-1px); }
.cn-card-section { padding: var(--space-4); }
.cn-card-divider { background: transparent; border-bottom: 1px solid var(--bd-neutral); font-weight: 600; }
details.cn-card summary { cursor: pointer; list-style: none; outline: none; }
details.cn-card summary::-webkit-details-marker { display: none; }
details.cn-card[open] .cn-card-divider { border-bottom-color: var(--bd-strong); }


/* ==========================================================================
   10  BADGES & PILLS
   ========================================================================== */

.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; }

/* --- Legacy Pills (auslaufend) ------------------------------------------ */
.cn-pill { position: absolute; left: 8px; bottom: 8px; display: inline-block; border-radius: 999px; padding: 2px 10px; font-weight: 600; text-decoration: none; }
.cn-pill--orange { background: var(--brand-orange); color: var(--text-default); border: 1px solid var(--bd-orange); }
.cn-pill--orange:hover, .cn-pill--orange:focus { background: var(--brand-orange-hover); }

/* --- cnn3 Tag (Mono-Pille mit Branchen-Varianten) ----------------------- */
.cnn3-c-tag {
	display: inline-flex;
	align-items: center;
	font-family: var(--cnn3-font-mono);
	font-size: var(--cnn3-fs-tag);
	line-height: var(--cnn3-lh-tag);
	font-weight: var(--cnn3-fw-regular);
	color: var(--cnn3-color-text-primary);
	background-color: var(--cnn3-color-surface-100);
	border: 1px solid var(--cnn3-color-border);
	padding: var(--cnn3-space-1) var(--cnn3-space-3);
	border-radius: var(--cnn3-radius-pill);
	font-feature-settings: "ss01", "zero";
	white-space: nowrap;
}
.cnn3-c-tag--it          { border-color: var(--cnn3-color-branche-it);          color: var(--cnn3-color-branche-it); }
.cnn3-c-tag--engineering { border-color: var(--cnn3-color-branche-engineering); color: var(--cnn3-color-branche-engineering); }
.cnn3-c-tag--business    { border-color: var(--cnn3-color-branche-business);    color: var(--cnn3-color-branche-business); }
.cnn3-c-tag--ai          { border-color: var(--cnn3-color-branche-ai);          color: var(--cnn3-color-branche-ai); }


/* ==========================================================================
   11  TABELLEN
   ========================================================================== */

.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);
	}
}

/* --- cnn3 Tabelle (Atlas-Daten-Pattern) --------------------------------- */
.cnn3-c-table {
	width: 100%;
	border-collapse: collapse;
	font-family: var(--cnn3-font-sans);
	font-size: var(--cnn3-fs-body);
	line-height: var(--cnn3-lh-body);
}
.cnn3-c-table__head { background-color: var(--cnn3-color-schiefer); color: var(--cnn3-color-paper); }
.cnn3-c-table thead th {
	padding: var(--cnn3-space-3) var(--cnn3-space-4);
	text-align: left;
	font-family: var(--cnn3-font-mono);
	font-size: var(--cnn3-fs-tag); line-height: var(--cnn3-lh-tag);
	font-weight: var(--cnn3-fw-medium);
	letter-spacing: var(--cnn3-ls-caption);
	text-transform: uppercase;
	color: var(--cnn3-color-paper);
	background-color: var(--cnn3-color-schiefer);
	font-feature-settings: "ss01", "zero";
}
.cnn3-c-table tbody td {
	padding: var(--cnn3-space-3) var(--cnn3-space-4);
	border-bottom: var(--cnn3-border-default);
	color: var(--cnn3-color-text-primary);
	vertical-align: top;
}
.cnn3-c-table tbody tr:nth-child(even) td { background-color: var(--cnn3-color-surface-50); }
.cnn3-c-table tbody tr:last-child td      { border-bottom: none; }


/* ==========================================================================
   12  NAVIGATION — Breadcrumb / Pagination
   ========================================================================== */

.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; }

.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;
}

/* --- cnn3 Hauptnavigation ----------------------------------------------- */
.cnn3-c-nav { display: flex; align-items: center; gap: var(--cnn3-space-7); }
.cnn3-c-nav a {
	text-decoration: none;
	color: var(--cnn3-color-text-primary);
	font-size: var(--cnn3-fs-body-small);
	font-weight: var(--cnn3-fw-medium);
	padding: var(--cnn3-space-2) 0;
	border-bottom: 2px solid transparent;
	transition: border-color .15s ease, color .15s ease;
}
.cnn3-c-nav a:hover         { color: var(--cnn3-color-tinte); border-bottom-color: var(--cnn3-color-tinte); }
.cnn3-c-nav a.is-active     { color: var(--cnn3-color-tinte); border-bottom-color: var(--cnn3-color-kupfer); }


/* ==========================================================================
   13  ICONS
   ========================================================================== */

.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; }


/* ==========================================================================
   14  MEDIA — Bilder, Aspect-Ratios
   --------------------------------------------------------------------------
   Hinweis: globaler Bild-Reset (`img, svg, video, canvas`) liegt in Abschnitt 03.
   ========================================================================== */

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

/* 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; }

/* --- Media-Helper (cnn2) ------------------------------------------------ */
/* abgerundete Ecken + Clipping für .cnn-ratio Wrapper */
.cnn2-media-rounded { border-radius: var(--cnn-radius-md); overflow: hidden; }


/* ==========================================================================
   15  SPEZIALKOMPONENTEN — Content-Box, Brandbar, Calendar, Footer-Note
   --------------------------------------------------------------------------
   Komplett Legacy (auslaufend) — bisher keine cnn- Pendants.
   ========================================================================== */

/* --- Content-Box --------------------------------------------------------- */
.cn-content-box { background-color: #003d70; border-radius: 25px; color: #fff; padding: 2rem; }
@media all and (min-width: 768px)  { .cn-content-box { padding: 3rem; } }
@media all and (min-width: 1024px) { .cn-content-box { padding: 4rem; } }
.cn-content-box a { color: inherit; }
.cn-content-box.cn-content-box--secondary { background-color: #ff862e; color: #000806; }

/* --- Brandbar ------------------------------------------------------------ */
.cn-brandbar { border-radius: var(--radius-lg); padding: var(--space-3) var(--space-4); }

/* --- Calendar ------------------------------------------------------------ */
.cn-calendar { border: 1px solid var(--bd-neutral); border-radius: var(--radius-lg); padding: var(--space-3); }
.cn-calendar__weekdays { display: grid; grid-template-columns: repeat(7, 1fr); gap: var(--space-2); margin-bottom: var(--space-1); color: #6b7280; font-weight: 600; text-align: center; }
.cn-calendar__grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: var(--space-2); }
.cn-calendar__cell { position: relative; background: #fff; border: 1px solid var(--bd-neutral); border-radius: 12px; min-height: 68px; padding: 8px; }
.cn-calendar__cell--muted { border-style: dashed; opacity: .5; }
.cn-calendar__cell--event { background: #fff7ed; border: 2px solid var(--bd-orange); }
.cn-calendar__day { font-size: 14px; color: #6b7280; }

/* --- Footer-Note --------------------------------------------------------- */
.cn-footer-note { border-top: 1px solid var(--bd-neutral); color: #6b7280; font-size: 14px; padding: var(--space-3) var(--space-4); margin-top: var(--space-5); }

/* --- Footer-Cap (cnn2) --------------------------------------------------- */
/* weisser Abschluss-Streifen mit dunkler Top-Linie ("Zurück zum Seitenanfang") */
.cnn2-footer-cap { background-color: #fff; border-top: 1px solid #023E73; }

/* --- Logo inline an Text-Baseline (cnn2) -------------------------------- */
/* leichte vertikale Korrektur für SVG-Logos in Headlines */
.cnn2-logo-baseline { transform: translateY(3px); vertical-align: baseline; }

/* --- cnn3 Topbar -------------------------------------------------------- */
.cnn3-c-topbar {
	background: var(--cnn3-color-schiefer);
	color: var(--cnn3-color-paper);
	font-size: var(--cnn3-fs-caption);
	letter-spacing: var(--cnn3-ls-caption);
	text-transform: uppercase;
}
.cnn3-c-topbar__inner {
	display: flex; align-items: center; justify-content: space-between;
	height: 32px;
	font-family: var(--cnn3-font-mono);
	font-feature-settings: "ss01", "zero";
}
.cnn3-c-topbar a       { color: var(--cnn3-color-paper); text-decoration: none; opacity: 0.85; }
.cnn3-c-topbar a:hover { opacity: 1; text-decoration: underline; }
.cnn3-c-topbar__group  { display: flex; align-items: center; gap: var(--cnn3-space-5); }
.cnn3-c-topbar__dot    { width: 6px; height: 6px; border-radius: 50%; background: var(--cnn3-color-cta-bg); display: inline-block; }

/* --- cnn3 Header / Logo ------------------------------------------------- */
.cnn3-c-header {
	border-bottom: var(--cnn3-border-default);
	background: var(--cnn3-color-paper);
	position: sticky; top: 0; z-index: 50;
}
.cnn3-c-header__inner {
	display: flex; align-items: center; justify-content: space-between;
	height: 72px;
	gap: var(--cnn3-space-6);
}
.cnn3-c-header__actions { display: flex; align-items: center; gap: var(--cnn3-space-3); }
.cnn3-c-header__login {
	color: var(--cnn3-color-text-primary);
	text-decoration: none;
	font-size: var(--cnn3-fs-body-small);
	font-weight: var(--cnn3-fw-medium);
}
.cnn3-c-header__login:hover { color: var(--cnn3-color-tinte); }

.cnn3-c-logo {
	display: inline-flex; align-items: baseline; gap: 2px;
	font-family: var(--cnn3-font-sans);
	font-weight: var(--cnn3-fw-semibold);
	font-size: 1.375rem;
	letter-spacing: -0.02em;
	color: var(--cnn3-color-text-primary);
}
.cnn3-c-logo__dot {
	width: 10px; height: 10px; border-radius: 50%;
	background: var(--cnn3-color-kupfer);
	display: inline-block; margin-right: 8px;
	transform: translateY(-2px);
}
.cnn3-c-logo__suffix { color: var(--cnn3-color-text-muted); font-weight: var(--cnn3-fw-regular); }

/* --- cnn3 Messe-Block --------------------------------------------------- */
.cnn3-c-messe {
	display: grid; grid-template-columns: 0.9fr 1.1fr; gap: var(--cnn3-space-9);
	align-items: start;
}
@media (max-width: 900px) { .cnn3-c-messe { grid-template-columns: 1fr; } }

.cnn3-c-messe__hero {
	background: var(--cnn3-color-tinte); color: var(--cnn3-color-paper);
	border-radius: var(--cnn3-radius-lg);
	padding: var(--cnn3-space-8);
	position: relative; overflow: hidden;
	display: flex; flex-direction: column; gap: var(--cnn3-space-5);
}
.cnn3-c-messe__hero::after {
	content: ""; position: absolute; right: -80px; top: -80px;
	width: 320px; height: 320px; border-radius: 50%;
	background: color-mix(in oklab, var(--cnn3-color-kupfer) 70%, transparent);
	filter: blur(40px); opacity: .35;
	pointer-events: none;
}
.cnn3-c-messe__date {
	font-family: var(--cnn3-font-mono); font-size: var(--cnn3-fs-data);
	letter-spacing: 0.04em;
	display: flex; align-items: center; gap: var(--cnn3-space-2);
	color: color-mix(in oklab, white 85%, transparent);
}
.cnn3-c-messe__date::before {
	content: ""; width: 8px; height: 8px; border-radius: 50%;
	background: var(--cnn3-color-kupfer);
}
.cnn3-c-messe__name {
	font-family: var(--cnn3-font-sans);
	font-size: clamp(2rem, 1.4rem + 2.5vw, 3rem);
	line-height: 1.05; letter-spacing: -0.02em;
	font-weight: var(--cnn3-fw-semibold);
}
.cnn3-c-messe__locale { color: color-mix(in oklab, white 75%, transparent); }
.cnn3-c-messe__stats  { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--cnn3-space-4); padding-top: var(--cnn3-space-4); border-top: 1px solid rgba(255,255,255,.18); }
.cnn3-c-messe__stat   { display: flex; flex-direction: column; gap: 2px; }
.cnn3-c-messe__stat strong { font-size: 1.75rem; font-weight: var(--cnn3-fw-semibold); letter-spacing: -0.01em; }
.cnn3-c-messe__stat span   { font-family: var(--cnn3-font-mono); font-size: var(--cnn3-fs-tag); letter-spacing: 0.04em; text-transform: uppercase; color: color-mix(in oklab, white 70%, transparent); }
.cnn3-c-messe__cta { display: flex; gap: var(--cnn3-space-3); flex-wrap: wrap; margin-top: var(--cnn3-space-2); }
.cnn3-c-messe__cta .cnn3-c-button--secondary { background: transparent; color: var(--cnn3-color-paper); border-color: rgba(255,255,255,.4); }
.cnn3-c-messe__cta .cnn3-c-button--secondary:hover { background: rgba(255,255,255,.08); }

/* --- cnn3 Programm-Agenda ----------------------------------------------- */
.cnn3-c-program { display: flex; flex-direction: column; gap: 0; }
.cnn3-c-program__day {
	font-family: var(--cnn3-font-mono); font-size: var(--cnn3-fs-tag);
	letter-spacing: 0.06em; text-transform: uppercase;
	color: var(--cnn3-color-text-muted);
	padding: var(--cnn3-space-3) 0;
	border-bottom: var(--cnn3-border-default);
}
.cnn3-c-program__item {
	display: grid; grid-template-columns: 96px 1fr auto; gap: var(--cnn3-space-4);
	align-items: start;
	padding: var(--cnn3-space-4) 0;
	border-bottom: var(--cnn3-border-default);
}
.cnn3-c-program__item:last-child { border-bottom: 0; }
.cnn3-c-program__time {
	font-family: var(--cnn3-font-mono);
	font-size: var(--cnn3-fs-data);
	color: var(--cnn3-color-text-primary);
	letter-spacing: 0.02em;
}
.cnn3-c-program__title   { font-size: var(--cnn3-fs-body); font-weight: var(--cnn3-fw-medium); }
.cnn3-c-program__speaker { font-family: var(--cnn3-font-mono); font-size: var(--cnn3-fs-tag); color: var(--cnn3-color-text-muted); margin-top: 2px; }
.cnn3-c-program__type {
	font-family: var(--cnn3-font-mono);
	font-size: var(--cnn3-fs-tag);
	color: var(--cnn3-color-text-muted);
	letter-spacing: 0.02em;
}
.cnn3-c-program__type::before {
	content: ""; display: inline-block; width: 6px; height: 6px;
	margin-right: 8px; border-radius: 2px;
	background: var(--cnn3-type-color, var(--cnn3-color-tinte));
	transform: translateY(-1px);
}
.cnn3-c-program__type--keynote    { --cnn3-type-color: var(--cnn3-color-kupfer); }
.cnn3-c-program__type--workshop   { --cnn3-type-color: var(--cnn3-color-branche-it); }
.cnn3-c-program__type--panel      { --cnn3-type-color: var(--cnn3-color-branche-ai); }
.cnn3-c-program__type--networking { --cnn3-type-color: var(--cnn3-color-branche-business); }

/* --- cnn3 Process (4-Schritt-Zeitleiste) -------------------------------- */
.cnn3-c-process { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--cnn3-space-5); }
@media (max-width: 900px) { .cnn3-c-process { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .cnn3-c-process { grid-template-columns: 1fr; } }
.cnn3-c-step {
	display: flex; flex-direction: column; gap: var(--cnn3-space-3);
	padding-top: var(--cnn3-space-5);
	border-top: 2px solid var(--cnn3-color-schiefer);
	position: relative;
}
.cnn3-c-step::before {
	content: ""; position: absolute; top: -7px; left: 0;
	width: 12px; height: 12px; border-radius: 50%; background: var(--cnn3-color-kupfer);
}
.cnn3-c-step__num {
	font-family: var(--cnn3-font-mono); font-size: var(--cnn3-fs-data);
	color: var(--cnn3-color-text-muted); letter-spacing: 0.04em;
}
.cnn3-c-step__title { font-size: var(--cnn3-fs-h4); font-weight: var(--cnn3-fw-medium); color: var(--cnn3-color-text-primary); }
.cnn3-c-step__body  { font-size: var(--cnn3-fs-body-small); color: var(--cnn3-color-text-muted); }

/* --- cnn3 Stats-Strip --------------------------------------------------- */
.cnn3-c-stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--cnn3-space-7); }
@media (max-width: 800px) { .cnn3-c-stats { grid-template-columns: repeat(2, 1fr); gap: var(--cnn3-space-5); } }
.cnn3-c-stat {
	display: flex; flex-direction: column; gap: var(--cnn3-space-2);
	padding-right: var(--cnn3-space-5);
	border-right: var(--cnn3-border-default);
}
.cnn3-c-stat:last-child { border-right: 0; }
.cnn3-c-stat__num {
	font-family: var(--cnn3-font-sans); font-weight: var(--cnn3-fw-semibold);
	font-size: clamp(2.5rem, 1.6rem + 2.5vw, 3.5rem);
	letter-spacing: -0.02em;
	color: var(--cnn3-color-text-primary);
	line-height: 1;
}
.cnn3-c-section--dark .cnn3-c-stat        { border-right-color: rgba(255,255,255,.18); }
.cnn3-c-section--dark .cnn3-c-stat__num   { color: var(--cnn3-color-paper); }
.cnn3-c-stat__label {
	font-family: var(--cnn3-font-mono); font-size: var(--cnn3-fs-tag);
	letter-spacing: 0.04em; text-transform: uppercase;
	color: var(--cnn3-color-text-muted);
}
.cnn3-c-section--dark .cnn3-c-stat__label { color: rgba(255,255,255,.65); }
.cnn3-c-stat__sub { font-size: var(--cnn3-fs-body-small); color: var(--cnn3-color-text-muted); }
.cnn3-c-section--dark .cnn3-c-stat__sub   { color: rgba(255,255,255,.65); }

/* --- cnn3 Logo-Strip ---------------------------------------------------- */
.cnn3-c-logos {
	display: grid; grid-template-columns: repeat(6, 1fr); gap: var(--cnn3-space-5);
	align-items: center;
}
@media (max-width: 900px) { .cnn3-c-logos { grid-template-columns: repeat(3, 1fr); } }
.cnn3-c-logo-tile {
	display: grid; place-items: center;
	height: 80px;
	border: var(--cnn3-border-default); border-radius: var(--cnn3-radius-md);
	background: var(--cnn3-color-paper);
	font-family: var(--cnn3-font-mono); font-weight: var(--cnn3-fw-medium);
	color: var(--cnn3-color-text-muted);
	letter-spacing: 0.04em;
	transition: color .15s ease, border-color .15s ease;
}
.cnn3-c-logo-tile:hover { color: var(--cnn3-color-tinte); border-color: var(--cnn3-color-tinte); }

/* --- cnn3 CTA-Banner ---------------------------------------------------- */
.cnn3-c-cta {
	background: var(--cnn3-color-schiefer); color: var(--cnn3-color-paper);
	border-radius: var(--cnn3-radius-lg);
	padding: var(--cnn3-space-9);
	display: grid; grid-template-columns: 1.4fr 1fr; gap: var(--cnn3-space-7);
	align-items: center;
	position: relative; overflow: hidden;
}
.cnn3-c-cta::after {
	content: ""; position: absolute; right: -100px; bottom: -100px;
	width: 380px; height: 380px;
	background: radial-gradient(circle, var(--cnn3-color-kupfer), transparent 60%);
	opacity: .25; pointer-events: none;
}
@media (max-width: 800px) { .cnn3-c-cta { grid-template-columns: 1fr; padding: var(--cnn3-space-7); } }
.cnn3-c-cta h2 { color: var(--cnn3-color-paper); }
.cnn3-c-cta p  { color: rgba(255,255,255,.78); margin-top: var(--cnn3-space-3); }
.cnn3-c-cta__actions { display: flex; gap: var(--cnn3-space-3); flex-wrap: wrap; justify-self: end; position: relative; z-index: 1; }
@media (max-width: 800px) { .cnn3-c-cta__actions { justify-self: start; } }
.cnn3-c-cta__actions .cnn3-c-button--secondary {
	background: transparent; color: var(--cnn3-color-paper); border-color: rgba(255,255,255,.4);
}
.cnn3-c-cta__actions .cnn3-c-button--secondary:hover { background: rgba(255,255,255,.08); }

/* --- cnn3 Atlas (Sidebar-Filter + Job/Company-Browser) ------------------ */
.cnn3-c-atlas { display: grid; grid-template-columns: 260px 1fr; gap: var(--cnn3-space-8); }
@media (max-width: 900px) { .cnn3-c-atlas { grid-template-columns: 1fr; } }
.cnn3-c-atlas__sidebar {
	display: flex; flex-direction: column; gap: var(--cnn3-space-6);
	position: sticky; top: 88px; align-self: start;
}
.cnn3-c-atlas__filter-group h4 {
	font-family: var(--cnn3-font-mono); font-size: var(--cnn3-fs-tag);
	letter-spacing: 0.06em; text-transform: uppercase;
	color: var(--cnn3-color-text-muted);
	font-weight: var(--cnn3-fw-medium);
	margin-bottom: var(--cnn3-space-3);
	padding-bottom: var(--cnn3-space-2);
	border-bottom: var(--cnn3-border-default);
}
.cnn3-c-atlas__filter-list { display: flex; flex-direction: column; gap: 2px; }
.cnn3-c-atlas__filter {
	display: flex; align-items: center; justify-content: space-between;
	padding: var(--cnn3-space-2) var(--cnn3-space-3);
	border-radius: var(--cnn3-radius-sm);
	font-size: var(--cnn3-fs-body-small);
	color: var(--cnn3-color-text-primary);
	cursor: pointer;
	background: transparent;
	border: 0; text-align: left;
	font-family: var(--cnn3-font-sans);
	transition: background-color .12s ease, color .12s ease;
}
.cnn3-c-atlas__filter:hover { background: var(--cnn3-color-surface-50); }
.cnn3-c-atlas__filter.is-active {
	background: var(--cnn3-color-tinte); color: var(--cnn3-color-paper);
}
.cnn3-c-atlas__filter.is-active .cnn3-c-atlas__count { color: rgba(255,255,255,.85); }
.cnn3-c-atlas__count {
	font-family: var(--cnn3-font-mono); font-size: var(--cnn3-fs-tag); color: var(--cnn3-color-text-muted);
}

.cnn3-c-atlas__main { display: flex; flex-direction: column; gap: var(--cnn3-space-5); }
.cnn3-c-atlas__toolbar { display: flex; align-items: center; gap: var(--cnn3-space-3); flex-wrap: wrap; }
.cnn3-c-atlas__search {
	flex: 1; min-width: 260px;
	display: flex; align-items: center; gap: var(--cnn3-space-2);
	border: var(--cnn3-border-default); border-radius: var(--cnn3-radius-md);
	padding: var(--cnn3-space-2) var(--cnn3-space-3); background: var(--cnn3-color-paper);
}
.cnn3-c-atlas__search:focus-within { border-color: var(--cnn3-color-tinte); box-shadow: var(--cnn3-shadow-focus); }
.cnn3-c-atlas__search input { border: 0; outline: 0; background: transparent; flex: 1; font-size: var(--cnn3-fs-body); }
.cnn3-c-atlas__search-icon { color: var(--cnn3-color-text-muted); font-family: var(--cnn3-font-mono); font-size: var(--cnn3-fs-data); }
.cnn3-c-atlas__sort {
	font-family: var(--cnn3-font-mono); font-size: var(--cnn3-fs-tag); color: var(--cnn3-color-text-muted);
	display: flex; align-items: center; gap: var(--cnn3-space-2);
}
.cnn3-c-atlas__sort select {
	border: var(--cnn3-border-default); border-radius: var(--cnn3-radius-sm);
	padding: var(--cnn3-space-2) var(--cnn3-space-3); background: var(--cnn3-color-paper);
	font-family: var(--cnn3-font-mono); font-size: var(--cnn3-fs-tag);
}
.cnn3-c-atlas__count-line {
	font-family: var(--cnn3-font-mono); font-size: var(--cnn3-fs-tag); color: var(--cnn3-color-text-muted);
	padding-bottom: var(--cnn3-space-2);
	border-bottom: var(--cnn3-border-default);
}
.cnn3-c-atlas__list { display: flex; flex-direction: column; gap: var(--cnn3-space-3); }

/* --- cnn3 Footer -------------------------------------------------------- */
.cnn3-c-footer {
	background: var(--cnn3-color-paper);
	border-top: var(--cnn3-border-default);
	padding: var(--cnn3-space-9) 0 var(--cnn3-space-6);
}
.cnn3-c-footer__grid {
	display: grid; grid-template-columns: 1.4fr repeat(4, 1fr); gap: var(--cnn3-space-7);
}
@media (max-width: 900px) { .cnn3-c-footer__grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px) { .cnn3-c-footer__grid { grid-template-columns: 1fr; } }
.cnn3-c-footer h4 {
	font-family: var(--cnn3-font-mono); font-size: var(--cnn3-fs-tag);
	letter-spacing: 0.06em; text-transform: uppercase;
	color: var(--cnn3-color-text-muted);
	font-weight: var(--cnn3-fw-medium);
	margin-bottom: var(--cnn3-space-4);
}
.cnn3-c-footer__col ul { display: flex; flex-direction: column; gap: var(--cnn3-space-2); }
.cnn3-c-footer__col a {
	text-decoration: none; color: var(--cnn3-color-text-primary);
	font-size: var(--cnn3-fs-body-small);
	transition: color .12s ease;
}
.cnn3-c-footer__col a:hover { color: var(--cnn3-color-tinte); text-decoration: underline; }
.cnn3-c-footer__about { display: flex; flex-direction: column; gap: var(--cnn3-space-4); }
.cnn3-c-footer__about p { color: var(--cnn3-color-text-muted); font-size: var(--cnn3-fs-body-small); max-width: 36ch; }
.cnn3-c-footer__bottom {
	display: flex; justify-content: space-between; align-items: center;
	gap: var(--cnn3-space-4); flex-wrap: wrap;
	padding-top: var(--cnn3-space-6); margin-top: var(--cnn3-space-7);
	border-top: var(--cnn3-border-default);
	font-family: var(--cnn3-font-mono); font-size: var(--cnn3-fs-tag); color: var(--cnn3-color-text-muted);
}
.cnn3-c-footer__bottom a       { text-decoration: none; color: var(--cnn3-color-text-muted); }
.cnn3-c-footer__bottom a:hover { color: var(--cnn3-color-tinte); }


/* ==========================================================================
   16  SURFACES & BACKGROUNDS
   ========================================================================== */

/* bewusst auch außerhalb HC verfügbar */
.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; }

/* --- Legacy (auslaufend) ------------------------------------------------- */
.cn-bg--brand-orange { background: var(--brand-orange) !important; color: var(--text-default) !important; }
.cn-bg--brand-blue   { background: var(--brand-blue)   !important; color: #fff !important; }
.cn-bg--black        { background: var(--brand-black)  !important; color: #fff !important; }
.cn-bg--white        { background: #fff                !important; color: var(--text-default) !important; }


/* ==========================================================================
   17  UTILITIES — Farbe / Text
   ========================================================================== */

.cnn-text       { color: var(--cnn-text); }
.cnn-text-muted { color: var(--cnn-text-muted); }

/* --- cnn3 ---------------------------------------------------------------- */
.cnn3-u-text-muted { color: var(--cnn3-color-text-muted); }

/* --- Legacy (auslaufend) ------------------------------------------------- */
.cn-text--black { color: var(--brand-black) !important; }
.cn-text--blue  { color: var(--brand-blue)  !important; }
.cn-text--white { color: #fff               !important; }


/* ==========================================================================
   18  UTILITIES — Borders / Radii / Shadows
   ========================================================================== */

.cnn-border-strong { border-color: var(--cnn-border-ui) !important; }

/* --- Divider (cnn2) ----------------------------------------------------- */
/* Trennlinie auf dunklem Hintergrund (z.B. Footer, blauer Bereich) */
.cnn2-divider-on-dark { border-bottom: 1px solid rgba(255,255,255,.5); }

/* --- Legacy (auslaufend) ------------------------------------------------- */
.cn-border          { border: 1px solid var(--bd-neutral); }
.cn-border-0        { border: 0 !important; }
.cn-border-strong   { border-color: var(--bd-strong)   !important; }
.cn-border-on-dark  { border-color: var(--bd-on-dark)  !important; }
.cn-border--orange  { border-color: var(--bd-orange)   !important; }
.cn-border--blue    { border-color: var(--bd-blue)     !important; }
.cn-border--black   { border-color: var(--bd-black)    !important; }

.cn-rounded-sm { border-radius: var(--radius-sm); }
.cn-rounded-md { border-radius: var(--radius-md); }
.cn-rounded-lg { border-radius: var(--radius-lg); }

.cn-shadow-sm { box-shadow: var(--shadow-sm); }
.cn-shadow-md { box-shadow: var(--shadow-md); }


/* ==========================================================================
   19  UTILITIES — Spacing (margin, padding)
   ========================================================================== */

.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); }

/* --- Spacing (cnn2) ----------------------------------------------------- */
/* Reset für Browser-Default-Margins (p, li, h*) — !important für sicheren Inline-Style-Ersatz */
.cnn2-m-0  { margin: 0 !important; }
.cnn2-mt-3 { margin-top: var(--cnn-space-3); }

/* --- Spacing-Utilities (cnn3) ------------------------------------------ */
.cnn3-u-mt-3  { margin-top: var(--cnn3-space-3); }
.cnn3-u-mt-6  { margin-top: var(--cnn3-space-6); }
.cnn3-u-gap-3 { gap: var(--cnn3-space-3); }

/* --- Legacy (auslaufend) ------------------------------------------------- */
.cn-mt-0 { margin-top:    0              !important; }
.cn-mb-0 { margin-bottom: 0              !important; }
.cn-mt-1 { margin-top:    var(--space-1) !important; }
.cn-mb-1 { margin-bottom: var(--space-1) !important; }
.cn-mt-2 { margin-top:    var(--space-2) !important; }
.cn-mb-2 { margin-bottom: var(--space-2) !important; }
.cn-mt-3 { margin-top:    var(--space-3) !important; }
.cn-mb-3 { margin-bottom: var(--space-3) !important; }
.cn-mt-4 { margin-top:    var(--space-4) !important; }
.cn-mb-4 { margin-bottom: var(--space-4) !important; }

.cn-p-0  { padding: 0              !important; }
.cn-p-2  { padding: var(--space-2) !important; }
.cn-p-3  { padding: var(--space-3) !important; }
.cn-px-3 { padding-left: var(--space-3) !important; padding-right: var(--space-3) !important; }
.cn-py-4 { padding-top:  var(--space-4) !important; padding-bottom: var(--space-4) !important; }


/* ==========================================================================
   20  UTILITIES — Display / Alignment / Visibility
   ========================================================================== */

.cnn-center { margin-inline: auto; }
.cnn-hide   { display: none !important; }

/* --- cnn3 ---------------------------------------------------------------- */
.cnn3-u-flex   { display: flex; }
.cnn3-u-hidden { display: none !important; }

/* --- Legacy (auslaufend) ------------------------------------------------- */
.cn-text-center { text-align: center; }
.cn-text-right  { text-align: right; }
.cn-flex-split  { display: flex; align-items: baseline; justify-content: space-between; flex-wrap: wrap; gap: var(--space-2); }


/* ==========================================================================
   21  UTILITIES — Overflow / Text-Wrapping
   ========================================================================== */

.cnn-wrap     { overflow-wrap: anywhere; word-break: break-word; }
.cnn-nowrap   { white-space: nowrap; }
.cnn-ellipsis { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }


/* ==========================================================================
   22  ACCESSIBILITY — Skip-Link, Visually Hidden
   ========================================================================== */

.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;
}

/* 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;
}

/* --- Legacy (auslaufend) ------------------------------------------------- */
.cn-visually-hidden { position: absolute !important; width: 1px; height: 1px; overflow: hidden; clip: rect(1px, 1px, 1px, 1px); white-space: nowrap; }
.cn-skip-link { position: absolute; left: -999px; top: auto; width: 1px; height: 1px; overflow: hidden; }
.cn-skip-link:focus { left: 1rem; top: 1rem; width: auto; height: auto; padding: .5rem .75rem; background: #fff; border: 2px solid var(--brand-blue-hover); border-radius: var(--radius-sm); z-index: 1000; }


/* ==========================================================================
   23  RESPONSIVE UTILITIES — Breakpoint-Token & -Klassen
   ========================================================================== */

/* 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; } }

/* 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; }
}


/* ==========================================================================
   24  FEATURE QUERIES — @supports color-mix (Progressive Enhancement)
   --------------------------------------------------------------------------
   Verfeinerungen für Browser mit color-mix(). Muss NACH den Basis-Regeln
   stehen, weil sie diese überschreibt.
   ========================================================================== */

@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); }
}


/* ==========================================================================
   25  GLOBALE MEDIA-QUERIES — reduced-motion, contrast, print
   --------------------------------------------------------------------------
   Globale Verhaltens-Anpassungen. Müssen NACH allen Basis-Regeln stehen,
   damit sie als Override greifen.
   ========================================================================== */

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

	/* cnn3 — feinere Variante (kurze Dauer statt komplett aus) */
	.cnn3-scope, :where(.cnn3-scope) *,
	:where(.cnn3-scope) *::before, :where(.cnn3-scope) *::after {
		animation-duration: 0.01ms;
		animation-iteration-count: 1;
		transition-duration: 0.01ms;
		scroll-behavior: auto;
	}
}

/* cnn3 — responsive Token-Overrides + Komponenten-Padding (Mobile) */
@media (max-width: 768px) {
	:root {
		--cnn3-fs-h3:         1.25rem;    /* 24 -> 20 */
		--cnn3-fs-h4:         1.125rem;   /* 20 -> 18 */
		--cnn3-fs-body-large: 1.0625rem;  /* 18 -> 17 */
		--cnn3-fs-tag:        0.75rem;    /* 13 -> 12 */
		--cnn3-fs-data:       0.875rem;   /* 15 -> 14 */
	}
	.cnn3-c-hero { padding: var(--cnn3-space-7) var(--cnn3-space-4); }
	.cnn3-c-card { padding: var(--cnn3-space-5); }
	.cnn3-c-table thead th,
	.cnn3-c-table tbody td { padding: var(--cnn3-space-2) var(--cnn3-space-3); }
}

/* 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; width:100%; }
	.cnn-card { box-shadow:none; border-color:#000; }
}

/* Legacy global reduced-motion (auslaufend) ------------------------------ */
@media (prefers-reduced-motion: reduce) { * { animation: none !important; transition: none !important; scroll-behavior: auto !important; } }
