/*
Theme Name: Cannasseure Berlins
Theme URI: http://localhost:8881/
Author: Cannasseure Berlins
Author URI: http://localhost:8881/
Description: Custom theme for Cannasseure Berlins. Dark editorial brand theme.
Version: 0.2.0
Requires at least: 6.0
Tested up to: 7.0
Requires PHP: 7.4
License: GPL-2.0-or-later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: cannasseure-berlins-theme
Tags: custom
*/

/* =========================================================================
   1. Design tokens — palette, type, layout
   Source: standalone/Startseite.html (Claude Design handoff)
   ========================================================================= */
:root {
	/* Palette */
	--cb-ink:             #14130f;
	--cb-charcoal:        #2a261f;
	--cb-bone:            #f3efe5;
	--cb-cream:           #ebe5d5;
	--cb-paper:           #faf7f0;
	--cb-forest:          #1f3a2c;
	--cb-moss:            #3a5a3d;
	--cb-spring:          #3E7352;
	--cb-sage:            #8a9a82;
	--cb-brass:           #b08a4a;

	--cb-rule:            rgba(20,19,15,0.18);
	--cb-rule-soft:       rgba(20,19,15,0.08);
	--cb-rule-dark:       rgba(243,239,229,0.20);
	--cb-rule-dark-soft:  rgba(243,239,229,0.10);
	--cb-muted:           rgba(243,239,229,0.65);

	/* Type */
	--serif:              'Cormorant Garamond', 'Cormorant SC', 'Times New Roman', serif;
	--serif-caps:         'Cormorant SC', 'Cormorant Garamond', serif;
	--sans:               'Inter', system-ui, sans-serif;
	--mono:               'JetBrains Mono', ui-monospace, monospace;

	/* Layout */
	--cb-header-height:   72px;
	--cb-pad-x:           72px;            /* desktop horizontal page padding */
}

/* =========================================================================
   2. Base reset & typography
   ========================================================================= */
*,
*::before,
*::after {
	box-sizing: border-box;
}

html,
body {
	margin: 0;
	padding: 0;
}

body {
	background: var(--cb-ink);
	color: var(--cb-bone);
	font-family: var(--sans);
	font-size: 16px;
	line-height: 1.55;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

img {
	max-width: 100%;
	height: auto;
	display: block;
}

a {
	color: inherit;
	text-decoration: none;
}

a:hover,
a:focus {
	color: var(--cb-bone);
}

ul {
	margin: 0;
	padding: 0;
	list-style: none;
}

p {
	margin: 0;
}

button {
	font: inherit;
	border: 0;
	background: transparent;
	color: inherit;
	cursor: pointer;
}

.site-main {
	display: block;
}

body.has-mobile-nav-open {
	overflow: hidden;
}

/* Reusable eyebrow label — small mono caps, spring-green accent. */
.cb-eyebrow {
	font-family: var(--mono);
	font-size: 11px;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--cb-muted);
}

.cb-eyebrow--spring {
	color: var(--cb-spring);
}

/* =========================================================================
   3. Site header — NavBar (dark, sticky)
   ========================================================================= */
.site-header {
	position: sticky;
	top: 0;
	z-index: 100;
	background: var(--cb-ink);
	border-bottom: 1px solid var(--cb-rule-dark-soft);
	transition: box-shadow 0.2s ease, background 0.2s ease;
}

.site-header.is-scrolled {
	box-shadow: 0 6px 28px rgba(0, 0, 0, 0.45);
}

.site-header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 24px;
	padding: 24px var(--cb-pad-x);
	min-height: var(--cb-header-height);
}

/* --- 3.1 Brand --- */
.site-header__brand {
	display: inline-flex;
	align-items: center;
	flex: 0 0 auto;
}

.site-header__logo {
	height: 28px;
	width: auto;
	display: block;
}

/* --- 3.2 Nav + CTA --- */
.site-header__nav {
	display: flex;
	align-items: center;
	gap: 40px;
}

.primary-menu {
	display: flex;
	gap: 40px;
	align-items: center;
	font-family: var(--mono);
	font-size: 11px;
	letter-spacing: 0.18em;
	text-transform: uppercase;
}

.primary-menu > li > a {
	color: var(--cb-muted);
	padding-bottom: 4px;
	border-bottom: 1px solid transparent;
	transition: color 0.15s ease, border-color 0.15s ease;
}

.primary-menu > li > a:hover,
.primary-menu > li > a:focus {
	color: var(--cb-bone);
}

.primary-menu > li.is-active > a,
.primary-menu > li.current-menu-item > a {
	color: var(--cb-bone);
	border-bottom-color: var(--cb-spring);
}

/* --- 3.3 CTA pill "AUF DIE LISTE" --- */
.cb-cta-btn {
	display: inline-block;
	background: var(--cb-bone);
	color: var(--cb-ink);
	font-family: var(--mono);
	font-size: 10px;
	letter-spacing: 0.22em;
	padding: 11px 20px;
	margin-left: 12px;
	transition: background 0.15s ease, color 0.15s ease, transform 0.05s ease;
}

