/*
Theme Name: Heiko
Theme URI: https://fanieng.com
Description: Child Theme fuer Twenty Twenty-Five im fanieng.com Designsystem.
Author: Heiko Fanieng
Author URI: https://fanieng.com
Template: twentytwentyfive
Version: 0.1.0
Text Domain: heiko
*/

:root {
	color-scheme: dark;

	--primitive-white: #ffffff;
	--primitive-silver-25: #fafafa;
	--primitive-silver-50: #f3f3f3;
	--primitive-silver-100: #dedede;
	--primitive-silver-300: #b7b7b7;
	--primitive-silver-600: #606060;
	--primitive-silver-800: #292929;
	--primitive-black: #020202;
	--primitive-red: #ef4136;

	--color-bg: #090909;
	--color-surface: #121212;
	--color-surface-muted: #1a1a1a;
	--color-surface-elevated: #232323;
	--color-text: #f7f7f7;
	--color-text-subtle: #d2d2d2;
	--color-text-muted: #a4a4a4;
	--color-border: #363636;
	--color-accent: var(--primitive-red);
	--color-accent-strong: var(--primitive-red);
	--color-accent-dark: #ffffff;
	--color-accent-soft: #232323;
	--color-on-accent: var(--primitive-black);

	--shadow-card: 0 1rem 2.5rem rgb(0 0 0 / 0.32);
	--radius-small: 0.25rem;
	--radius-medium: 0.5rem;
	--radius-large: 0.75rem;
	--container: 72rem;
	--container-narrow: 48rem;
	--sidebar-width: 17.5rem;
	--topbar-height: 4rem;
	--transition-fast: 160ms ease;

	--wp--style--global--content-size: var(--container-narrow);
	--wp--style--global--wide-size: var(--container);
}

body {
	background: var(--color-bg);
	color: var(--color-text);
	font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
	font-size: 1rem;
	line-height: 1.65;
}

body .wp-site-blocks {
	background: var(--color-bg);
	color: var(--color-text);
	min-height: 100vh;
	padding: 0;
}

a {
	color: inherit;
	text-decoration-color: var(--color-accent);
	text-decoration-thickness: 0.08em;
	text-underline-offset: 0.22em;
	transition:
		color var(--transition-fast),
		text-decoration-color var(--transition-fast);
}

a:hover {
	color: var(--color-accent-dark);
	text-decoration-color: var(--color-accent-strong);
}

h1,
h2,
h3,
h4 {
	letter-spacing: 0;
	line-height: 1.12;
}

h1 {
	max-width: 18ch;
	font-size: clamp(2.25rem, 5vw, 4.5rem);
	font-weight: 600;
}

h2 {
	font-size: clamp(2rem, 4vw, 3.25rem);
}

h3 {
	font-size: 1.4rem;
}

.eyebrow {
	padding-left: 0.65rem;
	border-left: 0.25rem solid var(--color-accent);
	margin: 0 0 1rem;
	color: var(--color-text);
	font-size: 0.78rem;
	font-weight: 800;
	letter-spacing: 0.12em;
	text-transform: uppercase;
}

.wp-site-blocks > header,
.wp-site-blocks > footer {
	border-color: var(--color-border);
	background: var(--color-surface);
	color: var(--color-text);
}

.heiko-site-header {
	position: fixed;
	z-index: 40;
	top: 0;
	right: 0;
	left: var(--sidebar-width);
	border-bottom: 1px solid var(--color-border);
	background: rgb(18 18 18 / 0.96);
	backdrop-filter: blur(0.5rem);
}

.heiko-site-header__inner {
	min-height: var(--topbar-height);
	width: 100%;
	max-width: none !important;
	gap: clamp(1rem, 3vw, 2rem);
	padding-inline: 1.25rem;
}

.heiko-site-brand,
.heiko-site-header__actions {
	gap: 0.75rem;
}

.heiko-site-brand {
	min-width: max-content;
}

.heiko-brand-mark {
	display: grid;
	width: 2.5rem;
	aspect-ratio: 1;
	place-items: center;
	border-radius: var(--radius-small);
	margin: 0;
	background: var(--color-accent);
	color: var(--color-on-accent);
	font-weight: 800;
	line-height: 1;
}

.heiko-shell-content {
	min-height: 100vh;
	margin-top: var(--topbar-height);
	margin-left: var(--sidebar-width);
}

.heiko-shell-main {
	min-height: calc(100vh - var(--topbar-height));
	padding-block: clamp(3rem, 6vw, 5rem);
	padding-inline: clamp(1.25rem, 4vw, 4rem);
}

