/* ===================== CSS RESET ===================== */
/* Universal box-sizing, zero default margin/padding */

*,
*::before,
*::after {
	box-sizing: border-box;
	margin: 0;
	padding: 0;
}

a {
	color: inherit;
	text-decoration: none;
}

/* picture { display: contents } — critical rendering fix:
   CSS child combinators like `.hero > img` and `.card > img` broke when
   WebP support required wrapping every <img> in a <picture> element.
   `display: contents` makes <picture> invisible to the layout engine so
   the img is treated as if it were the direct child of the parent. */
picture {
	display: contents;
}

/* ===================== DESIGN TOKENS ===================== */
/* CSS custom properties: breakpoints, colors, spacing, typography scale.
   Color naming: --aqua / --darkaqua are the Urbanova brand primary colors.
   --primary / --secondary alias the brand colors for semantic use. */

:root {

	--sm: 576px;
	--md: 768px;
	--lg: 992px;
	--xl: 1200px;

	--black: #000;
	--transblack: rgba(0, 0, 0, 0.7);
	--gray: #ccc;
	--darkgray: #555;
	--shadow: rgba(0, 0, 0, 0.2);
	--darkshadow: rgba(0, 0, 0, 0.4);

	--shadow-card: 0 2px 4px rgba(0, 0, 0, .05), 0 8px 24px rgba(0, 0, 0, .09);
	--shadow-card-hover: 0 6px 12px rgba(0, 0, 0, .08), 0 12px 30px rgba(0, 0, 0, .13);
	--white: #fff;
	--subwhite: rgba(255, 255, 255, 0.25);
	--halfwhite: rgba(255, 255, 255, 0.5);
	--transwhite: rgba(255, 255, 255, 0.75);
	--light: #f6f6f6;
	--lightgray: #f1f1f1;
	--beige: #F5F4F2;

	/* Urbanova CI — Projekt Parking Sp. z o.o. */
	--urbanova-blue: #053a66;
	--urbanova-darkblue: #021729;
	--urbanova-red: #be0005;
	--urbanova-darkred: #8c0005;
	--urbanova-blue-70: rgba(5, 58, 102, 0.7);
	--primary-tint: rgba(5, 58, 102, 0.07);
	--primary-border: rgba(5, 58, 102, 0.22);

	--blue: #053a66;
	--darkblue: #021729;
	--aqua: #0097be;
	--darkaqua: #007694;
	--red: #be0005;
	--darkred: #8c0005;
	--yellow: #ffb700;
	--darkyellow: #E09600;
	--green: #00BE86;

	--header: 70px;
	--radius: 10px;
	--radius-mid: 1.2rem;
	--radius-large: 2rem;
	--radius-full: 2000px;
	--gap: 1rem;
	--site-padding: 1rem;
	--sidebar-width: 300px;

	--font-size: 16px;
	--bold: 600;
	--semibold: 600;
	--regular: 400;
	--thin: 300;

	--limit-narrow: 765px;
	--limit-middle: 900px;
	--limit-wide: 1200px;

	--primary: var(--urbanova-blue);
	--secondary: var(--urbanova-red);
	--primary-dark: var(--urbanova-darkblue);
	--secondary-dark: var(--urbanova-darkred);
}

@media (min-width: 576px) {
	:root {
		--site-padding: 2rem;
	}
}

@media (min-width: 768px) {
	:root {
		--header: 100px;
		--font-size: 18px;
	}
}

@media (min-width: 992px) {
	:root {
		--site-padding: 3rem;
	}
}

@media (min-width: 1200px) {
	:root {
		--gap: 1.5rem;
		--site-padding: 4rem;
		--sidebar-width: 380px;
	}
}

@media (min-width: 1600px) {
	:root {
		--gap: 2rem;
	}
}

/* ===================== LAYOUT GRID ===================== */
/* 12-column responsive grid: .container, .row, .col-sm-*, .col-md-*, .col-lg-*, .col-xl-*
   Mirrors Bootstrap 3 col naming for legacy familiarity.
   Breakpoints match the CSS custom properties: --sm 576 / --md 768 / --lg 992 / --xl 1200 */

.container {
	width: 100%;
	margin: 0 auto;
	padding: 0 var(--site-padding);
	max-width: calc(1400px + 2 * var(--site-padding));
}

.container-narrow {
	width: 100%;
	margin: 0 auto;
	padding: 0 var(--site-padding);
	max-width: calc(var(--limit-middle) + 2 * var(--site-padding));
}

.prose {
	max-width: 65ch;
	margin-left: auto;
	margin-right: auto;
}

.container-wide {
	width: 100%;
	margin: 0 auto;
	padding: 0 var(--site-padding);
}

.container.full {
	padding: 0;
}

.container.has-sidebar {
	display: flex;
	flex-wrap: nowrap;
}

.row {
	display: flex;
	flex-wrap: wrap;
	margin: 0;
}

[class^="col-"] {
	flex: 1 1 100%;
	padding: 0;
	margin-bottom: 1.5rem;
}

@media (min-width: 576px) {

	.row {
		margin: 0 calc(-1 * var(--gap));
	}

	[class^="col-"] {
		padding: 0 var(--gap);
		margin-bottom: var(--gap);
	}

	.col-sm-1 {
		flex: 0 0 8.333%;
		max-width: 8.333%;
	}

	.col-sm-2 {
		flex: 0 0 16.666%;
		max-width: 16.666%;
	}

	.col-sm-3 {
		flex: 0 0 25%;
		max-width: 25%;
	}

	.col-sm-4 {
		flex: 0 0 33.333%;
		max-width: 33.333%;
	}

	.col-sm-5 {
		flex: 0 0 41.666%;
		max-width: 41.666%;
	}

	.col-sm-6 {
		flex: 0 0 50%;
		max-width: 50%;
	}

	.col-sm-7 {
		flex: 0 0 58.333%;
		max-width: 58.333%;
	}

	.col-sm-8 {
		flex: 0 0 66.666%;
		max-width: 66.666%;
	}

	.col-sm-9 {
		flex: 0 0 75%;
		max-width: 75%;
	}

	.col-sm-10 {
		flex: 0 0 83.333%;
		max-width: 83.333%;
	}

	.col-sm-11 {
		flex: 0 0 91.666%;
		max-width: 91.666%;
	}

	.col-sm-12 {
		flex: 0 0 100%;
		max-width: 100%;
	}
}

@media (min-width: 768px) {
	.col-md-1 {
		flex: 0 0 8.333%;
		max-width: 8.333%;
	}

	.col-md-2 {
		flex: 0 0 16.666%;
		max-width: 16.666%;
	}

	.col-md-3 {
		flex: 0 0 25%;
		max-width: 25%;
	}

	.col-md-4 {
		flex: 0 0 33.333%;
		max-width: 33.333%;
	}

	.col-md-5 {
		flex: 0 0 41.666%;
		max-width: 41.666%;
	}

	.col-md-6 {
		flex: 0 0 50%;
		max-width: 50%;
	}

	.col-md-7 {
		flex: 0 0 58.333%;
		max-width: 58.333%;
	}

	.col-md-8 {
		flex: 0 0 66.666%;
		max-width: 66.666%;
	}

	.col-md-9 {
		flex: 0 0 75%;
		max-width: 75%;
	}

	.col-md-10 {
		flex: 0 0 83.333%;
		max-width: 83.333%;
	}

	.col-md-11 {
		flex: 0 0 91.666%;
		max-width: 91.666%;
	}

	.col-md-12 {
		flex: 0 0 100%;
		max-width: 100%;
	}
}

@media (min-width: 992px) {
	.col-lg-1 {
		flex: 0 0 8.333%;
		max-width: 8.333%;
	}

	.col-lg-2 {
		flex: 0 0 16.666%;
		max-width: 16.666%;
	}

	.col-lg-3 {
		flex: 0 0 25%;
		max-width: 25%;
	}

	.col-lg-4 {
		flex: 0 0 33.333%;
		max-width: 33.333%;
	}

	.col-lg-5 {
		flex: 0 0 41.666%;
		max-width: 41.666%;
	}

	.col-lg-6 {
		flex: 0 0 50%;
		max-width: 50%;
	}

	.col-lg-7 {
		flex: 0 0 58.333%;
		max-width: 58.333%;
	}

	.col-lg-8 {
		flex: 0 0 66.666%;
		max-width: 66.666%;
	}

	.col-lg-9 {
		flex: 0 0 75%;
		max-width: 75%;
	}

	.col-lg-10 {
		flex: 0 0 83.333%;
		max-width: 83.333%;
	}

	.col-lg-11 {
		flex: 0 0 91.666%;
		max-width: 91.666%;
	}

	.col-lg-12 {
		flex: 0 0 100%;
		max-width: 100%;
	}
}

@media (min-width: 1200px) {
	.col-xl-1 {
		flex: 0 0 8.333%;
		max-width: 8.333%;
	}

	.col-xl-2 {
		flex: 0 0 16.666%;
		max-width: 16.666%;
	}

	.col-xl-3 {
		flex: 0 0 25%;
		max-width: 25%;
	}

	.col-xl-4 {
		flex: 0 0 33.333%;
		max-width: 33.333%;
	}

	.col-xl-5 {
		flex: 0 0 41.666%;
		max-width: 41.666%;
	}

	.col-xl-6 {
		flex: 0 0 50%;
		max-width: 50%;
	}

	.col-xl-7 {
		flex: 0 0 58.333%;
		max-width: 58.333%;
	}

	.col-xl-8 {
		flex: 0 0 66.666%;
		max-width: 66.666%;
	}

	.col-xl-9 {
		flex: 0 0 75%;
		max-width: 75%;
	}

	.col-xl-10 {
		flex: 0 0 83.333%;
		max-width: 83.333%;
	}

	.col-xl-11 {
		flex: 0 0 91.666%;
		max-width: 91.666%;
	}

	.col-xl-12 {
		flex: 0 0 100%;
		max-width: 100%;
	}
}

@media screen and (max-width: 575px) {
	.nomargin {
		width: calc(100% + 2 * var(--site-padding));
		margin-left: calc(-1 * var(--site-padding));
		margin-right: calc(-1 * var(--site-padding));
	}

	.nomargin img,
	.nomargin form {
		border-radius: 0 !important;
	}
}

.container.full .row {
	margin: 0 .5rem;
}

.container.full .row [class^="col-"] {
	padding: .5rem;
}

@media screen and (min-width: 576px) {
	.container.full .row [class^="col-"] {
		padding-bottom: 2.5rem;
	}
}

/* ===================== ACCESSIBILITY UTILITIES ===================== */
/* Skip navigation link (WCAG 2.4.1) and visually-hidden utility class.
   .visually-hidden hides content from sighted users while keeping it
   accessible to screen readers (preferred over display:none). */

.skip-link {
	position: absolute;
	left: -10000px;
	top: 0;
	width: 1px;
	height: 1px;
	overflow: hidden;
	z-index: 9999;
}