.cb-cta-btn:hover,
.cb-cta-btn:focus {
	background: var(--cb-spring);
	color: var(--cb-bone);
}

.cb-cta-btn:active {
	transform: translateY(1px);
}

/* --- 3.4 Hamburger (mobile only) --- */
.site-header__toggle {
	display: none;
	flex-direction: column;
	justify-content: center;
	gap: 5px;
	width: 40px;
	height: 40px;
	padding: 8px;
	border: 1px solid var(--cb-rule-dark);
	border-radius: 2px;
}

.site-header__toggle-bar {
	display: block;
	height: 1.5px;
	background: var(--cb-bone);
	transition: transform 0.2s ease, opacity 0.2s ease;
}

.site-header.is-open .site-header__toggle-bar:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.site-header.is-open .site-header__toggle-bar:nth-child(2) { opacity: 0; }
.site-header.is-open .site-header__toggle-bar:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* =========================================================================
   4. Header — responsive (drawer)
   ========================================================================= */
@media (max-width: 900px) {
	.site-header__inner {
		padding: 18px 24px;
	}

	.site-header__nav {
		display: none;
	}

	.site-header__toggle {
		display: inline-flex;
	}

	.site-header.is-open .site-header__nav {
		display: flex;
		position: fixed;
		top: var(--cb-header-height);
		left: 0;
		right: 0;
		bottom: 0;
		flex-direction: column;
		align-items: stretch;
		gap: 0;
		background: var(--cb-ink);
		padding: 24px;
		overflow-y: auto;
		border-top: 1px solid var(--cb-rule-dark-soft);
		z-index: 99;
	}

	.site-header.is-open .primary-menu {
		flex-direction: column;
		align-items: stretch;
		gap: 0;
	}

	.site-header.is-open .primary-menu > li > a {
		display: block;
		padding: 18px 8px;
		border-bottom: 1px solid var(--cb-rule-dark-soft);
	}

	.site-header.is-open .cb-cta-btn {
		margin: 24px 0 0;
		text-align: center;
		padding: 18px 20px;
	}
}

/* =========================================================================
   5. Front page — section 1: Hero image (S/W bud)
   ========================================================================= */
.cb-hero-image {
	position: relative;
	width: 100%;
	height: 440px;
	overflow: hidden;
	background: var(--cb-charcoal);
	border-bottom: 1px solid var(--cb-rule-dark-soft);
}

.cb-hero-image img {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	filter: grayscale(1) brightness(0.85) contrast(1.05);
}

.cb-hero-image__overlay {
	position: absolute;
	inset: 0;
	pointer-events: none;
	background: linear-gradient(
		180deg,
		rgba(20, 19, 15, 0.25) 0%,
		transparent 30%,
		transparent 60%,
		rgba(20, 19, 15, 0.6) 100%
	);
}

.cb-hero-image__eyebrow {
	position: absolute;
	bottom: 22px;
	left: var(--cb-pad-x);
	font-family: var(--mono);
	font-size: 10px;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--cb-bone);
	opacity: 0.75;
}

/* =========================================================================
   6. Front page — section 2: Hero (title + intro)
   ========================================================================= */
.cb-hero {
	padding: 120px var(--cb-pad-x) 84px;
	border-bottom: 1px solid var(--cb-rule-dark-soft);
}

.cb-hero .cb-eyebrow {
	margin-bottom: 56px;
}

.cb-hero__title {
	font-family: var(--serif);
	font-weight: 400;
	font-size: 116px;
	line-height: 0.94;
	letter-spacing: -0.025em;
	margin: 0;
	max-width: 1180px;
}

.cb-hero__title em {
	font-style: italic;
}

.cb-hero__grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 64px;
	margin-top: 72px;
	max-width: 1180px;
}

.cb-hero__lead {
	font-family: var(--serif);
	font-style: italic;
	font-weight: 400;
	font-size: 26px;
	line-height: 1.4;
	color: var(--cb-bone);
}

.cb-hero__body {
	display: flex;
	flex-direction: column;
	gap: 22px;
}

.cb-hero__body p {
	font-size: 15.5px;
	line-height: 1.75;
	color: var(--cb-muted);
}

/* =========================================================================
   7. Front page — section 3: Weitere Themen (2 link cards)
   ========================================================================= */
.cb-themen {
	padding: 96px var(--cb-pad-x);
	border-bottom: 1px solid var(--cb-rule-dark-soft);
}

.cb-themen .cb-eyebrow {
	margin-bottom: 28px;
}

.cb-themen__title {
	font-family: var(--serif);
	font-weight: 400;
	font-size: 64px;
	line-height: 1;
	letter-spacing: -0.02em;
	margin: 0 0 64px;
	max-width: 880px;
}

