/* ── Oddziały section ── */
.block-oddzialy {
	position: relative;
	z-index: 1;
	background: transparent;
	isolation: isolate;
	overflow: hidden;
	padding: var(--weblance-section-pad-y) 0;
}

.block-oddzialy__inner {
	position: relative;
	z-index: 2;
	padding-left: var(--calc-padding);
	padding-right: var(--calc-padding);
}

/* ── Header ── */
.block-oddzialy__header {
	text-align: center;
	margin-bottom: 48px;
}

.block-oddzialy__kicker {
	color: var(--color);
	font-size: var(--font-size-h5);
	font-weight: 600;
	margin-bottom: 8px;
}

.block-oddzialy__heading {
	margin: 0;
	color: #fff;
	font-size: var(--font-size-h2);
	font-weight: 400;
	line-height: 1.25;
}

.block-oddzialy__heading-line {
	width: 100%;
	max-width: 100%;
	height: 1px;
	margin: 20px auto 0;
	background: #fff;
}

/* ── Columns ── */
.block-oddzialy__columns {
	display: grid;
	grid-template-columns: 1fr 1.4fr;
	gap: 48px;
	align-items: start;
}

.block-oddzialy--layout-simple-grid .block-oddzialy__columns {
	grid-template-columns: 0.82fr 1.48fr;
}

/* ── Left column ── */
.block-oddzialy__col-left {
	display: flex;
	flex-direction: column;
	gap: 20px;
}

.block-oddzialy__col-title {
	display: flex;
	align-items: center;
	gap: 14px;
}

.block-oddzialy__col-icon {
	width: 32px;
	height: 32px;
	object-fit: contain;
	flex-shrink: 0;
}

.block-oddzialy__col-title h3 {
	margin: 0;
	color: #fff;
	font-size: var(--font-size-h3);
	font-weight: 400;
	line-height: 1.3;
}

.block-oddzialy__col-text {
	color: rgba(255, 255, 255, 0.8);
	font-size: var(--font-size-normal);
	line-height: 1.7;
	padding-bottom: 20px;
	border-bottom: 1px solid #fff;
}

.block-oddzialy__col-text p { margin: 0 0 8px; }
.block-oddzialy__col-text p:last-child { margin-bottom: 0; }

/* ── Select filter ── */
.block-oddzialy__filter {
	display: flex;
	flex-direction: column;
	gap: 8px;
	margin-top: 8px;
}

.block-oddzialy__filter-label {
	color: rgba(255, 255, 255, 0.6);
	font-size: var(--font-size-small);
}

.block-oddzialy__filter select {
	width: 100%;
	max-width: 100%;
}

.block-oddzialy__select {
	appearance: none;
	-webkit-appearance: none;
	width: 100%;
	max-width: 100%;
	padding: 14px 44px 14px 16px;
	border: 1px solid rgba(255, 255, 255, 0.25);
	border-radius: 0;
	background: rgba(255, 255, 255, 0.06);
	color: #fff;
	font-family: inherit;
	font-size: var(--font-size-normal);
	cursor: pointer;
	background-image: url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l5 5 5-5' stroke='white' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 16px center;
	transition: border-color 0.2s ease;
}

.block-oddzialy__select:hover,
.block-oddzialy__select:focus {
	border-color: var(--color);
	outline: none;
}

.block-oddzialy__select option {
	background: #082a54;
	color: #fff;
}

/* ── Interactive map ── */
.block-oddzialy__map-wrap {
	position: relative;
	width: fit-content;
	max-width: 100%;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 28px;
	overflow: visible;
}

.block-oddzialy__map {
	position: relative;
	z-index: 1;
	display: block;
	width: fit-content;
	max-width: 100%;
	transition: transform 0.35s ease;
}

.block-oddzialy__map-svg {
	display: block;
	width: auto;
	max-width: 100%;
	height: auto;
	max-height: 640px;
}

.block-oddzialy__map-svg [data-woj] {
	cursor: pointer;
}

.block-oddzialy__map-svg [data-woj].is-active {
	fill: rgba(70, 160, 255, 0.32);
	stroke: #ff3b30;
	stroke-width: 2;
}