.skip-link:focus,
.skip-link:focus-visible {
	left: 0;
	top: 0;
	width: auto;
	height: auto;
	padding: .75rem 1rem;
	background: var(--primary, #007694);
	color: var(--white, #fff);
	font-weight: 600;
	outline: 3px solid var(--secondary, #0097be);
}

.visually-hidden {
	position: absolute !important;
	width: 1px !important;
	height: 1px !important;
	padding: 0 !important;
	margin: -1px !important;
	overflow: hidden !important;
	clip: rect(0, 0, 0, 0) !important;
	white-space: nowrap !important;
	border: 0 !important;
}

.text-center {
	text-align: center;
}

@media (prefers-reduced-motion: no-preference) {
	html {
		scroll-behavior: smooth;
	}
}

*:focus {
	outline: none;
}

*:focus-visible {
	outline: 3px solid var(--secondary, #0097be);
	outline-offset: 2px;
}

/* ===================== URBANOVA BASE STYLES ===================== */
/* Scoped under body.urbanova to isolate from non-Urbanova pages (login2.php).
   Includes: @font-face (self-hosted Commissioner), body reset, typography scale,
   headings, lists with bullet markers, links, horizontal rules. */

body.urbanova,
body.urbanova *,
body.urbanova *::before,
body.urbanova *::after {
	box-sizing: border-box;
}

@font-face {
	font-family: 'Commissioner';
	font-style: normal;
	font-weight: 300 600;
	/* font-display: optional — browser uses fallback immediately if font not cached,
	   preventing FOUT (Flash of Unstyled Text) and layout shifts (CLS) */
	font-display: optional;
	src: url('/assets/fonts/commissioner/commissioner-latin-ext.woff2') format('woff2');
	unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF,
		U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF,
		U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

@font-face {
	font-family: 'Commissioner';
	font-style: normal;
	font-weight: 300 600;
	font-display: optional;
	src: url('/assets/fonts/commissioner/commissioner-latin.woff2') format('woff2');
	unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA,
		U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122,
		U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

body.urbanova,
body.urbanova * {
	font-family: "Commissioner", Arial, Helvetica, sans-serif;
}

body.urbanova {
	font-optical-sizing: auto;
	font-weight: var(--regular);
	font-style: normal;
	font-size: 1rem;
	line-height: 1.8;
	background-color: var(--beige);
	color: var(--black);
	overflow-x: hidden;
}

body.urbanova.no-scroll {
	overflow: hidden;
	height: 100%;
}

body.urbanova p,
body.urbanova main ul {
	margin-bottom: 1.5rem;
}

body.urbanova p {
	hyphens: auto;
	-webkit-hyphens: auto;
	overflow-wrap: break-word;
	text-wrap: pretty;
}

body.urbanova p small {
	display: block;
	font-size: 0.85rem;
	color: var(--black);
	margin-top: 0.5rem;
}

body.urbanova [class^="col-"]>p:last-child {
	margin-bottom: 0;
}

body.urbanova strong {
	font-weight: var(--semibold);
}

body.urbanova a:hover {
	color: inherit;
}

body.urbanova a.inactive {
	pointer-events: none;
	cursor: default;
}

body.urbanova p a:not(.btn):not(.glightbox):not([href^="tel"]),
body.urbanova .list a:not(.btn):not(.glightbox):not([href^="tel"]),
body.urbanova main ul li a:not(.btn):not(.glightbox):not(.issue-tile):not([href^="tel"]) {
	padding-bottom: 4px;
	background-size: 100% 2px, 0 2px;
	background-position: 100% 100%, 0 100%;
	background-repeat: no-repeat;
	transition: background-size 0.5s cubic-bezier(.65, .05, .36, 1);
	font-weight: var(--semibold);
	background-image: linear-gradient(var(--secondary), var(--secondary)), linear-gradient(var(--black), var(--black));
}

body.urbanova p a:not(.btn):not(.glightbox):not([href^="tel"]):hover,
body.urbanova .list a:not(.btn):not(.glightbox):not([href^="tel"]):hover,
body.urbanova main ul li a:not(.btn):not(.glightbox):not(.issue-tile):not([href^="tel"]):hover {
	background-size: 0 2px, 100% 2px;
}

body.urbanova .dark p a:not(.btn):not(.glightbox):not([href^="tel"]),
body.urbanova .dark .list a:not(.btn):not(.glightbox):not([href^="tel"]),
body.urbanova main .dark ul li a:not(.btn):not(.glightbox):not(.issue-tile):not([href^="tel"]),
body.urbanova .urbanova-footer p a:not(.btn):not([href^="tel"]) {
	background-image: linear-gradient(var(--transwhite), var(--transwhite)), linear-gradient(var(--white), var(--white));
}

body.urbanova .list,
body.urbanova main ul {
	margin-bottom: 1.5rem;
	line-height: 1.5;
}

body.urbanova .list li,
body.urbanova main ul li {
	margin-left: 1.5rem;
	margin-bottom: .75rem;
	text-indent: -.75rem;
	list-style: none;
}

body.urbanova .list li::before,
body.urbanova main ul li::before {
	font-weight: var(--bold);
	line-height: 0;
	font-size: 1rem;
	padding-right: .75rem;
	display: inline-block;
	content: "\FFED";
	position: relative;
	top: 0;
	color: var(--secondary);
}

body.urbanova .list-red li::before {
	color: var(--red);
}

body.urbanova .list-blue li::before {
	color: var(--blue);
}

body.urbanova .list-yellow li::before {
	color: var(--yellow);
}

body.urbanova .list-aqua li::before {
	color: var(--aqua);
}

body.urbanova h1,
body.urbanova .h1 {
	font-size: 2.1rem;
	font-weight: var(--bold);
	line-height: 1.1;
	margin-bottom: 2.5rem;
	letter-spacing: -.08rem;
	max-width: var(--limit-narrow);
	color: var(--primary);
	text-wrap: balance;
}

body.urbanova h1::after,
body.urbanova .h1::after {
	content: "";
	display: block;
	width: 5rem;
	height: 7px;
	background-color: var(--secondary);
	margin-top: 1.5rem;
}

body.urbanova h2,
body.urbanova .h2 {
	font-size: 1.7rem;
	font-weight: var(--semibold);
	line-height: 1.1;
	margin-bottom: 1.5rem;
	letter-spacing: -.05rem;
	color: var(--primary-dark);
	text-wrap: balance;
}

body.urbanova p+h2,
body.urbanova p+.h2,
body.urbanova ul+h2,
body.urbanova ul+.h2,
body.urbanova p+h3,
body.urbanova p+.h3,
body.urbanova ul+h3,
body.urbanova ul+.h3 {
	margin-top: 2.5rem;
}

body.urbanova h3,
body.urbanova .h3 {
	font-size: 1.5rem;
	font-weight: var(--semibold);
	line-height: 1.1;
	margin-bottom: 1.5rem;
}

body.urbanova h4,
body.urbanova .h4 {
	font-size: 1.111rem;
	font-weight: var(--bold);
	line-height: 1.1;
	margin-bottom: 1.4rem;
	text-transform: uppercase;
}

body.urbanova .h1,
body.urbanova .h2,
body.urbanova .h3,
body.urbanova .h4 {
	display: block;
}

@media (min-width: 576px) {

	body.urbanova h1,
	body.urbanova .h1 {
		font-size: 3.5rem;
		margin-bottom: 4rem;
		letter-spacing: -.15rem;
	}

	body.urbanova h1::after,
	body.urbanova .h1::after {
		width: 5rem;
		height: 7px;
		margin-top: 2rem;
	}

	body.urbanova h2,
	body.urbanova .h2 {
		font-size: 2.4rem;
		margin-bottom: 2rem;
		letter-spacing: -.09rem;
	}

	body.urbanova h3,
	body.urbanova .h3 {
		font-size: 1.6rem;
		margin-bottom: 1.5rem;
	}
}

@media (max-width: 991px) {
	body.urbanova .excerpt p {
		line-height: 1.4;
	}
}

@media (min-width: 992px) {

	body.urbanova p.copy,
	body.urbanova .copy p {
		font-size: 1.2rem;
		line-height: 1.6;
		margin-bottom: 1.75rem;
	}

	body.urbanova .copy .list {
		font-size: 1.16666rem;
		margin-bottom: 1.75rem;
	}

	body.urbanova .copy .block {
		margin-bottom: 2.5rem;
	}
}

body.urbanova hr {
	border: none;
	border-top: 2px solid var(--darkgray);
	margin: 2.5rem 0;
}

body.urbanova .dark hr {
	border-color: var(--white);
}

body.urbanova hr.spacer {
	border: none;
	margin: 0;
	padding: 2rem 0;
}

body.urbanova {
	font-size: var(--font-size);
}

/* ===================== BUTTON COMPONENTS ===================== */
/* .btn (primary), .btn-outline (secondary), .btn-accent, .btn-white, .btn-ghost, .btn-sm.
   All use inline-flex for icon alignment. Focus-visible ring for keyboard accessibility. */

body.urbanova .btn {
	display: inline-flex;
	align-items: center;
	gap: .5rem;
	padding: .7rem 1.5rem;
	background: var(--primary);
	color: var(--white);
	font-weight: var(--semibold);
	font-size: 1rem;
	line-height: 1.2;
	border-radius: var(--radius-full);
	border: 2px solid var(--primary);
	cursor: pointer;
	transition: background .2s ease, color .2s ease, border-color .2s ease, transform .15s ease;
	text-align: center;
	text-decoration: none;
	background-image: none;
}

body.urbanova .btn:hover {
	background: var(--primary-dark);
	border-color: var(--primary-dark);
	color: var(--white);
}

body.urbanova .btn:active {
	transform: translateY(1px);
}

body.urbanova .btn:focus-visible {
	outline: 3px solid var(--secondary);
	outline-offset: 3px;
}

body.urbanova .btn.btn-outline,
body.urbanova .btn.btn-secondary {
	background: transparent;
	color: var(--primary);
	border-color: var(--primary);
}

body.urbanova .btn.btn-outline:hover,
body.urbanova .btn.btn-secondary:hover {
	background: var(--primary);
	color: var(--white);
	border-color: var(--primary);
}

body.urbanova .btn.btn-block {
	width: 100%;
	justify-content: center;
}

body.urbanova .btn.btn-accent {
	background: var(--secondary);
	border-color: var(--secondary);
	color: var(--white);
}

body.urbanova .btn.btn-accent:hover {
	background: var(--secondary-dark);
	border-color: var(--secondary-dark);
	color: var(--white);
}

body.urbanova .btn.btn-white {
	background: var(--white);
	color: var(--primary);
	border-color: var(--white);
}

body.urbanova .btn.btn-white:hover {
	background: var(--primary);
	color: var(--white);
	border-color: var(--primary);
}

body.urbanova .btn.btn-ghost {
	background: rgba(0, 0, 0, 0.38);
	color: var(--white);
	border-color: rgba(255, 255, 255, 0.85);
}

body.urbanova .btn.btn-ghost:hover {
	background: rgba(0, 0, 0, 0.58);
	border-color: var(--white);
	color: var(--white);
}

body.urbanova .btn-sm {
	padding: .4rem 1.1rem;
	font-size: 0.85rem;
}

body.urbanova .hero-cta {
	display: flex;
	flex-wrap: wrap;
	gap: 1rem;
	margin-top: 2rem;
}

/* ===================== HERO SECTIONS ===================== */
/* .hero (base), .hero-band (fixed-height banner), .hero-full (viewport-height),
   .hero-content (text overlay), .home-hero (homepage variant with full-width bleed).
   hero>picture is set to display:block (overrides display:contents) so the picture
   element participates in the flex/grid layout as expected. */

body.urbanova .hero {
	position: relative;
	width: 100%;
	overflow: hidden;
	background: var(--lightgray);
}

body.urbanova .hero>img,
body.urbanova .hero>picture {
	display: block;
	width: 100%;
	height: 100%;
}

body.urbanova .hero>picture>img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
	filter: brightness(0.7);
}

body.urbanova .hero>img {
	object-fit: cover;
	object-position: center;
	filter: brightness(0.55);
}

body.urbanova .hero-band {

	aspect-ratio: 16 / 5;
	min-height: 200px;
	max-height: 50vh;
}

body.urbanova .hero-full {

	aspect-ratio: 16 / 9;
	min-height: 60vh;
}

body.urbanova .hero-content {
	position: absolute;
	inset: 0;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	padding: var(--site-padding);
	color: var(--white);
	background: linear-gradient(to top, rgba(0, 0, 0, .55) 0%, rgba(0, 0, 0, 0) 60%);
}

body.urbanova .hero-content h1 {
	color: var(--white);
	max-width: var(--limit-wide);
	text-shadow: 0 1px 3px rgba(0, 0, 0, .6), 0 2px 14px rgba(0, 0, 0, .45);
}

body.urbanova .hero-band .hero-content {
	padding-bottom: 0.75rem;
	background: linear-gradient(to top,
			rgba(0, 0, 0, .65) 0%,
			rgba(0, 0, 0, .30) 55%,
			rgba(0, 0, 0, 0) 85%);
}

/* ===================== CARD COMPONENTS ===================== */
/* .card (square image card with hover lift), .cards-grid (4-column grid),
   .card-with-list (card + bullet list below), .card-title / .card-arrow overlay.
   card>picture is set to display:block so picture fills the aspect-ratio container. */

body.urbanova .card {
	position: relative;
	display: block;
	aspect-ratio: 1 / 1;
	overflow: hidden;
	border-radius: var(--radius);
	background: var(--gray);
	color: var(--white);
	text-decoration: none;
	background-image: none;
	transition: transform .25s ease, box-shadow .25s ease;
	box-shadow: 0 2px 6px rgba(0, 0, 0, .07), 0 6px 20px rgba(0, 0, 0, .11);
}

body.urbanova .card:hover {
	transform: translateY(-2px);
	box-shadow: var(--shadow-card-hover);
	color: var(--white);
}

body.urbanova .card>img,
body.urbanova .card>picture {
	display: block;
	width: 100%;
	height: 100%;
}

body.urbanova .card>picture>img,
body.urbanova .card>img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
	transition: transform .4s ease, filter .25s ease;
}

body.urbanova .card:hover>picture>img,
body.urbanova .card:hover>img {
	transform: scale(1.04);
	filter: brightness(.55);
}

body.urbanova .card + p {
	margin-top: 1.25rem;
}

body.urbanova .card-title {
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	padding: 2.5rem 1.1rem 1.1rem;
	background: linear-gradient(to top,
			rgba(0, 0, 0, .78) 0%,
			rgba(0, 0, 0, .52) 40%,
			rgba(0, 0, 0, 0) 70%);
	color: var(--white);
	font-weight: var(--semibold);
	font-size: 1rem;
	line-height: 1.2;
	pointer-events: none;

	display: -webkit-box;
	-webkit-line-clamp: 2;
	line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

body.urbanova .card-arrow {
	position: absolute;
	top: 50%;
	left: 50%;
	width: 44px;
	height: 44px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: var(--primary);
	color: var(--white);
	border-radius: 50%;
	box-shadow: 0 1px 6px rgba(0, 0, 0, .35);
	opacity: 0;
	transform: translate(-50%, -50%) scale(0.8);
	transition: opacity .25s ease, transform .25s ease;
	pointer-events: none;
}

body.urbanova .card:hover .card-arrow {
	opacity: 1;
	transform: translate(-50%, -50%) scale(1);
}

/* ===================== GALLERY GRID ===================== */
/* CSS Grid photo gallery used in news articles, anfahrtsskizzen, VZ-Katalog.
   Default: 2 columns → 3 at ≥576px → 4 at ≥992px.
   All gallery images use position:absolute/inset:0 instead of height:100%
   because the parent <a> has aspect-ratio (not a fixed height), which makes
   height:100% resolve to 0 in most browsers. */

body.urbanova .gallery {
	list-style: none;
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--gap);
	margin: 0 0 1.5rem;
	padding: 0;
}

body.urbanova .gallery li {
	margin: 0;
	padding: 0;
	text-indent: 0;
}

body.urbanova .gallery li::before {
	content: none;
}

body.urbanova .gallery a {
	display: block;
	position: relative;
	aspect-ratio: 1 / 1;
	overflow: hidden;
	border-radius: var(--radius);
	background: var(--lightgray);
	background-image: none;
	padding-bottom: 0;
	box-shadow: 0 2px 8px var(--shadow);
	transition: box-shadow .3s ease, transform .2s ease;
}

body.urbanova .gallery a:hover {
	box-shadow: 0 6px 20px var(--darkshadow);
	transform: translateY(-2px);
}

body.urbanova .gallery img {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform .4s ease;
}

body.urbanova .gallery a:hover img {
	transform: scale(1.04);
}

@media (min-width: 576px) {
	body.urbanova .gallery {
		grid-template-columns: repeat(3, 1fr);
	}
}

@media (min-width: 992px) {
	body.urbanova .gallery {
		grid-template-columns: repeat(4, 1fr);
	}
}

/* ===================== SECTION WRAPPERS ===================== */
/* .section (vertical padding), .section-light (beige bg), .section-white,
   .section-blue (brand blue #053a66), .section-dark (dark blue), .section-accent (primary color).
   Padding scales with viewport: 3rem → 5rem → 6rem. */

body.urbanova .section {
	padding: 3rem 0;
}

@media (min-width: 768px) {
	body.urbanova .section {
		padding: 5rem 0;
	}
}

@media (min-width: 1200px) {
	body.urbanova .section {
		padding: 6rem 0;
	}
}

body.urbanova .section-light {
	background: var(--beige);
	color: var(--black);
}

body.urbanova .section-white {
	background: var(--white);
	color: var(--black);
}

body.urbanova .section-blue {
	background: var(--blue);
	color: var(--white);
}

body.urbanova .section-blue.section-blue *,
body.urbanova .section-blue h1,
body.urbanova .section-blue h2,
body.urbanova .section-blue h3,
body.urbanova .section-blue h4 {
	color: var(--white);
}

/* Buttons on .section-blue — specificity 0,4,1 beats .section-blue.section-blue * (0,3,1).
   btn-white: white bg + primary text; hover deepens to darkblue (primary hover = same as bg → invisible).
   btn-outline: white border + white text; hover inverts to white bg + primary text.
   btn (plain primary): bg same as section → darken to darkblue. */
body.urbanova .section-blue .btn.btn-white {
	background: var(--white);
	color: var(--primary);
	border-color: var(--white);
}

body.urbanova .section-blue .btn.btn-white:hover,
body.urbanova .section-blue .btn.btn-white:focus-visible {
	background: var(--darkblue);
	color: var(--white);
	border-color: var(--darkblue);
}

body.urbanova .section-blue .btn.btn-outline,
body.urbanova .section-blue .btn.btn-secondary {
	background: transparent;
	color: var(--white);
	border-color: var(--white);
}

body.urbanova .section-blue .btn.btn-outline:hover,
body.urbanova .section-blue .btn.btn-secondary:hover,
body.urbanova .section-blue .btn.btn-outline:focus-visible,
body.urbanova .section-blue .btn.btn-secondary:focus-visible {
	background: var(--white);
	color: var(--primary);
	border-color: var(--white);
}

body.urbanova .section-blue .btn:not(.btn-white):not(.btn-outline):not(.btn-secondary):not(.btn-accent):not(.btn-ghost) {
	background: var(--darkblue);
	color: var(--white);
	border-color: var(--darkblue);
}

body.urbanova .section-blue .btn:not(.btn-white):not(.btn-outline):not(.btn-secondary):not(.btn-accent):not(.btn-ghost):hover {
	background: var(--black);
	color: var(--white);
	border-color: var(--black);
}

body.urbanova .section-dark {
	background: var(--darkblue);
	color: var(--white);
}

body.urbanova .section-dark.section-dark *,
body.urbanova .section-dark h1,
body.urbanova .section-dark h2,
body.urbanova .section-dark h3,
body.urbanova .section-dark h4 {
	color: var(--white);
}

body.urbanova .section-accent {
	background: var(--primary);
	color: var(--white);
}

/* ===================== SUBMENU NAVIGATION ===================== */
/* Bottom-of-page "continue reading" nav used on service pages and Über uns.
   .submenu-leistungen variant: two-column layout with a "Verbundene Lösungen"
   pills column (product cross-links). .submenu-totop is the scroll-to-top arrow. */

body.urbanova .submenu {
	border-top: 1px solid var(--primary);
	padding-top: 2.5rem;
	margin-top: 3rem;
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
	position: relative;
}

@media (min-width: 768px) {
	body.urbanova .submenu {
		flex-direction: row;
		justify-content: space-between;
		align-items: flex-start;
	}
}

body.urbanova .submenu-title {
	font-size: 0.72rem;
	font-weight: var(--semibold);
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--darkgray);
	margin: 0 0 1rem;
}

body.urbanova .submenu-title a {
	color: inherit;
	background-image: none;
	padding-bottom: 0;
}

body.urbanova .submenu-title a:hover {
	color: var(--primary);
}

body.urbanova .submenu-title-secondary {
	margin-top: 1.5rem;
}

body.urbanova .submenu-list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
}

body.urbanova .submenu-list li {
	margin: 0 !important;
	padding: 0 !important;
	text-indent: 0;
}

body.urbanova .submenu-list li::before {
	content: none;
}

body.urbanova .submenu-list li a {
	display: inline-flex;
	align-items: center;
	padding: 0.3rem 0.85rem;
	border-radius: 2rem;
	font-size: 0.82rem;
	font-weight: var(--semibold);
	color: var(--primary);
	background: rgba(0, 160, 160, 0.07) !important;
	border: 1px solid rgba(0, 160, 160, 0.22);
	background-image: none !important;
	background-size: auto !important;
	padding-bottom: 0.3rem !important;
	transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease, transform 0.15s ease;
}

body.urbanova .submenu-list li a:hover {
	background: var(--secondary) !important;
	background-image: none !important;
	color: var(--white);
	border-color: var(--secondary);
	transform: translateY(-1px);
}

body.urbanova .submenu-totop {
	position: absolute;
	top: -1.35rem;
	right: 0;
	width: 2.7rem;
	height: 2.7rem;
	border-radius: 50%;
	background: var(--white);
	border: 1.5px solid var(--primary);
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--primary);
	font-size: 0;
	background-image: none;
	padding-bottom: 0;
	transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease, transform 0.2s ease;
}

body.urbanova .submenu-totop::before {
	content: none;
}

body.urbanova .submenu-totop:hover {
	background: var(--primary);
	color: var(--white);
	transform: translateY(-3px);
	box-shadow: var(--shadow-card);
}

@media (min-width: 768px) {
	body.urbanova .submenu-leistungen {
		flex-direction: column;
		align-items: stretch;
	}
}

body.urbanova .submenu-leistungen__body {
	display: grid;
	grid-template-columns: 1fr;
	gap: 2rem;
}

@media (min-width: 768px) {
	body.urbanova .submenu-leistungen__body {
		grid-template-columns: 1fr 1fr;
		gap: 3rem;
	}
}

body.urbanova .submenu-leistungen__label {
	font-size: 0.72rem;
	font-weight: var(--semibold);
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--darkgray);
	margin: 0 0 1rem;
}