.cb-themen__title em {
	font-style: italic;
}

.cb-themen__grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 24px;
}

.cb-thema-card {
	display: block;
	position: relative;
	padding: 40px 36px 36px;
	border: 1px solid var(--cb-rule-dark-soft);
	background: rgba(243, 239, 229, 0.02);
	color: var(--cb-bone);
	transition: background 0.15s ease, border-color 0.15s ease, transform 0.15s ease;
}

.cb-thema-card:hover,
.cb-thema-card:focus {
	background: rgba(243, 239, 229, 0.05);
	border-color: var(--cb-rule-dark);
	transform: translateY(-2px);
	color: var(--cb-bone);
}

.cb-thema-card__arrow {
	position: absolute;
	top: 32px;
	right: 32px;
	font-family: var(--serif);
	font-style: italic;
	font-size: 22px;
	opacity: 0.4;
	transition: opacity 0.15s ease, transform 0.15s ease;
}

.cb-thema-card:hover .cb-thema-card__arrow,
.cb-thema-card:focus .cb-thema-card__arrow {
	opacity: 0.9;
	transform: translateX(4px);
}

.cb-thema-card__nummer {
	font-family: var(--mono);
	font-size: 10px;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	opacity: 0.5;
	margin-bottom: 16px;
}

.cb-thema-card__titel {
	font-family: var(--serif);
	font-weight: 400;
	font-size: 36px;
	line-height: 1.1;
	letter-spacing: -0.015em;
	margin-bottom: 14px;
}

.cb-thema-card__beschreibung {
	font-family: var(--serif);
	font-style: italic;
	font-size: 17px;
	line-height: 1.55;
	color: var(--cb-muted);
	max-width: 440px;
}

/* =========================================================================
   8. Front page — section 4: Mitgliedschaft-Intro
   ========================================================================= */
.cb-mitgliedschaft {
	padding: 96px var(--cb-pad-x);
	border-bottom: 1px solid var(--cb-rule-dark-soft);
	display: grid;
	grid-template-columns: 320px 1fr;
	gap: 64px;
}

.cb-mitgliedschaft__label .cb-eyebrow {
	line-height: 1.4;
}

.cb-mitgliedschaft__body {
	max-width: 780px;
	display: flex;
	flex-direction: column;
	gap: 24px;
}

.cb-mitgliedschaft__body p {
	font-family: var(--serif);
	font-style: italic;
	font-size: 22px;
	line-height: 1.5;
}

/* =========================================================================
   9. Front page — section 5: Interessentenliste (signup form)
   ========================================================================= */
.cb-interessenten {
	padding: 120px var(--cb-pad-x);
	background: var(--cb-charcoal);
	border-bottom: 1px solid var(--cb-rule-dark-soft);
	scroll-margin-top: calc(var(--cb-header-height) + 24px);
}

.cb-interessenten__inner {
	max-width: 1080px;
	margin: 0 auto;
}

.cb-interessenten .cb-eyebrow {
	margin-bottom: 28px;
}

.cb-interessenten__title {
	font-family: var(--serif);
	font-weight: 400;
	font-size: 72px;
	line-height: 1;
	letter-spacing: -0.02em;
	margin: 0 0 40px;
}

.cb-interessenten__title em {
	font-style: italic;
}

.cb-interessenten__lead {
	font-family: var(--serif);
	font-style: italic;
	font-size: 22px;
	line-height: 1.55;
	margin: 0 0 64px;
	color: var(--cb-bone);
	opacity: 0.9;
	max-width: 880px;
}

.cb-interessenten__form {
	display: block;
}

.cb-interessenten__grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 32px;
	margin-bottom: 32px;
}

/* --- 9.1 Input fields --- */
.cb-field {
	display: flex;
	flex-direction: column;
}

.cb-field__label {
	font-family: var(--mono);
	font-size: 10px;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--cb-muted);
	margin-bottom: 10px;
}

.cb-field__input {
	appearance: none;
	background: transparent;
	border: 0;
	border-bottom: 1px solid var(--cb-bone);
	border-radius: 0;
	padding: 14px 0;
	height: 48px;
	font-family: var(--serif);
	font-size: 24px;
	font-style: italic;
	color: var(--cb-bone);
	outline: none;
	transition: border-color 0.15s ease;
}

.cb-field__input::placeholder {
	color: var(--cb-bone);
	opacity: 0.4;
}

.cb-field__input:focus {
	border-bottom-color: var(--cb-spring);
}

/* --- 9.2 Consent checkbox --- */
.cb-interessenten__consent {
	display: flex;
	align-items: center;
	gap: 12px;
	margin-bottom: 36px;
	font-family: var(--mono);
	font-size: 11px;
	letter-spacing: 0.04em;
	color: var(--cb-muted);
	cursor: pointer;
}

