/* ── Full page width breakout ────────────────────────────────────────────── */
.elementor-element > .e-con-inner:has(> .elementor-widget-blaek-servicelinks-widget),
.elementor-element > .e-con-inner:has(> .elementor-widget-blaek-servicelinks-widget-offen){
	padding: 0 !important;
}

/* The widget element and its inner container must stay overflow-visible
   so the content is not clipped during the JS breakout. */
.elementor-widget-blaek-servicelinks-widget:has(.blaek-servicelinks-widget--page-width),
.elementor-widget-blaek-servicelinks-widget:has(.blaek-servicelinks-widget--page-width) > .elementor-widget-container {
	overflow: visible !important;
}

/* JS sets width + margin-left on .elementor-widget-blaek-servicelinks-widget */
.blaek-servicelinks-widget--page-width {
	box-sizing: border-box;
}

/* Inner wrapper: constrains content to --content-width inside the full-vw breakout */
.blaek-servicelinks-widget__inner {
	max-width: var(--content-width);
	margin-left: auto;
	margin-right: auto;
	width: 100%;
	box-sizing: border-box;
}

/* ── List wrapper (flexbox, auto-centres when items < columns) ───────────── */

.blaek-servicelinks-widget__list {
	--blaek-slw-columns: 4;
	--blaek-slw-col-gap: 90px;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
	column-gap: 90px;
	row-gap: 90px;
	width: 100%;
}

/* ── Individual item ─────────────────────────────────────────────────────── */

.blaek-servicelinks-widget__item {
	flex: 0 0 calc((100% - (var(--blaek-slw-columns, 4) - 1) * var(--blaek-slw-col-gap, 90px)) / var(--blaek-slw-columns, 4));
	max-width: calc((100% - (var(--blaek-slw-columns, 4) - 1) * var(--blaek-slw-col-gap, 90px)) / var(--blaek-slw-columns, 4));
	display: flex;
	flex-direction: column;
	padding: 0;
	/* overflow: hidden; */
	transition: background-color 0.3s ease;
	box-sizing: border-box;
}

/* ── Icon ────────────────────────────────────────────────────────────────── */

.blaek-servicelinks-widget__icon {
	display: inline-flex;
	align-items: center;
	line-height: 1;
	margin-bottom: 20px;
	transition: color 0.3s ease, fill 0.3s ease;
}

.blaek-servicelinks-widget__icon svg {
	display: block;
	fill: currentColor;
	transition: fill 0.3s ease;
}

/* ── Title ───────────────────────────────────────────────────────────────── */

.blaek-servicelinks-widget__title {
	margin: 0 0 16px 0;
	line-height: 1.3;
	transition: color 0.3s ease;
}

/* ── Hidden content (description + button): revealed on hover ────────────── */

.blaek-servicelinks-widget__description {
	opacity: 0;
	max-height: 0;
	/* overflow: hidden; */
	transform: translateY(10px);
	transition: all 0.4s ease;
	margin-bottom: 0;
}

.blaek-servicelinks-widget__button-wrapper {
	margin-top: auto;
	opacity: 0;
	overflow: hidden;
	max-height: 0;
	transform: translateY(10px);
	transition: all 0.4s ease;
}

/* ── Button ──────────────────────────────────────────────────────────────── */

.blaek-servicelinks-widget__button {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	text-decoration: none;
	transition: color 0.2s ease;
}

.blaek-servicelinks-widget__button:hover {
	text-decoration: none;
}

.blaek-servicelinks-widget__button-text {
	position: relative;
}

.blaek-servicelinks-widget__button-icon {
	display: inline-flex;
	align-items: center;
	flex-shrink: 0;
	color: inherit;
}

.blaek-servicelinks-widget__button-icon svg {
	display: block;
	fill: currentColor;
	transition: fill 0.3s ease;
}

.blaek-servicelinks-widget__button-icon svg * {
	transition: fill 0.3s ease;
}

/* ── Hover: reveal description and button ────────────────────────────────── */

@media (hover: hover) and (pointer: fine) {
	.blaek-servicelinks-widget:not(.blaek-servicelinks-widget--offen) .blaek-servicelinks-widget__item:hover .blaek-servicelinks-widget__description {
		opacity: 1;
		transform: translateY(0);
		max-height: 200px;
	}
	.blaek-servicelinks-widget:not(.blaek-servicelinks-widget--offen) .blaek-servicelinks-widget__item:hover .blaek-servicelinks-widget__button-wrapper {
		opacity: 1;
		transform: translateY(0);
		max-height: 120px;
	}
}

/* ── Focus: same reveal as hover, for keyboard users on every device ─────── */

.blaek-servicelinks-widget:not(.blaek-servicelinks-widget--offen) .blaek-servicelinks-widget__item:focus-within .blaek-servicelinks-widget__description {
	opacity: 1;
	transform: translateY(0);
	max-height: 200px;
}
.blaek-servicelinks-widget:not(.blaek-servicelinks-widget--offen) .blaek-servicelinks-widget__item:focus-within .blaek-servicelinks-widget__button-wrapper {
	opacity: 1;
	transform: translateY(0);
	max-height: 120px;
}

/* ── Touch fallback: always show description and button ──────────────────── */

@media (hover: none) {
	.blaek-servicelinks-widget__description {
		opacity: 1;
		max-height: none;
		transform: translateY(0);
	}
	.blaek-servicelinks-widget__button-wrapper {
		opacity: 1;
		max-height: 120px;
		transform: translateY(0);
	}
}

/* ── Servicelinks Widget offen: always visible, no hover transform ───────── */

.blaek-servicelinks-widget--offen .blaek-servicelinks-widget__description {
	opacity: 1;
	max-height: none;
	overflow: visible;
	transform: none;
	transition: none;
}

.blaek-servicelinks-widget--offen .blaek-servicelinks-widget__description > *:last-child {
	margin-bottom: 0;
}

.blaek-servicelinks-widget--offen .blaek-servicelinks-widget__button-wrapper {
	opacity: 1;
	max-height: none;
	overflow: visible;
	transform: none;
	transition: none;
}