body.urbanova .submenu-leistungen__tags {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
}

body.urbanova .submenu-leistungen__tags li {
	margin: 0 !important;
	padding: 0 !important;
	text-indent: 0;
}

body.urbanova .submenu-leistungen__tags li::before {
	content: none;
}

body.urbanova .submenu-leistungen__tags li a {
	display: inline-flex;
	align-items: center;
	padding: 0.3rem 0.85rem;
	border-radius: 2rem;
	font-size: 0.82rem;
	font-weight: var(--semibold);
	color: var(--primary);
	background: rgba(0, 160, 160, 0.07) !important;
	border: 1px solid rgba(0, 160, 160, 0.22);
	background-image: none !important;
	background-size: auto !important;
	padding-bottom: 0.3rem !important;
	transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease, transform 0.15s ease;
}

body.urbanova .submenu-leistungen__tags li a:hover {
	background: var(--secondary) !important;
	background-image: none !important;
	color: var(--white);
	border-color: var(--secondary);
	transform: translateY(-1px);
}

body.urbanova .submenu-leistungen .submenu-totop::before {
	content: none;
}

/* ===================== INFO & CONTACT CARDS ===================== */
/* .info-card (generic sidebar card — IHK badge, application CTA, etc.)
   .contact-card (service page sticky sidebar with team member photo + email)
   .contact-card.sticky: position:sticky to follow the user while scrolling long articles */

body.urbanova .info-card {
	background: var(--white);
	border: 1px solid var(--lightgray);
	border-radius: var(--radius);
	padding: 1.25rem;
	margin-bottom: 1rem;
}

body.urbanova .info-card h3 {
	color: var(--primary);
}

body.urbanova .info-card a:not(.btn) {
	background-image: none;
	padding-bottom: 0;
	color: var(--primary);
}

body.urbanova .info-card a:not(.btn):hover {
	color: var(--secondary-dark);
}

body.urbanova .info-card .btn {
	display: flex;
	width: 100%;
	justify-content: center;
}

body.urbanova .contact-card {
	background: var(--white);
	border: 1px solid var(--lightgray);
	border-radius: var(--radius);
	padding: 1.5rem;
	margin-bottom: 1.5rem;
}

body.urbanova .contact-card h3 {
	font-size: 1rem;
	margin-bottom: 1rem;
	color: var(--darkgray);
	text-transform: uppercase;
	letter-spacing: .05rem;
}

body.urbanova .contact-card-avatar {
	display: block;
	width: 6rem;
	height: 6rem;
	overflow: hidden;
	border-radius: 50%;
	margin: 0 0 1rem;
	background-image: none;
	padding-bottom: 0;
}

body.urbanova .contact-card-avatar img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

body.urbanova .contact-card h4 {
	font-size: 1.1rem;
	margin-bottom: .5rem;
	text-transform: none;
	color: var(--primary);
}

body.urbanova .contact-card p {
	margin: 0 0 .25rem;
	font-size: .95rem;
	line-height: 1.4;
	color: var(--black);
}

body.urbanova .contact-card p a {
	background-image: none;
	padding-bottom: 0;
}

@media (min-width: 992px) {

	body.urbanova .contact-card.sticky,
	body.urbanova .article-nav.sticky {
		position: sticky;
		top: calc(var(--header) + 1rem);
	}
}

/* ===================== SITE HEADER ===================== */
/* Sticky top navigation bar with logo, hamburger toggle (mobile), and nav drawer.
   Height adapts: 70px on mobile → 100px at ≥768px (via --header custom property).
   Nav drawer slides in from the right on mobile; displayed as a flex row on desktop.
   Focus trap and aria-expanded management handled by menu.js. */

body.urbanova .urbanova-header {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	width: 100%;
	background: var(--white);
	box-shadow: 0 1px 10px var(--shadow);
	z-index: 300;
	transition: top .3s ease-in-out, height .1s ease-in-out;
}

body.urbanova.header-hidden .urbanova-header {
	top: calc(-1 * var(--header));
}

body.urbanova .urbanova-header-container {
	display: flex;
	justify-content: space-between;
	align-items: center;
	height: var(--header);
	padding: 0 var(--site-padding);
	max-width: 100%;
}

body.urbanova .urbanova-header .logo {
	display: flex;
	align-items: center;
	z-index: 20;
	flex-shrink: 0;
}

body.urbanova .urbanova-header .logo img {
	height: 2rem;
	width: auto;
}

@media (min-width: 768px) {
	body.urbanova .urbanova-header .logo img {
		height: 2.5rem;
	}
}

body.urbanova main {
	padding-top: var(--header);
}

body.urbanova .menu-toggle {
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	width: 2.5rem;
	height: 2.5rem;
	background: transparent;
	border: none;
	cursor: pointer;
	padding: 0;
	z-index: 30;
	gap: 5px;
}

body.urbanova .menu-toggle span {
	display: block;
	width: 1.6rem;
	height: 2px;
	background: var(--black);
	transition: transform .3s ease, opacity .25s ease;
	border-radius: 1px;
}

body.urbanova .menu-toggle.open span:nth-child(1) {
	transform: translateY(7px) rotate(45deg);
}

body.urbanova .menu-toggle.open span:nth-child(2) {
	opacity: 0;
}

body.urbanova .menu-toggle.open span:nth-child(3) {
	transform: translateY(-7px) rotate(-45deg);
}

@media (min-width: 992px) {
	body.urbanova .menu-toggle {
		display: none;
	}
}

body.urbanova .urbanova-nav {
	position: fixed;
	top: 0;
	left: 0;
	bottom: 0;
	width: min(85vw, 360px);
	background: var(--white);
	box-shadow: 4px 0 20px var(--darkshadow);
	transform: translateX(-100%);
	transition: transform .35s cubic-bezier(.4, 0, .2, 1);
	z-index: 200;
	overflow-y: auto;
	padding: calc(var(--header) + 0.25rem) var(--site-padding) 2rem;
}

body.urbanova .urbanova-nav.open {
	transform: translateX(0);
}

body.urbanova .urbanova-nav ul {
	list-style: none;
	padding: 0;
	margin: 0;
}

body.urbanova .urbanova-nav ul li {
	margin: 0;
	padding: 0;
	text-indent: 0;
}

body.urbanova .urbanova-nav ul li::before {
	content: none;
}

body.urbanova .urbanova-nav ul li a {
	display: block;
	padding: 1rem 0;
	border-bottom: 1px solid var(--lightgray);
	color: var(--black);
	font-weight: var(--regular);
	font-size: 1.1rem;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	background-image: none;
	text-decoration: none;
}

body.urbanova .urbanova-nav ul li a.sel,
body.urbanova .urbanova-nav ul li a[aria-current="page"] {
	color: var(--primary);
	border-bottom-color: var(--secondary);
}

body.urbanova .urbanova-nav ul li a:hover,
body.urbanova .urbanova-nav ul li a:focus-visible {
	color: var(--primary);
}

body.urbanova .urbanova-nav ul li a.nav-login {
	margin-top: .75rem;
	background: var(--primary);
	color: var(--white);
	border-bottom: none;
	border-radius: var(--radius);
	text-align: center;
	font-weight: var(--semibold);
	font-size: .8rem;
	padding: .45rem 1rem;
}

body.urbanova .urbanova-nav ul li a.nav-login:hover,
body.urbanova .urbanova-nav ul li a.nav-login:focus-visible {
	background: var(--darkaqua);
	color: var(--white);
}

/* B2C nav item — "Parkujesz?" — mobile: separator + subtle tint */
body.urbanova .urbanova-nav ul li a.nav-b2c {
	margin-top: .5rem;
	padding-top: 1.25rem;
	border-top: 2px solid var(--lightgray);
	color: var(--black);
}

body.urbanova .nav-social {
	display: flex;
	gap: 1.25rem;
	padding: 1.75rem 0 0;
	align-items: center;
}

body.urbanova .nav-social a {
	display: flex;
	align-items: center;
	opacity: 0.45;
	transition: opacity .2s ease;
	background-image: none;
}

body.urbanova .nav-social a:hover {
	opacity: 1;
}

body.urbanova .nav-social img {
	display: block;
	filter: brightness(0);
}

@media (min-width: 992px) {
	body.urbanova .nav-social {
		display: none;
	}
}

body.urbanova .nav-overlay {
	position: fixed;
	inset: 0;
	background: var(--transblack);
	opacity: 0;
	visibility: hidden;
	transition: opacity .3s ease, visibility .3s ease;
	z-index: 150;
}

body.urbanova .nav-overlay.open {
	opacity: 1;
	visibility: visible;
}