.cb-interessenten__consent input[type="checkbox"] {
	appearance: none;
	width: 14px;
	height: 14px;
	border: 1px solid var(--cb-bone);
	border-radius: 0;
	background: transparent;
	cursor: pointer;
	flex: 0 0 14px;
	position: relative;
}

.cb-interessenten__consent input[type="checkbox"]:checked::after {
	content: "";
	position: absolute;
	left: 3px;
	top: 0px;
	width: 5px;
	height: 9px;
	border: solid var(--cb-bone);
	border-width: 0 1.5px 1.5px 0;
	transform: rotate(45deg);
}

/* --- 9.3 Submit button --- */
.cb-interessenten__submit {
	background: var(--cb-spring);
	color: var(--cb-bone);
	font-family: var(--serif-caps);
	font-size: 13px;
	letter-spacing: 0.32em;
	padding: 18px 36px;
	transition: background 0.15s ease, transform 0.05s ease;
}

.cb-interessenten__submit:hover,
.cb-interessenten__submit:focus {
	background: var(--cb-moss);
}

.cb-interessenten__submit:active {
	transform: translateY(1px);
}

/* =========================================================================
   10. Front page — responsive (homepage)
   ========================================================================= */
@media (max-width: 1100px) {
	.cb-hero__title         { font-size: 88px; }
	.cb-themen__title       { font-size: 52px; }
	.cb-interessenten__title { font-size: 58px; }
}

@media (max-width: 900px) {
	:root { --cb-pad-x: 24px; }

	.cb-hero-image {
		height: 320px;
	}
	.cb-hero-image__eyebrow {
		left: 24px;
	}

	.cb-hero {
		padding: 64px 24px 56px;
	}
	.cb-hero .cb-eyebrow { margin-bottom: 32px; }
	.cb-hero__title       { font-size: 56px; }
	.cb-hero__grid {
		grid-template-columns: 1fr;
		gap: 32px;
		margin-top: 40px;
	}
	.cb-hero__lead        { font-size: 22px; }

	.cb-themen {
		padding: 64px 24px;
	}
	.cb-themen__title     { font-size: 40px; margin-bottom: 40px; }
	.cb-themen__grid {
		grid-template-columns: 1fr;
		gap: 16px;
	}
	.cb-thema-card {
		padding: 32px 24px 28px;
	}
	.cb-thema-card__titel { font-size: 28px; }

	.cb-mitgliedschaft {
		padding: 64px 24px;
		grid-template-columns: 1fr;
		gap: 24px;
	}
	.cb-mitgliedschaft__body p { font-size: 18px; }

	.cb-interessenten {
		padding: 64px 24px;
	}
	.cb-interessenten__title  { font-size: 40px; }
	.cb-interessenten__lead   { font-size: 18px; margin-bottom: 40px; }
	.cb-interessenten__grid {
		grid-template-columns: 1fr;
		gap: 24px;
	}
}

/* =========================================================================
   10a-cf7. Interessentenliste form — CF7 markup overrides
   CF7 wraps every form-tag in <p> and adds its own classes (.wpcf7-form,
   .wpcf7-form-control-wrap, .wpcf7-list-item, .wpcf7-response-output…).
   These rules neutralise the wrapper margins and make CF7's generated
   inputs/checkboxes match the existing dark editorial form design.
   ========================================================================= */
.cb-interessenten .wpcf7 {
	margin: 0;
}

/* CF7 wraps each tag's <p> with its own paragraph — strip default spacing */
.cb-interessenten .wpcf7-form > p {
	margin: 0;
}

/* The form-control-wrap is an inline span by default; let it fill the label */
.cb-interessenten .wpcf7-form-control-wrap {
	display: block;
}

/* Make CF7-generated text/email inputs honour our .cb-field__input look */
.cb-interessenten .cb-field__input.wpcf7-form-control {
	width: 100%;
}

/* Acceptance checkbox — CF7 nests label-text inside .wpcf7-list-item-label */
.cb-interessenten__consent .wpcf7-acceptance,
.cb-interessenten__consent .wpcf7-list-item {
	margin: 0;
	display: inline;
}

.cb-interessenten__consent .wpcf7-list-item {
	display: inline-flex;
	align-items: center;
	gap: 12px;
}

.cb-interessenten__consent .wpcf7-list-item input[type="checkbox"] {
	/* Inherit the consent checkbox styling from .cb-interessenten__consent input. */
	margin: 0;
}

.cb-interessenten__consent .wpcf7-list-item-label {
	color: inherit;
	font: inherit;
	letter-spacing: inherit;
}

/* Submit button — keep our .cb-interessenten__submit but let CF7's spinner sit next to it */
.cb-interessenten__submit.wpcf7-submit {
	cursor: pointer;
}

.cb-interessenten .wpcf7-spinner {
	margin-left: 16px;
	vertical-align: middle;
}