.heiko-shell-main--home {
	padding: 0;
}

.heiko-app-sidebar {
	position: fixed;
	z-index: 30;
	top: 0;
	bottom: 0;
	left: 0;
	width: var(--sidebar-width);
	overflow-y: auto;
	border-right: 1px solid var(--color-border);
	background: var(--color-surface);
}

.heiko-sidebar-brand {
	min-height: var(--topbar-height);
	border-bottom: 1px solid var(--color-border);
	gap: 0.75rem;
}

.heiko-sidebar-brand > * {
	margin-block: 0;
}

.heiko-sidebar-nav-panel {
	width: 100%;
	max-width: none !important;
}

.heiko-navigation-label {
	margin: 0 0 0.5rem;
	color: var(--color-text-muted);
	font-size: 0.72rem;
	font-weight: 800;
	letter-spacing: 0.12em;
	text-transform: uppercase;
}

.wp-block-site-title,
.wp-block-site-title a {
	color: var(--color-text);
	font-weight: 800;
	text-decoration: none;
}

.wp-block-navigation {
	color: var(--color-text-muted);
	font-size: 0.92rem;
	font-weight: 750;
}

.wp-block-navigation a {
	text-decoration: none;
}

.wp-block-navigation a:hover,
.wp-block-navigation .current-menu-item > a,
.wp-block-navigation .current-menu-ancestor > a {
	color: var(--color-text);
}

.heiko-sidebar-navigation {
	display: grid;
	gap: 0.35rem;
	width: 100%;
}

.heiko-sidebar-navigation .wp-block-navigation__container {
	display: grid;
	gap: 0.35rem;
	width: 100%;
}

.heiko-sidebar-navigation .wp-block-navigation-item {
	width: 100%;
}

.heiko-sidebar-navigation .wp-block-navigation-item__content {
	--heiko-nav-icon: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' stroke='black' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71'/%3E%3Cpath d='M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71'/%3E%3C/g%3E%3C/svg%3E");
	position: relative;
	display: grid;
	grid-template-columns: 2.5rem minmax(0, 1fr);
	width: 100%;
	align-items: center;
	gap: 0.15rem 0.65rem;
	padding: 0.7rem;
	border: 1px solid transparent;
	border-radius: var(--radius-medium);
	background: transparent;
	color: var(--color-text-muted);
	text-decoration: none;
	transition:
		background var(--transition-fast),
		border-color var(--transition-fast),
		color var(--transition-fast);
}

.heiko-sidebar-navigation .wp-block-navigation-item__content::before {
	content: "";
	grid-row: 1 / span 2;
	display: inline-grid;
	width: 2.5rem;
	aspect-ratio: 1;
	border-radius: var(--radius-small);
	background: var(--color-surface-elevated);
	transition: background var(--transition-fast);
}

.heiko-sidebar-navigation .wp-block-navigation-item__content::after {
	content: "";
	position: absolute;
	top: 50%;
	left: calc(0.7rem + 0.675rem);
	width: 1.15rem;
	aspect-ratio: 1;
	background: var(--color-text-muted);
	-webkit-mask: var(--heiko-nav-icon) center / 1.15rem 1.15rem no-repeat;
	mask: var(--heiko-nav-icon) center / 1.15rem 1.15rem no-repeat;
	transform: translateY(-50%);
	transition: background var(--transition-fast);
}

.heiko-sidebar-navigation .wp-block-navigation-item__label,
.heiko-sidebar-navigation .wp-block-navigation-item__description {
	grid-column: 2;
	min-width: 0;
}

.heiko-sidebar-navigation .wp-block-navigation-item__label {
	line-height: 1.2;
}

.heiko-sidebar-navigation .wp-block-navigation-item__content:hover,
.heiko-sidebar-navigation .current-menu-item > .wp-block-navigation-item__content,
.heiko-sidebar-navigation .current-menu-ancestor > .wp-block-navigation-item__content,
.heiko-sidebar-navigation .wp-block-navigation-item__content[aria-current],
.home .heiko-sidebar-navigation .wp-block-navigation-item__content[href="/"],
.home .heiko-sidebar-navigation .wp-block-navigation-item__content[href="https://fanieng.com/"],
.front-page .heiko-sidebar-navigation .wp-block-navigation-item__content[href="/"] {
	border-color: var(--color-accent);
	background: var(--color-accent-soft);
	color: var(--color-text);
}