@media (min-width: 992px) {

	body.urbanova .urbanova-nav {
		position: static;
		width: auto;
		height: auto;
		background: transparent;
		box-shadow: none;
		transform: none;
		transition: none;
		overflow: visible;
		padding: 0;
		display: flex;
		align-items: center;
		flex: 1;
		justify-content: flex-end;
	}

	body.urbanova .urbanova-nav ul {
		display: flex;
		gap: 0.25rem;
		align-items: center;
	}

	body.urbanova .urbanova-nav ul li a {
		display: inline-block;
		padding: .45rem 1rem;
		border-bottom: none;
		border-radius: var(--radius-full);
		background: transparent;
		font-size: 1.1rem;
		font-weight: var(--regular);
		text-transform: uppercase;
		letter-spacing: 0.05em;
		transition: background .2s ease, color .2s ease;
	}

	body.urbanova .urbanova-nav ul li a.sel,
	body.urbanova .urbanova-nav ul li a[aria-current="page"] {
		background: var(--primary);
		color: var(--white);
	}

	body.urbanova .urbanova-nav ul li a:hover,
	body.urbanova .urbanova-nav ul li a:focus-visible {
		background: var(--primary);
		color: var(--white);
	}

	body.urbanova .urbanova-nav ul li a.nav-login {
		background: var(--primary);
		color: var(--white);
		margin-top: 0;
		margin-left: .5rem;
		border-radius: var(--radius-full);
		text-align: left;
	}

	body.urbanova .urbanova-nav ul li a.nav-login:hover,
	body.urbanova .urbanova-nav ul li a.nav-login:focus-visible {
		background: var(--darkaqua);
	}

	/* B2C nav item — desktop: light pill at rest, primary on hover */
	body.urbanova .urbanova-nav ul li a.nav-b2c {
		background: var(--light);
		margin-top: 0;
		padding-top: .45rem;
		border-top: none;
		margin-left: .25rem;
	}



	body.urbanova .urbanova-nav ul li a.nav-b2c.sel,
	body.urbanova .urbanova-nav ul li a.nav-b2c[aria-current="page"] {
		color: var(--black);
	}

	body.urbanova .urbanova-nav ul li a.nav-b2c:hover,
	body.urbanova .urbanova-nav ul li a.nav-b2c:focus-visible {
		background: var(--primary);
		color: var(--white);
	}

	body.urbanova .nav-overlay {
		display: none;
	}
}

/* ===================== SITE FOOTER ===================== */
/* Dark-blue footer with three-column office address grid, legal nav, and social icons.
   Footer address columns collapse to a single column on mobile. */

body.urbanova .urbanova-footer {
	background: var(--darkblue);
	color: var(--white);
	padding: 3rem 0 1rem;
}

body.urbanova .urbanova-footer a {
	color: var(--white);
	text-decoration: none;
}

body.urbanova .urbanova-footer a:hover {
	color: var(--subwhite);
}

body.urbanova .footer-addresses {
	margin-bottom: 2rem;
	align-items: flex-start;
}

body.urbanova .footer-address {
	margin-bottom: 1.5rem;
}

body.urbanova .footer-address-company {
	font-weight: var(--semibold);
	margin-bottom: .75rem;
	color: var(--white);
}

body.urbanova .footer-address p {
	color: var(--white);
	font-size: .95rem;
	line-height: 1.6;
	margin-bottom: 0;
}

body.urbanova .footer-address p span {
	display: inline-block;
	width: 2rem;
	color: var(--white);
	font-size: .85rem;
}

body.urbanova .footer-legal {
	border-top: 1px solid var(--subwhite);
	padding-top: 1.5rem;
	margin-top: 2rem;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: center;
	gap: 1rem;
}

body.urbanova .footer-legal ul {
	display: flex;
	flex-wrap: wrap;
	gap: 1.5rem;
	list-style: none;
	margin: 0;
	padding: 0;
}

body.urbanova .footer-legal ul li {
	margin: 0;
	padding: 0;
	text-indent: 0;
}

body.urbanova .footer-legal ul li::before {
	content: none;
}

body.urbanova .footer-legal ul li a {
	color: var(--white);
	font-size: .9rem;
}

body.urbanova .footer-legal ul li a:hover {
	color: var(--white);
}

body.urbanova .footer-copyright {
	font-size: .9rem;
	color: var(--white);
	margin: 0;
}

body.urbanova .footer-social {
	display: flex;
	gap: 1rem;
	margin-top: 1.5rem;
}

body.urbanova .footer-social a {
	width: 2.5rem;
	height: 2.5rem;
	display: flex;
	align-items: center;
	justify-content: center;
	background: var(--subwhite);
	border-radius: 50%;
	transition: background .2s ease;
}

body.urbanova .footer-social a:hover {
	background: var(--secondary);
}

body.urbanova .footer-social img,
body.urbanova .footer-social svg {
	width: 1.25rem;
	height: 1.25rem;
}

body.urbanova .footer-address--secondary,
body.urbanova .footer-address--secondary .footer-address-company,
body.urbanova .footer-address--secondary p,
body.urbanova .footer-address--secondary p span,
body.urbanova .footer-address--secondary a {
	color: var(--transwhite);
}

body.urbanova .footer-address--right {
	text-align: right;
}

body.urbanova .footer-group {
	text-align: center;
	margin-bottom: 1.5rem;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: flex-start;
}

@media (max-width: 767px) {
	body.urbanova .footer-address--right {
		text-align: left;
	}
	body.urbanova .footer-group {
		align-items: flex-start;
		text-align: left;
	}
}

body.urbanova .footer-group-label {
	font-size: .8rem;
	color: var(--transwhite);
	margin-bottom: 1.25rem;
}

body.urbanova .footer-group-logo {
	height: 1.155rem;
	width: auto;
	display: block;
	opacity: .75;
	transition: opacity .2s ease;
}

body.urbanova .footer-group a:hover .footer-group-logo {
	opacity: 1;
}

/* ===================== PAGE-SPECIFIC: IMPRESSUM, OFFICE CARDS, ARTICLE NAV ===================== */
/* .impressum-meta: definition list grid for legal imprint data.
   .office-card: sidebar contact card on impressum/kontakt pages.
   .article-nav: sticky sidebar navigation used on news and newsletter articles. */

body.urbanova .impressum-meta {
	display: grid;
	grid-template-columns: 1fr;
	gap: .5rem 1.5rem;
	margin: 0 0 1.5rem;
}

body.urbanova .impressum-meta dt {
	font-weight: var(--semibold);
	color: var(--primary);
}

body.urbanova .impressum-meta dd {
	margin: 0 0 1rem 0;
}

@media (min-width: 576px) {
	body.urbanova .impressum-meta {
		grid-template-columns: 22rem 1fr;
		gap: .75rem 1.5rem;
	}

	body.urbanova .impressum-meta dd {
		margin-bottom: 0;
	}
}

body.urbanova .office-card {
	background: var(--white);
	border: 1px solid var(--lightgray);
	border-radius: var(--radius);
	padding: 1.25rem;
	margin-bottom: 1rem;
}

body.urbanova .office-card h3 {
	color: var(--primary);
}

body.urbanova .office-card p {
	margin-bottom: 0;
	font-size: .95rem;
	line-height: 1.6;
}

body.urbanova .office-card p span {
	display: inline-block;
	width: 4.5rem;
	color: var(--darkgray);
	font-size: .85rem;
}

body.urbanova .office-card p:last-child {
	margin-top: 1.5rem;
}

body.urbanova a[href^="tel"] {
	pointer-events: none;
	cursor: text;
}

@media (max-width: 767px) {
	body.urbanova a[href^="tel"] {
		color: var(--primary);
		font-weight: var(--semibold);
		text-decoration: underline;
		pointer-events: auto;
		cursor: pointer;
	}
}

body.urbanova .article-nav-heading {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	color: var(--primary);
}

body.urbanova .article-nav-heading a {
	color: inherit;
	background-image: none;
	padding-bottom: 0;
}

body.urbanova .article-nav-heading a:hover {
	color: var(--secondary-dark);
}

body.urbanova .article-nav-btns {
	display: flex;
	gap: 0.75rem;
	flex-wrap: wrap;
}

body.urbanova .article-nav-prev svg {
	transform: rotate(180deg);
}

body.urbanova .bio img {
	display: block;
	width: 100%;
	height: auto;
	max-width: 280px;
	margin: 0 0 1rem;
	border-radius: var(--radius);
}

body.urbanova .bio h3 {
	margin-bottom: 1.25rem;
}

/* ===================== ÜBER UNS: TEAM LIST ===================== */
/* .mitarbeiter-list: two-column name/role list on /ueber-uns/mitarbeiter. */

body.urbanova .mitarbeiter-list {
	display: grid;
	grid-template-columns: 1fr;
	gap: 0;
	margin: 1.5rem 0;
}

body.urbanova .mitarbeiter-list p {
	display: grid;
	grid-template-columns: 1fr;
	gap: .25rem;
	border-bottom: 1px solid var(--lightgray);
	padding: .6rem 0;
	margin: 0;
	font-size: .95rem;
}

body.urbanova .mitarbeiter-list p strong {
	color: var(--darkgray);
	font-weight: var(--regular);
	font-size: .85rem;
}

@media (min-width: 576px) {
	body.urbanova .mitarbeiter-list p {
		grid-template-columns: minmax(0, 16rem) 1fr;
		gap: 1rem;
		font-size: 1rem;
	}

	body.urbanova .mitarbeiter-list p strong {
		font-size: .95rem;
	}
}

@media (min-width: 992px) {
	body.urbanova .mitarbeiter-list {
		grid-template-columns: 1fr 1fr;
		column-gap: 2.5rem;
	}
}

/* ===================== MEMBERSHIPS PAGE ===================== */
/* .membership-card: card for each professional association on /ueber-uns/mitgliedschaften.
   Logo image + name + URL. Placeholder card marks "further regional memberships". */

body.urbanova .membership-card {
	display: flex;
	flex-direction: column;
	gap: .75rem;
	background: var(--white);
	border: 1px solid var(--lightgray);
	border-radius: var(--radius);
	padding: 1.5rem;
	height: 100%;
	color: var(--black);
	background-image: none;
	transition: border-color .2s ease, transform .2s ease, box-shadow .2s ease;
}

body.urbanova .membership-card:hover {
	border-color: var(--secondary);
	transform: translateY(-2px);
	box-shadow: 0 6px 18px var(--shadow);
	color: var(--black);
}

body.urbanova .membership-card-logo {
	display: flex;
	align-items: center;
	min-height: 60px;
}

body.urbanova .membership-card-logo img {
	max-height: 50px;
	width: auto;
	max-width: 100%;
}

body.urbanova .membership-card p {
	margin: 0;
	flex: 1;
	font-size: .95rem;
	line-height: 1.5;
	color: var(--black);
}

body.urbanova .membership-card-www {
	font-size: .85rem;
	color: var(--secondary-dark);
	font-weight: var(--semibold);
	margin-top: auto;
}

body.urbanova .membership-card:hover .membership-card-www {
	color: var(--primary);
}

body.urbanova .membership-card.placeholder {
	background: transparent;
	border: 1px dashed var(--gray);
	align-items: center;
	justify-content: center;
	min-height: 12rem;
}

body.urbanova .membership-card.placeholder p {
	color: var(--darkgray);
	text-align: center;
}

body.urbanova section[id] {
	scroll-margin-top: calc(var(--header) + 1rem);
}

body.urbanova .prospekt-download {
	background: var(--white);
	border: 1px solid var(--lightgray);
	border-radius: var(--radius);
	padding: 1.25rem;
	margin-bottom: 1rem;
	text-align: center;
}

body.urbanova .prospekt-download h3 {
	font-size: 1rem;
	margin-bottom: .75rem;
	text-transform: uppercase;
	letter-spacing: .05rem;
	color: var(--darkgray);
}

body.urbanova .prospekt-download a {
	display: inline-block;
	background-image: none;
	padding-bottom: 0;
	border-radius: var(--radius);
	overflow: hidden;
}

body.urbanova .prospekt-download img {
	display: block;
	max-width: 140px;
	width: 100%;
	height: auto;
}

body.urbanova .presse {
	margin-top: 2rem;
	padding-top: 1.5rem;
	border-top: 1px solid var(--lightgray);
}

body.urbanova .presse h2 {
	font-size: 1.5rem;
}

body.urbanova .prospekt-list {
	list-style: none;
	padding: 0;
	margin: 0 0 1rem;
}

body.urbanova .prospekt-list li {
	margin: 0 0 .5rem !important;
	padding: 0 !important;
	text-indent: 0;
}

body.urbanova .prospekt-list li::before {
	content: none;
}

body.urbanova .prospekt-list li a {
	display: inline-block;
	background-image: none;
	padding: .25rem 0 .25rem 1.5rem;
	background-image: url("/assets/img/layout/pdfico.png");
	background-repeat: no-repeat;
	background-position: left center;
	background-size: 1rem auto;
	color: var(--primary);
	font-weight: var(--semibold);
}

body.urbanova .prospekt-list li a:hover {
	color: var(--secondary-dark);
}

body.urbanova .award-block {
	margin: 1.25rem 0 0;
	padding-top: 1.25rem;
	border-top: 1px solid var(--lightgray);
}

body.urbanova .award-block:first-of-type {
	border-top: 0;
	padding-top: 0;
}

body.urbanova .award-block img {
	display: block;
	max-width: 180px;
	height: auto;
	margin-bottom: .5rem;
}

body.urbanova .award-block p {
	font-size: .85rem;
	line-height: 1.4;
	color: var(--darkgray);
	margin: 0;
}

/* ===================== PRODUCT / SERVICE PAGES ===================== */
/* SmaLa slideshow (CSS animation on /smarte-liefer-und-ladezonen),
   award block, prospekt-download, and other service-page-specific components. */

body.urbanova .smala-slideshow {
	max-width: 300px;
	margin: 0 auto;
}

body.urbanova .smala-slideshow .flexslider {
	background: transparent;
	border: 0;
	box-shadow: none;
}

body.urbanova .smala-slideshow img {
	width: 100%;
	height: auto;
	display: block;
}

body.urbanova .figure-feature {
	margin: 1.5rem 0;
}

body.urbanova .figure-feature img {
	display: block;
	width: 100%;
	max-width: 100%;
	height: auto;
	border-radius: var(--radius);
}