.block-oddzialy__map-points {
	position: absolute;
	inset: 0;
	z-index: 2;
	pointer-events: none;
}

.block-oddzialy__map-clusters {
	position: absolute;
	inset: 0;
	z-index: 2;
	pointer-events: none;
}

.block-oddzialy__map-point {
	position: absolute;
	width: 24px;
	height: 24px;
	margin-left: -12px;
	margin-top: -12px;
	border: 2px solid #fff;
	border-radius: 50%;
	background: var(--color);
	box-shadow: 0 0 0 6px rgba(31, 181, 255, 0.22);
	cursor: pointer;
	pointer-events: auto;
	transition: transform 0.2s ease;
}

.block-oddzialy__map-point.is-cluster-hidden {
	visibility: hidden;
	pointer-events: none;
}

.block-oddzialy__map-point--cluster {
	width: 34px;
	height: 34px;
	margin-left: -17px;
	margin-top: -17px;
	background: #ff3b30;
	box-shadow: 0 0 0 8px rgba(70, 160, 255, 0.26);
	font-size: 13px;
	font-weight: 700;
	line-height: 1;
	color: #fff;
	display: inline-flex;
	align-items: center;
	justify-content: center;
}

.block-oddzialy__map-point--cluster span {
	pointer-events: none;
}

.block-oddzialy__map-point:hover {
	transform: scale(1.08);
}

.block-oddzialy__map-popup {
	position: absolute;
	z-index: 3;
	min-width: 260px;
	max-width: min(360px, calc(100% - 24px));
	padding: 14px;
	border: 1px solid rgba(255, 255, 255, 0.3);
	background: rgba(8, 25, 49, 0.95);
	backdrop-filter: blur(8px);
	transform: translate(-50%, calc(-100% - 14px));
	color: #fff;
}

.block-oddzialy__map-popup[hidden] {
	display: none;
}

.block-oddzialy__map-popup-title {
	margin: 0 0 6px;
	font-size: var(--font-size-h5);
	line-height: 1.3;
}

.block-oddzialy__map-popup-address {
	margin: 0 0 8px;
	color: rgba(255, 255, 255, 0.75);
	font-size: var(--font-size-small);
	line-height: 1.45;
}

.block-oddzialy__map-popup-phone,
.block-oddzialy__map-popup-link {
	display: inline-block;
	font-size: var(--font-size-small);
	color: #fff;
	text-decoration: none;
}

.block-oddzialy__map-popup-phone {
	margin-bottom: 6px;
	font-weight: 600;
}

.block-oddzialy__map-popup-link {
	border-bottom: 1px solid rgba(255, 255, 255, 0.4);
}

/* ── Right column (Swiper lub siatka) ── */
.block-oddzialy__col-right {
	min-width: 0;
	overflow: hidden;
	margin-right: calc(-1 * var(--calc-padding));
	padding-right: var(--calc-padding);
}

.block-oddzialy__grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(min(100%, 280px), 1fr));
	gap: 16px;
	align-items: stretch;
	width: 100%;
}

/* Siatka: pełna szerokość bloku (bez lewej kolumny z treścią / filtrem) */
.block-oddzialy--layout-grid .block-oddzialy__grid--full {
	width: 100%;
	max-width: none;
	margin: 0;
	box-sizing: border-box;
	grid-template-columns: repeat(3, minmax(0, 1fr));
}

.block-oddzialy__grid-item {
	min-width: 0;
	display: flex;
}

.block-oddzialy__grid-item .block-oddzialy__card {
	width: 100%;
}

.block-oddzialy--layout-simple-grid .block-oddzialy__grid--simple {
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 16px;
}

.block-oddzialy__swiper {
	overflow: visible;
}

.block-oddzialy__slide {
	width: 340px;
	height: auto;
}

/* ── Card ── */
.block-oddzialy__card {
	position: relative;
	display: flex;
	flex-direction: column;
	gap: 10px;
	padding: 28px 24px;
	border: 1px solid rgba(255, 255, 255, 0.2);
	border-radius: 15px;
	background: rgba(255, 255, 255, 0.06);
	backdrop-filter: blur(8px);
	height: 100%;
	box-sizing: border-box;
	transition: border-color 0.2s ease, background 0.2s ease;
}