.heiko-sidebar-navigation .wp-block-navigation-item__content:hover::before,
.heiko-sidebar-navigation .current-menu-item > .wp-block-navigation-item__content::before,
.heiko-sidebar-navigation .current-menu-ancestor > .wp-block-navigation-item__content::before,
.heiko-sidebar-navigation .wp-block-navigation-item__content[aria-current]::before,
.home .heiko-sidebar-navigation .wp-block-navigation-item__content[href="/"]::before,
.home .heiko-sidebar-navigation .wp-block-navigation-item__content[href="https://fanieng.com/"]::before,
.front-page .heiko-sidebar-navigation .wp-block-navigation-item__content[href="/"]::before {
	background: var(--color-surface-elevated);
}

.heiko-sidebar-navigation .wp-block-navigation-item__content:hover::after,
.heiko-sidebar-navigation .current-menu-item > .wp-block-navigation-item__content::after,
.heiko-sidebar-navigation .current-menu-ancestor > .wp-block-navigation-item__content::after,
.heiko-sidebar-navigation .wp-block-navigation-item__content[aria-current]::after,
.home .heiko-sidebar-navigation .wp-block-navigation-item__content[href="/"]::after,
.home .heiko-sidebar-navigation .wp-block-navigation-item__content[href="https://fanieng.com/"]::after,
.front-page .heiko-sidebar-navigation .wp-block-navigation-item__content[href="/"]::after {
	background: var(--color-text-subtle);
}