body.urbanova .form-embed {
	background: var(--white);
	border: 1px solid var(--lightgray);
	border-radius: var(--radius);
	padding: 1.5rem;
	margin-top: 1rem;
}

/* ===================== NEWS LIST PAGE ===================== */
/* .news-entry: horizontal card on /aktuelles and /aktuelles/archiv.
   Image thumbnail + body with title, lead, "Mehr" link.
   Pinned entries get the .news-entry--pinned modifier and a pin icon badge. */

body.urbanova .news-entry {
	display: flex;
	flex-direction: column;
	gap: 1.25rem;
	padding: 1.5rem 0;
	border-bottom: 1px solid var(--lightgray);
}

body.urbanova .news-entry:first-of-type {
	padding-top: 0;
}

body.urbanova .news-entry:last-of-type {
	border-bottom: 0;
}

body.urbanova .news-entry-image {
	display: block;
	position: relative;
	flex-shrink: 0;
	overflow: hidden;
	border-radius: var(--radius);
	background: var(--lightgray);
	background-image: none;
	padding-bottom: 0;
	box-shadow: 0 2px 8px var(--shadow);
	transition: transform .25s ease, box-shadow .25s ease;
	aspect-ratio: 16 / 10;
	width: 100%;
}

body.urbanova .news-entry-image:hover {
	transform: translateY(-2px);
	box-shadow: 0 6px 18px var(--darkshadow);
}

body.urbanova .news-entry-image img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform .4s ease;
}

body.urbanova .news-entry-image:hover img {
	transform: scale(1.04);
}

body.urbanova .news-entry-body {
	flex: 1;
	min-width: 0;
}

body.urbanova .news-entry-date {
	display: block;
	font-size: .85rem;
	color: var(--darkgray);
	text-transform: uppercase;
	letter-spacing: .05rem;
	margin-bottom: .5rem;
}

body.urbanova .news-entry-title {
	font-size: 1.5rem !important;
	line-height: 1.2;
	margin-bottom: .75rem;
	color: var(--primary);
}

body.urbanova .news-entry-title a {
	color: inherit;
	background-image: none;
	padding-bottom: 0;
	font-weight: inherit;
}

body.urbanova .news-entry-title a:hover {
	color: var(--secondary-dark);
}

body.urbanova .news-entry-lead {
	margin-bottom: .75rem !important;
}

body.urbanova .news-entry-more {
	display: inline-block;
	color: var(--primary);
	font-weight: var(--semibold);
	background-image: none !important;
	padding-bottom: 0 !important;
}

body.urbanova .news-entry-more:hover {
	color: var(--secondary-dark);
}

body.urbanova .news-entry-more::after {
	content: " →";
}

@media (min-width: 768px) {
	body.urbanova .news-entry {
		flex-direction: row;
		gap: 2rem;
		align-items: flex-start;
	}

	body.urbanova .news-entry-image {
		width: 33%;
		max-width: 320px;
	}
}

/* ===================== NEWSLETTER ISSUE GRID ===================== */
/* .issue-grid: auto-fill grid of cover tiles on /newsletter and /downloads.
   .issue-tile: clickable cover image + label. .is-pdf variant shows a PDF icon overlay.
   Online editions link in-page; PDF editions open in a new tab. */

body.urbanova .issue-grid {
	list-style: none;
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(100px, 1fr));
	gap: 1rem;
	margin: 0 0 2rem;
	padding: 0;
}

body.urbanova .issue-grid li {
	margin: 0 !important;
	padding: 0 !important;
	text-indent: 0;
}

body.urbanova .issue-grid li::before {
	content: none;
}

body.urbanova .issue-tile {
	display: flex;
	flex-direction: column;
	gap: .5rem;
	color: var(--black);
	background-image: none;
	padding-bottom: 0;
}

body.urbanova .issue-tile-cover {
	display: block;
	aspect-ratio: 1 / 1;
	overflow: hidden;
	border-radius: var(--radius);
	background: var(--lightgray);
	box-shadow: var(--shadow-card);
	transition: transform .25s ease, box-shadow .25s ease;
}

body.urbanova .issue-tile:hover .issue-tile-cover {
	transform: translateY(-2px);
	box-shadow: var(--shadow-card-hover);
}

body.urbanova .issue-tile-cover img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

body.urbanova .issue-tile-label {
	display: block;
	font-weight: var(--semibold);
	font-size: .9rem;
	color: var(--primary);
	text-align: center;
}

body.urbanova .issue-tile.is-pdf .issue-tile-label::before {
	content: "PDF · ";
	color: var(--red);
	font-size: .75rem;
}

body.urbanova .issue-tile:hover .issue-tile-label {
	color: var(--secondary-dark);
}

/* ===================== ARTICLE BODY ===================== */
/* Rendered body_html for news and newsletter articles (.article-body).
   Key override: .article-body .gallery img restores height:100% which was needed
   to fill gallery tiles, but is overridden by the general .article-body img rule
   (height:auto + border-radius). Higher specificity on .gallery img wins. */

body.urbanova .article-body .date {
	display: block;
	font-size: .85rem;
	color: var(--darkgray);
	text-transform: uppercase;
	letter-spacing: .05rem;
	margin-bottom: 1rem;
}

body.urbanova .article-body>h1:first-of-type {
	margin-top: 0;
}

body.urbanova .article-body img {
	max-width: 100%;
	height: auto;
	border-radius: var(--radius);
}

body.urbanova .article-body .gallery img {
	height: 100%;
	max-width: none;
	border-radius: 0;
}

body.urbanova .article-body iframe {
	max-width: 100%;
}

body.urbanova .news-body-content {
	margin: 2rem 0 3rem 0;
}

body.urbanova .news-body-content img {
	display: block;
	width: 100%;
	height: auto;
	margin-top: 1.25rem;
	margin-bottom: 1.25rem;
}

/* Fallback: Quill może owinąć <img> w <p> — zerujemy marginesy takiego <p> */
body.urbanova .news-body-content p:has(> img:only-child) {
	margin: 0;
	padding: 0;
	line-height: 0;
}

/* Floating edit button (visible only to logged-in CMS admin) */
.cms-edit-fab {
	position: fixed;
	bottom: 1.5rem;
	left: 1.5rem;
	z-index: 9000;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 48px;
	height: 48px;
	background: #000;
	color: #fff;
	border-radius: 50%;
	text-decoration: none;
	box-shadow: 0 2px 10px rgba(0, 0, 0, .4);
	transition: background .2s ease, transform .15s ease;
}

.cms-edit-fab:hover {
	background: #333;
	color: #fff;
	transform: scale(1.08);
}

/* ===================== FORMS ===================== */
/* .form-stadtraum: shared form style for /kontakt and /verkehrszeichenkatalog.
   .form-field (label+input wrapper), .form-row (two-col layout), .form-consent (GDPR checkbox),
   .form-honeypot (hidden from sighted users via negative clip-path / overflow:hidden),
   .form-actions (submit button row), .form-result (post-submit success/error state),
   .form-message (inline AJAX feedback for VZ order form). */

body.urbanova .form-stadtraum {
	margin: 1.5rem 0;
}

body.urbanova .form-stadtraum h2 {
	font-size: 1.5rem;
	margin-bottom: 1.5rem;
}

body.urbanova .form-field {
	margin-bottom: 1.25rem;
}

body.urbanova .form-field label {
	display: block;
	font-weight: var(--semibold);
	margin-bottom: .4rem;
	color: var(--primary-dark);
	font-size: .95rem;
}

body.urbanova .form-field label .required {
	color: var(--red);
	margin-left: .2rem;
}

body.urbanova .form-field input[type="text"],
body.urbanova .form-field input[type="email"],
body.urbanova .form-field input[type="number"],
body.urbanova .form-field input[type="tel"],
body.urbanova .form-field input[type="password"],
body.urbanova .form-field textarea {
	display: block;
	width: 100%;
	padding: .75rem 1rem;
	font-size: 1rem;
	font-family: inherit;
	background: var(--white);
	border: 1px solid var(--gray);
	border-radius: var(--radius);
	color: var(--black);
	transition: border-color .2s ease, box-shadow .2s ease;
}

body.urbanova .form-field input:focus,
body.urbanova .form-field textarea:focus {
	border-color: var(--secondary);
	box-shadow: 0 0 0 3px rgba(0, 151, 190, .15);
	outline: 2px solid transparent;
}

body.urbanova .form-field textarea {
	min-height: 8rem;
	resize: vertical;
}

body.urbanova .form-row {
	display: grid;
	grid-template-columns: 1fr;
	gap: 0 var(--gap);
}

@media (min-width: 576px) {
	body.urbanova .form-row {
		grid-template-columns: 1fr 1fr;
	}
}

body.urbanova .form-consent-fieldset {
	border: 0;
	padding: 0;
	margin: 0;
}

body.urbanova .form-consent {
	display: flex;
	align-items: flex-start;
	gap: .75rem;
	background: var(--lightgray);
	border-radius: var(--radius);
	padding: 1rem 1.25rem;
	margin-bottom: 1.25rem;
}

body.urbanova .form-consent input[type="checkbox"] {
	flex-shrink: 0;
	margin-top: .25rem;
	width: 1.1rem;
	height: 1.1rem;
	accent-color: var(--secondary);
	cursor: pointer;
}

body.urbanova .form-consent p,
body.urbanova .form-consent label {
	margin: 0;
	font-size: .85rem;
	line-height: 1.5;
	color: var(--darkgray);
}

body.urbanova .form-actions {
	margin-top: 1.5rem;
}

body.urbanova .form-actions button[type="submit"],
body.urbanova .form-actions input[type="submit"] {
	cursor: pointer;
	font-family: inherit;
}

body.urbanova .form-actions button[disabled],
body.urbanova .form-actions input[disabled] {
	opacity: .5;
	cursor: not-allowed;
}

body.urbanova .form-honeypot {
	position: absolute;
	left: -99999px;
	width: 1px;
	height: 1px;
	overflow: hidden;
}

body.urbanova .form-result {
	text-align: center;
	padding: 2rem 1rem;
}

body.urbanova .form-result img {
	display: block;
	width: 4rem;
	height: 4rem;
	margin: 0 auto 1rem;
}

body.urbanova .form-result h2 {
	margin-bottom: 1rem;
}

body.urbanova .form-result .btn {
	margin-top: 1.5rem;
}

body.urbanova .form-message {
	padding: 1rem 1.25rem;
	border-radius: var(--radius);
	margin-top: 1rem;
	font-weight: var(--semibold);
}

body.urbanova .form-message.is-success {
	background: rgba(0, 190, 134, .12);
	color: var(--green);
	border: 1px solid var(--green);
}

body.urbanova .form-message.is-error {
	background: rgba(190, 0, 5, .08);
	color: var(--red);
	border: 1px solid var(--red);
}

/* ===================== VZ-KATALOG COMPONENTS ===================== */
/* .vz-cover-card: sidebar card on /verkehrszeichenkatalog showing pricing + cover image.
   .office-mini: compact address block on /kontakt sidebar with map thumbnail.
   .vz-download-block: promo block on /downloads with cover image + CTA. */

body.urbanova .vz-cover-card {
	background: var(--white);
	border: 1px solid var(--lightgray);
	border-radius: var(--radius);
	padding: 1.5rem;
	text-align: center;
	margin-bottom: 1.5rem;
}

body.urbanova .vz-cover-card h3 {
	font-size: 1rem;
	text-transform: uppercase;
	letter-spacing: .05rem;
	color: var(--darkgray);
	margin-bottom: .75rem;
}

body.urbanova .vz-cover-card p {
	font-size: .9rem;
	margin-bottom: 1rem;
	color: var(--black);
}

body.urbanova .vz-cover-card img {
	display: block;
	width: 100%;
	max-width: 220px;
	margin: 1rem auto 0;
	height: auto;
	border-radius: var(--radius);
}

body.urbanova .office-mini {
	background: var(--white);
	border: 1px solid var(--lightgray);
	border-radius: var(--radius);
	padding: 1.25rem;
	margin-bottom: 1rem;
}

body.urbanova .office-mini h3 {
	font-size: 1.05rem;
	color: var(--primary);
	margin-bottom: .75rem;
}

body.urbanova .office-mini p {
	margin: 0 0 .75rem;
	font-size: .9rem;
	line-height: 1.5;
}

body.urbanova .office-mini p span {
	display: inline-block;
	width: 4.5rem;
	color: var(--darkgray);
	font-size: .85rem;
}

body.urbanova .office-mini-map {
	display: block;
	width: 80px;
	height: 80px;
	overflow: hidden;
	border-radius: var(--radius);
	background-image: none;
	padding-bottom: 0;
	box-shadow: 0 1px 4px var(--shadow);
}

body.urbanova .office-mini-map img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

body.urbanova .vz-download-block {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.5rem;
	background: var(--white);
	border: 1px solid var(--lightgray);
	border-radius: var(--radius);
	padding: 1.5rem;
	margin-bottom: 1.5rem;
	align-items: center;
}

body.urbanova .vz-download-block .vz-thumb {
	display: block;
	background-image: none;
	padding-bottom: 0;
}

body.urbanova .vz-download-block .vz-thumb img {
	display: block;
	width: 100%;
	max-width: 250px;
	height: auto;
	border-radius: var(--radius);
}

body.urbanova .vz-download-block h2 {
	margin-top: 0;
	font-size: 1.5rem;
}

body.urbanova .vz-download-block p {
	margin-bottom: 1rem;
}

@media (min-width: 576px) {
	body.urbanova .vz-download-block {
		grid-template-columns: 180px 1fr;
		gap: 2rem;
		padding: 2rem;
	}

	body.urbanova .vz-download-block .vz-thumb img {
		max-width: 180px;
	}
}

@media (min-width: 992px) {
	body.urbanova .vz-download-block {
		grid-template-columns: 300px 1fr;
	}

	body.urbanova .vz-download-block .vz-thumb img {
		max-width: 300px;
	}
}

/* ===================== JOBS PAGE — CARDS & BADGES ===================== */
/* .job-card: individual job listing card in the results list.
   .jobs-badges: IHK training + Arbeitgeber der Zukunft badge row below results.
   .vz-summary: order confirmation block on /vz-kaufen.
   .jobs-info-banner: informational callout (e.g. stale cache notice). */