/* Response messages — success / validation errors / spam flag */
.cb-interessenten .wpcf7-response-output {
	margin: 28px 0 0 !important;
	padding: 14px 18px !important;
	border: 1px solid var(--cb-rule-dark) !important;
	border-radius: 0;
	color: var(--cb-bone);
	font-family: var(--mono);
	font-size: 11px;
	letter-spacing: 0.04em;
	line-height: 1.6;
	background: rgba(243, 239, 229, 0.04);
}

.cb-interessenten .wpcf7 form.sent .wpcf7-response-output {
	border-color: var(--cb-spring) !important;
	color: var(--cb-bone);
}

.cb-interessenten .wpcf7 form.invalid .wpcf7-response-output,
.cb-interessenten .wpcf7 form.unaccepted .wpcf7-response-output,
.cb-interessenten .wpcf7 form.failed .wpcf7-response-output {
	border-color: rgba(176, 64, 64, 0.55) !important;
}

/* Inline per-field validation message */
.cb-interessenten .wpcf7-not-valid-tip {
	display: block;
	margin-top: 6px;
	font-family: var(--mono);
	font-size: 10px;
	letter-spacing: 0.08em;
	color: rgba(220, 120, 120, 0.85);
}

.cb-interessenten input.wpcf7-not-valid {
	border-bottom-color: rgba(220, 120, 120, 0.85);
}

/* =========================================================================
   10b. Hintergrund page — sections and shared 2-col patterns
   Source: standalone/Hintergrund.html / page-hintergrund.jsx
   ========================================================================= */

/* --- Breadcrumb hero — small eyebrow + giant serif title --- */
.cb-breadcrumb-hero {
	padding: 88px var(--cb-pad-x) 64px;
	border-bottom: 1px solid var(--cb-rule-dark-soft);
}

.cb-breadcrumb-hero .cb-eyebrow {
	margin-bottom: 44px;
}

.cb-breadcrumb-hero__title {
	font-family: var(--serif);
	font-weight: 400;
	font-size: 116px;
	line-height: 0.94;
	letter-spacing: -0.025em;
	margin: 0;
	max-width: 1180px;
}

.cb-breadcrumb-hero__title em {
	font-style: italic;
}

/* --- 2-column row used by Etymologie / Philosophie / Aufnahme --- */
.cb-2col {
	display: grid;
	grid-template-columns: 320px 1fr;
	gap: 64px;
}

.cb-2col__body {
	max-width: 880px;
	display: flex;
	flex-direction: column;
	gap: 28px;
}

/* Numbered side-label (mono caps) */
.cb-num-label {
	font-family: var(--mono);
	font-size: 10px;
	letter-spacing: 0.24em;
	text-transform: uppercase;
	color: var(--cb-muted);
	line-height: 1.4;
}

.cb-num-label--spring {
	color: var(--cb-spring);
}

/* Italic serif lead paragraph */
.cb-italic-lead {
	font-family: var(--serif);
	font-style: italic;
	font-weight: 400;
	font-size: 28px;
	line-height: 1.4;
	margin: 0;
	color: var(--cb-bone);
}

.cb-italic-lead--xl {
	font-size: 26px;
	line-height: 1.45;
}

.cb-italic-lead .cb-roman,
.cb-roman {
	font-style: normal;
}

/* Muted body paragraph */
.cb-muted-body {
	font-size: 17px;
	line-height: 1.75;
	margin: 0;
	color: var(--cb-muted);
	max-width: 880px;
}

.cb-philosophie .cb-muted-body {
	font-size: 16px;
}

/* Mini rule used between lead and body */
.cb-rule-mini {
	height: 1px;
	width: 60px;
	background: var(--cb-rule-dark);
	margin: 0;
}

/* --- Etymologie section padding --- */
.cb-etymologie {
	padding: 88px var(--cb-pad-x) 96px;
	border-bottom: 1px solid var(--cb-rule-dark-soft);
}

/* --- Philosophie section --- */
.cb-philosophie {
	padding: 96px var(--cb-pad-x);
	border-bottom: 1px solid var(--cb-rule-dark-soft);
}

.cb-philosophie__header {
	margin-bottom: 64px;
}

.cb-philosophie__title {
	font-family: var(--serif);
	font-weight: 400;
	font-size: 64px;
	line-height: 1;
	letter-spacing: -0.02em;
	margin: 0;
	max-width: 880px;
}

.cb-philosophie__title em {
	font-style: italic;
}

/* --- Pull-quote block --- */
.cb-pullquote {
	margin: 88px 0;
	padding: 64px 0;
	border-top: 1px solid var(--cb-rule-dark);
	border-bottom: 1px solid var(--cb-rule-dark);
}

.cb-pullquote__text {
	font-family: var(--serif);
	font-style: italic;
	font-size: 30px;
	line-height: 1.4;
	margin: 0;
	color: var(--cb-bone);
	max-width: 880px;
}