.heiko-sidebar-navigation .wp-block-navigation-item__description {
	color: var(--color-text-muted);
	font-size: 0.78rem;
	font-weight: 600;
	line-height: 1.25;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.heiko-sidebar-navigation .wp-block-navigation-item__content[href="/"],
.heiko-sidebar-navigation .wp-block-navigation-item__content[href="https://fanieng.com/"],
.heiko-sidebar-navigation .wp-block-navigation-item__content[href$="/en/"],
.heiko-sidebar-navigation .wp-block-navigation-item__content[href$="/nl/"],
.heiko-sidebar-navigation .wp-block-navigation-item__content[href$="/pl/"],
.heiko-sidebar-navigation .wp-block-navigation-item__content[href$="/bn/"] {
	--heiko-nav-icon: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' stroke='black' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m3 10 9-7 9 7'/%3E%3Cpath d='M5 9v11h14V9'/%3E%3Cpath d='M9 20v-6h6v6'/%3E%3C/g%3E%3C/svg%3E");
}

.heiko-sidebar-navigation .wp-block-navigation-item__content[href$="/projekte/"] {
	--heiko-nav-icon: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' stroke='black' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M3 7.5h7l2 2h9v10H3z'/%3E%3Cpath d='M3 7.5v-3h7l2 2h7v3'/%3E%3C/g%3E%3C/svg%3E");
}

.heiko-sidebar-navigation .wp-block-navigation-item__content[href$="/kompetenzen/"] {
	--heiko-nav-icon: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' stroke='black' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 3 5 6.5v5c0 4.5 3 7.7 7 9.5 4-1.8 7-5 7-9.5v-5z'/%3E%3Cpath d='m9 12 2 2 4-4'/%3E%3C/g%3E%3C/svg%3E");
}

.heiko-sidebar-navigation .wp-block-navigation-item__content[href*="karriere-cockpit"] {
	--heiko-nav-icon: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' stroke='black' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M4 19v-6'/%3E%3Cpath d='M10 19V5'/%3E%3Cpath d='M16 19v-9'/%3E%3Cpath d='M22 19H2'/%3E%3C/g%3E%3C/svg%3E");
}

.wp-block-social-links.is-style-heiko-header-social {
	gap: 0.35rem;
	padding-left: 0;
	border-left: 0;
}

.wp-block-social-links.is-style-heiko-header-social .wp-social-link {
	background: transparent;
	color: var(--color-text-subtle);
}

.wp-block-social-links.is-style-heiko-header-social .wp-social-link a {
	display: inline-grid;
	width: 2rem;
	height: 2rem;
	place-items: center;
	border-radius: var(--radius-small);
	color: inherit;
	transition:
		background var(--transition-fast),
		color var(--transition-fast);
}

.wp-block-social-links.is-style-heiko-header-social .wp-social-link a:hover {
	background: var(--color-surface-muted);
	color: var(--color-text);
}

.heiko-theme-label {
	min-height: var(--topbar-height);
	padding-inline: 1.25rem;
	border-left: 1px solid var(--color-border);
	margin: 0;
	color: var(--color-text-subtle);
	font-size: 0.92rem;
	line-height: var(--topbar-height);
}

.heiko-language-navigation {
	min-height: var(--topbar-height);
	padding-inline: 1rem;
	border-left: 1px solid var(--color-border);
	color: var(--color-text-subtle);
	font-size: 0.82rem;
	font-weight: 800;
	letter-spacing: 0.08em;
}

.heiko-language-navigation .wp-block-navigation__container {
	gap: 0.35rem;
}

.heiko-language-navigation .wp-block-navigation-item__content {
	padding: 0;
	color: inherit;
}

.heiko-language-navigation .wp-block-navigation-item__content:hover {
	color: var(--color-text);
}

.wp-block-post-title a {
	text-decoration: none;
}

.wp-block-post-title a:hover {
	text-decoration: underline;
	text-decoration-color: var(--color-accent);
}

.wp-block-button__link,
.wp-element-button {
	border: 1px solid transparent;
	border-radius: var(--radius-small);
	background: var(--color-accent);
	color: var(--color-on-accent);
	font-weight: 750;
	line-height: 1.2;
	text-decoration: none;
	transition:
		background var(--transition-fast),
		border-color var(--transition-fast),
		color var(--transition-fast);
}

.wp-block-button__link:hover,
.wp-element-button:hover {
	background: var(--color-accent-strong);
	color: var(--color-on-accent);
}

.wp-block-button.is-style-outline .wp-block-button__link {
	border-color: var(--color-border);
	background: var(--color-surface);
	color: var(--color-text);
}

.wp-block-button.is-style-outline .wp-block-button__link:hover {
	border-color: var(--color-accent);
	background: var(--color-accent-soft);
	color: var(--color-text);
}

.wp-block-group.has-background,
.wp-block-cover,
.wp-block-post,
.wp-block-query .wp-block-post-template > li {
	border-color: var(--color-border);
}

.heiko-shell-main .wp-block-post-template > li,
.heiko-shell-main .wp-block-latest-posts > li,
.heiko-shell-main .wp-block-query .wp-block-post-template > li {
	border: 1px solid var(--color-border);
	border-radius: var(--radius-large);
	background: var(--color-surface);
	box-shadow: var(--shadow-card);
}

.heiko-shell-main .wp-block-post-template > li {
	padding: clamp(1.25rem, 3vw, 2rem);
}

.wp-block-post-date,
.wp-block-post-excerpt,
.wp-block-term-description,
.wp-block-query-pagination,
.wp-block-site-tagline {
	color: var(--color-text-muted);
}

.wp-block-separator {
	border-color: var(--color-border);
}

.wp-block-quote {
	border-left: 0.25rem solid var(--color-accent);
	color: var(--color-text-subtle);
}

.wp-block-code,
pre,
code {
	border-radius: var(--radius-medium);
	background: var(--color-surface-muted);
	color: var(--color-text-subtle);
}

.wp-block-table table {
	border-collapse: collapse;
}

.wp-block-table th,
.wp-block-table td {
	border-color: var(--color-border);
}

.has-base-background-color {
	background-color: var(--color-bg) !important;
}

.has-contrast-color {
	color: var(--color-text) !important;
}

.has-accent-1-background-color {
	background-color: var(--color-accent) !important;
}

.has-accent-1-color {
	color: var(--color-accent) !important;
}

.wp-block-cover.is-style-heiko-parallax,
.wp-block-cover.has-parallax {
	min-height: calc(100vh - var(--topbar-height));
	border-bottom: 1px solid var(--color-border);
	background-color: var(--color-bg);
}

.wp-block-cover.is-style-heiko-parallax .wp-block-cover__background {
	background: var(--color-bg);
	opacity: 1;
}

.wp-block-cover.is-style-heiko-parallax .wp-block-cover__inner-container {
	width: 100%;
	max-width: none;
	color: var(--color-text);
}

.wp-block-cover.is-style-heiko-parallax h1,
.wp-block-cover.is-style-heiko-parallax h2 {
	max-width: 18ch;
}

.heiko-product-hero {
	display: grid;
	align-items: center;
}

.heiko-product-hero__grid {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(18rem, 28rem);
	gap: clamp(3rem, 8vw, 8rem);
	align-items: center;
	width: min(calc(100% - 4rem), 82rem);
	margin-inline: auto;
}

.heiko-product-hero__copy {
	max-width: 52rem !important;
	margin: 0 !important;
}

.heiko-product-hero__copy > * {
	margin-left: 0 !important;
}

.heiko-product-hero__copy h1 {
	margin-block: 0 1.25rem;
	font-size: clamp(3rem, 5vw, 5.25rem) !important;
	font-weight: 650;
	line-height: 1.08;
}

.heiko-product-hero__copy p:not(.eyebrow) {
	max-width: 46rem;
	color: var(--color-text-muted);
	font-size: clamp(1.1rem, 1.5vw, 1.35rem) !important;
	line-height: 1.65;
}

.heiko-product-hero__copy .wp-block-buttons {
	margin-top: 2rem;
}

.heiko-product-hero__aside {
	display: grid;
	gap: 2rem;
	justify-items: center;
}

.heiko-hazard-mark {
	position: relative;
	display: grid;
	width: clamp(7rem, 11vw, 11rem);
	aspect-ratio: 1;
	place-items: center;
	border: 0.55rem solid var(--color-accent);
	margin: 0;
	color: transparent;
	font-size: clamp(4rem, 8vw, 7rem);
	font-weight: 900;
	line-height: 1;
	transform: rotate(45deg);
}

.heiko-hazard-mark::before {
	content: "!";
	position: absolute;
	color: var(--color-text);
	transform: rotate(-45deg);
}

.heiko-focus-card {
	width: min(100%, 22rem);
	padding: 2rem;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-large);
	background: var(--color-bg);
	box-shadow: var(--shadow-card);
}