body.urbanova .jobs-widget {
	margin: 1.5rem 0;
	min-height: 6rem;
}

body.urbanova .jobs-info-banner {
	background: rgba(0, 151, 190, .08);
	border-left: 4px solid var(--secondary);
	border-radius: 0 var(--radius) var(--radius) 0;
	padding: 1rem 1.25rem;
	margin: 1.5rem 0;
}

body.urbanova .jobs-info-banner p {
	margin: 0;
	font-size: .95rem;
	color: var(--primary-dark);
}

body.urbanova .jobs-badges {
	display: flex;
	gap: 1.5rem;
	flex-wrap: wrap;
	align-items: center;
	margin: 2rem 0;
}

body.urbanova .jobs-badges img {
	height: auto;
	max-height: 100px;
	width: auto;
}

body.urbanova .vz-summary {
	background: var(--white);
	border-left: 4px solid var(--green);
	border-radius: 0 var(--radius) var(--radius) 0;
	padding: 1.5rem 2rem;
	margin: 1.5rem 0;
}

body.urbanova .vz-summary h2 {
	color: var(--green);
	font-size: 1.5rem;
}

body.urbanova .db-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--gap);
	margin: 1.5rem 0;
	padding: 0;
	list-style: none;
}

@media (min-width: 576px) {
	body.urbanova .db-grid {
		grid-template-columns: repeat(3, 1fr);
	}
}

@media (min-width: 992px) {
	body.urbanova .db-grid {
		grid-template-columns: repeat(6, 1fr);
	}
}

body.urbanova .db-tile {
	background: var(--white);
	border: 1px solid var(--lightgray);
	border-radius: var(--radius);
	padding: 1.25rem 1rem;
	text-align: center;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: .5rem;
}

body.urbanova .db-tile>img {
	width: 64px;
	height: auto;
	margin: 0 auto;
}

body.urbanova .db-tile-title {
	font-weight: var(--semibold);
	font-size: .95rem;
	color: var(--primary-dark);
}

body.urbanova .db-tile>a {
	background-image: none;
	padding-bottom: 0;
	color: inherit;
	display: block;
}

body.urbanova .db-tile>a:hover {
	color: var(--primary);
}

body.urbanova .db-tile>a img {
	width: 64px;
	height: auto;
	transition: transform .2s ease;
}

body.urbanova .db-tile>a:hover img {
	transform: scale(1.05);
}

body.urbanova .db-tile ul {
	list-style: disc;
	text-align: left;
	margin: .5rem 0 0;
	padding-left: 1.25rem;
	font-size: .85rem;
	width: 100%;
}

body.urbanova .db-tile ul li {
	margin: .25rem 0 !important;
	padding: 0 !important;
	text-indent: 0;
}

body.urbanova .db-tile ul li::before {
	content: none;
}

/* ===================== JOBS FILTER SIDEBAR ===================== */
/* .jobs-filter: left-column sidebar form with text search, sort radios, and pill groups.
   .jobs-pills: flex-wrap row of toggle pill buttons (.jobs-pill, .is-active state).
   .jobs-filter__radios: radio button group for sort order.
   Filter interactions handled by jobs-filter.js (AJAX + URL state sync). */

body.urbanova .jobs-filter {
	background: var(--white);
	border: 1px solid var(--lightgray);
	border-radius: var(--radius);
	padding: 1.5rem;
	margin: 0;
}

@media (min-width: 992px) {
	body.urbanova .jobs-filter {
		position: sticky;
		top: calc(var(--header) + 1rem);
	}
}

body.urbanova .jobs-filter input[type="search"] {
	width: 100%;
	padding: .65rem 1rem;
	font-size: 1rem;
	font-family: inherit;
	background: var(--white);
	border: 1px solid var(--gray);
	border-radius: var(--radius);
	color: var(--black);
	margin-bottom: 1.25rem;
}

body.urbanova .jobs-filter input[type="search"]:focus {
	border-color: var(--secondary);
	box-shadow: 0 0 0 3px rgba(0, 151, 190, .15);
	outline: none;
}

body.urbanova .jobs-filter fieldset {
	border: 0;
	padding: 0;
	margin: 0 0 1.25rem;
}

body.urbanova .jobs-filter legend,
body.urbanova .jobs-filter-legend {
	font-weight: var(--semibold);
	font-size: .85rem;
	text-transform: uppercase;
	letter-spacing: .04rem;
	color: var(--darkgray);
	margin-bottom: .6rem;
	padding: 0;
}

body.urbanova .jobs-pills {
	display: flex;
	flex-wrap: wrap;
	gap: .4rem;
}

body.urbanova .jobs-pill {
	display: inline-block;
	padding: .35rem .85rem;
	border: 1px solid var(--gray);
	background: var(--white);
	border-radius: var(--radius-full);
	cursor: pointer;
	font-size: .85rem;
	font-family: inherit;
	color: var(--darkgray);
	transition: background .15s ease, color .15s ease, border-color .15s ease;
}

body.urbanova .jobs-pill:hover {
	border-color: var(--secondary);
	color: var(--primary);
}

body.urbanova .jobs-pill.is-active {
	background: var(--primary);
	border-color: var(--primary);
	color: var(--white);
}

body.urbanova .jobs-filter__radios {
	display: flex;
	flex-wrap: wrap;
	gap: 1rem;
}

body.urbanova .jobs-filter__radios label {
	display: inline-flex;
	align-items: center;
	gap: .35rem;
	font-size: .9rem;
	cursor: pointer;
}

body.urbanova .jobs-filter__radios input {
	accent-color: var(--secondary);
}

/* ===================== JOBS RESULTS ===================== */
/* .jobs-counter: "X von Y Stellen" count line (aria-live for screen reader updates).
   .jobs-loading: spinner shown during AJAX fetch (toggled by jobs-filter.js).
   .is-hidden: utility — display:none !important, used to hide/show elements via JS.
   .jobs-dept: department group heading within results.
   .job-card: individual job listing card.
   .jobs-empty: empty-state message when no jobs match the filter. */

body.urbanova .jobs-counter {
	margin-bottom: 1rem;
	color: var(--darkgray);
}

body.urbanova .jobs-loading {
	display: flex;
	align-items: center;
	gap: .75rem;
	color: var(--darkgray);
	margin: 1rem 0;
}

body.urbanova .jobs-loading.is-hidden,
body.urbanova .is-hidden {
	display: none !important;
}

body.urbanova .jobs-loading__spinner {
	width: 1.25rem;
	height: 1.25rem;
	border: 2px solid var(--lightgray);
	border-top-color: var(--secondary);
	border-radius: 50%;
	animation: jobs-spin .8s linear infinite;
}

@keyframes jobs-spin {
	to {
		transform: rotate(360deg);
	}
}

body.urbanova .jobs-dept {
	font-size: 1.4rem;
	margin: 2rem 0 1rem;
	padding-bottom: .5rem;
	border-bottom: 2px solid var(--secondary);
	color: var(--primary);
}

body.urbanova .jobs-dept:first-child {
	margin-top: 0;
}

body.urbanova .job-card {
	background: var(--white);
	border: 1px solid var(--lightgray);
	border-radius: var(--radius);
	padding: 1.5rem;
	margin-bottom: 1rem;
	transition: border-color .2s ease, box-shadow .2s ease;
}

body.urbanova .job-card:hover {
	border-color: var(--secondary);
	box-shadow: 0 4px 14px var(--shadow);
}

body.urbanova .job-card-title {
	font-size: 1.25rem;
	margin-bottom: .5rem;
}

body.urbanova .job-card-title a {
	color: var(--primary);
	background-image: none;
	padding-bottom: 0;
	font-weight: var(--semibold);
}

body.urbanova .job-card-title a:hover {
	color: var(--secondary-dark);
}

body.urbanova .job-card-meta {
	font-size: .85rem;
	color: var(--darkgray);
	margin-bottom: .75rem;
}

body.urbanova .job-card-excerpt {
	margin-bottom: 1rem;
	color: var(--black);
}

body.urbanova .job-card-actions {
	display: flex;
	flex-wrap: wrap;
	gap: .5rem;
	margin-bottom: 0;
}

body.urbanova .jobs-empty {
	background: var(--lightgray);
	border-radius: var(--radius);
	padding: 2rem;
	text-align: center;
}

body.urbanova .jobs-meta-note {
	font-size: .8rem;
	color: var(--darkgray);
	margin-top: 2rem;
}

/* ===================== HOMEPAGE ===================== */
/* .home-hero: full-bleed banner with aspect-ratio + min/max-height constraints.
   .home-hero .tagline: location + year line above the H1.
   .news-strip-wrapper: scroll container for the horizontal news carousel.
   .news-strip: flex row of .news-card elements with CSS scroll-snap.
   .news-strip-btn: prev/next arrow buttons (shown/hidden by news-strip.js).
   gradient edge fades (.strip-at-start / .strip-at-end) indicate more content. */

/* Flex container: hero rośnie razem z treścią zamiast clippować overflow */
body.urbanova .home-hero {
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	min-height: max(55vh, 380px);
}

/* Gradient jako pseudo-element — zawsze pokrywa pełną wysokość hero niezależnie od treści */
body.urbanova .home-hero::after {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(to top,
			rgba(5, 58, 102, .72) 0%,
			rgba(5, 58, 102, .18) 52%,
			transparent 78%);
	pointer-events: none;
	z-index: 1;
}

/* Obraz absolutny wypełnia cały hero (inset: 0 w position: relative rodzicu) */
body.urbanova .home-hero>img,
body.urbanova .home-hero>picture {
	position: absolute;
	inset: 0;
}

body.urbanova .home-hero>img,
body.urbanova .home-hero>picture>img {
	object-position: center bottom;
}

/* Treść hero w normalnym flow — ponad gradientem; hero rośnie, żeby ją zawsze pomieścić */
body.urbanova .home-hero .hero-content {
	position: relative;
	z-index: 2;
	background: none;
}

body.urbanova .home-hero h1 {
	color: var(--white);
	font-size: 1.8rem;
	font-weight: 400;
	margin-bottom: .75rem;
	max-width: var(--limit-middle);
	text-wrap: balance;
}

body.urbanova .home-hero h1::after {
	background-color: var(--white);
}

body.urbanova .home-hero .hero-content p {
	color: rgba(255, 255, 255, .88);
	max-width: 65ch;
	margin: .5rem 0 1.25rem;
	text-wrap: balance;
	hyphens: none;
	-webkit-hyphens: none;
}

body.urbanova .subline {
	text-transform: uppercase;
	letter-spacing: .04em;
	font-size: .85em;
}

@media (min-width: 576px) {
	body.urbanova .home-hero {
		min-height: max(58vh, 420px);
	}

	body.urbanova .home-hero h1 {
		font-size: 2.4rem;
	}
}

@media (min-width: 992px) {
	body.urbanova .home-hero {
		aspect-ratio: 16 / 9;
		min-height: 520px;
		max-height: 82vh;
	}

	body.urbanova .home-hero h1 {
		font-size: 3.2rem;
	}

	body.urbanova .home-hero .hero-content p {
		font-size: 1.1rem;
	}
}

@media (min-width: 1400px) {
	body.urbanova .home-hero {
		max-height: 73vh;
	}
}

body.urbanova .home-news-slider {
	margin: 1rem 0 2rem;
}

body.urbanova .home-news-slider .flexslider {
	background: transparent;
	border: 0;
	box-shadow: none;
	margin: 0;
}

body.urbanova .home-news-slider .slides>li {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.5rem;
	padding: 0;
	margin: 0;
	text-indent: 0;
}

body.urbanova .home-news-slider .slides>li::before {
	content: none;
}

body.urbanova .home-news-slider .slide-image {
	aspect-ratio: 16 / 9;
	overflow: hidden;
	border-radius: var(--radius);
	background-image: none;
	padding-bottom: 0;
	box-shadow: 0 2px 12px var(--shadow);
	order: -1;
}

body.urbanova .home-news-slider .slide-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

body.urbanova .home-news-slider h3 {
	font-size: 1.5rem;
	margin-bottom: .75rem;
}

body.urbanova .home-news-slider h3 a {
	color: var(--primary);
	background-image: none;
	padding-bottom: 0;
	font-weight: var(--semibold);
}

@media (min-width: 768px) {
	body.urbanova .home-news-slider .slides>li {
		grid-template-columns: 1fr 1fr;
		gap: 2rem;
		align-items: center;
	}

	body.urbanova .home-news-slider .slide-image {
		order: 1;
	}
}

body.urbanova .home-profil-aside .info-card {
	text-align: center;
}

body.urbanova .home-profil-aside img {
	max-width: 100%;
	height: auto;
}

body.urbanova .home-prospekt-card {
	background: var(--primary);
	color: var(--white);
	padding: 2rem 1.5rem;
	border-radius: var(--radius);
	text-align: center;
	margin-bottom: 1rem;
}

body.urbanova .home-prospekt-card h3 {
	color: var(--white);
	margin-bottom: 1rem;
}

body.urbanova .home-prospekt-card .btn {
	background: var(--white);
	color: var(--primary);
	border-color: var(--white);
}

body.urbanova .home-prospekt-card .btn:hover {
	background: var(--secondary);
	color: var(--white);
	border-color: var(--secondary);
}

body.urbanova #leistungen {
	scroll-margin-top: calc(var(--header) + 1rem);
}

body.urbanova .cards-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--gap);
	margin-bottom: var(--gap);
}

@media (min-width: 992px) {
	body.urbanova .cards-grid {
		grid-template-columns: repeat(4, 1fr);
	}

	body.urbanova .card-title {
		font-size: 1.25rem;
	}
}

body.urbanova #produkte {
	scroll-margin-top: calc(var(--header) + 1rem);
}

body.urbanova .card-list {
	margin-top: 2rem;
	padding: 0;
	list-style: none;
	font-size: 0.85rem;
	line-height: 1.45;
	color: var(--darkgray);
}

body.urbanova .card-list li {
	padding: 0.15rem 0;
}

@media (max-width: 575px) {
	body.urbanova .card-list {
		display: none;
	}
}

body.urbanova .news-strip-heading-link {
	color: inherit;
	background-image: none;
	padding-bottom: 0;
}

body.urbanova .news-strip-wrapper {
	position: relative;
}