/* --- Hintergrund responsive --- */
@media (max-width: 1100px) {
	.cb-breadcrumb-hero__title { font-size: 88px; }
	.cb-philosophie__title     { font-size: 52px; }
	.cb-pullquote__text        { font-size: 26px; }
}

@media (max-width: 900px) {
	.cb-breadcrumb-hero {
		padding: 56px 24px 40px;
	}
	.cb-breadcrumb-hero .cb-eyebrow { margin-bottom: 28px; }
	.cb-breadcrumb-hero__title { font-size: 48px; }

	.cb-2col {
		grid-template-columns: 1fr;
		gap: 24px;
	}

	.cb-etymologie,
	.cb-philosophie {
		padding: 56px 24px;
	}

	.cb-philosophie__header   { margin-bottom: 32px; }
	.cb-philosophie__title    { font-size: 36px; }

	.cb-italic-lead,
	.cb-italic-lead--xl       { font-size: 20px; }

	.cb-pullquote {
		margin: 48px 0;
		padding: 40px 0;
	}
	.cb-pullquote__text       { font-size: 22px; }
}

/* =========================================================================
   10c. DHV-Transparenzregeln page
   Source: standalone/DHV-Transparenzregeln.html / page-dhv.jsx
   ========================================================================= */

/* Vorwort — same shape as Etymologie */
.cb-dhv-intro {
	padding: 88px var(--cb-pad-x) 96px;
	border-bottom: 1px solid var(--cb-rule-dark-soft);
}

.cb-dhv-intro .cb-rule-mini {
	margin: 8px 0;
}

/* Squat en-dash in the DHV title — flattened to ~50% height, raised slightly,
   slightly smaller. Matches the JSX inline transform from page-dhv.jsx. */
.cb-dhv-dash {
	display: inline-block;
	font-family: var(--serif);
	font-style: normal;
	font-weight: 400;
	font-size: 0.85em;
	margin: 0 0.02em;
	vertical-align: 0.18em;
	transform: scaleY(0.5);
	transform-origin: center center;
}

/* --- Q&A list --- */
.cb-dhv-list {
	padding: 0 var(--cb-pad-x) 96px;
}

.cb-dhv-row {
	display: grid;
	grid-template-columns: 80px 320px 1fr;
	gap: 32px;
	padding: 40px 0 44px;
	border-bottom: 1px solid var(--cb-rule-dark-soft);
	align-items: flex-start;
}

.cb-dhv-row--last {
	border-bottom: 0;
}

.cb-dhv-row__num {
	font-family: var(--mono);
	font-size: 12px;
	letter-spacing: 0.18em;
	color: var(--cb-spring);
	padding-top: 6px;
}

.cb-dhv-row__heading {
	font-family: var(--mono);
	font-size: 9.5px;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--cb-muted);
	margin-bottom: 12px;
}

.cb-dhv-row__question {
	font-family: var(--serif);
	font-style: italic;
	font-size: 23px;
	line-height: 1.3;
	color: var(--cb-bone);
}

.cb-dhv-row__answer {
	font-size: 15.5px;
	line-height: 1.72;
	margin: 0;
	color: var(--cb-bone);
	max-width: 760px;
}

/* --- Single-card variant of the homepage Weitere Themen grid --- */
.cb-themen__grid--single {
	grid-template-columns: minmax(0, 760px);
	justify-content: start;
}

/* --- DHV responsive --- */
@media (max-width: 1100px) {
	.cb-dhv-row {
		grid-template-columns: 60px 280px 1fr;
		gap: 24px;
	}
	.cb-dhv-row__question { font-size: 20px; }
}

@media (max-width: 900px) {
	.cb-dhv-intro {
		padding: 56px 24px 64px;
	}
	.cb-dhv-list {
		padding: 0 24px 64px;
	}
	.cb-dhv-row {
		grid-template-columns: 1fr;
		gap: 16px;
		padding: 32px 0 36px;
	}
	.cb-dhv-row__num {
		padding-top: 0;
		font-size: 13px;
	}
	.cb-dhv-row__question { font-size: 19px; }
	.cb-themen__grid--single {
		grid-template-columns: 1fr;
	}
}

/* =========================================================================
   10d. Datenschutzerklärung page
   Source: standalone/Datenschutz.html / page-datenschutz.jsx
   Layout: numbered sections in a 80/320/1fr grid, italic serif rail labels,
           spring-green mono sub-headings, em-dash bullet lists, address card.
   ========================================================================= */

/* Section grid — same rhythm as DHV rows but with italic serif label */
.cb-ds-section {
	display: grid;
	grid-template-columns: 80px 320px 1fr;
	gap: 32px;
	padding: 64px var(--cb-pad-x) 68px;
	border-bottom: 1px solid var(--cb-rule-dark-soft);
	align-items: flex-start;
}

.cb-ds-section--last {
	border-bottom: 0;
}