.block-oddzialy__card:hover {
	border-color: rgba(255, 255, 255, 0.4);
	background: rgba(255, 255, 255, 0.1);
}

.block-oddzialy__card-link {
	position: absolute;
	inset: 0;
	z-index: 1;
}

.block-oddzialy__card-icon {
	color: rgba(255, 255, 255, 0.5);
}

.block-oddzialy__card-title {
	margin: 0;
	color: #fff;
	font-size: var(--font-size-h5);
	font-weight: 600;
	line-height: 1.3;
}

.block-oddzialy__card-address {
	margin: 0;
	color: rgba(255, 255, 255, 0.7);
	font-size: var(--font-size-normal);
	line-height: 1.5;
}

.block-oddzialy__card-phone {
	position: relative;
	z-index: 2;
	margin: 0;
	color: #fff;
	font-size: var(--font-size-h5);
	font-weight: 400;
	text-decoration: none;
	letter-spacing: 0.02em;
}

.block-oddzialy__card-phone:hover {
	color: var(--color);
}

/* ── Ship background (CSS animation) ── */
.block-oddzialy__ship {
	position: absolute;
	z-index: 0;
	pointer-events: none;
	bottom: -5%;
	right: -10%;
	opacity: 0;
	transition: opacity 0.6s ease;
}

.block-oddzialy__ship img {
	display: block;
	width: 350px;
	height: auto;
	object-fit: contain;
}

.block-oddzialy--ship-active .block-oddzialy__ship {
	opacity: 0.08;
	animation: oddzialy-ship-float 25s linear infinite;
}

@keyframes oddzialy-ship-float {
	0% {
		transform: translate(20%, 20%) rotate(35deg);
	}
	25% {
		transform: translate(-80vw, -30vh) rotate(35deg);
	}
	25.01% {
		transform: translate(80vw, 40vh) rotate(-145deg);
	}
	50% {
		transform: translate(-10%, -10%) rotate(-145deg);
	}
	50.01% {
		transform: translate(-80vw, 30vh) rotate(35deg);
	}
	75% {
		transform: translate(20vw, -40vh) rotate(35deg);
	}
	75.01% {
		transform: translate(80vw, -30vh) rotate(-145deg);
	}
	100% {
		transform: translate(20%, 20%) rotate(-145deg);
	}
}

/* ── Responsive ── */
@media (max-width: 1023px) {
	.block-oddzialy__columns {
		grid-template-columns: 1fr 1fr;
	}

	.block-oddzialy--layout-simple-grid .block-oddzialy__columns {
		grid-template-columns: 1fr;
		gap: 32px;
	}

	.block-oddzialy--layout-grid .block-oddzialy__grid--full {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.block-oddzialy--layout-simple-grid .block-oddzialy__grid--simple {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.block-oddzialy__slide {
		width: 300px;
	}
}

@media (max-width: 767px) {
	.block-oddzialy__map-wrap {
		margin-bottom: 20px;
	}

	.block-oddzialy__map-wrap--zoomed {
		overflow: hidden;
	}

	.block-oddzialy__map-point {
		width: 18px;
		height: 18px;
		margin-left: -9px;
		margin-top: -9px;
	}

	.block-oddzialy__map-point--cluster {
		width: 30px;
		height: 30px;
		margin-left: -15px;
		margin-top: -15px;
		font-size: 12px;
	}

	.block-oddzialy__map-popup {
		min-width: 220px;
	}

	.block-oddzialy__columns {
		grid-template-columns: 1fr;
		gap: 32px;
	}

	.block-oddzialy__col-title h3 {
		font-size: var(--font-size-h4);
	}

	.block-oddzialy__slide {
		width: 260px;
	}

	.block-oddzialy--layout-grid .block-oddzialy__grid--full {
		grid-template-columns: 1fr;
	}

	.block-oddzialy--layout-simple-grid .block-oddzialy__grid--simple {
		grid-template-columns: 1fr;
	}

	.block-oddzialy__ship img {
		width: 200px;
	}
}