body.urbanova .news-strip-wrapper::before,
body.urbanova .news-strip-wrapper::after {
	content: '';
	position: absolute;
	top: 0;
	bottom: 0;
	width: clamp(60px, 10vw, 140px);
	pointer-events: none;
	z-index: 1;
	transition: opacity 0.25s ease;
}

body.urbanova .news-strip-wrapper::before {
	left: 0;
	background: linear-gradient(to right, var(--beige) 20%, transparent);
	opacity: 0;
}

body.urbanova .news-strip-wrapper::after {
	right: 0;
	background: linear-gradient(to left, var(--beige) 20%, transparent);
	opacity: 1;
}

body.urbanova .news-strip-wrapper:not(.strip-at-start)::before {
	opacity: 1;
}

body.urbanova .news-strip-wrapper.strip-at-end::after {
	opacity: 0;
}

body.urbanova .news-strip {
	display: flex;
	overflow-x: auto;
	scroll-snap-type: x mandatory;
	gap: 1.25rem;

	padding-top: 0.75rem;
	padding-bottom: 3.5rem;
	padding-left: max(var(--site-padding), calc((100% - 1400px) / 2));
	padding-right: var(--site-padding);
	scroll-padding-left: max(var(--site-padding), calc((100% - 1400px) / 2));
	scrollbar-width: none;
	cursor: grab;
}

body.urbanova .news-strip:active {
	cursor: grabbing;
}

body.urbanova .news-strip::-webkit-scrollbar {
	display: none;
}

body.urbanova .news-card {
	position: relative;
	flex: 0 0 calc((100% - 3 * 1.25rem) / 3.5);
	min-width: 240px;
	scroll-snap-align: start;
	background: var(--white, #fff);
	border-radius: var(--radius, 6px);
	overflow: hidden;
	box-shadow: var(--shadow-card);
	transition: box-shadow .25s ease, transform .25s ease;
	display: flex;
	flex-direction: column;
}

body.urbanova .news-card:hover {
	box-shadow: var(--shadow-card-hover);
	transform: translateY(-2px);
}

@media (max-width: 991px) {
	body.urbanova .news-card {
		flex: 0 0 calc((100% - 2 * 1.25rem) / 2.5);
	}
}

@media (max-width: 575px) {
	body.urbanova .news-card {
		flex: 0 0 calc((100% - 1.25rem) / 1.2);
	}
}

body.urbanova .news-card-img-link {
	display: block;
	aspect-ratio: 16 / 9;
	overflow: hidden;
}

body.urbanova .news-card-img-link img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform 0.3s ease;
}

body.urbanova .news-card:hover .news-card-img-link img {
	transform: scale(1.04);
}

body.urbanova .news-card-body {
	padding: 1rem 1.125rem 1.25rem;
	display: flex;
	flex-direction: column;
	flex: 1;
}

body.urbanova .news-card-body h3 {
	font-size: 1.05rem;
	line-height: 1.35;
	margin: 0 0 0.5rem;
}

body.urbanova .news-card-body h3 a {
	color: var(--text, #222);
	text-decoration: none;
	background-image: none;
}

body.urbanova .news-card-body h3 a:hover {
	color: var(--primary, #007694);
}

body.urbanova .news-card-body p {
	font-size: 0.97rem;
	color: #555;
	line-height: 1.5;
	margin: 0 0 0.75rem;
	flex: 1;
}

body.urbanova .news-card-actions {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 0.5rem;
}

body.urbanova .news-strip-btn {
	position: absolute;
	top: 28%;
	transform: translateY(-50%);
	margin: 0;
	padding: 0.6rem;
	width: 44px;
	height: 44px;
	border: none;
	border-radius: 50%;
	background: var(--primary, #007694);
	color: #fff;
	cursor: pointer;
	box-shadow: 0 1px 6px 0 rgba(0, 0, 0, .35);
	display: flex;
	align-items: center;
	justify-content: center;
	transition: background 0.2s ease-in-out, box-shadow 0.2s ease-in-out;
	z-index: 2;
}

body.urbanova .news-strip-btn:hover {
	background: var(--primary-dark, #005a6e);
	box-shadow: 0 2px 10px rgba(0, 0, 0, .4);
}

body.urbanova .news-strip-btn[hidden] {
	display: none;
}

body.urbanova .news-strip-prev {
	left: 0.5rem;
}

body.urbanova .news-strip-next {
	right: 0.5rem;
}

body.urbanova .news-entry-pin {
	position: absolute;
	top: 0.6rem;
	left: 0.6rem;
	z-index: 1;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 2rem;
	height: 2rem;
	font-size: 0.97rem;
	line-height: 1;
	background: var(--white);
	border-radius: 50%;
	box-shadow: var(--shadow-card);
	color: var(--primary);
}

body.urbanova .news-card-pin {
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--black);
	flex-shrink: 0;
	opacity: 0.6;
}

body.urbanova .smala-slideshow {
	position: relative;
	max-width: 280px;
	margin: 0 auto;
	aspect-ratio: 9 / 18;
}

body.urbanova .smala-slideshow img {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: contain;
	opacity: 0;
	animation: smalaCrossfade 12s infinite;
}

body.urbanova .smala-slideshow img:nth-child(1) {
	animation-delay: 0s;
}

body.urbanova .smala-slideshow img:nth-child(2) {
	animation-delay: 4s;
}

body.urbanova .smala-slideshow img:nth-child(3) {
	animation-delay: 8s;
}

@keyframes smalaCrossfade {

	0%,
	25% {
		opacity: 1;
	}

	33%,
	100% {
		opacity: 0;
	}
}

@media (prefers-reduced-motion: reduce) {
	body.urbanova .smala-slideshow img {
		animation: none;
		opacity: 1;
		position: relative;
		inset: auto;
		display: block;
	}
}

/* ============================================================
   projekt-parking.com — overrides and extensions
   ============================================================ */

body.urbanova #oferta,
body.urbanova #o-firmie {
	scroll-margin-top: calc(var(--header) + 1rem);
}

/* 3-box offer grid (3 filary) */
body.urbanova .cards-grid-3 {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--gap);
	margin-bottom: var(--gap);
}

@media (min-width: 768px) {
	body.urbanova .cards-grid-3 {
		grid-template-columns: repeat(3, 1fr);
	}
}

body.urbanova .cards-grid>.card,
body.urbanova .cards-grid-3>.card {
	margin-bottom: 0;
}

/* Service page hero */
body.urbanova .service-hero {
	aspect-ratio: 16 / 5;
	min-height: 200px;
	max-height: 40vh;
}

/* Oferta submenu (anchor-nav dla stron-filarów) */
body.urbanova .oferta-subnav {
	position: sticky;
	top: var(--header);
	z-index: 100;
	background: var(--white);
	border-bottom: 1px solid var(--lightgray);
	box-shadow: 0 2px 8px var(--shadow);
}

body.urbanova .oferta-subnav-inner {
	display: flex;
	overflow-x: auto;
	scrollbar-width: none;
	gap: 0;
	padding: 0 var(--site-padding);
	max-width: calc(1400px + 2 * var(--site-padding));
	margin: 0 auto;
}

body.urbanova .oferta-subnav-inner::-webkit-scrollbar {
	display: none;
}

body.urbanova .oferta-subnav-inner a {
	flex-shrink: 0;
	display: block;
	padding: .85rem 1.1rem;
	font-size: .88rem;
	font-weight: var(--semibold);
	text-transform: uppercase;
	letter-spacing: .04em;
	color: var(--darkgray);
	border-bottom: 3px solid transparent;
	background-image: none;
	transition: color .2s ease, border-color .2s ease;
	white-space: nowrap;
}

body.urbanova .oferta-subnav-inner a:hover,
body.urbanova .oferta-subnav-inner a.active {
	color: var(--primary);
	border-bottom-color: var(--secondary);
}

/* Sekcja usługi (scroll-target na stronach filarów) */
body.urbanova .service-section {
	padding: 4rem 0;
	border-bottom: 1px solid var(--lightgray);
}

body.urbanova .service-section:last-of-type {
	border-bottom: none;
}

@media (min-width: 768px) {
	body.urbanova .service-section {
		padding: 5rem 0;
	}
}

/* Realizacje — grid referencji */
body.urbanova .references-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 0;
	border: 1px solid var(--lightgray);
	border-radius: var(--radius);
	overflow: hidden;
}

@media (min-width: 576px) {
	body.urbanova .references-grid {
		grid-template-columns: repeat(3, 1fr);
	}
}

@media (min-width: 992px) {
	body.urbanova .references-grid {
		grid-template-columns: repeat(4, 1fr);
	}
}

body.urbanova .references-grid-item {
	padding: .6rem 1rem;
	font-size: .88rem;
	border-bottom: 1px solid var(--lightgray);
	border-right: 1px solid var(--lightgray);
	color: var(--black);
}

body.urbanova .references-grid-item:nth-child(2n) {
	border-right: none;
}

@media (min-width: 576px) {
	body.urbanova .references-grid-item:nth-child(2n) {
		border-right: 1px solid var(--lightgray);
	}

	body.urbanova .references-grid-item:nth-child(3n) {
		border-right: none;
	}
}

@media (min-width: 992px) {
	body.urbanova .references-grid-item:nth-child(3n) {
		border-right: 1px solid var(--lightgray);
	}

	body.urbanova .references-grid-item:nth-child(4n) {
		border-right: none;
	}
}

/* BSPP — karta miasta */
body.urbanova .bspp-card {
	background: var(--white);
	border: 1px solid var(--lightgray);
	border-radius: var(--radius);
	padding: 1.5rem;
	margin-bottom: 1.5rem;
}

body.urbanova .bspp-card h3 {
	color: var(--primary);
	margin-bottom: .75rem;
}

body.urbanova .bspp-rates {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
	gap: .75rem;
	margin: 1rem 0;
}

body.urbanova .bspp-rate {
	background: var(--lightgray);
	border-radius: var(--radius);
	padding: .75rem 1rem;
	font-size: .9rem;
}

body.urbanova .bspp-rate strong {
	display: block;
	font-size: 1.1rem;
	color: var(--primary);
}

/* Kariera accordion */
body.urbanova .accordion-item {
	border-bottom: 1px solid var(--gray);
}

body.urbanova .accordion-trigger {
	width: 100%;
	background: none;
	border: none;
	padding: 1rem 0;
	text-align: left;
	font-size: 1.05rem;
	font-weight: var(--semibold);
	color: var(--primary);
	cursor: pointer;
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 1rem;
}

body.urbanova .accordion-trigger:hover {
	color: var(--secondary);
}

body.urbanova .accordion-trigger .accordion-icon {
	flex-shrink: 0;
	transition: transform 0.25s ease;
}

body.urbanova .accordion-trigger[aria-expanded="true"] .accordion-icon {
	transform: rotate(45deg);
}

body.urbanova .accordion-panel {
	overflow: hidden;
	max-height: 0;
	transition: max-height 0.3s ease;
}

body.urbanova .accordion-panel-inner {
	padding: 0 0 1.5rem;
}

/* Do pobrania — lista PDF */
body.urbanova .download-list {
	list-style: none;
	padding: 0;
	margin: 0 0 1rem;
}

body.urbanova .download-list li {
	margin: 0 0 .5rem !important;
	padding: 0 !important;
	text-indent: 0;
}

body.urbanova .download-list li::before {
	content: none;
}

body.urbanova .download-list li a {
	display: inline-flex;
	align-items: center;
	gap: .5rem;
	padding: .5rem .75rem;
	background: var(--white);
	border: 1px solid var(--lightgray);
	border-radius: var(--radius);
	color: var(--primary);
	font-weight: var(--semibold);
	font-size: .95rem;
	background-image: none;
	transition: border-color .2s ease, box-shadow .2s ease;
}

body.urbanova .download-list li a:hover {
	border-color: var(--secondary);
	box-shadow: 0 2px 8px var(--shadow);
	color: var(--primary);
}

/* =========================================================
   SESJA 4 — Realizacje + BSPP
   ========================================================= */

/* Lead paragraph pod nagłówkiem sekcji */
body.urbanova .section-lead {
	font-size: 1.05rem;
	color: var(--darkgray);
	max-width: 720px;
	margin-bottom: 2rem;
}

/* Karta projektu (aktywne SPP) — rozszerzenie .card */
body.urbanova .card-meta {
	display: flex;
	flex-direction: column;
	gap: .15rem;
	font-size: .82rem;
	color: var(--darkgray);
	padding: .25rem 1rem .5rem;
}

/* Badge sezonowości */
body.urbanova .badge-seasonal {
	display: inline-block;
	font-size: .7rem;
	font-weight: var(--semibold);
	background: var(--secondary);
	color: var(--white);
	border-radius: 4px;
	padding: .1em .45em;
	vertical-align: middle;
	margin-left: .35rem;
	white-space: nowrap;
}

body.urbanova .badge-seasonal-sm {
	font-size: .65rem;
	font-weight: var(--semibold);
	background: var(--secondary);
	color: var(--white);
	border-radius: 3px;
	padding: .05em .35em;
	vertical-align: middle;
	margin-left: .2rem;
}

/* Realizacje — zawartość komórki siatki referencji */
body.urbanova .references-grid-item strong {
	display: block;
	color: var(--primary);
	font-size: .88rem;
	font-weight: var(--semibold);
}

body.urbanova .ref-period {
	display: block;
	font-size: .78rem;
	color: var(--darkgray);
}

body.urbanova .ref-stats {
	display: block;
	font-size: .74rem;
	color: var(--gray);
}

/* ---- BSPP widok miasta ---- */

/* Okruszki breadcrumb w hero */
body.urbanova .breadcrumb {
	font-size: .82rem;
	color: rgba(255, 255, 255, .8);
	margin-bottom: .5rem;
	display: flex;
	align-items: center;
	gap: .4rem;
	flex-wrap: wrap;
}

body.urbanova .breadcrumb a {
	color: rgba(255, 255, 255, .85);
	text-decoration: none;
}

body.urbanova .breadcrumb a:hover {
	color: var(--white);
	text-decoration: underline;
}

/* Układ dwukolumnowy biuro + stawki */
body.urbanova .bspp-layout {
	align-items: flex-start;
}

/* Karta biura SPP */
body.urbanova .bspp-card {
	position: sticky;
	top: 5rem;
}