.cb-ds-section__num {
	font-family: var(--mono);
	font-size: 12px;
	letter-spacing: 0.18em;
	color: var(--cb-spring);
	padding-top: 6px;
}

.cb-ds-section__label {
	font-family: var(--serif);
	font-style: italic;
	font-weight: 400;
	font-size: 30px;
	line-height: 1.1;
	letter-spacing: -0.01em;
	color: var(--cb-bone);
}

.cb-ds-section__body {
	display: flex;
	flex-direction: column;
	gap: 18px;
}

/* Sub-heading inside a section body (spring-green mono caps) */
.cb-ds-sub {
	font-family: var(--mono);
	font-size: 10px;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--cb-spring);
	margin-top: 12px;
	margin-bottom: -8px;            /* hugs the paragraph below */
}

/* Body paragraph (slightly tighter than .cb-muted-body) */
.cb-ds-body {
	font-size: 15.5px;
	line-height: 1.72;
	margin: 0;
	color: var(--cb-muted);
	max-width: 760px;
}

.cb-ds-link {
	color: var(--cb-bone);
	text-decoration: underline;
	text-underline-offset: 3px;
}

.cb-ds-link:hover,
.cb-ds-link:focus {
	color: var(--cb-spring);
}

/* Em-dash bullet list */
.cb-ds-list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 12px;
	max-width: 760px;
}

.cb-ds-list li {
	display: grid;
	grid-template-columns: 22px 1fr;
	gap: 14px;
	font-size: 15.5px;
	line-height: 1.6;
	color: var(--cb-muted);
}

.cb-ds-list__dash {
	font-family: var(--mono);
	font-size: 11px;
	color: var(--cb-spring);
	padding-top: 3px;
}

/* Address / responsible-party callout card */
.cb-ds-address {
	border: 1px solid var(--cb-rule-dark);
	padding: 28px 32px;
	max-width: 520px;
	display: flex;
	flex-direction: column;
	gap: 4px;
}

.cb-ds-address__name {
	font-family: var(--serif);
	font-size: 22px;
	color: var(--cb-bone);
}

.cb-ds-address__name em {
	font-style: italic;
	opacity: 0.7;
}

.cb-ds-address__addr {
	font-size: 15.5px;
	line-height: 1.7;
	color: var(--cb-muted);
}

.cb-ds-address__email {
	margin-top: 14px;
	padding-top: 14px;
	border-top: 1px solid var(--cb-rule-dark-soft);
	font-family: var(--mono);
	font-size: 13px;
	letter-spacing: 0.04em;
	color: var(--cb-bone);
}

.cb-ds-address__email a {
	color: inherit;
	text-decoration: underline;
	text-underline-offset: 3px;
	transition: color 0.15s ease;
}

.cb-ds-address__email a:hover,
.cb-ds-address__email a:focus {
	color: var(--cb-spring);
}

/* Inline email/URL link used inside DHV answers and other body copy. */
.cb-inline-link {
	color: var(--cb-bone);
	text-decoration: underline;
	text-underline-offset: 3px;
	transition: color 0.15s ease;
}

.cb-inline-link:hover,
.cb-inline-link:focus {
	color: var(--cb-spring);
}

/* "Stand: <date>" row at the foot of the page */
.cb-ds-stand {
	display: grid;
	grid-template-columns: 80px 320px 1fr;
	gap: 32px;
	padding: 40px var(--cb-pad-x) 72px;
}

.cb-ds-stand__label {
	font-family: var(--mono);
	font-size: 11px;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--cb-muted);
}

/* --- Datenschutz responsive --- */
@media (max-width: 1100px) {
	.cb-ds-section,
	.cb-ds-stand {
		grid-template-columns: 60px 280px 1fr;
		gap: 24px;
	}
	.cb-ds-section__label { font-size: 26px; }
}

@media (max-width: 900px) {
	.cb-ds-section {
		grid-template-columns: 1fr;
		gap: 16px;
		padding: 48px 24px 52px;
	}
	.cb-ds-section__num {
		padding-top: 0;
		font-size: 13px;
	}
	.cb-ds-section__label { font-size: 22px; }

	.cb-ds-stand {
		grid-template-columns: 1fr;
		padding: 24px 24px 56px;
	}
}

/* =========================================================================
   10e. Impressum page
   Source: standalone/Impressum.html / page-impressum.jsx
   Reuses the section grid + sub/body primitives from Datenschutz (.cb-ds-*).
   Adds Impressum-specific .cb-im-card callouts and a closing italic note row.
   ========================================================================= */

/* Bordered callout card — reused for address, register table, responsible-party */
.cb-im-card {
	border: 1px solid var(--cb-rule-dark);
	padding: 28px 32px;
	max-width: 520px;
	font-size: 15.5px;
	line-height: 1.7;
	color: var(--cb-muted);
}