.heiko-focus-card .eyebrow {
	margin-bottom: 1.25rem;
}

.heiko-focus-card ul {
	display: grid;
	gap: 1rem;
	padding-left: 1.2rem;
	margin: 0;
	color: var(--color-text);
	font-weight: 750;
	line-height: 1.5;
}

.heiko-focus-card li::marker {
	color: var(--color-accent);
}

.wp-block-query.is-style-heiko-scroll-rail .wp-block-post-template {
	display: grid;
	grid-auto-columns: minmax(18rem, 26rem);
	grid-auto-flow: column;
	grid-template-columns: none;
	gap: 1rem;
	overflow-x: auto;
	padding-block: 0.25rem 1rem;
	scroll-padding-inline: 1rem;
	scroll-snap-type: x proximity;
}

.wp-block-query.is-style-heiko-scroll-rail .wp-block-post-template > li {
	display: flex;
	min-height: 19rem;
	flex-direction: column;
	scroll-snap-align: start;
}

.wp-block-query.is-style-heiko-scroll-rail .wp-block-post-excerpt {
	margin-top: auto;
}

.wp-block-group.is-style-heiko-card {
	border: 1px solid var(--color-border);
	border-radius: var(--radius-large);
	background: var(--color-surface);
	box-shadow: var(--shadow-card);
}

.wp-block-group.is-style-heiko-card:not(.has-global-padding) {
	padding: clamp(1.25rem, 3vw, 2rem);
}

@media (max-width: 48rem) {
	.heiko-site-header {
		left: 0;
	}

	.heiko-site-header__inner {
		flex-wrap: wrap !important;
		justify-content: center !important;
		padding-block: 0.75rem;
	}

	.heiko-site-header__actions {
		flex-wrap: wrap !important;
		justify-content: center !important;
	}

	.wp-block-social-links.is-style-heiko-header-social {
		padding-left: 0;
		border-left: 0;
	}

	.heiko-theme-label,
	.heiko-language-navigation {
		min-height: auto;
		border-left: 0;
		line-height: 1.2;
	}

	.heiko-shell-content {
		margin-left: 0;
	}

	.heiko-app-sidebar {
		position: static;
		width: auto;
		border-right: 0;
		border-bottom: 1px solid var(--color-border);
	}

	.heiko-sidebar-brand {
		display: none !important;
	}

	.heiko-shell-main {
		padding-inline: 1rem;
	}

	.heiko-shell-main--home {
		padding-inline: 0;
	}

	.wp-block-cover.is-style-heiko-parallax,
	.wp-block-cover.has-parallax {
		min-height: 32rem;
		background-attachment: scroll;
	}

	.heiko-product-hero__grid {
		grid-template-columns: 1fr;
		width: min(calc(100% - 2rem), 38rem);
		padding-block: 3rem;
	}

	.heiko-product-hero__copy h1 {
		font-size: clamp(2.4rem, 14vw, 4rem) !important;
	}

	.heiko-product-hero__aside {
		justify-items: start;
	}

	.wp-block-query.is-style-heiko-scroll-rail .wp-block-post-template {
		grid-auto-columns: minmax(16rem, 86vw);
	}
}