body.urbanova .bspp-card-title {
	display: flex;
	align-items: center;
	gap: .5rem;
	font-size: 1.1rem;
	font-weight: var(--semibold);
	color: var(--primary);
	margin-bottom: 1rem;
}

body.urbanova .bspp-address {
	font-style: normal;
	line-height: 1.6;
	margin-bottom: .75rem;
	font-size: .93rem;
}

body.urbanova .bspp-phone {
	display: flex;
	align-items: flex-start;
	gap: .4rem;
	margin-bottom: .75rem;
	font-size: .93rem;
}

body.urbanova .bspp-phone a {
	color: var(--primary);
	text-decoration: none;
}

body.urbanova .bspp-phone a:hover {
	color: var(--secondary);
}

body.urbanova .bspp-hours {
	margin: .75rem 0;
	font-size: .88rem;
	border-top: 1px solid var(--lightgray);
	padding-top: .75rem;
}

body.urbanova .bspp-hours div {
	display: flex;
	justify-content: space-between;
	gap: .5rem;
	padding: .25rem 0;
	border-bottom: 1px solid var(--lightgray);
}

body.urbanova .bspp-hours dt {
	color: var(--darkgray);
}

body.urbanova .bspp-hours dd {
	font-weight: var(--semibold);
	color: var(--primary);
	text-align: right;
}

body.urbanova .bspp-stats {
	margin-top: 1rem;
	border-top: 1px solid var(--lightgray);
	padding-top: .75rem;
	font-size: .85rem;
}

body.urbanova .bspp-stats div {
	display: flex;
	justify-content: space-between;
	gap: .5rem;
	padding: .2rem 0;
}

body.urbanova .bspp-stats dt {
	color: var(--darkgray);
}

body.urbanova .bspp-stats dd {
	font-weight: var(--semibold);
	color: var(--primary);
}

/* Sekcje stawek */
body.urbanova .bspp-section {
	margin-bottom: 2rem;
}

body.urbanova .bspp-section h2 {
	font-size: 1.2rem;
	margin-bottom: 1rem;
}

body.urbanova .bspp-section h3 {
	font-size: 1rem;
	font-weight: var(--semibold);
	color: var(--primary);
	margin-bottom: .6rem;
	padding-bottom: .3rem;
	border-bottom: 2px solid var(--secondary);
	display: inline-block;
}

/* Lista stawek */
body.urbanova .fees-list {
	list-style: none;
	padding: 0;
	margin: 0 0 .5rem;
}

body.urbanova .fees-list li {
	display: flex;
	justify-content: space-between;
	align-items: baseline;
	gap: .5rem;
	padding: .4rem 0;
	border-bottom: 1px solid var(--lightgray);
	font-size: .9rem;
}

body.urbanova .fees-list li:first-child {
	border-top: 1px solid var(--lightgray);
}

body.urbanova .fee-label {
	color: var(--darkgray);
	flex: 1;
}

body.urbanova .fee-price {
	font-weight: var(--semibold);
	color: var(--primary);
	white-space: nowrap;
}

/* Abonamenty — cena pod etykietą na małych ekranach */
body.urbanova .fees-list-sub li {
	flex-wrap: wrap;
}

body.urbanova .fees-list-sub .fee-label {
	width: 100%;
}

@media (min-width: 576px) {
	body.urbanova .fees-list-sub li {
		flex-wrap: nowrap;
	}

	body.urbanova .fees-list-sub .fee-label {
		width: auto;
	}
}

/* Opłaty dodatkowe */
body.urbanova .fees-list-additional li {
	display: list-item;
	list-style: disc;
	list-style-position: outside;
	margin-left: 1.2rem;
	padding: .25rem 0;
	border: none;
	font-size: .9rem;
	color: var(--darkgray);
}

body.urbanova .fees-list-additional li:first-child {
	border-top: none;
}

/* Uwagi do stawek */
body.urbanova .fees-note {
	font-size: .88rem;
	color: var(--darkgray);
	margin-bottom: 1rem;
}

body.urbanova .fees-note-small {
	font-size: .83rem;
	color: var(--gray);
	margin-top: .5rem;
}

body.urbanova .fees-notes {
	list-style: disc;
	padding-left: 1.2rem;
	margin: .5rem 0;
}

body.urbanova .fees-notes li {
	font-size: .83rem;
	color: var(--darkgray);
	padding: .15rem 0;
}

/* Mobilet sekcja */
body.urbanova .bspp-mobilet {
	background: var(--offwhite, #f8f8f6);
	border-radius: var(--radius);
	padding: 1rem 1.25rem;
	margin-bottom: 2rem !important;
}

/* Zarządca zewnętrzny */
body.urbanova .bspp-manager {
	border-left: 3px solid var(--secondary);
	padding-left: 1rem;
}

/* Nawigacja między miastami — blue pills variant */
body.urbanova .bspp-city-nav {
	padding-top: 2rem !important;
	padding-bottom: 2rem !important;
}

body.urbanova .bspp-city-nav .submenu-list li a {
	color: var(--primary);
	background: var(--primary-tint) !important;
	border: 1px solid var(--primary-border);
	background-image: none !important;
	padding-bottom: 0.3rem !important;
}

body.urbanova .bspp-city-nav .submenu-list li a:hover {
	background: var(--primary) !important;
	border-color: var(--primary);
	color: var(--white);
}

body.urbanova .bspp-city-nav .submenu-totop {
	border-color: var(--primary);
	color: var(--primary);
}

body.urbanova .bspp-city-nav .submenu-totop:hover {
	background: var(--primary);
}

/* ============================================================
   HOME PAGE — nowe sekcje
   ============================================================ */

/* --- Shared: container-like inner wrapper --- */
body.urbanova .stats-bar__inner,
body.urbanova .offer-pillars__inner,
body.urbanova .differentiators__inner,
body.urbanova .references-teaser__inner,
body.urbanova .cta-strip__inner,
body.urbanova .b2c-section__inner {
	width: 100%;
	margin: 0 auto;
	padding: 0 var(--site-padding);
	max-width: calc(var(--limit-wide) + 2 * var(--site-padding));
}

/* --- Shared: vertical padding (matches .section rhythm: 3 → 5 → 6rem) --- */
body.urbanova .offer-pillars,
body.urbanova .differentiators,
body.urbanova .references-teaser,
body.urbanova .cta-strip,
body.urbanova .b2c-section {
	padding: 3rem 0;
}

@media (min-width: 768px) {

	body.urbanova .offer-pillars,
	body.urbanova .differentiators,
	body.urbanova .references-teaser,
	body.urbanova .cta-strip,
	body.urbanova .b2c-section {
		padding: 5rem 0;
	}
}

@media (min-width: 1200px) {

	body.urbanova .offer-pillars,
	body.urbanova .differentiators,
	body.urbanova .references-teaser,
	body.urbanova .cta-strip,
	body.urbanova .b2c-section {
		padding: 6rem 0;
	}
}

/* --- Stats bar --- */
body.urbanova .stats-bar {
	background: var(--darkblue);
	padding: 2.5rem 0;
}

body.urbanova .stats-bar__inner {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 2rem 3.5rem;
}

body.urbanova .stats-bar__item {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	min-width: 130px;
}

body.urbanova .stats-bar__value {
	font-size: 2rem;
	font-weight: var(--semibold);
	color: var(--white);
	line-height: 1.1;
}

body.urbanova .stats-bar__label {
	font-size: 1em;
	color: var(--halfwhite);
	margin-top: 0.25rem;
	line-height: 1.3;
}

@media (max-width: 575px) {
	body.urbanova .stats-bar__inner {
		gap: 1.5rem 2rem;
	}

	body.urbanova .stats-bar__value {
		font-size: 1.6rem;
	}
}

/* --- Filary oferty --- */
body.urbanova .offer-pillars {
	background: var(--white);
}

body.urbanova .offer-pillars__heading {
	text-align: center;
}

body.urbanova .offer-pillars__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--gap);
	margin-top: 2.5rem;
}

body.urbanova .offer-pillars__card {
	background: var(--white);
	border-radius: var(--radius);
	box-shadow: var(--shadow-card);
	overflow: hidden;
	display: flex;
	flex-direction: column;
	transition: transform .25s ease, box-shadow .25s ease;
}

body.urbanova .offer-pillars__card:hover {
	transform: translateY(-2px);
	box-shadow: var(--shadow-card-hover);
}

body.urbanova .offer-pillars__img {
	aspect-ratio: 16 / 9;
	background: var(--lightgray);
	overflow: hidden;
}

body.urbanova .offer-pillars__img picture {
	display: block;
	width: 100%;
	height: 100%;
}

body.urbanova .offer-pillars__img img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform .4s ease;
}

body.urbanova .offer-pillars__card:hover .offer-pillars__img img {
	transform: scale(1.04);
}

body.urbanova .offer-pillars__body {
	padding: 1.5rem;
	display: flex;
	flex-direction: column;
	flex: 1;
}

body.urbanova .offer-pillars__title {
	font-size: 1.2rem;
	font-weight: var(--semibold);
	color: var(--primary-dark);
	margin: 0 0 0.6rem;
	letter-spacing: 0;
	line-height: 1.25;
}

body.urbanova .offer-pillars__desc {
	font-size: 0.97rem;
	line-height: 1.65;
	color: var(--darkgray);
	flex: 1;
	margin: 0 0 1.25rem;
	hyphens: auto;
}

body.urbanova .offer-pillars__body .btn {
	align-self: flex-start;
}

@media (max-width: 767px) {
	body.urbanova .offer-pillars__grid {
		grid-template-columns: 1fr;
	}
}

/* --- Dlaczego Projekt Parking --- */
body.urbanova .differentiators {
	background: var(--beige);
}

body.urbanova .differentiators__heading {
	text-align: center;
}

body.urbanova .differentiators__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 2rem;
	margin-top: 2.5rem;
}

body.urbanova .differentiators__item {
	border-left: 3px solid var(--secondary);
	padding-left: 1.25rem;
}

body.urbanova .differentiators__title {
	font-size: 1.2rem;
	font-weight: var(--semibold);
	color: var(--primary-dark);
	margin: 0 0 0.6rem;
	letter-spacing: 0;
	line-height: 1.25;
}

body.urbanova .differentiators__desc {
	font-size: 0.97rem;
	line-height: 1.65;
	color: var(--darkgray);
	margin: 0;
	hyphens: auto;
}

@media (max-width: 767px) {
	body.urbanova .differentiators__grid {
		grid-template-columns: 1fr;
		gap: 1.5rem;
	}
}

/* --- Realizacje teaser --- */
body.urbanova .references-teaser {
	background: var(--white);
}

body.urbanova .references-teaser__grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 3rem;
	border-top: 1px solid var(--lightgray);
	padding-top: 1.75rem;
}

body.urbanova .references-teaser__col-label {
	display: block;
	font-size: 0.75rem;
	font-weight: var(--semibold);
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: var(--primary);
	margin-bottom: 0.75rem;
}

body.urbanova .references-teaser__list {
	list-style: none;
	padding: 0;
	margin: 0 0 1.25rem;
}

body.urbanova .references-teaser__list li {
	font-size: 1rem;
	color: var(--primary-dark);
	padding: 0.35rem 0;
	border-bottom: 1px solid var(--lightgray);
	margin: 0;
	text-indent: 0;
}

body.urbanova .references-teaser__list li::before {
	content: none;
}

body.urbanova .references-teaser__placeholder {
	font-size: 0.97rem;
	color: var(--darkgray);
	margin: 0 0 1.25rem;
	font-style: italic;
}

body.urbanova .references-teaser__col .btn {
	margin-top: 1.25rem;
}

body.urbanova .references-teaser__footnote {
	font-size: 0.85rem;
	color: var(--darkgray);
	margin: 1.75rem 0 0;
	border-top: 1px solid var(--lightgray);
	padding-top: 1rem;
}

@media (max-width: 767px) {
	body.urbanova .references-teaser__grid {
		grid-template-columns: 1fr;
		gap: 2rem;
	}
}

/* --- CTA strip --- */
body.urbanova .cta-strip {
	background: var(--primary-dark);
	text-align: center;
}

body.urbanova .cta-strip__inner {
	max-width: calc(680px + 2 * var(--site-padding));
}

body.urbanova .cta-strip__heading {
	font-size: 1.6rem;
	font-weight: var(--semibold);
	color: var(--white);
	margin: 0 0 0.75rem;
	letter-spacing: -.05rem;
	text-wrap: balance;
}

body.urbanova .cta-strip__desc {
	color: var(--transwhite);
	margin: 0 0 1.75rem;
	line-height: 1.6;
}

@media (min-width: 576px) {
	body.urbanova .cta-strip__heading {
		font-size: 2rem;
	}
}

/* --- Dla parkujących (B2C) --- */
body.urbanova .b2c-section {
	background: var(--beige);

}

body.urbanova .b2c-section__heading {
	font-size: 0.75rem;
	font-weight: var(--semibold);
	color: var(--darkgray);
	text-transform: uppercase;
	letter-spacing: 0.08em;
	margin: 0 0 1.5rem;
}

body.urbanova .b2c-section__grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--gap);
}

body.urbanova .b2c-section__card {
	background: var(--white);
	border-radius: var(--radius);
	box-shadow: var(--shadow-card);
	padding: 1.5rem;
	display: flex;
	flex-direction: column;
}

body.urbanova .b2c-section__title {
	font-size: 1rem;
	font-weight: var(--semibold);
	color: var(--primary-dark);
	margin: 0 0 0.6rem;
	letter-spacing: 0;
	line-height: 1.25;
}

body.urbanova .b2c-section__desc {
	font-size: 0.97rem;
	line-height: 1.6;
	color: var(--darkgray);
	flex: 1;
	margin: 0 0 1.25rem;
}

body.urbanova .b2c-section__link {
	font-size: 0.97rem;
	font-weight: var(--semibold);
	color: var(--primary);
	text-decoration: none;
	align-self: flex-start;
	background-image: none;
	padding-bottom: 0;
}

body.urbanova .b2c-section__link:hover {
	text-decoration: underline;
	color: var(--primary);
}

@media (max-width: 575px) {
	body.urbanova .b2c-section__grid {
		grid-template-columns: 1fr;
	}
}