.cb-im-card__name {
	font-family: var(--serif);
	font-size: 22px;
	color: var(--cb-bone);
	margin-bottom: 6px;
}

.cb-im-card__name em {
	font-style: italic;
	opacity: 0.7;
}

/* Register table inside a card */
.cb-im-card--register {
	max-width: 620px;
}

.cb-im-register {
	display: grid;
	grid-template-columns: auto 1fr;
	gap: 8px 24px;
	margin: 0;
}

.cb-im-register dt {
	font-family: var(--mono);
	font-size: 11px;
	letter-spacing: 0.06em;
	color: var(--cb-spring);
}

.cb-im-register dd {
	margin: 0;
	color: var(--cb-bone);
}

/* Inline mailto with mono face */
.cb-im-mailto {
	font-family: var(--mono);
	font-size: 14px;
	color: var(--cb-bone);
	text-decoration: underline;
	text-underline-offset: 3px;
}

.cb-im-mailto:hover,
.cb-im-mailto:focus {
	color: var(--cb-spring);
}

/* Closing "Gründungsphase" note — italic serif, framed, sits in the body column */
.cb-im-note-row {
	display: grid;
	grid-template-columns: 80px 320px 1fr;
	gap: 32px;
	padding: 40px var(--cb-pad-x) 72px;
}

.cb-im-note {
	border: 1px solid var(--cb-rule-dark);
	padding: 24px 28px;
	max-width: 760px;
	font-family: var(--serif);
	font-style: italic;
	font-size: 19px;
	line-height: 1.5;
	color: var(--cb-bone);
}

/* --- Impressum responsive --- */
@media (max-width: 1100px) {
	.cb-im-note-row {
		grid-template-columns: 60px 280px 1fr;
		gap: 24px;
	}
}

@media (max-width: 900px) {
	.cb-im-card,
	.cb-im-note {
		padding: 20px 22px;
	}

	.cb-im-register {
		grid-template-columns: 1fr;
		gap: 4px 0;
	}

	.cb-im-register dt {
		margin-top: 8px;
	}

	.cb-im-note-row {
		grid-template-columns: 1fr;
		padding: 24px 24px 56px;
	}

	.cb-im-note { font-size: 17px; }
}

/* =========================================================================
   11. Site footer (dark, 3-col, bottom bar)
   ========================================================================= */
.site-footer {
	padding: 72px var(--cb-pad-x) 36px;
	background: var(--cb-ink);
	color: var(--cb-bone);
	border-top: 1px solid var(--cb-rule-dark-soft);
}

.site-footer__inner {
	max-width: 1400px;
	margin: 0 auto;
}

.site-footer__cols {
	display: grid;
	grid-template-columns: 1.6fr 1fr 1fr;
	gap: 56px;
	padding-bottom: 48px;
	border-bottom: 1px solid var(--cb-rule-dark-soft);
}

.site-footer__brand {
	display: inline-block;
}

.site-footer__logo {
	height: 32px;
	width: auto;
}

.site-footer__tagline {
	margin: 22px 0 0;
	font-family: var(--serif);
	font-style: italic;
	font-size: 18px;
	line-height: 1.5;
	color: var(--cb-bone);
	opacity: 0.78;
	max-width: 380px;
}

.site-footer__col-title {
	font-family: var(--mono);
	font-size: 10px;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--cb-bone);
	opacity: 0.55;
	margin-bottom: 18px;
}

.site-footer__list li {
	font-family: var(--serif);
	font-size: 17px;
	line-height: 1.7;
}

.site-footer__list a {
	color: var(--cb-bone);
	transition: opacity 0.15s ease, color 0.15s ease;
}

.site-footer__list a:hover,
.site-footer__list a:focus {
	opacity: 0.7;
}

/* Make mailto/tel links visibly clickable in the footer */
.site-footer__list a[href^="mailto:"],
.site-footer__list a[href^="tel:"] {
	text-decoration: underline;
	text-underline-offset: 3px;
	word-break: break-word;
}

.site-footer__list a[href^="mailto:"]:hover,
.site-footer__list a[href^="mailto:"]:focus,
.site-footer__list a[href^="tel:"]:hover,
.site-footer__list a[href^="tel:"]:focus {
	opacity: 1;
	color: var(--cb-spring);
}

.site-footer__bottom {
	display: flex;
	flex-wrap: wrap;
	gap: 16px;
	justify-content: space-between;
	align-items: center;
	padding-top: 24px;
	font-family: var(--mono);
	font-size: 10px;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--cb-bone);
	opacity: 0.5;
}

/* =========================================================================
   12. Footer — responsive
   ========================================================================= */
@media (max-width: 900px) {
	.site-footer {
		padding: 56px 24px 28px;
	}
	.site-footer__cols {
		grid-template-columns: 1fr;
		gap: 40px;
	}
	.site-footer__bottom {
		flex-direction: column;
		align-items: flex-start;
	}
}
